



# ARM PrimeCell<sup>®</sup> NAND Flash Memory Controller (PL351) Errata Notice

This document contains all errata known at the date of issue in releases up to and including revision r2p1 of NAND Flash Memory Controller -3yr Term

### **Proprietary notice**

Words and logos marked with ® or ™ are registered trademarks or trademarks of ARM Limited in the EU and other countries, except as otherwise stated below in this proprietary notice. Other brands and names mentioned herein may be the trademarks of their respective owners.

Neither the whole nor any part of the information contained in, or the product described in, this document may be adapted or reproduced in any material form except with the prior written permission of the copyright holder.

The product described in this document is subject to continuous developments and improvements. All particulars of the product and its use contained in this document are given by ARM Limited in good faith. However, all warranties implied or expressed, including but not limited to implied warranties of merchantability, or fitness for purpose, are excluded.

This document is intended only to assist the reader in the use of the product. ARM Limited shall not be liable for any loss or damage arising from the use of any information in this document, or any error or omission in such information, or any incorrect use of the product.

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

### Web address

http://www.arm.com/

### Feedback on the product

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

- The product name
- A concise explanation of your comments.

### Feedback on this document

If you have any comments on about this document, please send email to mailto:errata@arm.com giving:

- The document title
- The documents number
- The page number(s) to which your comments refer
- A concise explanation of your comments

General suggestion for additions and improvements are also welcome.

### **Contents**

| INT | RODUCTIO   | ON CONTRACTOR OF THE CONTRACTO | 6  |
|-----|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| ERR | RATA SUM   | MARY TABLE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 10 |
| ERR | RATA - CAT | ΓEGORY 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 13 |
|     | There are  | no Errata in this Category                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 13 |
| ERR | RATA - CAT | TEGORY 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 14 |
|     | 393151:    | Following a period with nand_booten asserted, interrupt not always cleared                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 14 |
|     | 443976:    | ECC does not detect 2-bit errors                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 15 |
|     | 445912:    | Invalid signals in the NAND fsm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 16 |
|     | 455815:    | tRHW is not programmable and can be violated (by software or the ECC block)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 17 |
|     | 456826:    | PREADY not returned early for APB writes to direct_cmd register when PCLKEN is not tied high                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 18 |
|     | 501623:    | CS not deasserted in accesses to NAND in certain modes of operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 19 |
|     | 721059:    | SLC ECC misses single error to bit0 byte0 and fails to detect some double error cases                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 21 |
| ERR | RATA - CAT | TEGORY 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 24 |
|     | 381382:    | Memory FSM incorrectly coded for use with NAND boot enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 24 |
|     | 404770:    | NAND boot mode problem for some NAND memory device protocols                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 25 |
|     | 412923:    | Can enter low_power mode while transactions are still outstanding                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 26 |
|     | 445213:    | Remap functionality can be wrong                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 27 |
|     | 447567:    | READY not returned when zero's written to memc_cfg_set & memc_cfg_clr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 28 |
|     | 456825:    | Command phase time may be one cycle short during ECC if aclk synchronously greater than mclk                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 29 |
|     | 533517:    | FIFO depths chosen in AMBA Designer may be inconsistent                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 30 |
|     | 583618:    | Explicit Perl paths causing RTL rendering issues on certain machines                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 31 |
| ERR | RATA - DO  | CUMENTATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 33 |
|     | 404182:    | DDI0380C SMC (PL350 series) r1p1 TRM, incorrect reset value for sram_cycles register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 33 |
|     | 404184:    | DDI0380C SMC (PL350 series) r1p1 TRM, incorrect waveform in Fig 2-16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 34 |
|     | 404865:    | DDI0380C SMC (PL350 series) r1p1 TRM, Figure 3-5 has incorrect address mapping                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 35 |
|     | 405861:    | Incorrect version of documentation in release                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 36 |

|    | 408513:   | DDI0380D SMC (PL350 series) r1p2 TRM, memory configuration register description is incorrect                    | 37 |
|----|-----------|-----------------------------------------------------------------------------------------------------------------|----|
|    | 408962:   | DII0137C SMC (PL350 series) r1p1 IM, how to connect EBI to SMC when the interfaces run at different frequencies | 38 |
|    | 411811:   | DDI0380C SMC (PL350 series) r1p1 TRM, Fig 5-1 shows incorrect values for set_cycles_val                         | 39 |
|    | 442865:   | DDI0380E SMC (PL350) TRM, incorrect ecc_value field width in ecc_value register                                 | 40 |
|    | 445215:   | Use of ClearCS or nand_csl with the EBI can result in deadlock                                                  | 41 |
| ER | RATA – DR | RIVER SOFTWARE                                                                                                  | 43 |
|    | There are | no Errata in this Category                                                                                      | 43 |

### Introduction

Date of Issue: 12-Aug-2009

### Scope

This document describes errata categorised 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

### **Related Products**

This document only captures defects specific to the ZA815 product. The current release is r0p0-00dev0 and has been based on PL301-r1p1-00bet2. All defects on that apply to this PL301 revision will apply to ZA815 too and details can be found in the latest PL301-DC-11001 Errata document. If instantiating the DMP then all declared erratum relating to PL368 will also apply and document PL368-DC-11001 should be consulted.

### **Categorisation of Errata**

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

- Category 1 Behavior that is impossible to work around and that severely restricts the use of the product in all, or the majority of applications, rendering the device unusable.
- Category 2 Behavior that contravenes the specified behavior and that might limit or severely impair the intended use of specified features, but does not render the product unusable in all or the majority of applications.
- Category 3 Behavior that was not the originally intended behavior but should not cause any problems in applications.

### **Change Control**

| Cha   | ange Co     | ntrol     |         |                                                                                              |
|-------|-------------|-----------|---------|----------------------------------------------------------------------------------------------|
| 12 Au | ug 2009: C  | hanges ir | n Docur | nent v15                                                                                     |
| Page  | Status      | ID        | Cat     | Summary                                                                                      |
| 21    | New         | 721059    | Cat 2   | SLC ECC misses single error to bit0 byte0 and fails to detect some double error cases        |
| 04 No | ov 2008: C  | hanges ir | n Docum | nent v14                                                                                     |
| Page  | Status      | ID        | Cat     | Summary                                                                                      |
| 18    | New         | 456826    | Cat 2   | PREADY not returned early for APB writes to direct_cmd register when PCLKEN is not tied high |
| 30    | New         | 533517    | Cat 3   | FIFO depths chosen in AMBA Designer may be inconsistent                                      |
| 31    | Updated     | 583618    | Cat 3   | Explicit Perl paths causing RTL rendering issues on certain machines                         |
| 29 Fe | eb 2008: Cł | nanges in | Docun   | nent v13                                                                                     |
| Page  | Status      | ID        | Cat     | Summary                                                                                      |
| 19    | New         | 501623    | Cat 2   | CS not deasserted in accesses to NAND in certain modes of operation                          |
| 28    | Updated     | 447567    | Cat 3   | READY not returned when zero's written to memc_cfg_set & memc_cfg_clr                        |
| 41    | Updated     | 445215    | Doc     | Use of ClearCS or nand_csl with the EBI can result in deadlock                               |
| 23 O  | ct 2007: Ch | nanges in | Docum   | nent v11                                                                                     |
| Page  | Status      | ID        | Cat     | Summary                                                                                      |
| 16    | New         | 445912    | Cat 2   | PL35x uses invalid signals in the NAND fsm                                                   |
| 14    | Updated     | 393151    | Cat 2   | Following a period with nand_booten asserted, interrupt not always cleared                   |
| 17    | Updated     | 455815    | Cat 2   | tRHW is not programmable and can be violated (by software or the ECC block)                  |
| 28    | New         | 447567    | Cat 3   | PREADY not returned when zero's written to memc_cfg_set & memc_cfg_clr                       |
| 24    | Updated     | 381382    | Cat 3   | Memory FSM incorrectly coded for use with NAND boot enable                                   |
| 25    | Updated     | 404770    | Cat 3   | NAND boot mode problem for some NAND memory device protocols                                 |
| 29    | Updated     | 456825    | Cat 3   | Command phase time may be one cycle short during ECC if aclk synchronously greater than mclk |
| 34    | Updated     | 404184    | Doc     | DDI0380C SMC (PL350 series) r1p1 TRM, incorrect waveform in Fig 2-16                         |
| 35    | Updated     | 404865    | Doc     | DDI0380C SMC (PL350 series) r1p1 TRM, Figure 3-5 has incorrect address mapping               |
| 40    | Updated     | 442865    | Doc     | DDI0380E SMC (PL350) TRM, incorrect ecc_value field width in ecc_value register              |
| 41    | Updated     | 445215    | Doc     | Use of ClearCS or nand_csl with the EBI can result in deadlock                               |
| 20 Se | ep 2007: CI | hanges ir | n Docun | nent v10                                                                                     |
| Page  | Status      | ID        | Cat     | Summary                                                                                      |
| 17    | New         | 455815    | Cat 2   | tRHW is not programmable and can be violated (by software or the ECC block)                  |

| 29 | New     | 456825 | Cat 3 | Command phase time may be one cycle short during ECC if aclk synchronously greater than mclk |
|----|---------|--------|-------|----------------------------------------------------------------------------------------------|
| 25 | Updated | 404770 | Cat 3 | NAND boot mode problem for some NAND memory device protocols                                 |
| 37 | New     | 408513 | Doc   | DDI0380D SMC (PL350 series) r1p2 TRM, memory configuration register description is incorrect |

### 30 Jul 2007: Changes in Document v9

| Page | Status  | ID     | Cat   | Summary                                                                         |
|------|---------|--------|-------|---------------------------------------------------------------------------------|
| 15   | New     | 443976 | Cat 2 | ECC does not detect 2-bit errors                                                |
| 27   | New     | 445213 | Cat 3 | Remap functionality can be wrong                                                |
| 25   | Updated | 404770 | Cat 3 | NAND boot mode problem for some NAND memory device protocols                    |
| 40   | New     | 442865 | Doc   | DDI0380E SMC (PL350) TRM, incorrect ecc_value field width in ecc_value register |
| 41   | New     | 445215 | Doc   | Use of ClearCS or nand_csl with the ebi can result in deadlock                  |

### 22 Dec 2006: Changes in Document v8

No changes in this document revision

### 21 Nov 2006: Changes in Document v7

| Page  | Status     | ID     | Cat    | Summary                                                                                         |
|-------|------------|--------|--------|-------------------------------------------------------------------------------------------------|
| 14    | Updated    | 393151 | Cat 2  | Following a period with nand_booten asserted, interrupt not always cleared                      |
| 26    | New        | 412923 | Cat 3  | Can enter low_power mode while transactions are still outstanding                               |
| 25    | Updated    | 404770 | Cat 3  | NAND boot mode problem for some NAND memory device protocols                                    |
| 24    | Updated    | 381382 | Cat 3  | Memory FSM incorrectly coded for use with NAND boot enable                                      |
| 39    | New        | 411811 | Doc    | TRM error on set_cycles_val                                                                     |
| 38    | New        | 408962 | Doc    | Lack of documentation on connecting EBI to memory controllers that run at different frequencies |
| 37    | New        | 408513 | Doc    | Memory configuration register description incorrect in TRM                                      |
| 35    | New        | 404865 | Doc    | TRM Figure 3-5 has incorrect address mapping                                                    |
| 34    | New        | 404184 | Doc    | Incorrect waveform in Fig 2-16 of TRM                                                           |
| 36    | Updated    | 405861 | Doc    | Incorrect version of documentation in release                                                   |
| 33    | Updated    | 404182 | Doc    | Incorrect reset value for sram_cycles register                                                  |
| 07.0- | - 200C. Ch |        | Daarra | and vic                                                                                         |

### 27 Sep 2006: Changes in Document v6

| Page | Status | ID     | Cat   | Summary                                                      |
|------|--------|--------|-------|--------------------------------------------------------------|
| 25   | New    | 404770 | Cat 3 | NAND boot mode problem for some NAND memory device protocols |
| 36   | New    | 405861 | Doc   | Incorrect version of documentation in release                |
| 33   | New    | 404182 | Doc   | Incorrect reset value for sram_cycles register in TRM        |

### 07 Sep 2006: Changes in Document v5

| Page Status | ID | Cat | Summary |  |
|-------------|----|-----|---------|--|
|             |    |     |         |  |

14 Updated 393151 Cat 2 Following a period with nand\_booten asserted, interrupt not always cleared

Document Revision 15.0

24 Updated 381382 Cat 3 Memory FSM incorrectly coded for use with NAND boot enable

14 Aug 2006: Changes in Document v4

No changes in this document revision

10 Jul 2006: Changes in Document v3

No changes in this document revision

21 Jun 2006: Changes in Document v2

Page Status ID Cat Summary

14 New 393151 Cat 2 Following a period with nand\_booten asserted, interrupt not always cleared

24 New 381382 Cat 3 Memory FSM incorrectly coded for use with NAND boot enable

18 Apr 2006: Changes in Document v1

No Errata in this document revision

### **Errata Summary Table**

The errata associated with this product affect product versions as below.

A cell shown thus **X** indicates that the defect affects the revision shown at the top of that column.

**NOTE**: Some documentation errata are not directly applicable to the PL351 but are included in this table as the documentation is common across the PL351, PL352, PL353, PL354 products. This may result in certain product revisions appearing in the table for which no corresponding PL351 release actually exists.

| ID     | Cat | Summary of Erratum                                                                                              |             |             |             |             |             |             |             |             |             |             |
|--------|-----|-----------------------------------------------------------------------------------------------------------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|
|        |     |                                                                                                                 | r0p0-00rel0 | r1p0-00rel0 | r1p1-00rel0 | r1p1-00rel1 | r1p1-01rel0 | r1p1-01rel1 | r1p2-00rel0 | r2p0-00rel0 | r2p0-02rel0 | r2p1-00rel0 |
| 404182 | Doc | DDI0380C SMC (PL350 series) r1p1 TRM, incorrect reset value for sram_cycles register                            | X           | X           | X           | X           | X           | X           |             |             |             |             |
| 404184 | Doc | DDI0380C SMC (PL350 series) r1p1 TRM, incorrect waveform in Fig 2-16                                            |             |             | X           | X           | X           | X           | X           |             |             |             |
| 404865 | Doc | DDI0380C SMC (PL350 series) r1p1 TRM, Figure 3-5 has incorrect address mapping                                  |             |             | X           | X           | X           | X           | X           |             |             |             |
| 405861 | Doc | Incorrect version of documentation in release                                                                   |             |             |             | X           |             |             |             |             |             |             |
| 408513 | Doc | DDI0380D SMC (PL350 series) r1p2 TRM, memory configuration register description is incorrect                    |             |             | X           | X           | X           | X           | X           |             |             |             |
| 408962 | Doc | DII0137C SMC (PL350 series) r1p1 IM, how to connect EBI to SMC when the interfaces run at different frequencies |             |             | X           | X           | X           | X           | X           |             |             |             |

| ID     | Cat   | Summary of Erratum                                                                                    | 0 1         | 0 1         | Oli         | 1           | 01          | Ţ.          | 01          | 01          | Oli         | 01          |
|--------|-------|-------------------------------------------------------------------------------------------------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|
|        |       |                                                                                                       | r0p0-00rel0 | r1p0-00rel0 | r1p1-00rel0 | r1p1-00rel1 | r1p1-01rel0 | r1p1-01rel1 | r1p2-00rel0 | r2p0-00rel0 | r2p0-02rel0 | r2p1-00rel0 |
| 411811 | Doc   | DDI0380C SMC (PL350 series) r1p1 TRM, Fig 5-1 shows incorrect values for set_cycles_val               |             |             | X           | X           | X           | X           | X           |             |             |             |
| 442865 | Doc   | DDI0380E SMC (PL350) TRM, incorrect ecc_value field width in ecc_value register                       |             |             |             |             |             |             |             | X           |             |             |
| 445215 | Doc   | Use of ClearCS or nand_csl with the EBI can result in deadlock                                        | X           | X           | X           | X           | X           | X           | X           | X           | X           | X           |
| 393151 | Cat 2 | Following a period with nand_booten asserted, interrupt not always cleared                            |             | X           | X           |             |             |             |             |             |             |             |
| 443976 | Cat 2 | ECC does not detect 2-bit errors                                                                      |             |             |             |             |             |             |             | X           |             |             |
| 445912 | Cat 2 | Invalid signals in the NAND fsm                                                                       | X           | X           | X           | X           | X           | X           | X           |             |             |             |
| 455815 | Cat 2 | tRHW is not<br>programmable and can be<br>violated (by software or<br>the ECC block)                  |             |             |             |             |             |             |             | X           | X           |             |
| 456826 | Cat 2 | PREADY not returned<br>early for APB writes to<br>direct_cmd register when<br>PCLKEN is not tied high | X           | X           | X           | X           | X           | X           | X           | X           | X           |             |
| 501623 | Cat 2 | CS not deasserted in accesses to NAND in certain modes of operation                                   |             |             |             |             |             |             |             | X           | X           | X           |
| 721059 | Cat 2 | SLC ECC misses single<br>error to bit0 byte0 and fails<br>to detect some double<br>error cases        |             |             |             |             |             |             |             |             |             | X           |

| ID     | Cat   | Summary of Erratum                                                                           |             |             |             |             |             |             |             |             |             |             |
|--------|-------|----------------------------------------------------------------------------------------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|
|        |       |                                                                                              | r0p0-00rel0 | r1p0-00rel0 | r1p1-00rel0 | r1p1-00rel1 | r1p1-01rel0 | r1p1-01rel1 | r1p2-00rel0 | r2p0-00rel0 | r2p0-02rel0 | r2p1-00rel0 |
| 381382 | Cat 3 | Memory FSM incorrectly coded for use with NAND boot enable                                   |             | X           | X           |             |             |             |             |             |             |             |
| 404770 | Cat 3 | NAND boot mode problem<br>for some NAND memory<br>device protocols                           | X           | X           | X           | X           |             |             |             |             |             |             |
| 412923 | Cat 3 | Can enter low_power mode while transactions are still outstanding                            | X           | X           | X           | X           | X           | X           |             |             |             |             |
| 445213 | Cat 3 | Remap functionality can be wrong                                                             | X           | X           | X           | X           | Х           | X           | X           | X           | X           | X           |
| 447567 | Cat 3 | READY not returned when zero's written to memc_cfg_set & memc_cfg_clr                        | X           | X           | X           | X           | X           | X           | X           |             |             |             |
| 456825 | Cat 3 | Command phase time may be one cycle short during ECC if aclk synchronously greater than mclk |             |             |             |             |             |             |             | X           | X           |             |
| 533517 | Cat 3 | FIFO depths chosen in<br>AMBA Designer may be<br>inconsistent                                |             |             |             |             |             | X           | X           | X           | X           | X           |
| 583618 | Cat 3 | Explicit Perl paths causing RTL rendering issues on certain machines                         | X           | X           | X           | X           | X           | X           | X           | X           | X           | X           |

Errata - Category 1

Date of Issue: 12-Aug-2009

There are no Errata in this Category

### Errata - Category 2

### 393151: Following a period with nand\_booten asserted, interrupt not always cleared

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Cat 2, Present in: r1p0-00rel0,r1p1-00rel0, Fixed in r1p1-00rel1.

### **Description**

The signal nand\_booten is asserted when the controller is used to boot from NAND memory devices. The controller will suspend operation during busy periods by internally waiting for the interrupt before continuing.

When nand\_booten is de-asserted, it is possible for an interrupt to be outstanding. If this interrupt is not cleared before the next read, software may try to access the nand chip whilst it is busy.

### **Implications**

If the interrupt is not cleared when exiting boot mode, on the first read to NAND software may incorrectly assume the busy period has expired and access the memory whilst it is busy.

### Workaround

The fix for this involves updating the fsm to clear the interrupt when entering the data state, and ensuring that the boot\_busy flag is only set when moving out of command to idle state.

A software fix would be to always manually clear the interrupt upon exit of nand booten mode.

### 443976: ECC does not detect 2-bit errors

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Cat 2, Present in: r2p0-00rel0, Fixed in r2p0-02rel0.

### **Description**

When the PL351 is configured with the ECC block enabled, the ECC is generated correctly but there is an issue in the detection algorithm resulting in 2-bit errors not being detected.

There are no issues with the PL351 with ECC disabled.

### **Implications**

2-bit errors are not detected correctly.

### Workaround

There is no workaround. If ECC is required please use a later release.

NAND Flash Memory Controller (PL351)

Document Revision **15.0** 

Date of Issue: 12-Aug-2009

### 445912: Invalid signals in the NAND fsm

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Cat 2, Present in: r0p0-00rel0,r1p0-00rel0,r1p1-00rel0,r1p1-00rel1,r1p1-01rel0,r1p1-01rel1,r1p2-00rel0, Fixed in r2p0-00rel0.

### **Description**

The NAND fsm has a term that references two signals (**rfifo\_space\_ok** and **next\_read\_n\_write**) from the command FIFO. These signals are used without checking they are valid from the command fifo.

Using these signals when they are not valid can lead to a requested end command being omitted.

This can occur if one of the following rare sequences of events arises:

1) A read is followed by a program operation containing fewer AXI transactions than the cfifo depth and the read data has not been accepted by the master,

or,

2) A program operation (write data phase) is immediately followed by a read operation (without a command phase in between).

### **Implications**

It is possible for a write sequence that is programmed to generate an end command to omit that end command.

### Workaround

Case 1) can be avoided by ensuring that all reads have completed before starting a program operation or by ensuring that all program operations contain more AXI transactions than the command fifo depth.

Case 2) should never happen during NAND operation. If software is going to poll the NAND memory to detect the completion of a write, it should issue a status read command phase access before starting to poll.

### 455815: tRHW is not programmable and can be violated (by software or the ECC block)

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Cat 2, Present in: r2p0-00rel0,r2p0-02rel0, Fixed in r2p1-00rel0.

### **Description**

No timing parameter is enforced between the read and write enable signals on the nand interface.

However, some memories do require this timing delay.

The controller only does this when using column change commands during ECC reads.

### **Implications**

If tRHW gets violated it might result in data corruption in the memory

### Workaround

- 1) If using ecc use the full jump mode
- 2) Running the controller in async mode will increase the delay by 2 mclk cycles.

# 456826: PREADY not returned early for APB writes to direct\_cmd register when PCLKEN is not tied high

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Cat 2, Present in: r0p0-00rel0,r1p0-00rel0,r1p1-00rel0,r1p1-00rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel0,r1p1-

01rel1,r1p2-00rel0,r2p0-00rel0,r2p0-02rel0, Fixed in r2p1-00rel0.

### **Description**

If the APB is clocked at a slower frequency than ACLK (i.e. PCLKEN is not tied high) then PREADY may not be returned until the completion of the access. For APB direct\_command accesses this can involve a sequence of the current APB access and one or more AXI accesses. In this instance PREADY will not be retuned until the data match occurs.

### **Implications**

In some systems it may not be possible to write to the AXI channel until the APB channel has completed. This could cause a system deadlock. Please note that the NAND flash memory controller is not affected by this problem.

### Workaround

When executing AXI direct\_command sequences ensure PCLKEN is tied high.

### 501623: CS not deasserted in accesses to NAND in certain modes of operation

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Cat 2, Present in: r2p0-00rel0,r2p0-02rel0,r2p1-00rel0, Open.

### **Description**

PL351/353 is designed to support NAND devices that require **CS** to be held low between data-phase accesses, as well as devices that do not have this requirement. To satisfy both types of memory the ECC block will not deassert **CS** after a block has been completed if it is about to issue a command.

However, in certain modes of operation (specifically when column-change commands are enabled and you are not reading ECC codes between blocks), PL351/353 incorrectly assumes that it is about to perform an operation and cancels the request to ClearCS.

This results in **CS** not being deasserted after the last transfer in a 512 byte block and while **CS** is deasserted the EBI will not be released. The following timing diagram illustrates the **CS** behaviour.



### **Implications**

Under the above mentioned conditions, **CS** will not be deasserted. This could result in a deadlock situation if data or code required to create the next transaction is stored through the same EBI.

#### Workaround

If ECC is disabled, this problem will not occur.

When using ECC, there are two possible work arounds:

1. Use the ECC block in full command mode for writes, and read ECC codes between blocks for reads.

Date of Issue: 12-Aug-2009 AF

2. If you are reading or writing more than one 512 byte block, ensure that the data crosses the 512 byte boundary in a single un-interrupted transaction.

**ARM Errata Notice** 

Date of Issue: 12-Aug-2009

### 721059: SLC ECC misses single error to bit0 byte0 and fails to detect some double error cases

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Cat 2, Present in: r2p1-00rel0, Open.

### **Description**

There is a defect in the coding of the SLC ECC algorithm.

Only the odd half of the parity calculation is being tested to check for pass / fail.

When reading the data from NAND with the SLC ECC enabled, in some specifc cases, the results indicated in the registers will be incorrect.

The rendered file

pl35x\_ecc\_reg\_<xmlcfg>.v will contain multiple instances of a line such as

assign next\_ecc1\_data\_0\_pass\_fail = |ecc1\_data\_0\_ecc\_odd & next\_ecc1\_data\_0\_read;

Only the " ecc odd" vector is being tested to determine pass fail.

Both the odd and even halves should be tested.

assign next\_ecc1\_data\_0\_pass\_fail = ((|ecc1\_data\_0\_ecc\_odd) || (|ecc1\_data\_0\_ecc\_even)) & next\_ecc1\_data\_0\_read;

### **Implications**

There are three implications of this errata.

1. A single bit error in data byte 0, bit 0 will not be detected.

This error case will result in a false positive that the data has passed the error check.

2. A single bit error in second 12 bits of the 3 parity bytes read from the spare area, will incorrectly be identified as having passed the error check.

The algorithm intent is that errors occurring in the spare area, will be flagged as uncorrectable fail.

3. Some double error cases are not correctly identified as uncorrectable fail.

90 double errors out of the 8485140 possible double error combinations are not correctly identified as uncorrectable fail.

- All double errors in the data (8386560 possible errors) will be correctly identified as uncorrectable fail.
- 66 of the 276 possible double errors in the parity bytes are not identified as uncorrectable fail
- 24 of the 98304 possible 1 error in data 1 error in parity, will not be identified as uncorrectable fail

These 90 cases will result in a false positive that the data has passed the error check.

### Workaround

There is a software workaround to the first implication of this defect.

PL351-RLNC-000225 v15.0

Non Confidential

If a single bit error occurs to byte 0, bit 0, the ECC register values return ecc\_fail = 1'b0 ecc\_correct = 1'b1

This result uniquely identifies a single bit error to byte 0, bit 0 in the current implementation.

The register values can be read to identify this case, and the bit error can be corrected.

A more complex software workaround is to manually read the ECC parity data stored in the spare area and then use software to calulate the ECC result independently of the hardware mechanism.

NAND Flash Memory Controller (PL351)

Date of Issue: 12-Aug-2009 ARM Errata Notice Document Revision 15.0

Errata - Category 3

Date of Issue: 12-Aug-2009

### 381382: Memory FSM incorrectly coded for use with NAND boot enable

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Cat 3, Present in: r1p0-00rel0,r1p1-00rel0, Fixed in r1p1-00rel1.

### **Description**

When in NAND boot mode, the controller uses the interrupt to pause operation during busy periods.

At the end of each command access the interrupt is cleared, so that it can be set again after the busy period has elapsed.

The controller will resume operation when the interrupt is set again (on the rising edge of the NAND busy signal).

An error in the FSM causes the interrupt to be cleared before the data read can start, and therefore the controller gets stalled indefinitely.

### **Implications**

The NAND boot feature cannot be guaranteed to work as expected.

### Workaround

None

### 404770: NAND boot mode problem for some NAND memory device protocols

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Cat 3, Present in: r0p0-00rel0,r1p0-00rel0,r1p1-00rel0,r1p1-00rel1, Fixed in r1p1-01rel0.

### **Description**

Date of Issue: 12-Aug-2009

In NAND boot mode, the static memory controller stalls operation during the NAND busy period following the command phase of a read access.

The flag that controls this stall internally is currently set when moving from command state to idle state, for example when finishing the second command of a page read program.

For memories that do not require this second command, this flag is not being set and hence the controller does not stall operation during the NAND busy period.

### **Implications**

When using the NAND boot feature, if the PL350 controller does not issue a second command in a read program, then it will not stall during the memory device's busy period.

Therefore, if the memory device cannot accept a second command and the data access is attempted before the busy period elapses a violation will occur.

### Workaround

Some NAND devices automatically power-on in page-read mode.

Memories which cannot support a second command as part of a page read program, but power-on in read mode could be booted from by only issuing read data accesses without the command phase.

The necessary code for booting and loading the driver would need to fit into the first page of memory as other pages could not be accessed without a read command.

### 412923: Can enter low\_power mode while transactions are still outstanding

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Cat 3, Present in: r0p0-00rel0,r1p0-00rel0,r1p1-00rel0,r1p1-00rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01rel1,r1p1-01re

Fixed in r1p2-00rel0.

### **Description**

If the SMC is idle and receives a power down request followed by an AXI transaction in the same or subsequent cycle the transaction will get registered into the AXI interface but the SMC will still enter low-power mode.

If all the necessary data has been been received (or the transaction is a read) it will be completed by the SMC. However, if the there is still data outstanding the transaction will not complete until a power-up request is received.

If this occurs, resetting the SMC while in low-power mode, before all the transactions have been completed, would result in AXI protocol violations.

### **Implications**

AXI protocol violations could result from this activity.

### Workaround

There are no registers in the SMC that cannot be accessed while not in low-power mode. Therefore, low-power mode should not be entered unless all masters have completed accessing the SMC.

### 445213: Remap functionality can be wrong

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Cat 3, Present in: r0p0-00rel0,r1p0-00rel0,r1p1-00rel0,r1p1-00rel1,r1p1-01rel0,r1p1-

01rel1,r1p2-00rel0,r2p0-00rel0,r2p0-02rel0,r2p1-00rel0, Open.

### **Description**

The remap pins on PL35x can be used to map chip 0 of a memory interface to address 0x000000000.

However, it aliases chip 0 but does not hide other chips out of the way.

For example if PL35x is set up so that chip 1 is at 0x00000000 and chip 0 is at 0x0100000 then when remap is asserted PL35x would try to map an incoming AXI command to both chips.

The other chip can be on either interface on dual interface configurations

There are three possible (pre-silicon) workarounds

- 1) Do not place any memory chip selects at base address 0x00000000
- 2) Configure chip select 0 at address 0x00000000 therefore removing the need for a remap.
- 3) Tie the address match and mask pins to programmble registers to allow the chip select addresses to be programmable.

### **Implications**

PL350 does not support accesses to two chips at the same time. The behaviour is undefined.

#### Workaround

None

### 447567: READY not returned when zero's written to memc\_cfg\_set & memc\_cfg\_clr

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Cat 3, Present in: r0p0-00rel0,r1p0-00rel0,r1p1-00rel0,r1p1-00rel1,r1p1-01rel0,r1p1-

01rel1,r1p2-00rel0, Fixed in r2p0-00rel0.

### **Description**

The memc\_cfg\_set and memc\_cfg\_clear registers are write-only registers in which each bit enables or disables a particular function.

Writing 32'h00000000 to these registers should have no functional effect. However,

pready is never returned if such a write does occur.

(This will prevent **hready** being returned in an AHB based system)

### **Implications**

The APB (or connected AHB) transaction will never complete.

### Workaround

Do not write zero to either the memc\_cfg\_clear or memc\_cfg\_set registers.

### 456825: Command phase time may be one cycle short during ECC if aclk synchronously greater than mclk

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Cat 3, Present in: r2p0-00rel0,r2p0-02rel0, Fixed in r2p1-00rel0.

### **Description**

If aclk and mclk are synchronous to each other and aclk is greater than mclk and the ecc column jump function is enabled, then it may be possible for the command phase to be one cycle short.

### **Implications**

Undefined behaviour may be observed from the memory device as timing paramters may be violated.

### Workaround

If using the column jump functionality of the ecc block ensure that t\_wc and t\_wp are both one cycle longer than required.

### 533517: FIFO depths chosen in AMBA Designer may be inconsistent

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Cat 3, Present in: r1p1-01rel1,r1p2-00rel0,r2p0-00rel0,r2p0-02rel0,r2p1-00rel0, Open.

### **Description**

Date of Issue: 12-Aug-2009

When configuring the memory controller in AMBA Designer there is a potential case that choosing Read FIFO depths may cause confusion.

In the configuration window, the desired Read FIFO depth can be selected for each memory interface (for example "12").

If the desired memory width is then chosen, the Read FIFO depth is reset to the default for that memory width (eg "2"). This is because the valid options change for different memory widths.

If the "OK" button is pressed, the memory controller is generated with the default Read FIFO depth (eg "2").

If the right click AMBA Designer -> "reconfigure" option is now selected, the configuration window is opened. The value in the Read FIFO depth is the "12" input above, not that of the rendered memory controller (which was the default "2").

If the "OK" button is pressed the memory controller will be generated with the Read FIFO depth from the configuration window (here "12"). This would lead to changing the Read FIFO depth, without specifically choosing to.

The values in the configuration window, when "OK" is pressed are always those used for RTL generation.

### **Implications**

Confusion may arise when selecting FIFO depths.

The options in the configuration window are those used in the RTL generation process.

### Workaround

Check all the values in the configuration window, before pressing the "OK" button.

The values in the configuration window are those used in the RTL generation process.

### 583618: Explicit Perl paths causing RTL rendering issues on certain machines

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Cat 3, Present in: r0p0-00rel0,r1p0-00rel0,r1p1-00rel0,r1p1-00rel1,r1p1-01rel0,r1p1-01rel1,r1p2-00rel0,r2p0-00rel0,r2p0-02rel0,r2p1-00rel0, Open.

### **Description**

The Perl script used to render the desired configuration of the RTL has a hard coded path to where it expects Perl to be installed.

shared/bin/render.pl

contains:

#!/usr/local/bin/perl -w

If a suitable Perl version is not installed here, an error can occur.

The cause of the error can be hard to trace.

### **Implications**

During the render process an error may occur.

The RTL will not be rendered successfully.

### Workaround

The simplest workaround is to create a unix soft link so that the installed version of Perl is found in /usr/local/bin/perl.

Alternatively the render.pl script can be modified to replace

#!/usr/local/bin/perl -w

with

```
eval "exec perl -w -S $0 $@" # -*- Perl -*-
```

if (\$running\_under\_some\_sh);

undef (\$running\_under\_some\_sh);

This ensures the script uses the installed version of Perl.

NAND Flash Memory Controller (PL351)

Date of Issue: 12-Aug-2009 ARM Errata Notice Document Revision 15.0

### **Errata - Documentation**

# 404182: DDI0380C SMC (PL350 series) r1p1 TRM, incorrect reset value for sram\_cycles register

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Doc, Present in: r0p0-00rel0,r1p0-00rel0,r1p1-00rel0,r1p1-00rel1,r1p1-01rel0,r1p1-01rel1,

Fixed in r1p2-00rel0.

### **Description**

In Table 3-1 of the TRM DDI0380C, the reset value of register sram\_cycles<x>\_<n> is given as 0x0000AAFF. This is incorrect. The reset value should be set to 0x0002B3CC.

### **Implications**

none

### Workaround

### 404184: DDI0380C SMC (PL350 series) r1p1 TRM, incorrect waveform in Fig 2-16

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status:

Doc, Present in: r1p1-00rel0,r1p1-00rel1,r1p1-01rel0,r1p1-01rel1,r1p2-00rel0, Fixed in r2p0-

00rel0.

### **Description**

In Fig 2-16 of the TRM DDI0380C, the WE waveform is incorrect. It is shown as being asserted many cycles after CS gets asserted.

WE should be shown to go low, that is get asserted on the same cycle as CS.

WE in this figure should also be shown to be asserted for twp+2 cycles instead of twp, since in asynchronous mux-mode WE is asserted for twp+2 cycles.

The following restriction on timing parameters should also be mentioned:

For writes in mux mode, tWC should be set to a value >= tWP + 2.

### **Implications**

none

### Workaround

# 404865: DDI0380C SMC (PL350 series) r1p1 TRM, Figure 3-5 has incorrect address mapping

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Doc, Present in: r1p1-00rel0,r1p1-00rel1,r1p1-01rel0,r1p1-01rel1,r1p2-00rel0, Fixed in r2p0-

00rel0.

### **Description**

The top four registers

Comp\_id\_3, Comp\_id\_2, Comp\_id\_1, Comp\_id\_0

should be replaced by

pcell\_id\_3, pcell\_id\_2, pcell\_id\_1 and pcell\_id\_0 respectively.

The addresses shown on the right hand side of the figure are not correct.

From bottom to top, they should be

0xFE0 (corresponding to Periph\_id\_0), 0xFE4, 0xFE8, 0xFEC, 0xFF0, 0xFF4, 0xFF8 and 0xFFC.

### **Implications**

none

### Workaround

### 405861: Incorrect version of documentation in release

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Doc, Present in: r1p1-00rel1, Fixed in r1p1-01rel0.

### **Description**

Incorrect documentation versions relating to product revision r1p0 were delivered in error with the release of product r1p1-00rel1.

### **Implications**

None

### Workaround

Documentation from the previous (r1p1-00rel0) or subsequent (r1p1-01rel0) releases can be used.

# 408513: DDI0380D SMC (PL350 series) r1p2 TRM, memory configuration register description is incorrect

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Doc, Present in: r1p1-00rel0,r1p1-01rel0,r1p1-01rel0,r1p1-01rel1,r1p2-00rel0, Fixed in r2p0-

00rel0.

### **Description**

In the Memory Interface Configuration Register description on page 3-8 of TRM DDI0380C

### bits[9:8] memory\_type1 should read

```
Returns the memory interface 1 type:
```

b00 = Configuration does not include this memory interface

b01 = SRAM non-muxed

b10 = NAND

b11 = SRAM muxed

If b00, the remaining bit slices for memory interface 1 are always read as 0.

### (not SRAM mixed as it currently states)

### similarly bits[1:0] memory\_type0 should read

```
Returns the memory interface 0 type:
```

b00 = Reserved

b01 = SRAM non-muxed

b10 = NAND

b11 = SRAM muxed.

However due to an rtl defect the register will never read b11. If the rtl defect is not fixed both the above descriptions should be:

b01 = SRAM

b10 = NAND

b11 = Reserved.

### **Implications**

none

### Workaround

# 408962: DII0137C SMC (PL350 series) r1p1 IM, how to connect EBI to SMC when the interfaces run at different frequencies

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Doc, Present in: r1p1-00rel0,r1p1-00rel1,r1p1-01rel0,r1p1-01rel1,r1p2-00rel0, Fixed in r2p0-

00rel0.

### **Description**

On page 2-9 of the IM, the following note should be added for better clarification of system connectivity:

If the EBI were used to interface between two memory controllers (for instance SMC0 and SMC1), and SMC0 and the EBI were running faster than SMC1, then the EBIGRANT signal from EBI to SMC1 must be synchronised to the slow clock domain of SMC1.

Since EBICLOCK is synchronous to the memory controller clock domain, one flip-flop is enough to match the EBIGRANT signal from the EBICLK domain to the memory controller clock domain.

This logic is applicable even if the two different memory interfaces of PL350 are running at different frequencies, or if one of the memory controllers were a DMC.

### **Implications**

none

#### Workaround

# 411811: DDI0380C SMC (PL350 series) r1p1 TRM, Fig 5-1 shows incorrect values for set\_cycles\_val

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Doc, Present in: r1p1-00rel0,r1p1-01rel0,r1p1-01rel1,r1p2-00rel0, Fixed in r2p0-

00rel0.

### **Description**

In the TRM DDI0380C, Figure 5-1 says:

This should be changed to

```
set\_cycles\_val = (t6<<20) | (t5<<17) | (t4<<14) | (t3<<11) | (t2<<8) | (t1<<4) | (t0);
```

### **Implications**

none

### Workaround

# 442865: DDI0380E SMC (PL350) TRM, incorrect ecc\_value field width in ecc\_value register

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Doc, Present in: r2p0-00rel0, Fixed in r2p0-02rel0.

### **Description**

In PL350 r2p0 TRM, in table 3-22

Field ecc\_value is given as bits [24:0]. This should be [23:0].

The reserved bits are given as bits [26:25]. This should be [26:24].

### **Implications**

None

### Workaround

None

### 445215: Use of ClearCS or nand csl with the EBI can result in deadlock

### **Status**

Affects: product AXI Static Memory Controller, NAND Flash Memory Controller -3yr Term.

Fault status: Doc, Present in: r0p0-00rel0,r1p0-00rel0,r1p1-00rel0,r1p1-00rel1,r1p1-01rel0,r1p1-01rel0,r2p0-00rel0,r2p0-02rel0,r2p1-00rel0, Open.

### **Description**

Both the ClearCS bit in a NAND data phase command and the nand\_csl tie-off cause the SMC to hold CS low after completing a transaction.

This is intended behaviour that is required by certain NAND memory devices.

In systems that share the NAND memory interface using an EBI it must be noted that while the SMC holds CS low it also keeps requesting the EBI.

This means that there are a number of conditions that may create a deadlock:

- 1. A master controlling the NAND command sequence interleaves transactions with another memory interface connected to another port on the EBI.
- 2. An independant master(s) accesses another memory interface in the same memory controller as the NAND memory interface and prevents the next NAND command reaching the NAND memory interface.

It is therefore a system design requirement to ensure these conditions cannot occur.

### **Implications**

The system can deadlock

### Workaround

Don't use NAND memory devices that requires chip select to be held low between transactions.

NAND Flash Memory Controller (PL351)

Date of Issue: 12-Aug-2009 ARM Errata Notice Document Revision 15.0

### Errata – Driver Software

There are no Errata in this Category