## TMS320VC5505/5504 DSP External Memory Interface (EMIF)

# **User's Guide**



Literature Number: SPRUFO8A September 2009–Revised March 2010



## **Contents**

| Prefa | ace   |                  |                                                                     | . 9 |
|-------|-------|------------------|---------------------------------------------------------------------|-----|
| 1     | Exter | nal Me           | mory Interface (EMIF)                                               | 13  |
|       | 1.1   |                  | iction                                                              |     |
|       |       | 1.1.1            | Purpose of the External Memory Interface                            | 13  |
|       |       | 1.1.2            | Features                                                            |     |
|       |       | 1.1.3            | Functional Block Diagram                                            | 14  |
|       | 1.2   | Archite          | cture                                                               | 14  |
|       |       | 1.2.1            | Clock Control                                                       | 14  |
|       |       | 1.2.2            | EMIF Requests                                                       | 15  |
|       |       | 1.2.3            | Memory Map                                                          | 16  |
|       |       | 1.2.4            | Signal Descriptions                                                 | 16  |
|       |       | 1.2.5            | Pin Multiplexing                                                    | 17  |
|       |       | 1.2.6            | Asynchronous Controller and Interface                               | 17  |
|       |       | 1.2.7            | BYTEMODE Bits of The EMIF System Control Register                   | 35  |
|       |       | 1.2.8            | Data Bus Parking                                                    | 36  |
|       |       | 1.2.9            | Priority and Arbitration                                            | 36  |
|       |       | 1.2.10           | Reset Considerations                                                | 36  |
|       |       | 1.2.11           | Initialization                                                      | 37  |
|       |       | 1.2.12           | Interrupt Support                                                   |     |
|       |       | 1.2.13           | DMA Event Support                                                   |     |
|       |       | 1.2.14           |                                                                     |     |
|       |       | 1.2.15           | Emulation Considerations                                            |     |
|       |       |                  | CPU Instruction Pipeline Considerations                             |     |
|       | 1.3   | •                | ers                                                                 |     |
|       |       | 1.3.1            | Revision Register (REV)                                             |     |
|       |       | 1.3.2            | Status Register (STATUS)                                            |     |
|       |       | 1.3.3            | Asynchronous Wait Cycle Configuration Registers (AWCCR1 and AWCCR2) |     |
|       |       | 1.3.4            | Asynchronous Configuration Registers (ACSnCR1 and ACSnCR2)          |     |
|       |       | 1.3.5            | Interrupt Raw Register (EIRR)                                       |     |
|       |       | 1.3.6            | Interrupt Mask Register (EIMR)                                      |     |
|       |       | 1.3.7            | Interrupt Mask Set Register (EIMSR)                                 |     |
|       |       | 1.3.8            | Interrupt Mask Clear Register (EIMCR)                               |     |
|       |       | 1.3.9            | NAND Flash Control Register (NANDFCR)                               |     |
|       |       | 1.3.10<br>1.3.11 | Page Mode Control Registers (PAGEMODCTRL1) and (PAGEMODCTRL2)       |     |
|       |       |                  | NAND Flash CSn 1-Bit ECC Registers (NCSnECC1 ) and (NCSnECC2 )      |     |
|       |       | 1.3.12           |                                                                     |     |
|       |       | 1.3.13           | <b>ö</b>                                                            |     |
|       |       | 1.3.14           | NAND Flash 4-Bit ECC Register 2 (NAND4BITECC2)                      |     |
|       |       | 1.3.15           | NAND Flash 4-Bit ECC Register 2 (NAND4BITECC2)                      |     |
|       |       | 1.3.10           |                                                                     |     |
|       |       | 1.3.18           |                                                                     |     |
|       |       | 1.3.19           |                                                                     |     |
|       |       | 1.3.20           |                                                                     |     |
|       |       | 1.3.21           |                                                                     |     |
|       |       |                  |                                                                     |     |

3



| 1.3.22 | NAND Flash 4-Bit ECC Error Address Register 1 (NANDERRADD1) | 62 |
|--------|-------------------------------------------------------------|----|
| 1.3.23 | NAND Flash 4-Bit ECC Error Address Register 2 (NANDERRADD2) | 63 |
| 1.3.24 | NAND Flash 4-Bit ECC Error Address Register 3 (NANDERRADD3) | 63 |
| 1.3.25 | NAND Flash 4-Bit ECC Error Address Register 4 (NANDERRADD4) | 63 |
| 1.3.26 | NAND Flash 4-Bit ECC Error Value Register 1 (NANDERRVAL1)   | 63 |
| 1.3.27 | NAND Flash 4-Bit ECC Error Value Register 2 (NANDERRVAL2)   | 64 |
| 1.3.28 | NAND Flash 4-Bit ECC Error Value Register 3 (NANDERRVAL3)   | 65 |
| 1.3.29 | NAND Flash 4-Bit ECC Error Value Register 4 (NANDERRVAL4)   | 65 |



## List of Figures

| 1-1.  | EMIF Functional Block Diagram                                        | 14             |
|-------|----------------------------------------------------------------------|----------------|
| 1-2.  | Clocking Diagram for the EMIF                                        | 15             |
| 1-3.  | EMIF Asynchronous Interface                                          | 18             |
| 1-4.  | Connecting Data and Address Bus to Asynchronous Memory Devices       | 18             |
| 1-5.  | Common Asynchronous Interface                                        | 19             |
| 1-6.  | Timing Waveform of an Asynchronous Read Cycle in Normal Mode         | 23             |
| 1-7.  | Timing Waveform of an Asynchronous Write Cycle in Normal Mode        | 25             |
| 1-8.  | Timing Waveform of an Asynchronous Read Cycle in Select Strobe Mode  | 27             |
| 1-9.  | Timing Waveform of an Asynchronous Write Cycle in Select Strobe Mode | 28             |
| 1-10. | EMIF to NAND Flash Interface                                         |                |
| 1-11. | ECC Value for 8-Bit NAND Flash                                       |                |
| 1-12. | Revision Register (REV)                                              |                |
| 1-13. | Status Register (STATUS)                                             |                |
| 1-14. | Asynchronous Wait Cycle Configuration Register 1 (AWCCR1)            | 44             |
| 1-15. | Asynchronous Wait Cycle Configuration Register 2 (AWCCR2)            | 44             |
| 1-16. | Asynchronous CS2 Configuration Register 1 (ACS2CR1)                  |                |
| 1-17. | Asynchronous CS2 Configuration Register 2 (ACS2CR2)                  | 45             |
| 1-18. | Asynchronous CS3 Configuration Register 1 (ACS3CR1)                  | 45             |
| 1-19. | Asynchronous CS3 Configuration Register 2 (ACS3CR2)                  | 46             |
| 1-20. | Asynchronous CS4 Configuration Register 1 (ACS4CR1)                  |                |
| 1-21. | Asynchronous CS4 Configuration Register 2 (ACS4CR2)                  |                |
| 1-22. | Asynchronous CS5 Configuration Register 1 (ACS5CR1)                  | 46             |
| 1-23. | Asynchronous CS5 Configuration Register 2 (ACS5CR2)                  |                |
| 1-24. | Interrupt Raw Register (EIRR)                                        | 48             |
| 1-25. | Interrupt Mask Register (EIMR)                                       |                |
| 1-26. | Interrupt Mask Set Register (EIMSR)                                  | 50             |
| 1-27. | Interrupt Mask Clear Register (EIMCR)                                |                |
| 1-28. | NAND Flash Control Register (NANDFCR)                                |                |
| 1-29. | NAND Flash Status Register 1 (NANDFSR1)                              |                |
| 1-30. | NAND Flash Status Register 2 (NANDFSR2)                              |                |
| 1-31. | Page Mode Control Register 1 (PAGEMODCTRL1)                          |                |
| 1-32. | Page Mode Control Register 2 (PAGEMODCTRL2)                          |                |
| 1-33. | NAND Flash CSn 1-Bit ECC Register 1 (NCSnECC1)                       |                |
| 1-34. | NAND Flash CSn 1-Bit ECC Register 2 (NCSnECC2)                       |                |
| 1-35. | NAND Flash 4-Bit ECC Load Register (NAND4BITECCLOAD)                 |                |
| 1-36. | NAND Flash 4-Bit ECC Load Register 1 (NAND4BITECC1)                  |                |
| 1-37. | NAND Flash 4-Bit ECC Register 2 (NAND4BITECC2)                       | 59             |
| 1-38. | NAND Flash 4-Bit ECC Register 3 (NAND4BITECC3)                       |                |
| 1-39. | NAND Flash 4-Bit ECC Register 4 (NAND4BITECC4)                       | <del>6</del> 0 |
| 1-40. | NAND Flash 4-Bit ECC Register 5 (NAND4BITECC5)                       |                |
| 1-41. | NAND Flash 4-Bit ECC Register 6 (NAND4BITECC6)                       |                |
| 1-42. | NAND Flash 4-Bit ECC Register 7 (NAND4BITECC7)                       | 61             |
| 1-43. | NAND Flash 4-Bit ECC Register 8 (NAND4BITECC8)                       |                |
| 1-44. | NAND Flash 4-Bit ECC Error Address Register 1 (NANDERRADD1)          |                |
| 1-45. | NAND Flash 4-Bit ECC Error Address Register 2 (NANDERRADD2)          |                |
| 1-46. | NAND Flash 4-Bit ECC Error Address Register 3 (NANDERRADD3)          |                |
| 1-47. | NAND Flash 4-Bit ECC Error Address Register 4 (NANDERRADD4)          | 63             |



| 1-48. | NAND Flash 4-Bit ECC Error Value Register 1 (NANDERRVAL1) | 64 |
|-------|-----------------------------------------------------------|----|
| 1-49. | NAND Flash 4-Bit ECC Error Value Register 2 (NANDERRVAL2) | 64 |
| 1-50. | NAND Flash 4-Bit ECC Error Value Register 3 (NANDERRVAL3) | 65 |
| 1-51. | NAND Flash 4-Bit ECC Error Value Register 4 (NANDERRVAL4) | 65 |



### List of Tables

Ι

| 1-1.  | EMIF Memory Map                                                                                 | 16        |
|-------|-------------------------------------------------------------------------------------------------|-----------|
| 1-2.  | EMIF Pins Used to Access Asynchronous Devices                                                   | 16        |
| 1-3.  | EMIF Pins Specific to Asynchronous Devices                                                      | 16        |
| 1-4.  | Normal Mode vs. Select Strobe Mode                                                              | 17        |
| 1-5.  | Description of the Asynchronous CSn Configuration Registers (ACSnCR1 and ACSnCR2)               | 20        |
| 1-6.  | Description of the Asynchronous Wait Cycle Configuration Registers (AWCCR1 and AWCCR2)          | 21        |
| 1-7.  | Description of the EMIF Interrupt Mask Set Register (EIMSR)                                     | 21        |
| 1-8.  | Description of the EMIF Interrupt Mask Clear Register (EIMCR)                                   | 21        |
| 1-9.  | Asynchronous Read Operation in Normal Mode                                                      | 22        |
| 1-10. | Asynchronous Write Operation in Normal Mode                                                     | 23        |
| 1-11. | Asynchronous Read Operation in Select Strobe Mode                                               | 26        |
| 1-12. | Asynchronous Write Operation in Select Strobe Mode                                              | 27        |
| 1-13. | Description of the NAND Flash Control Register (NANDFCR)                                        | 29        |
| 1-14. | CPU and DMA Address to EMIF Address Pin Mapping                                                 | 30        |
| 1-15. | Effect of BYTEMODE Bits on EMIF Accesses                                                        | 35        |
| 1-16. | Interrupt Monitor and Control Bit Fields                                                        | 38        |
| 1-17. | Partial Pipeline Diagram of Consecutive Instructions That Write and Read at Different Addresses | 39        |
| 1-18. | NOP Instructions Inserted in the Code of Figure 1-3 to Make the Write Occur Before the Read     | 39        |
| 1-19. | EMIF Registers                                                                                  |           |
| 1-20. | EMIF System Registers                                                                           | 41        |
| 1-21. | Revision Register (REV) Field Descriptions                                                      | 43        |
| 1-22. | Status Register (STATUS) Field Descriptions                                                     | 43        |
| 1-23. | Asynchronous Wait Cycle Configuration Register 1 (AWCCR1) Field Descriptions                    | 44        |
| 1-24. | Asynchronous Wait Cycle Configuration Register 2 (AWCCR2) Field Descriptions                    | 44        |
| 1-25. | Asynchronous CSn Configuration Register 1 (ACSnCR1) Field Descriptions                          |           |
| 1-26. | Asynchronous CSn Configuration Register 2 (ACSnCR2) Field Descriptions                          | 47        |
| 1-27. | Interrupt Raw Register (EIRR) Field Descriptions                                                | 48        |
| 1-28. | Interrupt Mask Register (EIMR) Field Descriptions                                               | 49        |
| 1-29. | Interrupt Mask Set Register (EIMSR) Field Descriptions                                          | <b>50</b> |
| 1-30. | Interrupt Mask Clear Register (EIMCR) Field Descriptions                                        | 51        |
| 1-31. | NAND Flash Control Register (NANDFCR) Field Descriptions                                        | 51        |
| 1-32. | NAND Flash Status Register 1 (NANDFSR1) Field Descriptions                                      | 53        |
| 1-33. | NAND Flash Status Register 2 (NANDFSR2) Field Descriptions                                      | 54        |
| 1-34. | Page Mode Control Register 1 (PAGEMODCTRL1) Field Descriptions                                  | 55        |
| 1-35. | Page Mode Control Register 2 (PAGEMODCTRL2) Field Descriptions                                  | <b>56</b> |
| 1-36. | NAND Flash CSn 1-Bit ECC Register 1 (NCSnECC1) Field Descriptions                               | 57        |
| 1-37. | NAND Flash CSn 1-Bit ECC Register 2 (NCSnECC2) Field Descriptions                               | 58        |
| 1-38. | NAND Flash 4-Bit ECC Load Register (NAND4BITECCLOAD) Field Descriptions                         | 59        |
| 1-39. | NAND Flash 4-Bit ECC Load Register 1 (NAND4BITECC1) Field Descriptions                          | <b>59</b> |
| 1-40. | NAND Flash 4-Bit ECC Register 2 (NAND4BITECC2) Field Descriptions                               | 59        |
| 1-41. | NAND Flash 4-Bit ECC Register 3 (NAND4BITECC3) Field Descriptions                               | <b>60</b> |
| 1-42. | NAND Flash 4-Bit ECC Register 4 (NAND4BITECC4) Field Descriptions                               | 60        |
| 1-43. | NAND Flash 4-Bit ECC Register 5 (NAND4BITECC5) Field Descriptions                               | 61        |
| 1-44. | NAND Flash 4-Bit ECC Register 6 (NAND4BITECC6) Field Descriptions                               | 61        |
| 1-45. | NAND Flash 4-Bit ECC Register 7 (NAND4BITECC7) Field Descriptions                               | 61        |
| 1-46. | NAND Flash 4-Bit ECC Register 8 (NAND4BITECC8) Field Descriptions                               | 62        |
| 1-47. | NAND Flash 4-Bit ECC Error Address Register 1 (NANDERRADD1) Field Descriptions                  | 62        |

7



| NAND Flash 4-Bit ECC Error Address Register 2 (NANDERRADD2) Field Descriptions | 63                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NAND Flash 4-Bit ECC Error Address Register 3 (NANDERRADD3) Field Descriptions | 63                                                                                                                                                                                                                                                                                                                                                                                                               |
| NAND Flash 4-Bit ECC Error Address Register 4 (NANDERRADD4) Field Descriptions | 63                                                                                                                                                                                                                                                                                                                                                                                                               |
| NAND Flash 4-Bit ECC Error Value Register 1 (NANDERRVAL1) Field Descriptions   | 64                                                                                                                                                                                                                                                                                                                                                                                                               |
| NAND Flash 4-Bit ECC Error Value Register 2 (NANDERRVAL2) Field Descriptions   | 64                                                                                                                                                                                                                                                                                                                                                                                                               |
| NAND Flash 4-Bit ECC Error Value Register 3 (NANDERRVAL3) Field Descriptions   | 65                                                                                                                                                                                                                                                                                                                                                                                                               |
| NAND Flash 4-Bit ECC Error Value Register 4 (NANDERRVAL4) Field Descriptions   | 65                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                | NAND Flash 4-Bit ECC Error Address Register 3 (NANDERRADD3) Field Descriptions<br>NAND Flash 4-Bit ECC Error Address Register 4 (NANDERRADD4) Field Descriptions<br>NAND Flash 4-Bit ECC Error Value Register 1 (NANDERRVAL1) Field Descriptions<br>NAND Flash 4-Bit ECC Error Value Register 2 (NANDERRVAL2) Field Descriptions<br>NAND Flash 4-Bit ECC Error Value Register 3 (NANDERRVAL3) Field Descriptions |



SPRUF08A-September 2009-Revised March 2010

## **Read This First**

#### About This Manual

This document describes the operation of the external memory interface (EMIF) in the TMS320VC5505/5504 Digital Signal Processor (DSP). The purpose of the EMIF is to provide a means to connect to a variety of external asynchronous devices including NOR Flash, NAND Flash, and SRAM.

1

#### **Notational Conventions**

This document uses the following conventions.

- Hexadecimal numbers are shown with the suffix h. For example, the following number is 40 hexadecimal (decimal 64): 40h.
- Registers in this document are shown in figures and described in tables.
  - Each register figure shows a rectangle divided into fields that represent the fields of the register.
     Each field is labeled with its bit name, its beginning and ending bit numbers above, and its read/write properties below. A legend explains the notation used for the properties.
  - Reserved bits in a register figure designate a bit that is used for future device expansion.

#### **Related Documentation From Texas Instruments**

The following documents describe the TMS320C5515/14/05/04 Digital Signal Processor (DSP) Digital Signal Processor (DSP). Copies of these documents are available on the internet at http://www.ti.com.

<u>SWPU073</u> — TMS320C55x 3.0 CPU Reference Guide. This manual describes the architecture, registers, and operation of the fixed-point TMS320C55x digital signal processor (DSP) CPU.

<u>SPRU652</u> — TMS320C55x DSP CPU Programmer's Reference Supplement. This document describes functional exceptions to the CPU behavior.

SPRUF00 — TMS320VC5505/5504 Digital Signal Processor (DSP) Universal Serial Bus 2.0 (USB) User's Guide. This document describes the universal serial bus 2.0 (USB) in the TMS320VC5505/5504 Digital Signal Processor (DSP) devices. The USB controller supports data throughput rates up to 480 Mbps. It provides a mechanism for data transfer between USB devices.

<u>SPRUF01A</u> — TMS320C5515/14/05/04/VC05/VC04 Digital Signal Processor (DSP) Inter-Integrated Circuit (I2C) Peripheral User's Guide. This document describes the inter-integrated circuit (I2C) peripheral in the TMS320C5515/14/05/04/VC05/VC04 Digital Signal Processor (DSP) devices. The I2C peripheral provides an interface between the device and other devices compliant with Phillips Semiconductors Inter-IC bus (I2C-bus) specification version 2.1 and connected by way of an I2C-bus. This document assumes the reader is familiar with the I2C-bus specification.

SPRUFO2 — TMS320C5515/14/05/04/VC05/VC04 Digital Signal Processor (DSP) Timer/Watchdog Timer User's Guide. This document provides an overview of the three 32-bit timers in the TMS320C5515/14/05/04/VC05/VC04 Digital Signal Processor (DSP) devices. The 32-bit timers of the device are software programmable timers that can be configured as general-purpose (GP) timers. Timer 2 can be configured as a GP, a Watchdog (WD), or both simultaneously.

q



SPRUF03 — TMS320C5515/14/05/04/VC05/VC04 Digital Signal Processor (DSP) Serial Peripheral Interface (SPI) User's Guide. This document describes the serial peripheral interface (SPI) in the TMS320C5515/14/05/04/VC05/VC04 Digital Signal Processor (DSP) devices. The SPI is a high-speed synchronous serial input/output port that allows a serial bit stream of programmed length (1 to 32 bits) to be shifted into and out of the device at a programmed bit-transfer rate. The SPI supports multi-chip operation of up to four SPI slave devices. The SPI can operate as a master device only.

1

- <u>SPRUF04</u> TMS320C5515/14/05/04/VC05/VC04 Digital Signal Processor (DSP) General-Purpose Input/Output (GPIO) User's Guide. This document describes the general-purpose input/output (GPIO) on the TMS320C5515/14/05/04/VC05/VC04 digital signal processor (DSP) devices. The GPIO peripheral provides dedicated general-purpose pins that can be configured as either inputs or outputs. When configured as an input, you can detect the state of an internal register. When configured as an output you can write to an internal register to control the state driven on the output pin.
- SPRUF05 TMS320C5515/14/05/04/VC05/VC04 Digital Signal Processor (DSP) Universal Asynchronous Receiver/Transmitter (UART) User's Guide. This document describes the universal asynchronous receiver/transmitter (UART) peripheral in the TMS320C5515/14/05/04/VC05/VC04 Digital Signal Processor (DSP) devices. The UART performs serial-to-parallel conversions on data received from a peripheral device and parallel-to-serial conversion on data received from the CPU.
- SPRUFO6 TMS320VC5505/5504 Digital Signal Processor (DSP) Multimedia Card (MMC)/Secure Digital (SD) Card Controller User's Guide. This document describes the Multimedia Card (MMC)/Secure Digital (SD) Card Controller on the TMS320C5515/14/05/04/VC05/VC04 Digital Signal Processor (DSP) devices. The multimedia card (MMC)/secure digital (SD) card is used in a number of applications to provide removable data storage. The MMC/SD card controller provides an interface to external MMC and SD cards.
- <u>SPRUF07</u> TMS320VC5505/5504 Digital Signal Processor (DSP) Real-Time Clock (RTC) User's Guide. This document describes the operation of the Real-Time Clock (RTC) module in the TMS320VC5505/5504 Digital Signal Processor (DSP) devices. The RTC also has the capability to wake-up the power management and apply power to the rest of the device through an alarm, periodic interrupt, or external WAKEUP signal.
- <u>SPRUF08A</u> TMS320VC5505/5504 Digital Signal Processor (DSP) External Memory Interface (EMIF) User's Guide. This document describes the operation of the external memory interface (EMIF) in the TMS320VC5505/5504 Digital Signal Processor (DSP) devices. The purpose of the EMIF is to provide a means to connect to a variety of external devices.
- SPRUF09 TMS320VC5505/5504 Digital Signal Processor (DSP) Direct Memory Access (DMA) Controller User's Guide. This document describes the features and operation of the DMA controller that is available on the TMS320VC5505/5504 Digital Signal Processor (DSP) devices. The DMA controller is used to move data among internal memory, external memory, and peripherals without intervention from the CPU and in the background of CPU operation.
- SPRUFP0 TMS320VC5505 Digital Signal Processor (DSP) System User's Guide. This document describes various aspects of the TMS320VC5505/5504 digital signal processor (DSP) including: system memory, device clocking options and operation of the DSP clock generator, power management features, interrupts, and system control.
- <u>SPRUGL6</u> TMS320VC5504 Digital Signal Processor (DSP) System User's Guide. This document describes various aspects of the TMS320VC5505/5504 digital signal processor (DSP) including: system memory, device clocking options and operation of the DSP clock generator, power management features, interrupts, and system control.

SPRUFP1 — TMS320C5515/05/VC05 Digital Signal Processor (DSP) Successive Approximation (SAR) Analog to Digital Converter (ADC) User's Guide. This document provides an overview of the Successive Approximation (SAR) Analog to Digital Converter (ADC) on the TMS320C5515/14/05/04/VC05/VC04 Digital Signal Processor (DSP) devices. The SAR is a 10-bit ADC using a switched capacitor architecture which converts an analog input signal to a digital value.

1

- <u>SPRUFP3</u> TMS320C5515/05/VC05 Digital Signal Processor (DSP) Liquid Crystal Display Controller (LCDC) User's Guide. This document describes the liquid crystal display controller (LCDC) in the TMS320C5515/14/05/04/VC05/VC04 Digital Signal Processor (DSP) devices. The LCD controller includes a LCD Interface Display Driver (LIDD) controller.
- SPRUFP4 TMS320VC5505/5504 Digital Signal Processor (DSP) Inter-IC Sound (I2S) Bus User's Guide. This document describes the features and operation of Inter-IC Sound (I2S) Bus in the TMS320VC5505/5504 Digital Signal Processor (DSP) devices. This peripheral allows serial transfer of full duplex streaming data, usually streaming audio, between DSP and an external I2S peripheral device such as an audio codec.



Chapter 1 SPRUF08A–September 2009–Revised March 2010

## External Memory Interface (EMIF)

#### 1.1 Introduction

This document describes the operation of the External Memory Interface (EMIF) in the TMS320VC5505/5504 Digital Signal Processor (DSP).

### WARNING

1

Word and/or byte swaps can occur based on the datapath. For more details, see the *TMS320VC5505/VC5504* Fixed-Point Digital Signal Processor Silicon Revision 1.4 Silicon Errata (SPRZ281).

#### 1.1.1 Purpose of the External Memory Interface

The purpose of the EMIF is to provide a means to connect to a variety of external asynchronous devices including:

• NOR Flash, NAND Flash, and SRAM

#### 1.1.2 Features

The EMIF has the following features:

- Supports asynchronous devices (e.g. RAM, ROM, NOR Flash).
  - Up to 8 MB asynchronous address range over 4 chip selects.
  - Supports 8 and 16-bit data bus widths.
  - Programmable cycle timings for each chip select.
  - Page mode for NOR Flash.
  - Supports extended wait cycles.
  - Supports select strobe mode.
- Supports NAND Flash on 4 asynchronous chip selects.
  - Supports 8 and 16-bit data bus widths.
  - Programmable cycle timings for each chip select.
  - Supports 1-bit ECC for 8 and 16-bit NAND Flash.
  - Supports 4-bit ECC for 8-bit and 16-bit NAND Flash.
  - Does not perform error correction.



#### 1.1.3 Functional Block Diagram

Figure 1-1 illustrates a high-level view of the EMIF and its connections within the device. The CPU and DMA controller access the EMIF through a switched central resource. Section 1.2.3 describes the EMIF external pins and summarizes their purpose when interfacing with external devices.

1





#### 1.2 Architecture

This section provides details about the architecture and operation of the EMIF. Asynchronous interface is covered, along with other system-related topics such as clock control and pin multiplexing.

#### 1.2.1 Clock Control

As shown in Figure 1-2, the clock generator receives either the real-time clock (RTC) or a signal from an external clock source and produces the DSP system clock. This clock is used by the DSP CPU and peripherals.

The EMIF input clock is used to generate the access cycles in asynchronous mode. It can be used as-is or it can be divided by two.

The device includes logic which can be used to gate the clock to its on-chip peripherals, including the EMIF. The input clock to the EMIF can be enabled and disabled through the peripheral clock gating configuration register 1 (PCGCR1).





### Figure 1-2. Clocking Diagram for the EMIF

Ι

#### 1.2.2 EMIF Requests

Different modules within the DSP can make requests to the EMIF. These requests consist of accesses to asynchronous memory and EMIF registers. Because the EMIF can process only one request at a time, a switch central resource (SCR) exists within the DSP to provide prioritized requests from the different sources to the EMIF.

- 1. CPU (peripheral register access)
- 2. CPU (data access)
- 3. CPU (instruction fetch)
- 4. DMA Controller 3
- 5. USB
- 6. LCD

If a request is submitted to the EMIF from two or more sources simultaneously, the SCR will arbitrate between the difference sources using a round-robin approach. Upon completion of a request, the SCR again evaluates the pending requests and forwards the next pending request to the EMIF.



Architecture

When the EMIF receives a request, it may or may not be immediately processed. In some cases, the EMIF will perform one or more auto refresh cycles before processing the request. For details on the internal arbitration of the EMIF between performing requests and performing auto refresh cycles, see Section 1.2.9.

1

#### CAUTION

The EMIF does not support constant addressing mode. All request serviced by the EMIF must use a linear (incrementing) addressing mode.

#### 1.2.3 Memory Map

External memory is divided into several chip select spaces. On the device CPU, DMA controller 3 (DMA3) and USB and LCD can access external memory. The starting address for each of the chip select spaces in external memory is different from the point-of-view of these modules. The memory map as seen by these modules are shown in Table 1-1.

|                         |              |                           | •                          | •                         |                           |
|-------------------------|--------------|---------------------------|----------------------------|---------------------------|---------------------------|
| DSP Memory<br>Map       | Size (Bytes) | CPU Start Word<br>Address | DMA3 Start Byte<br>Address | USB Start Byte<br>Address | LCD Start Byte<br>Address |
| EMIF CS2                | 4M           | 40 0000h                  | 0200 0000h                 | 0200 0000h                | 0200 0000h                |
| EMIF CS3                | 2M           | 60 0000h                  | 0300 0000h                 | 0300 0000h                | 0300 0000h                |
| EMIF CS4                | 1M           | 70 0000h                  | 0400 0000h                 | 0400 0000h                | 0400 0000h                |
| EMIF CS5 <sup>(1)</sup> | 1M           | 78 0000h                  | 0500 0000h                 | 0500 0000h                | 0500 0000h                |

#### Table 1-1. EMIF Memory Map

<sup>(1)</sup> When MP/MC = 0 the upper 128K bytes of EMIF CS5 is used for ROM data.

#### 1.2.4 Signal Descriptions

Table 1-2 describes the EMIF pins that are used to interface to external devices.

| Table 1-2. | EMIF Pins | Used to Access | s Asynchronous Devices |
|------------|-----------|----------------|------------------------|
|------------|-----------|----------------|------------------------|

| Pin(s)      | Туре         | Description                                                                                                                                                                        |
|-------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EM_A[20:0]  | Output       | EMIF address bus. These pins are used in conjunction with the EM_BA[1:0] pins to form the address that is sent to the device.                                                      |
| EM_D[15:0]  | Input/Output | EMIF data bus.                                                                                                                                                                     |
| EM_BA[1:0]  | Output       | These pins are used in conjunction with the EM_A[20:0] pins to form the address that is sent to the device.                                                                        |
| EM_DQM[1:0] | Output       | Active-low byte enables. These pins are connected to byte enables.                                                                                                                 |
| EM_WE       | Output       | Active-low write enable. When interfacing to an asynchronous device, this pin provides a signal that is active-low during the strobe period of an asynchronous write access cycle. |

#### Table 1-3. EMIF Pins Specific to Asynchronous Devices

| Pin(s)       | Туре   | Description                                                                                                                                                                                                                                                            |
|--------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EM_CS[5:2]   | Output | Active-low chip select pins for asynchronous devices. These pins are meant to be<br>connected to the chip-select pins of the attached asynchronous device. These<br>pins are active only during accesses to the asynchronous memory.                                   |
| EM_OE        | Output | Active-low pin enable for asynchronous devices. This pin provides a signal which is active-low during the strobe period of an asynchronous read access cycle.                                                                                                          |
| EM_R/W       | Output | Active-low read/write select pin. This pin is high for the duration of an<br>asynchronous read access cycle and low for the duration of an asynchronous<br>write cycle.                                                                                                |
| EM_WAIT[3:0] | Input  | Wait input with programmable polarity / NAND Flash ready input. An<br>asynchronous device can extend the strobe period of an access cycle by asserting<br>the wait input pins. When connected to NAND flash devices these pins function as<br>NAND Flash ready inputs. |



#### 1.2.5 Pin Multiplexing

The EMIF address pins EM\_A[20:15] are multiplexed with GPIO pins GPIO[26:21]. The external bus selection register (EBSR) controls the functionality of these pins. For more details on this register, please refer to the device-specific data manual.

1

#### 1.2.6 Asynchronous Controller and Interface

The EMIF easily interfaces to a variety of asynchronous devices including: NOR Flash, NAND Flash, and SRAM. It can be operated in two major modes (see Table 1-4):

- Normal Mode
- Select Strobe Mode

The default mode of operation is Normal Mode, in which the  $\overline{\text{EM}_D\text{QM}}$  pins of the EMIF function as byte enables. In this mode, the  $\overline{\text{EM}_C\text{S}[5:2]}$  pins behave as typical chip select signals, remaining active for the duration of the asynchronous access. See Section 1.2.6.1 for an example interface with multiple 8-bit devices.

In Select Strobe Mode the  $\overline{\text{EM}_CS[5:2]}$  pins act as a strobe-active only during the strobe period of an access. In this mode, the  $\overline{\text{EM}_DQM}$  pins of the EMIF function as standard byte enables for reads and writes.

A summary of the differences between the two modes of operation are shown in Table 1-4. Refer to Section 1.2.6.4 for the details of asynchronous operations in Normal Mode, and Section 1.2.6.5 for the details of asynchronous operations in Select Strobe Mode.

The EMIF hardware defaults to Normal Mode for each chip select space, but can be manually switched to Select Strobe Mode by setting the SS bit of the Asynchronous CSn Configuration Register 2 (ACSnCR2).

| Mode               | Function of EM_DQM Pins | Operation of EM_CS[5:2] Pins                            |
|--------------------|-------------------------|---------------------------------------------------------|
| Normal Mode        | Byte enables            | Active during the entire asynchronous access cycle      |
| Select Strobe Mode | Byte enables            | Active only during the strobe period of an access cycle |

#### Table 1-4. Normal Mode vs. Select Strobe Mode

In both Normal Mode and Select Strobe Mode, the EMIF can be configured to operate in a sub-mode called NAND Flash Mode. In NAND Flash Mode, the EMIF is able to calculate an error correction code (ECC) for transfers up to 512 bytes.

The EMIF also provides configurable cycle timing parameters and an Extended Wait Mode that allows the connected device to extend the strobe period of an access cycle. The following sections describe the features related to interfacing with external asynchronous devices.

#### 1.2.6.1 Interfacing to Asynchronous Memory

Figure 1-3 shows the EMIF's external pins used in interfacing with an asynchronous device. The pin  $EM_CS[n]$  can be any of these chip select pins:  $EM_CS[5:2]$ .

### Figure 1-3. EMIF Asynchronous Interface

1



A. n=2, 3, 4, or 5

Of special note is the connection between the EMIF and the external device's address bus. The EMIF address pins EM\_A[20:0] always provide the least significant bits of a double-word (32-bit) address. The EM\_BA[1:0] pins provide word (16-bit) and byte selection functionality according to the data bus width configured in the Asynchronous CSn Configuration Register 1 (ACSnCR1). Figure 1-4 shows the mapping between the EMIF's and the connected device's data and address pins for an 8- and 16-bit data bus configuration.

#### Figure 1-4. Connecting Data and Address Bus to Asynchronous Memory Devices







b) EMIF to 16-bit memory interface



Figure 1-5 shows a common interface between the EMIF and an external asynchronous memory with byte enables. The EMIF should be operated in either Normal Mode or Select Strobe Mode when using this interface so that the EM\_DQM signals operate as byte enables.



1





#### 1.2.6.2 Accessing Larger Asynchronous Memories

The external memory address space within the DSP's memory map and the number of dedicated EMIF address pins limits the maximum size of any asynchronous memory device connected to the EMIF. If an asynchronous memory device with a size larger than that allowed by these restrictions is needed, then GPIO pins may be used to control the upper address lines of the memory device.

An approach like this is useful in a system which requires that application code be loaded from slower/larger flash memory into faster/smaller internal memory. In this type of system, the DSP's ROM Bootloader can load a secondary Bootloader from flash. The secondary Bootloader can then finish the boot process by loading the actual application code.

When the ROM Bootloader copies the secondary Bootloader from the lower portion of the flash it does not need to manipulate the upper address lines. Only the secondary Bootloader, which is board-specific and is stored in the external flash, needs to know which GPIO pins have been assigned to the function of upper address lines. Therefore, the secondary Bootloader can perform the task of configuring the selected pins as GPIO and loading the remainder of the code from the upper flash memory.

The ROM Bootloader assumes that any GPIO pins used to control the upper address lines of the flash memory will be pulled to '0' after reset. This means that normally the GPIO pins selected for this function will be either spare or used as outputs only by the application, and therefore can be pulled to '0' at reset with an external pull-down resistor. The GPIO pins chosen should be tri-stated by default on device reset. For details on which GPIO-capable pins are tri-stated on device reset, see the device Data Manual.

#### **1.2.6.3 Configuring the EMIF for Asynchronous Accesses**

The operation of the EMIF's asynchronous interface can be configured by programming the appropriate register fields. The tables below list the register fields that can be programmed and describe the purpose of each field. These registers must be programmed prior to accessing the external memory. A transfer following a write to these registers will use the new configuration.

**Note:** Section 1.3 provides the reset value and bit position for each register field. However, the Bootloader documentation should be consulted to determine if the fields are programmed during boot.



## Table 1-5. Description of the Asynchronous CSn Configuration Registers (ACSnCR1 and ACSnCR2)

| Parameter         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SS                | Select Strobe mode. This bit selects the EMIF's mode of operation in the following way:                                                                                                                                                                                                                                                                                                                                                                                                 |
|                   | <ul> <li>SS = 0h selects Normal Mode</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                   | <ul> <li>EM_DQM pins function as byte enables</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                   | <ul> <li>EM_CS[5:2] pins are active for duration of access</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                   | <ul> <li>SS = 1h selects Select Strobe Mode</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                   | <ul> <li>EM_DQM pins function as byte enables</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                   | <ul> <li>EM_CS[5:2] pins acts as a strobe</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| EW                | Extended Wait Mode enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                   | <ul> <li>EW = 0h disables Extended Wait Mode</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                   | <ul> <li>EW = 1h enables Extended Wait Mode</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                   | When set to 1, the EMIF enables its Extended Wait Mode in which the strobe width of an<br>access cycle can be extended in response to the assertion of the wait pins (EM_WAIT[3:0]).<br>The WPn bits in the Asynchronous Wait Cycle Configuration Register 2 (AWCCR2) controls to<br>polarity of wait pins.                                                                                                                                                                             |
|                   | <b>NOTE:</b> Extended Wait Mode should not be used while in NAND Flash Mode. See Section 1.2.6.6 for more details on this mode of operation                                                                                                                                                                                                                                                                                                                                             |
| N_SETUP/R_SETUP   | Ready/Write setup widths.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                   | These fields define the number of EMIF clock cycles of setup time for the address pins (EM_A[20:0] and EM_BA[1:0]), byte enables (EM_DQM[1:0]), and asynchronous chip select pins (EM_CS[5:2]) before the read strobe pin (EM_OE) or write strobe pin (EM_WE) falls, minus one cycle.                                                                                                                                                                                                   |
|                   | For writes, the W_SETUP field also defines the setup time for the data pins (EM_D[15:0]). Refer to the datasheet of the external asynchronous device to determine the appropriate setting for this field.                                                                                                                                                                                                                                                                               |
| W_STROBE/R_STROBE | Read/Write strobe widths.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                   | These fields define the number of EMIF clock cycles between the falling and rising of the read strobe pin (EM_OE) or write strobe pin (EM_WE), minus one cycle. If Extended Wait Mode is enabled (EW = 1), these fields must be set to a value greater than zero. Refer to the datashee of the external asynchronous device to determine the appropriate setting for this field.                                                                                                        |
| W_HOLD/R_HOLD     | Read/Write hold widths.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                   | These fields define the number of EMIF clock cycles of hold time for the address pins (EM_A[20:0] and EM_BA[1:0]), byte enables (EM_DQM[1:0]), and asynchronous chip select pins (EM_CS[5:2]) after the read strobe pin (EM_OE) or write strobe pin (EM_WE) rises, minus one cycle.                                                                                                                                                                                                     |
|                   | For writes, the W_HOLD field also defines the hold time for the data pins (EM_D[15:0]). Refer to the datasheet of the external asynchronous device to determine the appropriate setting for this field.                                                                                                                                                                                                                                                                                 |
| TA                | Minimum turnaround time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                   | This field defines the minimum number of EMIF clock cycles between asynchronous reads and writes, minus one cycle. The purpose of this feature is to avoid contention on the bus. Refer to the datasheet of the external asynchronous device to determine the appropriate setting for this field.                                                                                                                                                                                       |
|                   | Asynchronous device bus width.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                   | This field determines the data bus width of the asynchronous interface in the following way:                                                                                                                                                                                                                                                                                                                                                                                            |
|                   | <ul> <li>ASIZE = 0h selects an 8-bit bus</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                   | <ul> <li>ASIZE = 1h selects a 16-bit bus</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| ASIZE             | The configuration of ASIZE determines the function of the EM_A[20:0] and EM_BA[1:0] pins as described in Section 1.2.6.1. This field also determines the number of external accesses required to fulfill a request generated by one of the sources mentioned in . For example, a request for a double-word (32 bits) would require four external access when ASIZE = 0h. Refe to the datasheet of the external asynchronous device to determine the appropriate setting for this field. |

## Table 1-6. Description of the Asynchronous Wait Cycle Configuration Registers (AWCCR1 and AWCCR2)

1

| Parameter | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| WP[3:0]   | Wait pin polarity.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |
|           | <ul> <li>WPn = 0h selects active-high polarity</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
|           | <ul> <li>WPn = 1h selects active-low polarity When set to 1, the EMIF will wait if the wait pin is<br/>high. When set to 0, the EMIF will wait if the wait pin is low. The EMIF must have the<br/>Extended Wait Mode enabled for the wait pins to affect the width of the strobe period. The<br/>polarity of the wait pins is programmable.</li> </ul>                                                                                                                  |  |  |  |  |  |  |  |
|           | NOTE: The polarity of the wait pins is not programmable in NAND Flash Mode.                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
| MEWC      | Maximum Extended Wait Cycles.                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |
|           | This field configures the number of EMIF clock cycles the EMIF will wait for the wait pins<br>(EM_WAIT[3:0]) to be deactivated during the strobe period of an access cycle.                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
|           | The maximum number of EMIF clock cycles it will wait is determined by the following formula:                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |
|           | Maximum Extended Wait Cycles = (MEWC + 1) * 16                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
|           | If the wait pin is not deactivated within the time specified by this field, the EMIF resumes the access cycle, registering whatever data is on the bus and preceding to the hold period of the access cycle. This situation is referred to as an Asynchronous Timeout. An Asynchronous Timeout generates an interrupt if it has been enabled in the EMIF Interrupt Mask Set Register (EIMSR). Refer to Section 1.2.12 for more information about the EMIF's interrupts. |  |  |  |  |  |  |  |
|           | <b>NOTE:</b> Extended Wait Mode should not be used while in NAND Flash Mode. See Section 1.2.6.6 for more details on this mode of operation.                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |

#### Table 1-7. Description of the EMIF Interrupt Mask Set Register (EIMSR)

| Parameter | Description                                                                                                                   |  |  |  |  |  |  |
|-----------|-------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| WRMSET    | Wait Rise Mask Set.                                                                                                           |  |  |  |  |  |  |
|           | Writing a 1 to this bit enables an interrupt to be generated when a rising edge on a wait pin occurs while in NAND Flash Mode |  |  |  |  |  |  |
| ATMSET    | Asynchronous Timeout Mask Set.                                                                                                |  |  |  |  |  |  |
|           | Writing a 1 to this bit enables an interrupt to be generated when an Asynchronous Timeout occurs.                             |  |  |  |  |  |  |

#### Table 1-8. Description of the EMIF Interrupt Mask Clear Register (EIMCR)

| Parameter | Description                                                                                                              |  |  |  |  |  |
|-----------|--------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|           | Wait Rise Mask Clear.                                                                                                    |  |  |  |  |  |
| WRMCLR    | Writing a 1 to this bit disables the interrupt, clearing the WRMSET bit in the EMIF interrupt mask set register (EIMSR). |  |  |  |  |  |
| ATMCLR    | Asynchronous Timeout Mask Clear.                                                                                         |  |  |  |  |  |
|           | Writing a 1 to this bit enables an interrupt to be generated when an Asynchronous Timeout occurs.                        |  |  |  |  |  |

#### 1.2.6.4 Read and Write Operations in Normal Mode

Normal Mode is the asynchronous interface's default mode of operation. It is selected when the SS bit of the Asynchronous CSn Configuration Register 2 (ACSnCR2) is cleared to 0. In this mode, the EM\_DQM pins operate as byte enables. Section 1.2.6.4.1 and Section 1.2.6.4.2 explain the details of read and write operations while in Normal Mode.

#### 1.2.6.4.1 Asynchronous Read Operations (Normal Mode)

An asynchronous read is performed when any of the requesters mentioned in Section 1.2.2 request a read from the attached asynchronous memory. After the request is received, a read operation is initiated once it becomes the EMIF's highest priority task, according to the priority scheme detailed in Section 1.2.9. In the event that the read request cannot be serviced by a single access cycle to the external device, multiple access cycles will be performed by the EMIF until the entire request is fulfilled. The details of an asynchronous read operation in Normal Mode are described in Table 1-9. Also, Figure 1-6 shows an example timing diagram of a basic read operation.



| Time Interval      | Pin Activity in Normal Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| Turn-around period | Once the read operation becomes the highest priority task for the EMIF, the EMIF waits for the programmed number of turn-around cycles before proceeding to the setup period of the operation. The number of wait cycles is taken directly from the TA field of the Asynchronous CSn Configuration Register 1 (ACSnCR1). There are two exceptions to this rule:                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |
|                    | <ul> <li>If the current read operation was directly proceeded by another read operation, no turnaround cycles are<br/>inserted.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |
|                    | <ul> <li>If the current read operation was directly proceeded by a write operation and the TA field has been set to<br/>Oh, one turn-around cycle will be inserted.</li> <li>After the EMIF has waited for the turnaround cycles to complete, it again checks to make sure that the read<br/>operation is still its highest priority task. If so, the EMIF proceeds to the setup period of the operation. If it is<br/>no longer the highest priority task, the EMIF terminates the operation.</li> </ul>                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |
| Start of the setup | The following actions occur at the start of the setup period:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |
| period             | <ul> <li>The setup, strobe, and hold values are set according to the R_SETUP, R_STROBE, and R_HOLD<br/>values in ACSnCR1 and ACSNCR2.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |
|                    | <ul> <li>The address pins EM_A[20:0] and EM_BA[1:0] become valid and carry the values described in<br/>Figure 1-6.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |
|                    | EM_DQM[1:0] becomes valid.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |
|                    | • EM_CS[n] (where n = 2, 3, 4, or 5) falls to enable the external device (if not already low from a previous operation).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
| Strobe period      | The following actions occur during the strobe period of a read operation:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |
|                    | 1. EM_OE falls at the start of the strobe period                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |
|                    | 2. On the rising edge of the clock which is concurrent with the end of the strobe period:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |
|                    | EM_OE rises                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |
|                    | • The data on the EM_D[15:0] bus is sampled by the EMIF.<br>In Figure 1-6, the wait pins (EM_WAIT[3:0]) are inactive. If wait pins are instead activated, the strobe period can be extended by the external device to give it more time to provide the data. Section 1.2.5 contains more details on using the wait pins.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
| End of the hold    | At the end of the hold period:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |
| period             | <ul> <li>The address pins EM_A[20:0], EM_BA[1:0], and EM_DQM[1:0] become invalid</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |
|                    | • EM_CS[n] rises (if no more operations are required to complete the current request)<br>EMIF may be required to issue additional read operations to a device with a small data bus width in order to<br>complete an entire word access. In this case, the EMIF immediately re-enters the setup period to begin<br>another operation without incurring the turn-round cycle delay. The setup, strobe, and hold values are not<br>updated in this case. If the entire word access has been completed, the EMIF returns to its previous state<br>unless another asynchronous request has been submitted and is currently the highest priority task. If this is<br>the case, the EMIF instead enters directly into the turnaround period for the pending read or write operation. |  |  |  |  |  |  |  |  |  |

Table 1-9. Asynchronous Read Operation in Normal Mode





Figure 1-6. Timing Waveform of an Asynchronous Read Cycle in Normal Mode

A. During the entirety of an asychronous read operation, the EM\_WE and EM\_R/W pins are driven high.

B. n=2, 3, 4, or 5

#### 1.2.6.4.2 Asynchronous Write Operations (Normal Mode)

An asynchronous write is performed when any of the requesters mentioned in Section 1.2.2 request a write to memory in the asynchronous bank of the EMIF. After the request is received, a write operation is initiated once it becomes the EMIF's highest priority task, according to the priority scheme detailed in Section 1.2.9. In the event that the write request cannot be serviced by a single access cycle to the external device, multiple access cycles will be performed by the EMIF until the entire request is fulfilled. The details of an asynchronous write operation in Normal Mode are described in Table 1-10. Also, Figure 1-7 shows an example timing diagram of a basic write operation.

| Time Interval<br>Turnaround<br>period | Pin Activity in Normal Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |
|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
|                                       | Once the write operation becomes the highest priority task for the EMIF, the EMIF waits for the programmed number of turn-around cycles before proceeding to the setup period of the operation. The number of wait cycles is taken directly from the TA field of the Asynchronous CSn Configuration Register 1 (ACSnCR1). There are two exceptions to this rule:                                                                                                                               |  |  |  |  |  |  |  |  |
|                                       | <ul> <li>If the current write operation was directly proceeded by another write operation, no turn-around cycles are<br/>inserted.</li> </ul>                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
|                                       | <ul> <li>If the current write operation was directly proceeded by a read operation and the TA field has been set to 0h, one turnaround cycle will be inserted.</li> <li>After the EMIF has waited for the turn-around cycles to complete, it again checks to make sure that the write operation is still its highest priority task. If so, the EMIF proceeds to the setup period of the operation. If it is no longer the highest priority task, the EMIF terminates the operation.</li> </ul> |  |  |  |  |  |  |  |  |

#### Table 1-10. Asynchronous Write Operation in Normal Mode



| Time Interval      | Pin Activity in Normal Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| Start of the setup | The following actions occur at the start of the setup period:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |
| period             | <ul> <li>The setup, strobe, and hold values are set according to the W_SETUP, W_STROBE, and W_HOLD values in ACSnCR2.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |  |
|                    | <ul> <li>The address pins EM_A[20:0] and EM_BA[1:0] and the data pins EM_D[15:0] become valid. The<br/>EM_A[20:0] and EM_BA[1:0] pins carry the values described in Section 1.2.6.1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |
|                    | EM_DQM[1:0] become valid.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |
|                    | <ul> <li>The EM_R/W pin falls to indicate a write (if not already low from a previous operation).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |
|                    | <ul> <li>EM_CS[n] (where n = 2, 3, 4, or 5) falls to enable the external device (if not already low from a previous operation).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |
| Strobe period      | The following actions occur at the start of the strobe period of a write operation:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |
|                    | 1. EM_WE falls                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |
|                    | <ol> <li>Normal Mode<br/>The following actions occur on the rising edge of the clock which is concurrent with the end of the strobe<br/>period:</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |  |
|                    | 1. EM_WE rises                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |
|                    | <ol> <li>Normal Mode         In Figure 1-7, the wait pins (EM_WAIT[3:0]) are inactive. If the wait pins are instead activated, the strobe         period can be extended by the external device to give it more time to accept the data. Section 1.2.6.7 contains         more details on using the wait pins.     </li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |
| End of the hold    | At the end of the hold period:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |
| period             | <ul> <li>The address pins EM_A[20:0] and EM_BA[1:0] become invalid</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |
|                    | The data pins become invalid                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |
|                    | <ul> <li>The EM_R/W pin rises (if no more operations are required to complete the current request)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |
|                    | <ul> <li>EM_CS[n] rises (if no more operations are required to complete the current request)</li> <li>The EMIF may be required to issue additional write operations to a device with a small data bus width in order to complete an entire word access. In this case, the EMIF immediately re-enters the setup period to begin another operation without incurring the turnaround cycle delay. The setup, strobe, and hold values are not updated in this case. If the entire word access has been completed, the EMIF returns to its previous state unless another asynchronous request has been submitted and is currently the highest priority task. If this is th case, the EMIF instead enters directly into the turnaround period for the pending read or write operation.</li> </ul> |  |  |  |  |  |  |  |  |  |

Table 1-10. Asynchronous Write Operation in Normal Mode (continued)





Figure 1-7. Timing Waveform of an Asynchronous Write Cycle in Normal Mode

1

#### 1.2.6.5 Read and Write Operation in Select Strobe Mode

Select Strobe Mode is the EMIF's second mode of operation. It is selected when the SS bit of the Asynchronous CSn Configuration Register 2 (ACSnCR2) is set to 1. In this mode, the  $\overline{EM}_DQM[1:0]$  pins operate as byte enables and the  $\overline{EM}_CS[5:2]$  pins are only active during the strobe period of an access cycle. Section 1.2.6.5.1 and Section 1.2.6.5.2 explain the details of read and write operations while in Select Strobe Mode.

#### 1.2.6.5.1 Asynchronous Read Operations (Select Strobe Mode)

An asynchronous read is performed when any of the requesters mentioned in Section 1.2.2 request a read from the attached asynchronous memory. After the request is received, a read operation is initiated once it becomes the EMIF's highest priority task, according to the priority scheme detailed in Section 1.2.9. In the event that the read request cannot be serviced by a single access cycle to the external device, multiple access cycles will be performed by the EMIF until the entire request is fulfilled. The details of an asynchronous read operation in Select Strobe Mode are described in Table 1-11. Also, Figure 1-8 shows an example timing diagram of a basic read operation.



| Time Interval        | Pin Activity in Select Strobe Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| Turnaround<br>period | Once the read operation becomes the highest priority task for the EMIF, the EMIF waits for the programmed number of turn-around cycles before proceeding to the setup period of the operation. The number of wait cycles is taken directly from the TA field of the Asynchronous CSn Configuration Register 1 (ACSnCR1). There are two exceptions to this rule:                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |  |
|                      | <ul> <li>If the current read operation was directly proceeded by another read operation, no turn-around cycles are inserted.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |
|                      | <ul> <li>If the current read operation was directly proceeded by a write operation and the TA field has been set to<br/>0h, one turn-around cycle will be inserted.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |
|                      | After the EMIF has waited for the turn-around cycles to complete, it again checks to make sure that the read operation is still its highest priority task. If so, the EMIF proceeds to the setup period of the operation. If it is no longer the highest priority task, the EMIF terminates the operation.                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |
| Start of the setup   | The following actions occur at the start of the setup period:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |
| period               | <ul> <li>The setup, strobe, and hold values are set according to the R_SETUP, R_STROBE, and R_HOLD values<br/>in ACSnCR1 and ACSnCR2.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
|                      | <ul> <li>The address pins EM_A[20:0] and EM_BA[1:0] become valid and carry the values described in<br/>Section 1.2.6.1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |  |
|                      | <ul> <li>The EM_DQM pins become valid as byte enables.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |  |
| Strobe period        | The following actions occur during the strobe period of a read operation:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |
|                      | 1. $\overline{\text{EM}_{\text{CS}}[n]}$ (where n = 2, 3, 4, or 5) and $\overline{\text{EM}_{\text{OE}}}$ fall at the start of the strobe period                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |  |
|                      | 2. On the rising edge of the clock which is concurrent with the end of the strobe period:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |  |
|                      | EM_CS[n] and EM_OE rise                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |  |
|                      | <ul> <li>The data on the EM_D[15:0] bus is sampled by the EMIF.</li> <li>In Figure 1-8, the wait pins (EM_WAIT[3:0]) are inactive. If the wait pins are instead activated, the strobe period can be extended by the external device to give it more time to provide the data. Section 1.2.6.7 contains more details on using the wait pins.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |  |
| End of the hold      | At the end of the hold period:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |  |
| period               | <ul> <li>The address pins EM_A[20:0] and EM_BA[1:0] become invalid</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |  |
|                      | <ul> <li>The EM_DQM pins become invalid</li> <li>The EMIF may be required to issue additional read operations to a device with a small data bus width in order to complete an entire word access. In this case, the EMIF immediately re-enters the setup period to begin another operation without incurring the turnaround cycle delay. The setup, strobe, and hold values are not updated in this case. If the entire word access has been completed, the EMIF returns to its previous state unless another asynchronous request has been submitted and is currently the highest priority task. If this is the case, the EMIF instead enters directly into the turnaround period for the pending read or write operation.</li> </ul> |  |  |  |  |  |  |  |  |  |

Table 1-11. Asynchronous Read Operation in Select Strobe Mode



Figure 1-8. Timing Waveform of an Asynchronous Read Cycle in Select Strobe Mode

1

A. During the entirety of an asychronous read operation, the EM\_WE and EM\_R/W pins are driven high.

B. n=2, 3, 4, or 5

#### 1.2.6.5.2 Asynchronous Write Operations (Select Strobe Mode)

An asynchronous write is performed when any of the requesters mentioned in Section 1.2.2 request a write to memory in the asynchronous bank of the EMIF. After the request is received, a write operation is initiated once it becomes the EMIF's highest priority task, according to the priority scheme detailed in Section 1.2.9. In the event that the write request cannot be serviced by a single access cycle to the external device, multiple access cycles will be performed by the EMIF until the entire request is fulfilled. The details of an asynchronous write operation in Select Strobe Mode are described in Table 1-12. Also, Figure 1-9 shows an example timing diagram of a basic write operation.

| Time Interval        | Pin Activity in Select Strobe Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |  |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Turnaround<br>period | Once the write operation becomes the highest priority task for the EMIF, the EMIF waits for the programmed number of turn-around cycles before proceeding to the setup period of the operation. The number of wait cycles is taken directly from the TA field of the Asynchronous CSn Configuration Register 1 (ACSnCR1). There are two exceptions to this rule:                                                                                                                                           |  |  |  |  |  |  |  |  |
|                      | <ul> <li>If the current write operation was directly proceeded by another write operation, no turn-around cycles are<br/>inserted.</li> </ul>                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |
|                      | <ul> <li>If the current write operation was directly proceeded by a read operation and the TA field has been set to<br/>Oh, one turnaround cycle will be inserted.</li> <li>After the EMIF has waited for the turn-around cycles to complete, it again checks to make sure that the write<br/>operation is still its highest priority task. If so, the EMIF proceeds to the setup period of the operation. If it is no<br/>longer the highest priority task, the EMIF terminates the operation.</li> </ul> |  |  |  |  |  |  |  |  |
| Start of the setup   | The following actions occur at the start of the setup period:                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |
| period               | <ul> <li>The setup, strobe, and hold values are set according to the W_SETUP, W_STROBE, and W_HOLD values in ACSnCR2.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |  |
|                      | <ul> <li>The address pins EM_A[20:0] and EM_BA[1:0] and the data pins EM_D[15:0] become valid. The<br/>EM_A[20:0] and EM_BA[1:0] pins carry the values described in Section 1.2.6.1.</li> </ul>                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |
|                      | <ul> <li>The EM_R/W pin falls to indicate a write (if not already low from a previous operation).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |
|                      | • EM_CS[n] (where n = 2, 3, 4, or 5) falls to enable the external device (if not already low from a previous operation).                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |  |

Table 1-12. Asynchronous Write Operation in Select Strobe Mode



| Time Interval             | Pin Activity in Select Strobe Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| Strobe period             | The following actions occur at the start of the strobe period of a write operation:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |  |  |
|                           | 1. EM_WE falls                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
|                           | <ol> <li>The EM_DQM pins become active as write strobes.</li> <li>The following actions occur on the rising edge of the clock which is concurrent with the end of the strobe period:</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |  |  |
|                           | 1. EM_WE rises                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
|                           | 2. The EM_DQM pins deactivate<br>In Figure 1-9, the wait pins (EM_WAIT[3:0]) are inactive. If the wait pins are instead activated, the strobe period<br>can be extended by the external device to give it more time to accept the data. Section 1.2.6.7 contains more<br>details on using the wait pins.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |  |
| End of the hold<br>period | At the end of the hold period:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |  |
|                           | <ul> <li>The address pins EM_A[20:0] and EM_BA[1:0] become invalid</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |
|                           | The data pins become invalid                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |  |
|                           | <ul> <li>The EM_R/W pin rises (if no more operations are required to complete the current request)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |  |  |
|                           | • EM_CS[n] rises (if no more operations are required to complete the current request)<br>The EMIF may be required to issue additional write operations to a device with a small data bus width in order<br>to complete an entire word access. In this case, the EMIF immediately re-enters the setup period to begin<br>another operation without incurring the turnaround cycle delay. The setup, strobe, and hold values are not<br>updated in this case. If the entire word access has been completed, the EMIF returns to its previous state<br>unless another asynchronous request has been submitted and is currently the highest priority task. If this is the<br>case, the EMIF instead enters directly into the turnaround period for the pending read or write operation. |  |  |  |  |  |  |  |  |

 Table 1-12. Asynchronous Write Operation in Select Strobe Mode (continued)

Ι





A. During the entirety of an asychronous write operation, the EM\_OE pin is driven high. B.  $\,$  n=2, 3, 4, or 5  $\,$ 

#### 1.2.6.6 NAND Flash Mode

NAND Flash Mode is a sub-mode of both Normal Mode and Select Strobe Mode. The chip select pins (EM\_CS[5:2]) may be placed in NAND Flash mode by setting the CSn\_USE\_NAND bits in the NAND Flash control register (NANDFCR). Note that the NAND Flash Mode can be independently enabled for each chip select space. Table 1-13 displays the bit fields present in NANDFCR and briefly describes their use.

1

When a chip select space is configured to operate in NAND Flash mode, the EMIF hardware can calculate the error correction code (ECC) for each 512 byte data transfer to that chip select space. The EMIF hardware will not automatically generate a NAND access cycle, which includes the command, address, and data phases, necessary to complete a transfer to NAND Flash. All NAND Flash operations can be divided into single asynchronous cycles and with the help of software, the EMIF can execute a complete NAND access cycle.

**NOTE:** By default, the  $\overline{\text{EM}_{CS2}}$  pin is set to NAND Flash mode after reset. The NAND Flash mode is disabled for the other chip select pins ( $\overline{\text{EM}_{CS[3:5]}}$ ).

| Parameter     | Description                                                                                                                                                      |  |  |  |  |  |  |  |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| CS2_ECC_START | NAND Flash ECC state for EM_CS2.                                                                                                                                 |  |  |  |  |  |  |  |
|               | Set to 1 to start an ECC calculation for NAND Flash connected to EM_CS2. This bit is cleared to 0 when the NAND Flash 1-Bit ECC Registers for EMIF CS2 are read. |  |  |  |  |  |  |  |
| CS2_USE_NAND  | NAND Flash mode for EM_CS2.                                                                                                                                      |  |  |  |  |  |  |  |
|               | Set to 1 to enable NAND Flash mode for EM_CS2.                                                                                                                   |  |  |  |  |  |  |  |
| CS3_ECC_START | NAND Flash ECC state for EM_CS3.                                                                                                                                 |  |  |  |  |  |  |  |
|               | Set to 1 to start an ECC calculation for NAND Flash connected to EM_CS3. This bit is cleared to 0 when the NAND Flash 1-Bit ECC Registers for EMIF CS3 are read. |  |  |  |  |  |  |  |
| CS3_USE_NAND  | NAND Flash mode for EM_CS3.                                                                                                                                      |  |  |  |  |  |  |  |
|               | Set to 1 to enable NAND Flash mode for EM_CS3.                                                                                                                   |  |  |  |  |  |  |  |
| CS4_ECC_START | NAND Flash ECC state for EM_CS4.                                                                                                                                 |  |  |  |  |  |  |  |
|               | Set to 1 to start an ECC calculation for NAND Flash connected to EM_CS4. This bit is cleared to 0 when the NAND Flash 1-Bit ECC Registers for EMIF CS4 are read. |  |  |  |  |  |  |  |
| CS4_USE_NAND  | NAND Flash mode for EM_CS4.                                                                                                                                      |  |  |  |  |  |  |  |
|               | Set to 1 to enable NAND Flash mode for EM_CS4.                                                                                                                   |  |  |  |  |  |  |  |
| CS5_ECC_START | NAND Flash ECC state for EM_CS5.                                                                                                                                 |  |  |  |  |  |  |  |
|               | Set to 1 to start an ECC calculation for NAND Flash connected to EM_CS5. This bit is cleared to 0 when the NAND Flash 1-Bit ECC Registers for EMIF CS5 are read. |  |  |  |  |  |  |  |
| CS5_USE_NAND  | NAND Flash mode for EM_CS5.                                                                                                                                      |  |  |  |  |  |  |  |
|               | Set to 1 to enable NAND Flash mode for EM_CS5.                                                                                                                   |  |  |  |  |  |  |  |

#### Table 1-13. Description of the NAND Flash Control Register (NANDFCR)

#### 1.2.6.6.1 Configuring for NAND Flash Mode

Similar to the asynchronous accesses previously described, the EMIF's registers must be programmed appropriately to interface to a NAND Flash device. In addition to the fields listed in Table 1-13, you should set the CSn\_USE\_NAND bits of the NAND Flash Control Register (NANDFCR) to 1 for the chip select spaces you want to operate in NAND Flash Mode. Note that the Extended Wait Mode of any chip select space being used in NAND Flash Mode should be disabled by setting EW = 0 in the Asynchronous CSn Configuration Register 2 (ACSnCR2).

#### 1.2.6.6.2 Connecting to NAND Flash

Figure 1-10 shows the EMIF external pins used to interface with a NAND Flash device. EMIF address lines are used to drive the NAND Flash device's command latch enable (CLE) and address latch enable (ALE) signals. Note that you can use any EMIF address lines to drive the CLE and ALE signals of the NAND Flash.

**NOTE:** The EMIF will not control the NAND Flash device's write protect pin. The write protect pin must be controlled outside of the EMIF.

Architecture



**NOTE:** By default, the  $\overline{\text{EM}_{CS2}}$  pin is set to NAND Flash mode after reset. The NAND Flash mode is disabled for the other chip select pins ( $\overline{\text{EM}_{CS[3:5]}}$ ).

Ι









b) Connection to 16-Bit NAND Device

A. n=2, 3, 4, or 5 B. m=0, 1, 2, or 3

#### 1.2.6.6.3 Driving CLE and ALE

As described in Section 1.2.6.6.2, any of the EMIF address lines can be used to drive the ALE and CLE pins of the NAND Flash device. The following must be considered when using this approach:

- The CPU cannot generate 8-bit accesses to its data or I/O space. However, the EMIF can be
  programmed to access a single byte for every word access initiated by the CPU (see Section 1.2.7 for
  more details).
- As stated in Section 1.2.6.1, the EMIF always drives the least significant bit of a double-word (32-bit) address on EM\_A[0].

Table 1-14 shows how a CPU word address (EM\_A[21:0]) is driven on the EMIF address pins. Table 1-14 also shows how a DMA byte address is driven on the EMIF address pins.

| CPU Word Address | DMA Byte Address | EMIF Address Pins |  |  |  |  |
|------------------|------------------|-------------------|--|--|--|--|
| A21              | A22              | EM_A[20]          |  |  |  |  |
|                  |                  |                   |  |  |  |  |
| A13              | A14              | EM_A[12]          |  |  |  |  |
| A12              | A13              | EM_A[11]          |  |  |  |  |
|                  |                  |                   |  |  |  |  |
| A1               | A2               | EM_A[0]           |  |  |  |  |
| A0               | A1               | EM_BA[1]          |  |  |  |  |
| 0                | A0               | EM_BA[0]          |  |  |  |  |

#### Table 1-14. CPU and DMA Address to EMIF Address Pin Mapping

#### Notes:

- The EM\_BA[1:0] pins are not required when interfacing to NAND Flash memory, however, they are included in this figure to provide a complete picture of CPU address to EMIF address pin mapping.
- The EM\_BA[0] pin is only used if the EMIF data bus is configured as an 8-bit bus (ASIZE = 00b).

1

As an example, suppose that the EMIF address pins EM\_A[12] and EM\_A[11] are used to drive the CLE and ALE pins of the NAND Flash memory and that the EM\_CS2 is used to drive the CE pin. In this situation, a write or read from the following CPU word addresses can be used to manipulate the CLE and ALE pins:

- 40 0000h (40 0000h + 00 0000h): a CPU write or read from this address drives CLE and ALE low.
- 40 2000h (40 0000h + 00 2000h): a CPU write or read from this address drives CLE high and ALE low.
- 40 1000h (40 0000h + 00 1000h); a CPU write or read from this address drives CLE low and ALE high.

Note that in this example the CPU must access EMIF CS2 to initiate accesses with the memory device. As indicated by Table 1-1, EMIF CS2 starts at CPU word address 40 0000h. When using other chip select spaces to interface to NAND, simply replace base address used in this example with that of chip select being used.

#### 1.2.6.6.4 NAND Read and Program Operations

A NAND Flash access cycle is composed of a command, address, and data phase. The EMIF will not automatically generate these three phases to complete a NAND access with one transfer request. To complete a NAND access cycle, multiple single asynchronous access cycles (as described above) must be completed by the EMIF. Software must be used to request the appropriate asynchronous accesses to complete a NAND Flash access cycle. This software must be developed to the specification of the chosen NAND Flash device.

Since NAND operations are divided into single asynchronous access cycles, the chip select signal will not remain activated for the duration of the NAND operation. Instead, the chip select signal will deactivate between each asynchronous access cycle. For this reason, the EMIF does not support NAND Flash devices that require the chip select signal to remain low during the  $t_R$  time for a read. See Section 1.2.6.6.9 for workaround.

Care must be taken when performing a NAND read or write operation via the DMA controller. See Section 1.2.6.6.5 for more details.

**NOTE:** The EMIF does not support NAND Flash devices that require the chip select signal to remain low during the  $t_R$  time for a read. See Section 1.2.6.6.9 for workaround.

#### 1.2.6.6.5 NAND Data Read and Write via DMA Controller

When performing NAND accesses, the DMA controller is most efficiently used for the data phase of the access. The command and address phases of the NAND access require only a few words of data to be transferred and therefore do not take advantage of the DMA controller's ability to transfer larger quantities of data with a single request. Furthermore, since the minimum amount of data the DMA controller can transfer is one double-word (32-bits), it cannot be used during NAND command and address phases. In this section we will focus on using the DMA controller for the data phase of a NAND access.

There are two conditions that require care to be taken when performing NAND reads and writes via the DMA controller. These are:

- The address lines used to drive CLE and ALE signals must be driven low.
- The EMIF does not support a constant address mode, but only supports linear incrementing address modes.

Since the EMIF does not support a constant addressing mode, when programming the DMA, a linear incrementing address mode must be used. When using a linear incrementing address mode, care must be taken not to increase the address into a range that drives CLE and/or ALE high. To prevent the address from incrementing into a range that drives CLE and/or ALE high, the DMA start address and transfer size must be carefully considered.



Consider a system in which EM\_A[12] is connected to CLE and EM\_A[11] is connected to ALE. In this case, per Figure 1-11, the transfer size of the DMA must stay below 8192 bytes (2^13) to avoid driving the CLE and ALE pins to 1. The DMA setup for a NAND Flash data read would look as follows:

I

•  $4 \leq \text{LENGTH} \leq 8192 \text{ bytes}$ 

Architecture

- DSTAMODE = 00b, automatic post increment
- SRCAMODE = 00b, automatic post increment
- SSA (source start address) = CE base address
- DSA (destination start address) = address of internal memory buffer

Similarly, the DMA setup for a NAND Flash data write would be as follows:

- $4 \leq \text{LENGTH} \leq 8192$  bytes
- DSTAMODE = 00b, automatic post increment
- SRCAMODE = 00b, automatic post increment
- SSA (source start address) = address of internal memory buffer
- DSA (destination start address) = CE base address

#### 1.2.6.6.6 1-Bit ECC Generation

If the CSn\_USE\_NAND bits in the NAND Flash control register (NANDFCR) are set to 1, the EMIF supports ECC calculation for up to 512 bytes for the corresponding chip select space. To perform the ECC calculation, the corresponding CSn\_ECC\_START bits in NANDFCR must be set to 1. It is the responsibility of the software to start the ECC calculation prior to issuing a write or read to NAND Flash. It is also the responsibility of the software to read the calculated ECC from the NAND Flash 1-Bit ECC registers once the transfer to NAND Flash has completed. If the software writes or reads more than 512 bytes, the ECC will be incorrect.

Reading a NAND Flash 1-Bit ECC register clears the corresponding CSn\_ECC\_START bit in NANDFCR. Also, the NAND Flash 1-Bit ECC registers are cleared upon writing a 1 to the corresponding CSn\_ECC\_START bit in NANDFCR.

Figure 1-11 shows the algorithm used to calculate the ECC value for an 8-bit NAND Flash.

For an 8-bit NAND Flash, p1o through p4e are column parities and p8e through p2048o are row parities. Similarly, the algorithm can be extended to a 16-bit NAND Flash. For a 16-bit NAND Flash p1o through p8e are column parities and p16e through p2048o are row parities. The software must ignore the unwanted parity bits if ECC is desired for less than 512 bytes of data. For example, p2048e and p2048o are not required for ECC on 256 bytes of data. Similarly, p1024e, p1024o, p2048e, and p2048o are not required for ECC on 128 bytes of data.

| Byte 1 | Bit 7   | Bit 6 | Bit 5   | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | p8e |      |      |        |
|--------|---------|-------|---------|-------|-------|-------|-------|-------|-----|------|------|--------|
| Byte 2 | Bit 7   | Bit 6 | Bit 5   | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | p8o | p16e | p32e |        |
| Byte 3 | Bit 7   | Bit 6 | Bit 5   | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | p8e | p160 |      | p2048e |
| Byte 4 | Bit 7   | Bit 6 | Bit 5   | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | p8o | p16o |      | p20400 |
|        |         |       |         |       |       |       |       |       |     |      | •    |        |
|        |         |       |         |       |       |       |       |       |     |      | •    |        |
|        |         |       |         |       |       |       |       |       |     |      |      |        |
| Byte 1 | Bit 7   | Bit 6 | Bit 5   | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | p8e | p16e |      |        |
| Byte 2 | Bit 7   | Bit 6 | Bit 5   | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | p8o | pice | p32e | p2048o |
| Byte 3 | Bit 7   | Bit 6 | Bit 5   | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | p8e | p16o | psze |        |
| Byte 4 | Bit 7   | Bit 6 | Bit 5   | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | p8o | p100 |      |        |
|        | p1o     | p1e   | p1o     | p1e   | p1o   | p1e   | p1o   | p1e   |     |      |      |        |
|        | p2o p2e |       | p2o p2e |       |       |       |       |       |     |      |      |        |
|        | p4o     |       |         | p4e   |       |       |       |       |     |      |      |        |
|        |         |       |         |       | ÷     |       |       |       |     |      |      |        |

#### Figure 1-11. ECC Value for 8-Bit NAND Flash



#### 1.2.6.6.7 4-Bit ECC Generation

The EMIF supports 4-bit ECC for 8-bit and 16-bit NAND Flash. In NAND mode, if the NAND Flash 4-bit ECC start bit (4BIT\_ECC\_START) in the NAND Flash Control register (NANDFCR) is set, the EMIF calculates 4-bit ECC for the selected chip select. Only one chip select can be selected for the 4-bit ECC calculation at one time. The selection of the chip select is done by programming the 4-bit ECC CS select bit field (4BIT\_ECC\_SEL) in NANDFCR.

The calculated parity (for writes) and syndrome (for reads) can be read from the NAND Flash 4-Bit ECC registers (NAND4BITECC1[8:1]). The 4-bit ECC start bit (4BIT\_ECC\_START) is cleared upon reading any of the NAND Flash 4-Bit ECC registers. The NAND Flash 4-Bit ECC registers are cleared upon writing 1 to the 4-bit ECC start bit (4BIT\_ECC\_START).

The 4-bit ECC algorithm works on a 10-bit data bus. Since the 4-bit ECC is calculated over an 8-bit value for 8- and 16-bit NAND Flash, the EMIF zeroes the upper two bits. However, the parity and the syndrome value read from the NAND Flash 4-Bit ECC registers are 10 bits wide. It is the responsibility of software to convert 10-bit parity values to 8 or 16 bits before writing to the spare location of the NAND Flash after a write operation. Similarly, it is the responsibility of the software to convert the 8- or 16-bit parity values read from the spare location of the NAND Flash after a read operation to 10 bits before writing the NAND Flash 4-Bit ECC Load register (NAND4BITECCLOAD).

At the end of the syndrome calculation after read, the error address and the error value can be calculated by setting the address and error value calculation start bit (ADDR\_CALC\_ST) in the NAND Flash Control register (NANDFCR). The end of address calculation is flagged by the 4-bit ECC correction state field (CORRSTATE) in the NAND Flash Status register 1 (NANDFSR1). The number of errors can be read from the 4-bit number of errors field (ERRNUM) in the NAND Flash Status register 2 (NANDFSR2). The error address value can be read from the NAND Flash 4-Bit ECC Error Address registers (NANDERRADD[4:1]). The error value can be read from the NAND Flash 4-Bit ECC Error Value registers (NANDERRVAL1[4:1]).

The address and error value start bit (ADDR\_CALC\_ST) are cleared upon reading any of the NAND Flash 4-Bit ECC Error Address registers or the NAND Flash 4-Bit ECC Error Value registers. The EMIF records the syndrome value internally before the error address and error value calculation. Therefore, a new read operation can be performed simultaneously with the error address calculation.

The EMIF supports 4-bit ECC calculation up to 518 bytes. The software needs to follow the following procedure for 4-bit ECC calculation:

For writes:

- 1. Set the (4BIT\_ECC\_START) bit in the NAND Flash Control register (NANDFCR) to 1.
- 2. Write 518 bytes of data to the NAND Flash.
- 3. Read the parity from the NAND Flash 4-Bit ECC registers (NAND4BITECC1[8:1]).
- 4. Convert the 10-bit parity values to 8 or 16 bits depending on the width of the connected NAND Flash memory. All 10-bit parity values can be concatenated together with ECC value 1 (4BIT\_ECC\_VAL1) as the LSB and ECC value 8 (4BIT\_ECC\_VAL8) as the MSB. Then the concatenated value can be broken down into ten 8-bit or five 16-bit values.
- 5. Store the parity to a spare location in the NAND Flash.

For reads:

- 1. Set the (4BIT\_ECC\_START) bit in the NAND Flash Control register (NANDFCR) to 1.
- 2. Read 518 bytes of data from the NAND Flash.
- 3. Clear the (4BIT\_ECC\_START) bit in NANDFCR by reading any of the NAND Flash 4-Bit ECC registers.
- 4. Read the parity stored in the spare location in the NAND Flash.
- 5. Convert the 8-bit or 16-bit parity values to 10-bits. Reverse of the conversion that was done during writes.
- 6. Write the parity values in the NAND Flash 4-bit ECC Load register (NAND4BITECCLOAD). Write each parity value one at a time starting from 4BIT\_ECC\_VAL8 to 4BIT\_ECC\_VAL1.
- 7. Perform a dummy read to the EMIF revision register (REV). This is only required to ensure time for syndrome calculation after writing the ECC values in step 6.



Architecture

8. Read the syndrome from the NAND Flash 4-Bit ECC registers (NAND4BITECC1[8:1]). A syndrome value of 0 means no bit errors. If the syndrome is non-zero continue to step 9.

I

- 9. Set the (ADDR\_CALC\_ST) it in NANDFCR to 1.
- 10. Start another read from NAND if required (a new thread from step 1).
- 11. Wait for the 4-bit ECC correction state field (CORRSTATE) in NANDFSR1 to be equal to 1h, 2h, or 3h.
- 12. The number of errors can be read from the 4-bit number of errors field (ERRNUM) in the NANDFSR2.
- Read the error address from the NAND Flash 4-Bit ECC Error Address registers (NANDERRADD[4:1]). The address for the word in error is equal to: total\_words\_read + 7 address\_value. For 518 bytes, the address will be equal to: 525 - address\_value.
- 14. Read the error value from NAND Flash 4-Bit ECC Error Value registers (NANDERRVAL[4:1]). The values from these registers can be XORed with the errored word to correct the errors.

**NOTE:** You must perform step 13 or 14. Otherwise the ADDR\_CALC\_ST bit will not be cleared and you will not be able to start a new address and value error calculation.

#### 1.2.6.6.8 NAND Flash Status Registers (NANDFSR1 and NANDFSR2)

The NAND Flash status register 1 (NANDFSR1) indicates the raw status of the EM\_WAIT[3:0] pins while in NAND Flash Mode. A wait pin should be connected to the NAND Flash device's R/B signal, so that it can indicate whether or not the NAND Flash device is busy.

During a read, the R/B signal will transition and remain low while the NAND Flash retrieves the data requested. Once the R/B signal transitions high, the requested data is ready and should be read by the EMIF. During a write/program operation, the R/B signal transitions and remains low while the NAND Flash is programming the Flash with the data it has received from the EMIF. Once the R/B signal transitions high, the data has been written to the Flash and the next phase of the transaction may be performed.

From this explanation, you can see that the NAND Flash status register is useful to the software for indicating the status of the NAND Flash device and determining when to proceed to the next phase of a NAND Flash operation.

When a rising edge occurs on a wait pin, the EMIF sets the corresponding WR (wait rise) bit in the EMIF Interrupt Raw Register (EIRR). Therefore, the EMIF Wait Rise interrupt may be used to indicate the status of the NAND Flash device. The WPn bits in the Asynchronous Wait Cycle Configuration Register (AWCCR) do not affect the NAND Flash status register (NANDFSR) or the WR bits in EIRR. See Section 1.2.12 for more a detailed description of the wait rise interrupt.

#### 1.2.6.6.9 Interfacing to a Non-CE Don't Care NAND Flash

As explained in Section 1.2.6.6.4, the EMIF does not support NAND Flash devices that require the chip select signal to remain low during the  $t_R$  time for a read. One way to work around this limitation is to use a GPIO pin to drive the CE signal of the NAND Flash device. If this work around is implemented, software will configure the selected GPIO to be low, then begin the NAND Flash operation, starting with the command phase. Once the NAND Flash operation has completed the software can then configure the selected GPIO to be high.

#### 1.2.6.7 Extended Wait Mode and the Wait Pins

The EMIF supports the Extend Wait Mode. This is a mode in which the external asynchronous device may assert control over the length of the strobe period. The Extended Wait Mode can be enabled on a per chip select basis by setting the EW bit in the Asynchronous CSn Configuration register 2 (ACSnCR2). When this bit is set, the EMIF monitors the wait pin corresponding to the chip select being accessed to determine if the attached device wishes to extend the strobe period of the current access cycle beyond the programmed number of clock cycles.

If the EMIF detects that the wait pin has been asserted, it will begin inserting extra strobe cycles into the operation until the wait pin is deactivated by the external device. The EMIF will then return to the last cycle of the programmed strobe period and the operation will proceed as usual from this point. Please refer to the device data manual for details on the timing requirements of the wait pins.

The wait pins cannot be used to extend the strobe period indefinitely. The programmable MEWC field in the Asynchronous Wait Cycle Configuration Register 1 (AWCCR1) determines the maximum number of EMIF clock cycles the strobe period may be extended beyond the programmed length. When the counter expires, the EMIF proceeds to the hold period of the operation regardless of the state of the wait pin. The EMIF can also generate an interrupt upon expiration of this counter. See Section 1.2.12 for details on enabling this interrupt.

For the EMIF to function properly in the Extended Wait mode, the wait pin polarity bits (WPn) of AWCCR2 must be programmed to set the polarity of the wait pins. In its reset state of 1, the EMIF will insert wait cycles when the wait pin is sampled high. When set to 0, the EMIF will insert wait cycles only when wait pin is sampled low. This programmability allows for a glueless connection to larger variety of asynchronous devices.

By default, a wait pin is assigned to each chip select space. You can change the default wait pin assignment using the CSn\_WAIT bits of AWCCR2. You are allowed to assign a single wait pin to more than one chip select space.

Finally, a restriction is placed on the strobe period timing parameters when operating in Extended Wait mode. Specifically, the W\_STROBE and R\_STROBE fields must not be set to 0 for proper operation.

### 1.2.7 BYTEMODE Bits of The EMIF System Control Register

### WARNING

The BYTEMODE bits affect CPU program and data accesses to external memory as well as CPU accesses to the EMIF registers. Therefore, to avoid data corruption issues you must always set BYTEMODE = 00b (16-bit access) after you have completed all 8-bit CPU accesses to external memory or EMIF registers. External memory accesses by other modules are not affected by these bits.

The CPU cannot generate 8-bit accesses to its data or I/O space. This presents a problem given that it is often necessary to access a single byte when communicating with NAND Flash devices.

For these situations, the BYTEMODE bits of the EMIF System Control Register (ESCR) can be used to program the DSP switched central resource (SCR) such that a CPU word access generates a single byte access when reading or writing from external memory or when accessing the EMIF registers. Table 1-15 summarizes the effect of the BYTEMODE bits for different CPU operations. For more details on ESCR please refer to the *TMS320VC5505 DSP System User's Guide* (SPRUFP0).

**NOTE:** The BYTEMODE bits should only be used for controlling CPU accesses to NAND Flash devices and EMIF registers.

| BYTEMODE Setting                                      | CPU Access to EMIF Register                      | CPU Access To External Memory                                                                                                                                         |
|-------------------------------------------------------|--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BYTEMODE = 00b (16-bit<br>word access)                | Entire register contents are accessed            | ASIZE = 01b (16-bit data bus): EMIF generates a<br>single 16-bit access to external memory for every<br>CPU word access.                                              |
|                                                       |                                                  | ASIZE = 00b (8-bit data bus): EMIF generates two<br>8-bit accesses to external memory for every CPU<br>word access.                                                   |
| BYTEMODE = 01b (8-bit access with high byte selected) | Only the upper byte of the register is accessed. | ASIZE = 01b (16-bit data bus): EMIF generates a<br>16-bit access to external memory for every CPU word<br>access; only the high byte of the EMIF data bus is<br>used. |
|                                                       |                                                  | ASIZE = 00b (8-bit data bus): EMIF generates a single 8-bit access to external memory for every CPU word access.                                                      |

Table 1-15. Effect of BYTEMODE Bits on EMIF Accesses



| BYTEMODE Setting                                        | CPU Access to EMIF Register                      | CPU Access To External Memory                                                                                                                                        |
|---------------------------------------------------------|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BYTEMODE = 10b (8-bit<br>access with low byte selected) | Only the lower byte of the register is accessed. | ASIZE = 01b (16-bit data bus): EMIF generates a<br>16-bit access to external memory for every CPU word<br>access; only the low byte of the EMIF data bus is<br>used. |
|                                                         |                                                  | ASIZE = 00b (8-bit data bus): EMIF generates a<br>single 8-bit access to external memory for every CPU<br>word access.                                               |

Table 1-15. Effect of BYTEMODE Bits on EMIF Accesses (continued)

#### 1.2.8 Data Bus Parking

The EMIF always drives the data bus to the previous write data value when it is idle. This feature is called data bus parking. Only when the EMIF issues a read command to the external memory does it stop driving the data bus. After the EMIF latches the last read data, it immediately parks the data bus again.

The one exception to this behavior occurs after performing an asynchronous read operation while the EMIF is in the self-refresh state. In this situation, the read operation is not followed by the EMIF parking the data bus, instead the EMIF tri-states the data bus. Therefore, it is not recommended to perform asynchronous read operations while the EMIF is in the self-refresh state, in order to prevent floating inputs on the data bus. External pull-up or pull-down resistors should be placed on the EMIF data bus pins if it is required to perform reads in this situation. The precise resistor value should be chosen so that the worst case combined off-state leakage currents do not cause the voltage levels on the associated pins to drop below the high-level input voltage requirement.

#### 1.2.9 Priority and Arbitration

Section 1.2.2 of this document describes the external prioritization and arbitration among requests from different sources within the DSP. The result of this external arbitration is that only one request is presented to the EMIF at a time. Once the EMIF completes a request, the external arbitration the provides the EMIF with the next pending request.

Internally, the EMIF undertakes memory device transactions according to a strict priority scheme. The highest priority events are:

• A hardware reset (see Section 1.2.10).

This event will cause the EMIF to immediately commence its initialization sequence.

#### 1.2.10 Reset Considerations

The EMIF has one reset source: a hardware reset. This reset is always initiated during a full chip reset. Alternatively, software can force a hardware reset on the EMIF through the PG1\_RST bit of the peripheral reset control register (PRCR). See the device data manual for more details on PRCR. Please note that the EMIF input clock must be enabled for PG1\_RST to have an affect on the EMIF (see Section 1.2.1). Also note that the PG1\_RST bit resets other modules in the DSP.

When a hardware reset occurs, the EMIF state machine and registers are reset. Command and data stored in the EMIF memory controller FIFOs is lost.

**NOTE:** External memory accesses and EMIF register accesses should not be performed while PG1\_RST is asserted.



### 1.2.11 Initialization

The following initialization procedure describes the basic setup of the EMIF.

- 1. Perform the necessary device pin multiplexing setup (see Section 1.2.5 for more details).
- 2. Set the EDIV bit of the EMIF clock divider register (ECDR): half the CPU clock rate or equal to the CPU clock rate.
- 3. Reset the EMIF using the PG1\_RST bit of the peripheral reset control register (PRCR). See Section 1.2.10 for more details on this bit.
- 4. If you want to use interrupts, you can enable them in this step. The EMIF can generate interrupts on three conditions: the rising edge of the wait signals (EM\_WAIT[3:0]), asynchronous memory access time-outs, and addressing errors. More information on interrupts is given in Section 1.2.12.
- 5. If using the EMIF to access asynchronous memories or other devices, configure the EMIF as described in Section 1.2.6.3.

# 1.2.12 Interrupt Support

The EMIF supports a single interrupt to the CPU. Section 1.2.12.1 details the generation and internal masking of EMIF interrupts, and Section 1.2.12.2 describes how the EMIF interrupts are sent to the CPU.

### 1.2.12.1 Interrupt Events and Requests

There are three conditions that may cause the EMIF to generate an interrupt to the CPU. These conditions are:

- A rising edge on the EM\_WAIT[3:0] signals (wait interrupt).
- An asynchronous memory access time out.
- Usage of unsupported addressing mode (line trap interrupt).

The wait interrupt is not affected by the wait pin polarity configuration bits (WPn) in the asynchronous wait cycle configuration register 2 (AWCCR2). The asynchronous time out interrupt condition occurs when the attached asynchronous device fails to dessert the EM\_WAIT pin within the number of cycles defined by the MEWC bits in the asynchronous wait cycle configuration register 1 (AWCCR1).

The EMIF supports only linear incrementing addressing mode. If an access request for an unsupported addressing mode is received, the EMIF will set the LT bit in interrupt raw register and treat the request as a linear incrementing request.

#### Only when the interrupt is enabled by setting the appropriate bit

(WRMASKSET/ATMASKSET/LTMASKSET) in the EMIF interrupt mask set register (EIMSR) to 1, will the interrupt be sent to the CPU. Once enabled, the interrupt may be disabled by writing a 1 to the corresponding bit in the EMIF interrupt mask clear register (EIMCR). The bit fields in both the EIMSR and EIMCR may be used to indicate whether the interrupt is enabled. When the interrupt is enabled, the corresponding bit field in both the EIMSR and EIMCR will have a value of 1; when the interrupt is disabled, the corresponding bit field will have a value of 0.

The EMIF interrupt raw register (EIRR) and the EMIF interrupt mask register (EIMR) indicate the status of each interrupt. The appropriate bit (WR/AT/LT) in EIRR is set when the interrupt condition occurs, whether or not the interrupt has been enabled. However, the appropriate bit

(WRMASKED/ATMASKED/LTMASKED) in EIMR is set only when the interrupt condition occurs and the interrupt is enabled. Writing a 1 to the bit in EIRR clears the EIRR bit as well as the corresponding bit in EIMR.



Architecture

Table 1-16 contains a brief summary of the interrupt status and control bit fields. See Section 1.3 for complete details on the register fields.

1

| Register Name                              | Bit Name       | Description                                                                                                                                                                                                             |
|--------------------------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EMIF interrupt raw register (EIRR)         | WR[3:0]        | These bits are set when an rising edge on the wait signals (EM_WAIT[3:0]) occurs. Writing a 1 clears the WR bits as well as the WRMASKED bits in EIMR. Each WR bit corresponds to an EM_WAIT pin.                       |
|                                            | AT             | This bit is set when an asynchronous timeout occurs. Writing a 1 clears the AT bit as well as the ATMASKED bit in EIMR.                                                                                                 |
|                                            | LT             | This bit is set when an unsupported addressing mode is used. Writing a 1 clears LT bit as well as the LTMASKED bit in EIMR.                                                                                             |
| EMIF interrupt mask register (EIMR)        | WRMASKED[3:0]  | These bits are set only when a rising edge on the wait signals (EM_WAIT[3:0]) occurs and the interrupt has been enabled by writing a 1 to the WRMASKSET bits in EIMSR. Each WRMASKED bit corresponds to an EM_WAIT pin. |
|                                            | ATMASKED       | This bit is set only when an asynchronous timeout occurs and the interrupt has been enabled by writing a 1 to the ATMASKSET bit in EIMSR.                                                                               |
|                                            | LTMASKED       | This bit is set only when line trap interrupt occurs and the interrupt has been enabled by writing a 1 to the LTMASKSET bit in EIMSR.                                                                                   |
| EMIF interrupt mask set register (EIMSR)   | WRMASKSET[3:0] | Writing a 1 to these bits enables the wait rise interrupt of the corresponding wait pin. Each WRMASKSET bit corresponds to an EM_WAIT pin.                                                                              |
|                                            | ATMASKSET      | Writing a 1 to this bit enables the asynchronous timeout interrupt.                                                                                                                                                     |
|                                            | LTMASKSET      | Writing a 1 to this bit enables the line trap interrupt.                                                                                                                                                                |
| EMIF interrupt mask clear register (EIMCR) | WRMASKCLR[3:0] | Writing a 1 to these bits disables the wait rise interrupt of the corresponding wait pin. Each WRMASKCLR bit corresponds to an EM_WAIT pin.                                                                             |
|                                            | ATMASKCLR      | Writing a 1 to this bit disables the asynchronous timeout interrupt.                                                                                                                                                    |
|                                            | LTMASKCLR      | Writing a 1 to this bit disables the line trap interrupt.                                                                                                                                                               |

#### 1.2.12.2 Interrupt Multiplexing

The EMIF interrupt to the DSP CPU is not multiplexed with any other interrupt source.

# 1.2.13 DMA Event Support

The EMIF does not generate any DMA events.

#### 1.2.14 Power Management

There are several ways to reduce the power consumption of the device EMIF. First, the EMIF power domain voltage can be selected during the board design phase based on the requirements of the devices connected to the EMIF. Running at lower voltages consumes less power. The lowest voltage allowable by the memory device should be used to minimize power consumption.

Second, the input clock of the EMIF can be turned off by using the peripheral clock gating configuration register (PCGCR). For detailed information on PCGCR see the device-specific data manual.

# 1.2.15 Emulation Considerations

The EMIF will remain fully functional during emulation halts to allow emulation access to external memory.

#### 1.2.16 CPU Instruction Pipeline Considerations

This section explains two special cases of pipeline operation that could impact external memory accesses.

As described in the *TMS320C55x DSP CPU Reference Guide* (<u>SPRU371</u>), the CPU uses instruction pipelining. Multiple instructions are processed simultaneously in the pipeline, and different instructions may access external memory during different phases of completion. The pipeline consists of a number of phases during which different, designated tasks are performed.



#### 1.2.16.1 A Write Followed by a Read at a Different Address

The read phase of the pipeline is used to read operands and other data needed to complete the execution of an instruction. The results of an instruction may be written to external memory in the write phase of the pipeline. The read phase occurs earlier in the pipeline than the write phase. For this reason, the read and write requests made to the EMIF may occur in an order which is different than the order in which the instructions entered the pipeline. For example, consider the following code segment:

1

I1: MOV T0, \*(#External\_Address\_1) ; Instruction 1 writes to external memory
I2: MOV \*(#External\_Address\_2), T1 ; Instruction 2 reads from external memory

Although the code shows the write followed by the read, the read actually occurs first on the EMIF because of the pipelining effect, as shown in Table 1-17. The figure shows the two instructions passing through the read (R), execute (X), and write (W) phases.

For some applications, maintaining the proper write-read order is critical. In such cases, NOP (no operation) instructions (or other instructions that do not perform external memory accesses) can be inserted between the original instructions to delay the read operation. This technique is shown in Table 1-18.

# Table 1-17. Partial Pipeline Diagram of Consecutive Instructions That Write and Read at Different Addresses

| R  | X  | W  | Cycle | Commnet                          |
|----|----|----|-------|----------------------------------|
| l1 |    |    | n     |                                  |
| 12 | l1 |    | n+1   | Read initiated by instruction 2  |
|    | 12 | l1 | n+2   | Write initiated by instruction 1 |
|    |    | 12 | n+3   |                                  |

# Table 1-18. NOP Instructions Inserted in the Code of Figure 1–3 to Make the Write Occur Before the Read

| R   | X   | W   | Cycle | Commnet                          |
|-----|-----|-----|-------|----------------------------------|
| l1  |     |     | n     |                                  |
| NOP | 11  |     | n+1   |                                  |
| NOP | NOP | l1  | n+2   | Write initiated by instruction 1 |
| 12  | NOP | NOP | n+3   | Read initiated by instruction 2  |
|     | 12  | NOP | n+4   |                                  |
|     |     | 12  | n+5   |                                  |

#### 1.2.16.2 A Write Followed by a Read at the Same Address

In most cases, when a write to memory is followed immediately by a read at the same address, the data written is the same data expected back during the read. The C55x CPU takes advantage of this fact with a special memory-bypass feature. During the read, the CPU gets a copy of the data directly from the write bus(es) instead of accessing memory.

When the CPU is accessing external devices, there may be cases in which the memory-bypass feature would lead to unwanted results. For example, suppose two physical memory locations X and Y are mapped to the same address. Writing modifies location X, and reading gets data from location Y. If the memory-bypass feature takes effect, location Y is not read.

To prevent the memory bypass, insert three or more NOP instructions (or other instructions) between the instructions that perform the write and the read. For example:

MOVT0,\*(#External\_Address\_1) ; Write to address 1
NOP ; 3-cycle delay
NOP
NOP
MOV\*(#External\_Address\_1), T1 ; Read from address 1



### 1.3 Registers

Table 1-19 list the registers associated with the device EMIF. The EMIF registers can be accessed by the CPU at the 16-bit addresses specified in Table 1-19. Note that the CPU accesses all peripheral registers through its I/O space. All other register addresses not listed in Table 1-19 should be considered as reserved locations and the register contents should not be modified.

Two additional registers—the EMIF clock divider register and the EMIF system control clock register—affect the operation of the EMIF, see Table 1-20. These registers are not part of the EMIF module; they are part of the DSP system. For more information on these registers please refer to the *TMS320VC5505 DSP System Guide* (SPRUFP0).

# WARNING

All EMIF registers support only 16-bit accesses; performing byte accesses to these registers results in undefined behavior. The BYTEMODE bits should be set to 00b (16-bit access) when accessing any register. See Section 1.2.7 for more details on the BYTEMODE bits.

#### Table 1-19. EMIF Registers

| CPU Word<br>Address | Acronym     | Register Description                             | Section            |
|---------------------|-------------|--------------------------------------------------|--------------------|
| 1000h               | REV         | Revision Register                                | Section 1.3.1      |
| 1001h               | STATUS      | Status Register                                  | Section 1.3.2      |
| 1004h               | AWCCR1      | Asynchronous Wait Cycle Configuration Register 1 | Section 1.3.3      |
| 1005h               | AWCCR2      | Asynchronous Wait Cycle Configuration Register 2 | Section 1.3.3      |
| 1010h               | ACS2CR1     | Asynchronous CS2 Configuration Register 1        | Section 1.3.4      |
| 1011h               | ACS2CR2     | Asynchronous CS2 Configuration Register 2        | Section 1.3.4      |
| 1014h               | ACS3CR1     | Asynchronous CS3 Configuration Register 1        | Section 1.3.4      |
| 1015h               | ACS3CR2     | Asynchronous CS3 Configuration Register 2        | Section 1.3.4      |
| 1018h               | ACS4CR1     | Asynchronous CS4 Configuration Register 1        | Section 1.3.4      |
| 1019h               | ACS4CR2     | Asynchronous CS4 Configuration Register 2        | Section 1.3.4      |
| 101Ch               | ACS5CR1     | Asynchronous CS5 Configuration Register 1        | Section 1.3.4      |
| 101Dh               | ACS5CR2     | Asynchronous CS5 Configuration Register 2        | Section 1.3.4      |
| 1040h               | EIRR        | EMIF Interrupt Raw Register                      | Section 1.3.5      |
| 1044h               | EIMR        | EMIF Interrupt Mask Register                     | Section 1.3.6      |
| 1048h               | EIMSR       | EMIF Interrupt Mask Set Register                 | Section 1.3.7      |
| 104Ch               | EIMCR       | EMIF Interrupt Mask Clear Register               | Section 1.3.8      |
| 1060h               | NANDFCR     | NAND Flash Control Register                      | Section 1.3.9      |
| 1064h               | NANDFSR1    | NAND Flash Status Register 1                     | Section 1.3.1<br>0 |
| 1065h               | NANDFSR2    | NAND Flash Status Register 2                     | Section 1.3.1<br>0 |
| 1068h               | PGMODECTRL1 | Page Mode Control Register 1                     | Section 1.3.1<br>1 |
| 1069h               | PGMODECTRL2 | Page Mode Control Register 2                     | Section 1.3.1<br>1 |
| 1070h               | NCS2ECC1    | NAND Flash CS2 1-Bit ECC Register 1              | Section 1.3.1<br>2 |
| 1071h               | NCS2ECC2    | NAND Flash CS2 1-Bit ECC Register 2              | Section 1.3.1<br>2 |

TEXAS INSTRUMENTS

www.ti.com

| Table 1-19. EMIF Registers (continu |
|-------------------------------------|
|-------------------------------------|

Ι

|                     |                 | Table 1-19. EMIF Registers (continued)        |                         |
|---------------------|-----------------|-----------------------------------------------|-------------------------|
| CPU Word<br>Address | Acronym         | Register Description                          | Section                 |
| 1074h               | NCS3ECC1        | NAND Flash CS3 1-Bit ECC Register 1           | Section 1.3.1<br>2      |
| 1075h               | NCS3ECC2        | NAND Flash CS3 1-Bit ECC Register 2           | Section 1.3.1<br>2      |
| 1078h               | NCS4ECC1        | NAND Flash CS4 1-Bit ECC Register 1           | Section 1.3.1<br>2      |
| 1079h               | NCS4ECC2        | NAND Flash CS4 1-Bit ECC Register 2           | Section 1.3.1<br>2      |
| 107Ch               | NCS5ECC1        | NAND Flash CS5 1-Bit ECC Register 1           | Section 1.3.1<br>2      |
| 107Dh               | NCS5ECC2        | NAND Flash CS5 1-Bit ECC Register 2           | Section 1.3.1           |
| 10BCh               | NAND4BITECCLOAD | NAND Flash 4-Bit ECC Load Register            | Section 1.3.1           |
| 10C0h               | NAND4BITECC1    | NAND Flash 4-Bit ECC Register 1               | Section 1.3.1           |
| 10C1h               | NAND4BITECC2    | NAND Flash 4-Bit ECC Register 2               | Section 1.3.1<br>5      |
| 10C4h               | NAND4BITECC3    | NAND Flash 4-Bit ECC Register 3               | Section 1.3.1           |
| 10C5h               | NAND4BITECC4    | NAND Flash 4-Bit ECC Register 4               | Section 1.3.1           |
| 10C8h               | NAND4BITECC5    | NAND Flash 4-Bit ECC Register 5               | Section 1.3.1           |
| 10C9h               | NAND4BITECC6    | NAND Flash 4-Bit ECC Register 6               | Section 1.3.1           |
| 10CCh               | NAND4BITECC7    | NAND Flash 4-Bit ECC Register 7               | Section 1.3.2           |
| 10CDh               | NAND4BITECC8    | NAND Flash 4-Bit ECC Register 8               | Section 1.3.2           |
| 10D0h               | NANDERRADD1     | NAND Flash 4-Bit ECC Error Address Register 1 | Section 1.3.2           |
| 10D1h               | NANDERRADD2     | NAND Flash 4-Bit ECC Error Address Register 2 | 2<br>Section 1.3.2<br>3 |
| 10D4h               | NANDERRADD3     | NAND Flash 4-Bit ECC Error Address Register 3 | Section 1.3.2           |
| 10D5h               | NANDERRADD4     | NAND Flash 4-Bit ECC Error Address Register 4 | 4<br>Section 1.3.2      |
| 10D8h               | NANDERRVAL1     | NAND Flash 4-Bit ECC Error Value Register 1   | 5<br>Section 1.3.2      |
| 10D9h               | NANDERRVAL2     | NAND Flash 4-Bit ECC Error Value Register 2   | 6<br>Section 1.3.2      |
| 10DCh               | NANDERRVAL3     | NAND Flash 4-Bit ECC Error Value Register 3   | 7<br>Section 1.3.2      |
| 10DDh               | NANDERRVAL4     | NAND Flash 4-Bit ECC Error Value Register 4   | 8<br>Section 1.3.2<br>9 |

# Table 1-20. EMIF System Registers

|   | CPU Word<br>Address | Acronym             | Register Description         |
|---|---------------------|---------------------|------------------------------|
| _ | 1C26h               | ECDR <sup>(1)</sup> | EMIF Clock Divider Register  |
| _ | 1C33h               | ESCR (1)            | EMIF System Control Register |
|   |                     |                     | с.<br>С                      |

<sup>(1)</sup> Refer to the *TMS320VC5505 DSP System Guide* (<u>SPRUFP0</u>) for more details on this register.

Registers



www.ti.com

Ι



# 1.3.1 Revision Register (REV)

This is a read only register indicating the major and minor revision of the EMIF. The revision register (REV) is shown in Figure 1-12 and described in Table 1-21.

Ι

# Figure 1-12. Revision Register (REV)

| 15 8           | 7 0            |  |
|----------------|----------------|--|
| MAJOR_REVISION | MINOR_REVISION |  |
| <br>R-02h      | R-05h          |  |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 1-21. Revision Register (REV) Field Descriptions

| Bit  | Field          | Value | Description                   |
|------|----------------|-------|-------------------------------|
| 15-8 | MAJOR_REVISION | 0-FFh | Major revision code for EMIF. |
| 7-0  | MINOR_REVISION | 0-FFh | Minor revision code for EMIF. |

# 1.3.2 Status Register (STATUS)

This is a read only register showing the module ID and clock rate configuration of the EMIF. The status register (STATUS) is shown in Figure 1-13 and described in Table 1-22.

### Figure 1-13. Status Register (STATUS)

| 15  | 14       | 13 |           | 8 |
|-----|----------|----|-----------|---|
| BE  | FULLRATE |    | MODULE_ID |   |
| R-0 | R-1      |    | R-0       |   |
| 7   |          |    |           | 0 |
|     |          |    | MODULE_ID |   |
|     |          |    | R-0       |   |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

# Table 1-22. Status Register (STATUS) Field Descriptions

| Bit  | Field     | Value   | Description                                                                                                                   |
|------|-----------|---------|-------------------------------------------------------------------------------------------------------------------------------|
| 15   | BE        |         | Big Endian. Reflects the endianess of the EMIF. This can not be changed.                                                      |
|      |           | 0       | EMIF is in little endian mode                                                                                                 |
|      |           | 1       | EMIF is in big endian mode                                                                                                    |
| 14   | FULLRATE  |         | Full rate status bit. This bit reflects the clock rate being used for the EMIF SDRAM CLK which is not supported on this chip. |
|      |           | 0       | EM_SDCLK, which is not supported on this device, is running at half the speed as the CPU clock.                               |
|      |           | 1       | EM_SDCLK, which is not supported on this device, is running at the same speed as the CPU clock.                               |
| 13-0 | MODULE_ID | 0-3FFFh | Module ID code for EMIF.                                                                                                      |

Registers

43

External Memory Interface (EMIF)



Registers

www.ti.com

# 1.3.3 Asynchronous Wait Cycle Configuration Registers (AWCCR1 and AWCCR2)

The asynchronous wait cycle configuration registers (AWCCR1 and AWCCR2) are used to configure the parameters for extended wait cycles. Both the polarity of the wait pins (EM\_WAIT[3:0]) and the maximum allowable number of extended wait cycles can be configured through these registers. AWCCR1 and AWCCR2 are shown in Figure 1-14 and Figure 1-15 and described in Table 1-23 and Table 1-24.

Ι

#### Figure 1-14. Asynchronous Wait Cycle Configuration Register 1 (AWCCR1)

| 15 8     | 7 0    |
|----------|--------|
| Reserved | MEWC   |
| R-0      | RW-40h |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Figure 1-15. Asynchronous Wait Cycle Configuration Register 2 (AWCCR2)

| 15   | 14                | 13   | 12   | 11       |      |      | 8    |  |  |
|------|-------------------|------|------|----------|------|------|------|--|--|
| WP3  | WP2               | WP1  | WP0  | Reserved |      |      |      |  |  |
| RW-1 | RW-1              | RW-1 | RW-1 | R-0      |      |      |      |  |  |
| 7    | 6                 | 5    | 4    | 3        | 2    | 1    | 0    |  |  |
| CS5_ | CS5_WAIT CS4_WAIT |      | WAIT | CS3_     | WAIT | CS2_ | WAIT |  |  |
| R    | RW-3 RW-2         |      | N-2  | RW-1 RW- |      |      | V-0  |  |  |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

### Table 1-23. Asynchronous Wait Cycle Configuration Register 1 (AWCCR1) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                                                                                                                                                    |
|------|----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-8 | Reserved | 0     | Reserved.                                                                                                                                                                                                                                      |
| 7-0  | MEWC     | 0-FFh | Maximum extended wait cycles. The EMIF will wait for a maximum of (MEWC + 1) x 16 clock cycles before it stops inserting asynchronous wait cycles and proceeds to the hold period of the access. This setting applies to all of the wait pins. |

#### Table 1-24. Asynchronous Wait Cycle Configuration Register 2 (AWCCR2) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                                                                                               |
|------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | WP3      |       | EM_WAIT3 polarity bit. This bit defines the polarity of the EM_WAIT3 pin.                                                                                                                 |
|      |          | 0     | Insert wait cycles if EM_WAIT3 is low.                                                                                                                                                    |
|      |          | 1     | Insert wait cycles if EM_WAIT3 is high.                                                                                                                                                   |
| 14   | WP2      |       | EM_WAIT2 polarity bit. This bit defines the polarity of the EM_WAIT2 pin.                                                                                                                 |
|      |          | 0     | Insert wait cycles if EM_WAIT2 is low.                                                                                                                                                    |
|      |          | 1     | Insert wait cycles if EM_WAIT2 is high.                                                                                                                                                   |
| 13   | WP1      |       | EM_WAIT1 polarity bit. This bit defines the polarity of the EM_WAIT1 pin.                                                                                                                 |
|      |          | 0     | Insert wait cycles if EM_WAIT1 is low.                                                                                                                                                    |
|      |          | 1     | Insert wait cycles if EM_WAIT1 is high.                                                                                                                                                   |
| 12   | WP0      |       | EM_WAIT0 polarity bit. This bit defines the polarity of the EM_WAIT0 pin.                                                                                                                 |
|      |          | 0     | Insert wait cycles if EM_WAIT0 is low.                                                                                                                                                    |
|      |          | 1     | Insert wait cycles if EM_WAIT0 is high.                                                                                                                                                   |
| 11-8 | Reserved | 0     | Reserved                                                                                                                                                                                  |
| 7-6  | CS5_WAIT |       | Wait pin mapping bits for EMIF CS5. By default, each asynchronous chip select space is assigned a wait input pin. You can use the wait pin mapping bits to change the default assignment. |
|      |          | 0     | Use the EM_WAIT0 pin.                                                                                                                                                                     |
|      |          | 1h    | Use the EM_WAIT1 pin.                                                                                                                                                                     |
|      |          | 2h    | Use the EM_WAIT2 pin.                                                                                                                                                                     |
|      |          | 3h    | Use the EM_WAIT3 pin.                                                                                                                                                                     |

#### Table 1-24. Asynchronous Wait Cycle Configuration Register 2 (AWCCR2) Field Descriptions (continued)

1

| Bit | Field    | Value | Description                                                                                                                                                                               |
|-----|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5-4 | CS4_WAIT |       | Wait pin mapping bits for EMIF CS4. By default, each asynchronous chip select space is assigned a wait input pin. You can use the wait pin mapping bits to change the default assignment. |
|     |          | 0     | Use the EM_WAIT0 pin.                                                                                                                                                                     |
|     |          | 1h    | Use the EM_WAIT1 pin.                                                                                                                                                                     |
|     |          | 2h    | Use the EM_WAIT2 pin.                                                                                                                                                                     |
|     |          | 3h    | Use the EM_WAIT3 pin.                                                                                                                                                                     |
| 3-2 | CS3_WAIT |       | Wait pin mapping bits for EMIF CS3. By default, each asynchronous chip select space is assigned a wait input pin. You can use the wait pin mapping bits to change the default assignment. |
|     |          | 0     | Use the EM_WAIT0 pin.                                                                                                                                                                     |
|     |          | 1h    | Use the EM_WAIT1 pin.                                                                                                                                                                     |
|     |          | 2h    | Use the EM_WAIT2 pin.                                                                                                                                                                     |
|     |          | 3h    | Use the EM_WAIT3 pin.                                                                                                                                                                     |
| 1-0 | CS2_WAIT |       | Wait pin mapping bits for EMIF CS2. By default, each asynchronous chip select space is assigned a wait input pin. You can use the wait pin mapping bits to change the default assignment. |
|     |          | 0     | Use the EM_WAIT0 pin.                                                                                                                                                                     |
|     |          | 1h    | Use the EM_WAIT1 pin.                                                                                                                                                                     |
|     |          | 2h    | Use the EM_WAIT2 pin.                                                                                                                                                                     |
|     |          | 3h    | Use the EM_WAIT3 pin.                                                                                                                                                                     |

# 1.3.4 Asynchronous Configuration Registers (ACSnCR1 and ACSnCR2)

The asynchronous CSn configuration registers (ACSnCR1 and ACSnCR2) are used to configure the shaping of the address and control signals during an access to asynchronous memory connected to EM\_CS2, EM\_CS3, EM\_CS4, and EM\_CS5. They are also used to program the width of asynchronous interface and to select from various modes of operation. These registers can be written prior to any transfer, and any asynchronous transfer following the write will use the new configuration. There are two registers per chip select pin. The ACSnCR1 and ACSnCR2 are shown in the following figures and described in Table 1-25 and Table 1-26.

### Figure 1-16. Asynchronous CS2 Configuration Register 1 (ACS2CR1)

| 15          | 13    | 12 |         | 7 | 6   | 4     | 3  | 2   | 1     | 0   |
|-------------|-------|----|---------|---|-----|-------|----|-----|-------|-----|
| RSETU       | JPLSB |    | RSTROBE |   |     | RHOLD |    |     | ASIZE |     |
| RW-3 RW-3Fh |       |    |         |   | RW- | 7     | RV | V-3 | RV    | V-0 |
|             |       |    |         |   |     |       |    |     |       |     |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

### Figure 1-17. Asynchronous CS2 Configuration Register 2 (ACS2CR2)

| 15   | 14   | 13   |     | 11 | 10      | 9 | 8         |
|------|------|------|-----|----|---------|---|-----------|
| SS   | EW   |      | WSE |    | WSTROBE |   |           |
| RW-0 | RW-0 |      | RW  | R\ | V-3Fh   |   |           |
| 7    |      |      | 4   | 3  |         | 1 | 0         |
|      | WSTI | ROBE |     |    | WHOLD   |   | RSETUPMSB |
|      | RW   | -3Fh |     |    | RW-7    |   | RW-1      |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Figure 1-18. Asynchronous CS3 Configuration Register 1 (ACS3CR1)

| 15    | 13    | 12 |         | 7  | 6  | 4   | 3     | 2 | 1    | 0 |
|-------|-------|----|---------|----|----|-----|-------|---|------|---|
| RSETU | JPLSB |    | RSTROBE | RH | TA |     | ASIZE |   |      |   |
| RV    | V-3   |    | RW-3Fh  |    | RV | V-7 | RW-3  |   | RW-1 |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset



Registers

|      | Figure 1-19. Asynchronous CS3 Configuration Register 2 (ACS3CR2) |     |     |        |         |   |           |  |  |  |  |  |
|------|------------------------------------------------------------------|-----|-----|--------|---------|---|-----------|--|--|--|--|--|
| 15   | 14                                                               | 13  |     | 11     | 10      | 9 | 8         |  |  |  |  |  |
| SS   | EW                                                               |     | WSE |        | WSTROBE |   |           |  |  |  |  |  |
| RW-0 | RW-0                                                             |     | RW  | RW-3Fh |         |   |           |  |  |  |  |  |
| 7    |                                                                  |     | 4   | 3      |         | 1 | 0         |  |  |  |  |  |
|      | WSTROBE                                                          |     |     |        | WHOLD   |   | RSETUPMSB |  |  |  |  |  |
|      | RW-                                                              | 3Fh |     |        | RW-7    |   | RW-1      |  |  |  |  |  |

Ι

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Figure 1-20. Asynchronous CS4 Configuration Register 1 (ACS4CR1)

| 15          | 13                                                       | 12 |  | 7 | 6         | 4 | 3 | 2     | 1    | 0 |  |
|-------------|----------------------------------------------------------|----|--|---|-----------|---|---|-------|------|---|--|
| RSETU       | RSETUPLSB RSTROBE                                        |    |  |   | RHOLD TA  |   |   | ASIZE |      |   |  |
| RW-3 RW-3Fh |                                                          |    |  |   | RW-7 RW-3 |   |   |       | RW-0 |   |  |
|             | $I = C \in N(N) = P = P = Q = Q = Q = Q = Q = Q = Q = Q$ |    |  |   |           |   |   |       |      |   |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Figure 1-21. Asynchronous CS4 Configuration Register 2 (ACS4CR2)

| 15   | 14   | 13   |     | 11 | 10      | 9     | 8         |
|------|------|------|-----|----|---------|-------|-----------|
| SS   | EW   |      | WSE |    | WSTROBE |       |           |
| RW-0 | RW-0 |      | RW- |    | R       | W-3Fh |           |
| 7    |      |      | 4   | 3  |         | 1     | 0         |
|      | WST  | ROBE |     |    | WHOLD   |       | RSETUPMSB |
|      | RW   | -3Fh |     |    | RW-7    |       | RW-1      |
|      | RW   | -3Fh |     |    | RW-7    |       | RW-1      |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Figure 1-22. Asynchronous CS5 Configuration Register 1 (ACS5CR1)

| 15                | 13 | 12 |                                                                   | 7 | 6         | 4  | 3 | 2     | 1 | 0 |
|-------------------|----|----|-------------------------------------------------------------------|---|-----------|----|---|-------|---|---|
| RSETUPLSB RSTROBE |    |    |                                                                   |   | RHC       | ТА |   | ASIZE |   |   |
| RW-3              |    |    | RW-3Fh                                                            |   | RW-7 RW-3 |    |   | RW-1  |   |   |
|                   |    |    | al a sha sa sa sa ta sa tu sa |   |           |    |   |       |   |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Figure 1-23. Asynchronous CS5 Configuration Register 2 (ACS5CR2)

| 15   | 14      | 13 |     | 11   | 10    | 9     | 8         |
|------|---------|----|-----|------|-------|-------|-----------|
| SS   | EW      |    | WSE | TUP  |       | WS    | TROBE     |
| RW-0 | RW-0    |    | RW  | /-Fh |       | W-3Fh |           |
| 7    |         |    | 4   | 3    |       | 1     | 0         |
|      | WSTROBE |    |     |      | WHOLD |       | RSETUPMSB |
|      | RW-3Fh  |    |     |      | RW-7  |       | RW-1      |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

### Table 1-25. Asynchronous CSn Configuration Register 1 (ACSnCR1) Field Descriptions

| Bit   | Field     | Value | Description                                                                                                                   |
|-------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------|
| 15-13 | RSETUPLSB | 0-7h  | These bits in conjunction with RSETUPMSB in ACE1CR2 define the read setup timing in EM_SDCLK cycles, minus one cycle.         |
| 12-7  | RSTROBE   | 0-3Fh | Read strobe width in EM_SDCLK cycles, minus one cycle.                                                                        |
| 6-4   | RHOLD     | 0-7h  | Read hold width in EM_SDCLK cycles, minus one cycle.                                                                          |
| 3-2   | ТА        | 0-3h  | Minimum turn-around time. This field defines the minimum number of EM_SDCLK cycles between reads and writes, minus one cycle. |
| 1-0   | ASIZE     | 0-3h  | Asynchronous data bus width. This field defines the width of the asynchronous device's data bus.                              |
|       |           | 0     | 8- bit data bus.                                                                                                              |



# Table 1-25. Asynchronous CSn Configuration Register 1 (ACSnCR1) Field Descriptions (continued)

Ι

| Bit | Field | Value | Description      |
|-----|-------|-------|------------------|
|     |       | 1h    | 16-bit data bus. |
|     |       | 2-3h  | Reserved.        |

# Table 1-26. Asynchronous CSn Configuration Register 2 (ACSnCR2) Field Descriptions

| Bit   | Field     | Value | Description                                                                                                           |
|-------|-----------|-------|-----------------------------------------------------------------------------------------------------------------------|
| 15    | SS        |       | Select Strobe bit. This bit defines whether the asynchronous interface operates in Normal Mode or Select Strobe Mode. |
|       |           | 0     | Normal Mode enabled.                                                                                                  |
|       |           | 1     | Select Strobe Mode enabled.                                                                                           |
| 14    | EW        |       | Extended wait cycles enable bit. This bit defines whether extended wait cycles will be enabled.                       |
|       |           | 0     | Extended wait cycles disabled.                                                                                        |
|       |           | 1     | Extended wait cycles enabled.                                                                                         |
| 13-10 | WSETUP    | 0-Fh  | Write setup width in EM_SDCLK cycles, minus one cycle.                                                                |
| 9-4   | WSTROBE   | 0-3Fh | Write strobe width in EM_SDCLK cycles, minus one cycle.                                                               |
| 3-1   | WHOLD     | 0-7h  | Write hold width in EM_SDCLK cycles, minus one cycle.                                                                 |
| 0     | RSETUPMSB | 0-1   | These bits in conjunction with RSETUPLSB in ACE1CR1 define the read setup timing in EM_SDCLK cycles, minus one cycle. |



#### Registers

# 1.3.5 Interrupt Raw Register (EIRR)

The EMIF Interrupt Raw Register (EIRR) is used to monitor and clear the EMIF's hardware-generated interrupts. The bits in this register will be set when an interrupt condition occurs regardless of the status of the Interrupt Mask Set Register and Interrupt Mast Clear Register. Writing a 1 to the bits of this register will clear them. The EMIF Interrupt Raw Register is shown in Figure 1-24 and described in Table 1-27.

Ι

#### Figure 1-24. Interrupt Raw Register (EIRR)

| 15   |      |   |          |   |         | 8       |
|------|------|---|----------|---|---------|---------|
|      |      |   | Reserved |   |         |         |
|      |      |   | R-0      |   |         |         |
| 7    | 6    | 5 |          | 2 | 1       | 0       |
| Rese | rved |   | WR       |   | LT      | AT      |
| R    | ·0   |   | R/W1C-0  |   | R/W1C-0 | R/W1C-0 |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset; W1C = write 1 to clear (writing 0 has no effect)

#### Table 1-27. Interrupt Raw Register (EIRR) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-6 | Reserved | 0     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                          |
| 5-2  | WR[3:0]  | 0-Fh  | Wait rise bits. These bits are set to 1 by hardware when a rising edge is detected on the wait pins. The polarity bits of AWCCR2 have not effect on these bits. Writing a 1 will clear these bits as well as the WRMASKED bits in the interrupt masked register (EMIR). Writing a 0 has no effect.                                                                                                                |
| 1    | LT       | 0     | Line trap. This bit is set to 1 by hardware to indicate illegal memory access. Writing a 1 will clear this bit as well as the LTMASKED bit in the interrupt masked register (EMIR). Writing a 1 has no effect.                                                                                                                                                                                                    |
| 0    | AT       | 0     | Asynchronous timeout. This bit is set to 1 by hardware to indicate that during an extended asynchronous memory access cycle, a wait pin did not go inactive within the number of cycles defined by the MEWC field in asynchronous wait cycle configuration register 1 (AWCCR1). Writing a 1 will clear these bits as well as the ATMASKED bit in the interrupt masked register (EMIR). Writing a 0 has no effect. |

# 1.3.6 Interrupt Mask Register (EIMR)

Like the EMIF Interrupt Raw Register (EIRR), the EMIF Interrupt Mask Register (EIMR) is used to monitor and clear the status of the EMIF's hardware-generated interrupts. The main difference between the two registers is that when the bits in this register are set, an active-high pulse will be sent to the CPU interrupt controller. Also, the bit fields in EIMR are only set to 1 if the associated interrupt has been enabled in the EMIF interrupt mask set register (EIMSR). The Interrupt Mask Register is shown in Figure 1-25 and described in Table 1-28.

Ι

#### Figure 1-25. Interrupt Mask Register (EIMR)

| 15  |       |   |          |   |          | 8        |
|-----|-------|---|----------|---|----------|----------|
|     |       |   | Reserved |   |          |          |
|     |       |   | R-0      |   |          |          |
| 7   | 6     | 5 |          | 2 | 1        | 0        |
| Res | erved |   | WRMASKED |   | LTMASKED | ATMASKED |
|     | -0    |   | R/W1C-0  |   | R/W1C-0  | R/W1C-0  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset; W1C = write 1 to clear (writing 0 has no effect)

### Table 1-28. Interrupt Mask Register (EIMR) Field Descriptions

| Bit  | Field         | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------|---------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-6 | Reserved      | 0     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 5-2  | WRMASKED[3:0] | 0-Fh  | Masked wait rise bits. These bits are set to 1 by hardware when a rising edge is detected on the wait pins. The polarity bits of AWCCR2 have not effect on these bits. Writing a 1 will clear these bits as well as the WR bits in the interrupt raw register (EIRR). Writing a 0 has no effect.                                                                                                                                                                                                  |
| 1    | LTMASKED      | 0     | Masked linetrap. This bit is set to 1 by hardware to indicate illegal memory access, only if the LTMASKSET bit in the interrupt mask set register (EMISR) is set to 1. Writing a 1 will clear this bit as well as the LT bit in the interrupt raw register (EIRR). Writing a 0 has no effect.                                                                                                                                                                                                     |
| 0    | ATMASKED      | 0     | Masked asynchronous timeout. This bit is set to 1 by hardware to indicate that during an extended asynchronous memory access cycle, a wait pin did not go inactive within the number of cycles defined by the MEWC field in asynchronous wait cycle configuration register 1 (AWCCR1), only if the ATMASKSET bit in the interrupt mask set register (EIMSR) is set to 1. Writing a 1 will clear these bits as well as the AT bit in the interrupt raw register (EIRR). Writing a 0 has no effect. |



# 1.3.7 Interrupt Mask Set Register (EIMSR)

The EMIF Interrupt Mask Set Register (EIMSR) is used to enable the EMIF interrupts. If read as 1, the corresponding bit in the EMIF Interrupt Masked Register (EIMR) will be set and an interrupt will be generated when the interrupt condition occurs. If read as 0, the corresponding bit in EIMR will always read 0 and no interrupt will be generated when the interrupt condition occurs. Writing a 1 to the bits of EIMSR enables the EMIF interrupts. The Interrupt Mask Set Register is shown in Figure 1-26 and described in Table 1-29.

Ι

#### Figure 1-26. Interrupt Mask Set Register (EIMSR)

| 15   |       |   |           |   |           | 8         |
|------|-------|---|-----------|---|-----------|-----------|
|      |       |   | Reserved  |   |           |           |
|      |       |   | R-0       |   |           |           |
| 7    | 6     | 5 |           | 2 | 1         | 0         |
| Rese | erved |   | WRMASKSET |   | LTMASKSET | ATMASKSET |
| R    | -0    |   | R/W1S-0   |   | R/W1S-0   | R/W1S-0   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset; W1S = write 1 to set (writing 0 has no effect)

### Table 1-29. Interrupt Mask Set Register (EIMSR) Field Descriptions

| Bit  | Field          | Value | Description                                                                                                                                                                                                                              |
|------|----------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-6 | Reserved       | 0     | Reserved                                                                                                                                                                                                                                 |
| 5-2  | WRMASKSET[3:0] | 0-Fh  | Mask set for WRMASKED bits in interrupt mask register (EIMR). Writing a 1 will enable the wait rise interrupts and set these bits as well as the WRMASKCLR bits in the interrupt mask clear register (EIMCR). Writing a 0 has no effect. |
| 1    | LTMASKSET      | 0     | Mask set for LTMASKED bits in interrupt mask register (EIMR). Writing a 1 will enable the interrupt and set these bits as well as the LTMASKCLR bits in the interrupt mask clear register (EIMCR). Writing a 0 has no effect.            |
| 0    | ATMASKSET      | 0     | Mask set for ATMASKED bit in interrupt mask register (EIMR). Writing a 1 will enable the interrupt and set this bit as well as the ATMASKCLR bit in the interrupt mask clear register (EIMCR). Writing a 0 has no effect.                |

# 1.3.8 Interrupt Mask Clear Register (EIMCR)

The EMIF Interrupt Mask Clear Register (EIMCR) is used to disable the EMIF interrupts. Writing a 1 to the bits of this register disables the interrupt. Writing a 0 has no effect. The EIMCR is shown in Figure 1-27 and described in Table 1-30.

### Figure 1-27. Interrupt Mask Clear Register (EIMCR)

| 15   |       |   |           |   |           | 8         |
|------|-------|---|-----------|---|-----------|-----------|
|      |       |   | Reserved  |   |           |           |
|      |       |   | R-0       |   |           |           |
| 7    | 6     | 5 |           | 2 | 1         | 0         |
| Rese | erved |   | WRMASKCLR |   | LTMASKCLR | ATMASKCLR |
| R    |       |   | R/W1C-0   |   | R/W1C-0   | R/W1C-0   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset; W1C = write 1 to clear (writing 0 has no effect)

#### Table 1-30. Interrupt Mask Clear Register (EIMCR) Field Descriptions

| Bit  | Field          | Value | Description                                                                                                                                                                                                                                 |
|------|----------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-6 | Reserved       | 0     | Reserved                                                                                                                                                                                                                                    |
| 5-2  | WRMASKCLR[3:0] | 0-Fh  | Mask clear for WRMASKED bits in interrupt mask register (EIMR). Writing a 1 will disable the wait rise interrupts and clear these bits as well as the WRMASKSET bits in the interrupt mask set register (EIMSR). Writing a 0 has no effect. |
| 1    | LTMASKCLR      | 0     | Mask clear for LTMASKED bits in interrupt mask register (EIMR). Writing a 1 will disable the interrupt and clear this bits as well as the LTMASKSET bits in the interrupt mask set register (EIMSR). Writing a 0 has no effect.             |
| 0    | ATMASKCLR      | 0     | Mask clear for ATMASKED bit in interrupt mask register (EIMR). Writing a 1 will disable the interrupt and clear this bit as well as the ATMASKSET bit in the interrupt mask set register (EIMSR). Writing a 0 has no effect.                |

# 1.3.9 NAND Flash Control Register (NANDFCR)

The NAND Flash Control Register (NANDFCR) is shown in Figure 1-28 and described in Table 1-31.

. . . . . . . . . . . .

|      | Figure 1-28. NAND Flash Control Register (NANDFCR) |              |                |               |               |               |               |  |  |  |
|------|----------------------------------------------------|--------------|----------------|---------------|---------------|---------------|---------------|--|--|--|
| 15   | 14                                                 | 13           | 12             | 11            | 10            | 9             | 8             |  |  |  |
| Rese | erved                                              | ADDR_CALC_ST | 4BIT_ECC_START | CS5_ECC_START | CS4_ECC_START | CS3_ECC_START | CS2_ECC_START |  |  |  |
| R    | -0                                                 | RW-0         | RW-0           | RW-0          | RW-0          | RW-0          | RW-0          |  |  |  |
| 7    | 6                                                  | 5            | 4              | 3             | 2             | 1             | 0             |  |  |  |
| Rese | erved                                              | 4BIT_E       | CC_SEL         | CS5_USE_NAND  | CS4_USE_NAND  | CS3_USE_NAND  | CS2_USE_NAND  |  |  |  |
| R    | R-0                                                |              | RW-0           |               | RW-0          | RW-0          | RW-1          |  |  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 1-31. NAND Flash Control Register (NANDFCR) Field Descriptions

| Bit   | Field          | Value | Description                                                                                                                                                                                                                                                                                                   |
|-------|----------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-14 | Reserved       | 0     | Reserved                                                                                                                                                                                                                                                                                                      |
| 13    | ADDR_CALC_ST   |       | NAND flash 4-bit ECC error address and error value calculation start. Set to 1 to start 4-bit ECC error address and error value calculation on read syndrome. This bit is cleared when any of the NAND flash error address registers or NAND flash error value registers are read. Writing a 0 has no effect. |
| 12    | 4BIT_ECC_START |       | NAND flash 4-bit ECC start for the selected chip select. Set to 1 to start 4-bit ECC calculation<br>on data for NAND flash on chip select selected by 4BIT_ECC_SEL field. This bit is cleared<br>when any of the NAND flash 4-Bit ECC registers are read. Writing a 0 has no effect.                          |
| 11    | CS5_ECC_START  |       | NAND flash 1-bit ECC start for EMIF CS5. Set to 1 to start 1-bit ECC calculation on data for NAND flash on EMIF CS5. This bit is cleared when NAND flash CS5 1-Bit ECC register is read. Writing a 0 has no effect.                                                                                           |



# Table 1-31. NAND Flash Control Register (NANDFCR) Field Descriptions (continued)

Ι

| Bit | Field         | Value | Description                                                                                                                                                                                                         |
|-----|---------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10  | CS4_ECC_START |       | NAND flash 1-bit ECC start for EMIF CS4. Set to 1 to start 1-bit ECC calculation on data for NAND flash on EMIF CS4. This bit is cleared when NAND flash CS4 1-Bit ECC register is read. Writing a 0 has no effect. |
| 9   | CS3_ECC_START |       | NAND flash 1-bit ECC start for EMIF CS3. Set to 1 to start 1-bit ECC calculation on data for NAND flash on EMIF CS3. This bit is cleared when NAND flash CS3 1-Bit ECC register is read. Writing a 0 has no effect. |
| 8   | CS2_ECC_START |       | NAND flash 1-bit ECC start for EMIF CS2. Set to 1 to start 1-bit ECC calculation on data for NAND flash on EMIF CS2. This bit is cleared when NAND flash CS2 1-Bit ECC register is read. Writing a 0 has no effect. |
| 7-6 | Reserved      | 0     | Reserved                                                                                                                                                                                                            |
| 5-4 | 4BIT_ECC_SEL  |       | NAND flash 4-bit ECC chip select selection. This field selects the chip select on which the 4-bit ECC will be calculated.                                                                                           |
|     |               | 0     | Select EMIF CS2 for 4-bit ECC calculation.                                                                                                                                                                          |
|     |               | 1h    | Select EMIF CS3 for 4-bit ECC calculation.                                                                                                                                                                          |
|     |               | 2h    | Select EMIF CS4 for 4-bit ECC calculation.                                                                                                                                                                          |
|     |               | 3h    | Select EMIF CS5 for 4-bit ECC calculation.                                                                                                                                                                          |
| 3   | CS5_USE_NAND  |       | NAND flash mode for EMIF CS5. Set to 1 if using NAND flash on EM_CS5.                                                                                                                                               |
|     |               | 0     | Not using NAND flash.                                                                                                                                                                                               |
|     |               | 1     | Using NAND flash on chip select pin.                                                                                                                                                                                |
| 2   | CS4_USE_NAND  |       | NAND flash mode for EMIF CS4. Set to 1 if using NAND flash on EM_CS4.                                                                                                                                               |
|     |               | 0     | Not using NAND flash.                                                                                                                                                                                               |
|     |               | 1     | Using NAND flash on chip select pin.                                                                                                                                                                                |
| 1   | CS3_USE_NAND  |       | NAND flash mode for EMIF CS3. Set to 1 if using NAND flash on EM_CS3.                                                                                                                                               |
|     |               | 0     | Not using NAND flash.                                                                                                                                                                                               |
|     |               | 1     | Using NAND flash on chip select pin.                                                                                                                                                                                |
| 0   | CS2_USE_NAND  |       | NAND flash mode for EMIF CS2. Set to 1 if using NAND flash on EM_CS2.                                                                                                                                               |
|     |               | 0     | Not using NAND flash.                                                                                                                                                                                               |
|     |               | 1     | Using NAND flash on chip select pin.                                                                                                                                                                                |

# 1.3.10 NAND Flash Status Registers (NANDFSR1) and (NANDFSR1)

The NAND Flash Status Registers are shown in Figure 1-29 and Figure 1-30 and described in Table 1-32 and Table 1-33.

# Figure 1-29. NAND Flash Status Register 1 (NANDFSR1)

| 15  | 12     | 11 | 8       | 7 |          | 4 | 3              |          | 0 |
|-----|--------|----|---------|---|----------|---|----------------|----------|---|
| Re  | served | CO | RRSTATE |   | Reserved |   | V              | /AITSTAT |   |
| R-0 |        |    | R-0     |   | R-0      |   | R-EM_WAIT[3:0] |          |   |
|     | -      |    |         |   |          |   |                |          |   |

Ι

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Figure 1-30. NAND Flash Status Register 2 (NANDFSR2)

| 15 |          | 2 | 1   | 0   |
|----|----------|---|-----|-----|
|    | Reserved |   | ERR | NUM |
|    | R-0      |   | R   | -0  |
|    |          |   |     |     |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 1-32. NAND Flash Status Register 1 (NANDFSR1) Field Descriptions

| Bit   | Field     | Value | Description                                                                                                                                                                                                                                                                              |
|-------|-----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12 | Reserved  | 0     | Reserved                                                                                                                                                                                                                                                                                 |
| 11-8  | CORRSTATE |       | 4-bit ECC state value when performing error address and error value calculation.                                                                                                                                                                                                         |
|       |           | 0     | No error.                                                                                                                                                                                                                                                                                |
|       |           | 1h    | Errors cannot be corrected (five or more errors).                                                                                                                                                                                                                                        |
|       |           | 2h    | Error correction complete (errors on bit 8 or 9).                                                                                                                                                                                                                                        |
|       |           | 3h    | Error correction complete (error exists).                                                                                                                                                                                                                                                |
|       |           | 4h    | Reserved.                                                                                                                                                                                                                                                                                |
|       |           | 5h    | Calculating number of errors.                                                                                                                                                                                                                                                            |
|       |           | 6h    | Preparing for error search.                                                                                                                                                                                                                                                              |
|       |           | 7h    | Preparing for error search.                                                                                                                                                                                                                                                              |
|       |           | 8h    | Searching for errors.                                                                                                                                                                                                                                                                    |
|       |           | 9h    | Reserved.                                                                                                                                                                                                                                                                                |
|       |           | 10h   | Reserved.                                                                                                                                                                                                                                                                                |
|       |           | 11h   | Reserved.                                                                                                                                                                                                                                                                                |
|       |           | 12h   | Calculating error value.                                                                                                                                                                                                                                                                 |
|       |           | 13h   | Calculating error value.                                                                                                                                                                                                                                                                 |
|       |           | 14h   | Calculating error value.                                                                                                                                                                                                                                                                 |
|       |           | 15h   | Calculating error value.                                                                                                                                                                                                                                                                 |
| 7-4   | Reserved  | 0     | Reserved                                                                                                                                                                                                                                                                                 |
| 3-0   | WAITSTAT  | 0-Fh  | These bits shows the raw status of the four wait input signals (EM_WAIT[3:0]). WAITSTAT[0] corresponds to EM_WAIT[0], WAITSTAT[1] corresponds to EM_WAIT[1], and so on. The polarity bits in the asynchronous wait cycle configuration register 2 (AWCCR2) have no effect on these bits. |



Registers

| Bit  | Field    | Value | Description                                                                                                                                   |
|------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 15-2 | Reserved | 0     | Reserved                                                                                                                                      |
| 1-0  | ERRNUM   |       | 4-bit ECC error number. This field shows the number for errors found after the error address calculation and error value calculation is done. |
|      |          | 0     | 1 error found.                                                                                                                                |
|      |          | 1h    | 2 errors found.                                                                                                                               |
|      |          | 2h    | 3 errors found.                                                                                                                               |
|      |          | 3h    | 4 errors found.                                                                                                                               |

# Table 1-33. NAND Flash Status Register 2 (NANDFSR2) Field Descriptions

# 1.3.11 Page Mode Control Registers (PAGEMODCTRL1) and (PAGEMODCTRL2)

The Page Mode Control Registers (PAGEMODCTRL1 and PAGEMODCTRL2) are shown in Figure 1-31 and Figure 1-32 and described in Table 1-34 and Table 1-35.

#### Figure 1-31. Page Mode Control Register 1 (PAGEMODCTRL1)

| 15 |                | 10 | 9             | 8              |
|----|----------------|----|---------------|----------------|
|    | CS3_PAGE_DELAY |    | CS3_PAGE_SIZE | CS3_PAGEMOD_EN |
|    | RW-3Fh         |    | RW-0          | RW-0           |
| 7  |                | 2  | 1             | 0              |
|    | CS2_PAGE_DELAY |    | CS2_PAGE_SIZE | CS2_PAGEMOD_EN |
|    | RW-3Fh         |    | RW-1          | RW-0           |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Figure 1-32. Page Mode Control Register 2 (PAGEMODCTRL2)

| 15 |                | 10 | 9                  | 8                   |
|----|----------------|----|--------------------|---------------------|
|    | CS5_PAGE_DELAY |    | CS5_PAGE_SIZE      | CS5_PAGEMOD_EN      |
|    | RW-3Fh         |    | RW-0               | RW-0                |
|    |                |    |                    |                     |
| 7  |                | 2  | 1                  | 0                   |
| 7  | CS4_PAGE_DELAY | 2  | 1<br>CS4_PAGE_SIZE | 0<br>CS4_PAGEMOD_EN |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 1-34. Page Mode Control Register 1 (PAGEMODCTRL1) Field Descriptions

| Bit   | Field          | Value | Description                                                                                                                                                                                            |
|-------|----------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-10 | CS3_PAGE_DELAY | 0-3Fh | Page access delay for NOR flash connected on $\overline{\text{EM}_{CS3}}$ . Number of EMIF clock cycles required for the page read data to be valid, minus one cycle. This value must not be set to 0. |
| 9     | CS3_PAGE_SIZE  |       | Page size for NOR flash connected on EM_CS3.                                                                                                                                                           |
|       |                | 0     | 4-word page.                                                                                                                                                                                           |
|       |                | 1     | 8-word page.                                                                                                                                                                                           |
| 8     | CS3_PAGEMOD_EN |       | Page mode enable for NOR flash connected on EM_CS3.                                                                                                                                                    |
|       |                | 0     | Disable page mode.                                                                                                                                                                                     |
|       |                | 1     | Enable page mode.                                                                                                                                                                                      |
| 7-2   | CS2_PAGE_DELAY | 0-3Fh | Page access delay for NOR flash connected on $\overline{\text{EM}_{CS2}}$ . Number of EMIF clock cycles required for the page read data to be valid, minus one cycle. This value must not be set to 0. |
| 1     | CS2_PAGE_SIZE  |       | Page size for NOR flash connected on EM_CS2.                                                                                                                                                           |
|       |                | 0     | 4-word page.                                                                                                                                                                                           |
|       |                | 1     | 8-word page.                                                                                                                                                                                           |
| 0     | CS2_PAGEMOD_EN |       | Page mode enable for NOR flash connected on EM_CS2.                                                                                                                                                    |
|       |                | 0     | Disable page mode.                                                                                                                                                                                     |
|       |                | 1     | Enable page mode.                                                                                                                                                                                      |



# Table 1-35. Page Mode Control Register 2 (PAGEMODCTRL2) Field Descriptions

| Bit   | Field          | Value | Description                                                                                                                                                                                                  |
|-------|----------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-10 | CS5_PAGE_DELAY | 0-3Fh | Page access delay for NOR flash connected on $\overline{\text{EM}_{CS5}}$ . Number of EMIF clock cycles required for the page read data to be valid, minus one cycle. This value must not be set to 0.       |
| 9     | CS5_PAGE_SIZE  |       | Page size for NOR flash connected on EM_CS5.                                                                                                                                                                 |
|       |                | 0     | 4-word page.                                                                                                                                                                                                 |
|       |                | 1     | 8-word page.                                                                                                                                                                                                 |
| 8     | CS5_PAGEMOD_EN |       | Page mode enable for NOR flash connected on EM_CS5.                                                                                                                                                          |
|       |                | 0     | Disable page mode.                                                                                                                                                                                           |
|       |                | 1     | Enable page mode.                                                                                                                                                                                            |
| 7-2   | CS4_PAGE_DELAY | 0-3Fh | Page access delay for NOR flash connected on $\overline{\text{EM}_C\text{CS4}}$ . Number of EMIF clock cycles required for the page read data to be valid, minus one cycle. This value must not be set to 0. |
| 1     | CS4_PAGE_SIZE  |       | Page size for NOR flash connected on EM_CS4.                                                                                                                                                                 |
|       |                | 0     | 4-word page.                                                                                                                                                                                                 |
|       |                | 1     | 8-word page.                                                                                                                                                                                                 |
| 0     | CS4_PAGEMOD_EN |       | Page mode enable for NOR flash connected on EM_CS4.                                                                                                                                                          |
|       |                | 0     | Disable page mode.                                                                                                                                                                                           |
|       |                | 1     | Enable page mode.                                                                                                                                                                                            |

#### Registers

# 1.3.12 NAND Flash CSn 1-Bit ECC Registers (NCSnECC1 ) and (NCSnECC2 )

The NAND Flash CSn 1-Bit ECC Registers are shown in Figure 1-33 and Figure 1-34 and described in Table 1-36 and Table 1-37.

Ι

### Figure 1-33. NAND Flash CSn 1-Bit ECC Register 1 (NCSnECC1)

|       | •    |       |      |        | 0 (    | ,     |       |
|-------|------|-------|------|--------|--------|-------|-------|
| 15    |      |       | 12   | 11     | 10     | 9     | 8     |
|       | Rese | erved |      | P2048E | P1024E | P512E | P256E |
|       | R·   | -0    |      | RW-0   | RW-0   | RW-0  | RW-0  |
| 7     | 6    | 5     | 4    | 3      | 2      | 1     | 0     |
| P128E | P64E | P32E  | P16E | P8E    | P4E    | P2E   | P1E   |
| RW-0  | RW-0 | RW-0  | RW-0 | RW-0   | RW-0   | RW-0  | RW-0  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Figure 1-34. NAND Flash CSn 1-Bit ECC Register 2 (NCSnECC2)

| 15    |      |       | 12   | 11     | 10     | 9     | 8     |
|-------|------|-------|------|--------|--------|-------|-------|
|       | Rese | erved |      | P2048O | P1024O | P512O | P256O |
|       | R    | -0    |      | RW-0   | RW-0   | RW-0  | RW-0  |
| 7     | 6    | 5     | 4    | 3      | 2      | 1     | 0     |
| P128O | P64O | P320  | P16O | P8O    | P40    | P2O   | P10   |
| RW-0  | RW-0 | RW-0  | RW-0 | RW-0   | RW-0   | RW-0  | RW-0  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 1-36. NAND Flash CSn 1-Bit ECC Register 1 (NCSnECC1) Field Descriptions

| Bit   | Field    | Value | Description                                                                                                                                                                                                                                                        |
|-------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12 | Reserved | 0     | Reserved                                                                                                                                                                                                                                                           |
| 11    | P2048E   |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1E, P2E, and P4E are column parities and P8E to P2048E are row parities. For 16-bit NAND Flash, P1E, P2E, P4E, and P8E are column parities and P16E to P2048E are row parities. |
| 10    | P1024E   |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1E, P2E, and P4E are column parities and P8E to P2048E are row parities. For 16-bit NAND Flash, P1E, P2E, P4E, and P8E are column parities and P16E to P2048E are row parities. |
| 9     | P512E    |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1E, P2E, and P4E are column parities and P8E to P2048E are row parities. For 16-bit NAND Flash, P1E, P2E, P4E, and P8E are column parities and P16E to P2048E are row parities. |
| 8     | P256E    |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1E, P2E, and P4E are column parities and P8E to P2048E are row parities. For 16-bit NAND Flash, P1E, P2E, P4E, and P8E are column parities and P16E to P2048E are row parities. |
| 7     | P128E    |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1E, P2E, and P4E are column parities and P8E to P2048E are row parities. For 16-bit NAND Flash, P1E, P2E, P4E, and P8E are column parities and P16E to P2048E are row parities. |
| 6     | P64E     |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1E, P2E, and P4E are column parities and P8E to P2048E are row parities. For 16-bit NAND Flash, P1E, P2E, P4E, and P8E are column parities and P16E to P2048E are row parities. |
| 5     | P32E     |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1E, P2E, and P4E are column parities and P8E to P2048E are row parities. For 16-bit NAND Flash, P1E, P2E, P4E, and P8E are column parities and P16E to P2048E are row parities. |
| 4     | P16E     |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1E, P2E, and P4E are column parities and P8E to P2048E are row parities. For 16-bit NAND Flash, P1E, P2E, P4E, and P8E are column parities and P16E to P2048E are row parities. |
| 3     | P8E      |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1E, P2E, and P4E are column parities and P8E to P2048E are row parities. For 16-bit NAND Flash, P1E, P2E, P4E, and P8E are column parities and P16E to P2048E are row parities. |
| 2     | P4E      |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1E, P2E, and P4E are column parities and P8E to P2048E are row parities. For 16-bit NAND Flash, P1E, P2E, P4E, and P8E are column parities and P16E to P2048E are row parities. |



# Table 1-36. NAND Flash CSn 1-Bit ECC Register 1 (NCSnECC1) Field Descriptions (continued)

Ι

| Bit | Field | Value | Description                                                                                                                                                                                                                                                        |
|-----|-------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | P2E   |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1E, P2E, and P4E are column parities and P8E to P2048E are row parities. For 16-bit NAND Flash, P1E, P2E, P4E, and P8E are column parities and P16E to P2048E are row parities. |
| 0   | P1E   |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1E, P2E, and P4E are column parities and P8E to P2048E are row parities. For 16-bit NAND Flash, P1E, P2E, P4E, and P8E are column parities and P16E to P2048E are row parities. |

# Table 1-37. NAND Flash CSn 1-Bit ECC Register 2 (NCSnECC2) Field Descriptions

| Bit   | Field    | Value | Description                                                                                                                                                                                                                                                        |
|-------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12 | Reserved | 0     | Reserved                                                                                                                                                                                                                                                           |
| 11    | P2048O   |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1O, P2O, and P4O are column parities and P8O to P2048O are row parities. For 16-bit NAND Flash, P1O, P2O, P4O, and P8O are column parities and P16O to P2048O are row parities. |
| 10    | P1024O   |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1O, P2O, and P4O are column parities and P8O to P2048O are row parities. For 16-bit NAND Flash, P1O, P2O, P4O, and P8O are column parities and P16O to P2048O are row parities. |
| 9     | P512O    |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1O, P2O, and P4O are column parities and P8O to P2048O are row parities. For 16-bit NAND Flash, P1O, P2O, P4O, and P8O are column parities and P16O to P2048O are row parities. |
| 8     | P256O    |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1O, P2O, and P4O are column parities and P8O to P2048O are row parities. For 16-bit NAND Flash, P1O, P2O, P4O, and P8O are column parities and P16O to P2048O are row parities. |
| 7     | P128O    |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1O, P2O, and P4O are column parities and P8O to P2048O are row parities. For 16-bit NAND Flash, P1O, P2O, P4O, and P8O are column parities and P16O to P2048O are row parities. |
| 6     | P64O     |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1O, P2O, and P4O are column parities and P8O to P2048O are row parities. For 16-bit NAND Flash, P1O, P2O, P4O, and P8O are column parities and P16O to P2048O are row parities. |
| 5     | P32O     |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1O, P2O, and P4O are column parities and P8O to P2048O are row parities. For 16-bit NAND Flash, P1O, P2O, P4O, and P8O are column parities and P16O to P2048O are row parities. |
| 4     | P16O     |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1O, P2O, and P4O are column parities and P8O to P2048O are row parities. For 16-bit NAND Flash, P1O, P2O, P4O, and P8O are column parities and P16O to P2048O are row parities. |
| 3     | P8O      |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1O, P2O, and P4O are column parities and P8O to P2048O are row parities. For 16-bit NAND Flash, P1O, P2O, P4O, and P8O are column parities and P16O to P2048O are row parities. |
| 2     | P4O      |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1O, P2O, and P4O are column parities and P8O to P2048O are row parities. For 16-bit NAND Flash, P1O, P2O, P4O, and P8O are column parities and P16O to P2048O are row parities. |
| 1     | P2O      |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1O, P2O, and P4O are column parities and P8O to P2048O are row parities. For 16-bit NAND Flash, P1O, P2O, P4O, and P8O are column parities and P16O to P2048O are row parities. |
| 0     | P10      |       | 1-Bit ECC code calculated while reading/writing NAND Flash. For 8-bit NAND Flash, P1O, P2O, and P4O are column parities and P8O to P2048O are row parities. For 16-bit NAND Flash, P1O, P2O, P4O, and P8O are column parities and P16O to P2048O are row parities. |



# 1.3.13 NAND Flash 4-Bit ECC Load Register (NAND4BITECCLOAD)

NAND Flash 4-Bit ECC Load Register is shown in Figure 1-35 and described in Table 1-38.

#### Figure 1-35. NAND Flash 4-Bit ECC Load Register (NAND4BITECCLOAD)

| 15 | 10       | 9 | 0             |  |
|----|----------|---|---------------|--|
| F  | Reserved |   | 4BIT_ECC_LOAD |  |
|    | R-0      |   | RW-0          |  |

Ι

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 1-38. NAND Flash 4-Bit ECC Load Register (NAND4BITECCLOAD) Field Descriptions

| Bit   | Field         | Value  | Description                                                                                                                  |
|-------|---------------|--------|------------------------------------------------------------------------------------------------------------------------------|
| 15-10 | Reserved      | 0      | Reserved                                                                                                                     |
| 9-0   | 4BIT_ECC_LOAD | 0-3FFh | 4-Bit ECC Load. This register is used to load 4-bit ECC values when performing syndrome calculation during NAND Flash reads. |

# 1.3.14 NAND Flash 4-Bit ECC Register 1 (NAND4BITECC1)

The NAND Flash 4-bit ECC Register 1 (NAND4BITECC1) is shown in Figure 1-36 and described in Table 1-39.

#### Figure 1-36. NAND Flash 4-Bit ECC Load Register 1 (NAND4BITECC1)

| 15 10    | 9 0           |
|----------|---------------|
| Reserved | 4BIT_ECC_VAL1 |
| R-0      | R-0           |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 1-39. NAND Flash 4-Bit ECC Load Register 1 (NAND4BITECC1) Field Descriptions

| Bit   | Field         | Value  | Description                                                                   |
|-------|---------------|--------|-------------------------------------------------------------------------------|
| 15-10 | Reserved      | 0      | Reserved                                                                      |
| 9-0   | 4BIT_ECC_VAL1 | 0-3FFh | 4-Bit ECC or syndrome value 1 calculated while writing or reading NAND Flash. |

# 1.3.15 NAND Flash 4-Bit ECC Register 2 (NAND4BITECC2)

The NAND Flash 4-bit ECC Register 2 (NAND4BITECC2) is shown in Figure 1-37 and described in Table 1-40.

#### Figure 1-37. NAND Flash 4-Bit ECC Register 2 (NAND4BITECC2)

| 15       | 10 | 9             | 0 |
|----------|----|---------------|---|
| Reserved |    | 4BIT_ECC_VAL2 |   |
| R-0      |    | R-0           |   |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 1-40. NAND Flash 4-Bit ECC Register 2 (NAND4BITECC2) Field Descriptions

| Bit   | Field         | Value  | Description                                                                   |
|-------|---------------|--------|-------------------------------------------------------------------------------|
| 15-10 | Reserved      | 0      | Reserved                                                                      |
| 9-0   | 4BIT_ECC_VAL2 | 0-3FFh | 4-Bit ECC or syndrome value 2 calculated while writing or reading NAND Flash. |

# 1.3.16 NAND Flash 4-Bit ECC Register 3 (NAND4BITECC3)

The NAND Flash 4-bit ECC Register 3 (NAND4BITECC3) is shown in Figure 1-38 and described in Table 1-41.



| Registers |                |     |                                           | www.ti.com |
|-----------|----------------|-----|-------------------------------------------|------------|
|           | Figure 1-38. N | AND | Flash 4-Bit ECC Register 3 (NAND4BITECC3) |            |
| 15        | 10             | g   | 9                                         | 0          |

Ι

| Reserved | 4BIT_ECC_VAL3 |
|----------|---------------|
| R-0      | R-0           |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 1-41. NAND Flash 4-Bit ECC Register 3 (NAND4BITECC3) Field Descriptions

| Bit   | Field         | Value  | Description                                                                   |
|-------|---------------|--------|-------------------------------------------------------------------------------|
| 15-10 | Reserved      | 0      | Reserved                                                                      |
| 9-0   | 4BIT_ECC_VAL3 | 0-3FFh | 4-Bit ECC or syndrome value 3 calculated while writing or reading NAND Flash. |

# 1.3.17 NAND Flash 4-Bit ECC Register 4 (NAND4BITECC4)

The NAND Flash 4-bit ECC Register 4 (NAND4BITECC4) is shown in Figure 1-39 and described in Table 1-42.

### Figure 1-39. NAND Flash 4-Bit ECC Register 4 (NAND4BITECC4)

| 15 10    | 9 0           |
|----------|---------------|
| Reserved | 4BIT_ECC_VAL4 |
| R-0      | R-0           |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 1-42. NAND Flash 4-Bit ECC Register 4 (NAND4BITECC4) Field Descriptions

| Bit   | Field         | Value  | Description                                                                   |
|-------|---------------|--------|-------------------------------------------------------------------------------|
| 15-10 | Reserved      | 0      | Reserved                                                                      |
| 9-0   | 4BIT_ECC_VAL4 | 0-3FFh | 4-Bit ECC or syndrome value 4 calculated while writing or reading NAND Flash. |



# 1.3.18 NAND Flash 4-Bit ECC Register 5 (NAND4BITECC5)

The NAND Flash 4-bit ECC Register 5 (NAND4BITECC5) is shown in Figure 1-40 and described in Table 1-43.

Ι

### Figure 1-40. NAND Flash 4-Bit ECC Register 5 (NAND4BITECC5)

| 15 10    | 9 0           |
|----------|---------------|
| Reserved | 4BIT_ECC_VAL5 |
| R-0      | R-0           |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 1-43. NAND Flash 4-Bit ECC Register 5 (NAND4BITECC5) Field Descriptions

| Bit   | Field         | Value  | Description                                                                   |
|-------|---------------|--------|-------------------------------------------------------------------------------|
| 15-10 | Reserved      | 0      | Reserved                                                                      |
| 9-0   | 4BIT_ECC_VAL5 | 0-3FFh | 4-Bit ECC or syndrome value 5 calculated while writing or reading NAND Flash. |

# 1.3.19 NAND Flash 4-Bit ECC Register 6 (NAND4BITECC6)

The NAND Flash 4-bit ECC Register 6 (NAND4BITECC6) is shown in Figure 1-41 and described in Table 1-44.

#### Figure 1-41. NAND Flash 4-Bit ECC Register 6 (NAND4BITECC6)

| 15 1     | 0 9 | 0             |
|----------|-----|---------------|
| Reserved |     | 4BIT_ECC_VAL6 |
| R-0      |     | R-0           |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

# Table 1-44. NAND Flash 4-Bit ECC Register 6 (NAND4BITECC6) Field Descriptions

| Bit   | Field         | Value  | Description                                                                   |
|-------|---------------|--------|-------------------------------------------------------------------------------|
| 15-10 | Reserved      | 0      | Reserved                                                                      |
| 9-0   | 4BIT_ECC_VAL6 | 0-3FFh | 4-Bit ECC or syndrome value 6 calculated while writing or reading NAND Flash. |

# 1.3.20 NAND Flash 4-Bit ECC Register 7 (NAND4BITECC7)

The NAND Flash 4-bit ECC Register 7 (NAND4BITECC7) is shown in Figure 1-42 and described in Table 1-45.

#### Figure 1-42. NAND Flash 4-Bit ECC Register 7 (NAND4BITECC7)

| 15 10    | 9             | 0 |
|----------|---------------|---|
| Reserved | 4BIT_ECC_VAL7 |   |
| R-0      | R-0           |   |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 1-45. NAND Flash 4-Bit ECC Register 7 (NAND4BITECC7) Field Descriptions

| ſ | Bit   | Field         | Value  | Description                                                                   |  |
|---|-------|---------------|--------|-------------------------------------------------------------------------------|--|
|   | 15-10 | Reserved      | 0      | Reserved                                                                      |  |
|   | 9-0   | 4BIT_ECC_VAL7 | 0-3FFh | 4-Bit ECC or syndrome value 7 calculated while writing or reading NAND Flash. |  |

# 1.3.21 NAND Flash 4-Bit ECC Register 8 (NAND4BITECC8)

The NAND Flash 4-bit ECC Register 8 (NAND4BITECC8) is shown in Figure 1-43 and described in Table 1-46.



| Registers |                  |                                              | www.ti.com |
|-----------|------------------|----------------------------------------------|------------|
|           | Figure 1-43. NAN | ID Flash 4-Bit ECC Register 8 (NAND4BITECC8) |            |
| 15        | 10               | 9                                            | 0          |

Ι

| Reserved | 4BIT_ECC_VAL8 |
|----------|---------------|
| R-0      | R-0           |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 1-46. NAND Flash 4-Bit ECC Register 8 (NAND4BITECC8) Field Descriptions

| Bit   | Field         | Value  | Description                                                                   |  |
|-------|---------------|--------|-------------------------------------------------------------------------------|--|
| 15-10 | Reserved      | 0      | Reserved                                                                      |  |
| 9-0   | 4BIT_ECC_VAL8 | 0-3FFh | 4-Bit ECC or syndrome value 8 calculated while writing or reading NAND Flash. |  |

# 1.3.22 NAND Flash 4-Bit ECC Error Address Register 1 (NANDERRADD1)

The NAND Flash 4-bit ECC Error Register 1 (NANDERRADD1) is shown in Figure 1-44 and described in Table 1-47.

### Figure 1-44. NAND Flash 4-Bit ECC Error Address Register 1 (NANDERRADD1)

| 15 10    | 9 0       |
|----------|-----------|
| Reserved | ERR_ADDR1 |
| R-0      | R-0       |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 1-47. NAND Flash 4-Bit ECC Error Address Register 1 (NANDERRADD1) Field Descriptions

| Bit   | Field     | Value  | Description                |  |
|-------|-----------|--------|----------------------------|--|
| 15-10 | Reserved  | 0      | Reserved                   |  |
| 9-0   | ERR_ADDR1 | 0-3FFh | 4-bit ECC error address 1. |  |



# 1.3.23 NAND Flash 4-Bit ECC Error Address Register 2 (NANDERRADD2)

The NAND Flash 4-bit ECC Error Register 2 (NANDERRADD2) is shown in Figure 1-45 and described in Table 1-48.

#### Figure 1-45. NAND Flash 4-Bit ECC Error Address Register 2 (NANDERRADD2)

| 15 10    | 9 0       |
|----------|-----------|
| Reserved | ERR_ADDR2 |
| R-0      | R-0       |

Ι

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 1-48. NAND Flash 4-Bit ECC Error Address Register 2 (NANDERRADD2) Field Descriptions

| Bit   | Field     | Value  | Description                |
|-------|-----------|--------|----------------------------|
| 15-10 | Reserved  | 0      | Reserved                   |
| 9-0   | ERR_ADDR2 | 0-3FFh | 4-bit ECC error address 2. |

# 1.3.24 NAND Flash 4-Bit ECC Error Address Register 3 (NANDERRADD3)

The NAND Flash 4-bit ECC Error Register 3 (NANDERRADD3) is shown in Figure 1-46 and described in Table 1-49.

#### Figure 1-46. NAND Flash 4-Bit ECC Error Address Register 3 (NANDERRADD3)

| 15       | 10 | 9         | 0 |
|----------|----|-----------|---|
| Reserved |    | ERR_ADDR3 |   |
| R-0      |    | R-0       |   |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 1-49. NAND Flash 4-Bit ECC Error Address Register 3 (NANDERRADD3) Field Descriptions

| Bit   | Field     | Value  | Description                |  |
|-------|-----------|--------|----------------------------|--|
| 15-10 | Reserved  | 0      | Reserved                   |  |
| 9-0   | ERR_ADDR3 | 0-3FFh | 4-bit ECC error address 3. |  |

# 1.3.25 NAND Flash 4-Bit ECC Error Address Register 4 (NANDERRADD4)

The NAND Flash 4-bit ECC Error Register 4 (NANDERRADD4) is shown in Figure 1-47 and described in Table 1-50.

#### Figure 1-47. NAND Flash 4-Bit ECC Error Address Register 4 (NANDERRADD4)

| 15       | 10 | 9 | 0         |  |
|----------|----|---|-----------|--|
| Reserved |    |   | ERR_ADDR4 |  |
| R-0      |    |   | R-0       |  |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 1-50. NAND Flash 4-Bit ECC Error Address Register 4 (NANDERRADD4) Field Descriptions

| Bit   | Field     | Value  | Description                |
|-------|-----------|--------|----------------------------|
| 15-10 | Reserved  | 0      | Reserved                   |
| 9-0   | ERR_ADDR4 | 0-3FFh | 4-bit ECC error address 4. |

# 1.3.26 NAND Flash 4-Bit ECC Error Value Register 1 (NANDERRVAL1)

The NAND Flash 4-bit ECC Error Value Register 1 (NANDERRVAL1) is shown in Figure 1-48 and described in Table 1-51.



| Registers |                       |                                                   | www.ti.com |
|-----------|-----------------------|---------------------------------------------------|------------|
|           | Figure 1-48. NAND Fla | sh 4-Bit ECC Error Value Register 1 (NANDERRVAL1) |            |
| 15        | 10                    | 9                                                 | 0          |

Ι

 Reserved
 ERR\_VALUE1

 R-0
 R-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 1-51. NAND Flash 4-Bit ECC Error Value Register 1 (NANDERRVAL1) Field Descriptions

| Bit   | Field      | Value  | Description              |
|-------|------------|--------|--------------------------|
| 15-10 | Reserved   | 0      | Reserved                 |
| 9-0   | ERR_VALUE1 | 0-3FFh | 4-bit ECC error value 1. |

# 1.3.27 NAND Flash 4-Bit ECC Error Value Register 2 (NANDERRVAL2)

The NAND Flash 4-bit ECC Error Value Register 2 (NANDERRVAL2) is shown in Figure 1-49 and described in Table 1-52.

### Figure 1-49. NAND Flash 4-Bit ECC Error Value Register 2 (NANDERRVAL2)

| 15 10    | 9 0        |
|----------|------------|
| Reserved | ERR_VALUE2 |
| R-0      | R-0        |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 1-52. NAND Flash 4-Bit ECC Error Value Register 2 (NANDERRVAL2) Field Descriptions

| Bit   | Field      | Value  | Description              |  |
|-------|------------|--------|--------------------------|--|
| 15-10 | Reserved   | 0      | Reserved                 |  |
| 9-0   | ERR_VALUE2 | 0-3FFh | 4-bit ECC error value 2. |  |



# 1.3.28 NAND Flash 4-Bit ECC Error Value Register 3 (NANDERRVAL3)

The NAND Flash 4-bit ECC Error Value Register 3 (NANDERRVAL3) is shown in Figure 1-50 and described in Table 1-53.

Ι

### Figure 1-50. NAND Flash 4-Bit ECC Error Value Register 3 (NANDERRVAL3)

| 15 10    | 9 0        |
|----------|------------|
| Reserved | ERR_VALUE3 |
| R-0      | R-0        |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 1-53. NAND Flash 4-Bit ECC Error Value Register 3 (NANDERRVAL3) Field Descriptions

| Bit   | Field      | Value  | Description              |
|-------|------------|--------|--------------------------|
| 15-10 | Reserved   | 0      | Reserved                 |
| 9-0   | ERR_VALUE3 | 0-3FFh | 4-bit ECC error value 3. |

# 1.3.29 NAND Flash 4-Bit ECC Error Value Register 4 (NANDERRVAL4)

The NAND Flash 4-bit ECC Error Value Register 4 (NANDERRVAL4) is shown in Figure 1-51 and described in Table 1-54.

#### Figure 1-51. NAND Flash 4-Bit ECC Error Value Register 4 (NANDERRVAL4)

| 15 10    | 9 0        |
|----------|------------|
| Reserved | ERR_VALUE4 |
| R-0      | R-0        |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 1-54. NAND Flash 4-Bit ECC Error Value Register 4 (NANDERRVAL4) Field Descriptions

| Bit   | Field      | Value  | Description              |
|-------|------------|--------|--------------------------|
| 15-10 | Reserved   | 0      | Reserved                 |
| 9-0   | ERR_VALUE4 | 0-3FFh | 4-bit ECC error value 4. |

#### **IMPORTANT NOTICE**

Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, modifications, enhancements, improvements, and other changes to its products and services at any time and to discontinue any product or service without notice. Customers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All products are sold subject to TI's terms and conditions of sale supplied at the time of order acknowledgment.

TI warrants performance of its hardware products to the specifications applicable at the time of sale in accordance with TI's standard warranty. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where mandated by government requirements, testing of all parameters of each product is not necessarily performed.

TI assumes no liability for applications assistance or customer product design. Customers are responsible for their products and applications using TI components. To minimize the risks associated with customer products and applications, customers should provide adequate design and operating safeguards.

TI does not warrant or represent that any license, either express or implied, is granted under any TI patent right, copyright, mask work right, or other TI intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information published by TI regarding third-party products or services does not constitute a license from TI to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI.

Reproduction of TI information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. Reproduction of this information with alteration is an unfair and deceptive business practice. TI is not responsible or liable for such altered documentation. Information of third parties may be subject to additional restrictions.

Resale of TI products or services with statements different from or beyond the parameters stated by TI for that product or service voids all express and any implied warranties for the associated TI product or service and is an unfair and deceptive business practice. TI is not responsible or liable for any such statements.

TI products are not authorized for use in safety-critical applications (such as life support) where a failure of the TI product would reasonably be expected to cause severe personal injury or death, unless officers of the parties have executed an agreement specifically governing such use. Buyers represent that they have all necessary expertise in the safety and regulatory ramifications of their applications, and acknowledge and agree that they are solely responsible for all legal, regulatory and safety-related requirements concerning their products and any use of TI products in such safety-critical applications, notwithstanding any applications-related information or support that may be provided by TI. Further, Buyers must fully indemnify TI and its representatives against any damages arising out of the use of TI products in such safety-critical applications.

TI products are neither designed nor intended for use in military/aerospace applications or environments unless the TI products are specifically designated by TI as military-grade or "enhanced plastic." Only products designated by TI as military-grade meet military specifications. Buyers acknowledge and agree that any such use of TI products which TI has not designated as military-grade is solely at the Buyer's risk, and that they are solely responsible for compliance with all legal and regulatory requirements in connection with such use.

TI products are neither designed nor intended for use in automotive applications or environments unless the specific TI products are designated by TI as compliant with ISO/TS 16949 requirements. Buyers acknowledge and agree that, if they use any non-designated products in automotive applications, TI will not be responsible for any failure to meet such requirements.

Following are URLs where you can obtain information on other Texas Instruments products and application solutions:

| Products                    |                        | Applications                  |                                   |
|-----------------------------|------------------------|-------------------------------|-----------------------------------|
| Amplifiers                  | amplifier.ti.com       | Audio                         | www.ti.com/audio                  |
| Data Converters             | dataconverter.ti.com   | Automotive                    | www.ti.com/automotive             |
| DLP® Products               | www.dlp.com            | Communications and<br>Telecom | www.ti.com/communications         |
| DSP                         | dsp.ti.com             | Computers and<br>Peripherals  | www.ti.com/computers              |
| Clocks and Timers           | www.ti.com/clocks      | Consumer Electronics          | www.ti.com/consumer-apps          |
| Interface                   | interface.ti.com       | Energy                        | www.ti.com/energy                 |
| Logic                       | logic.ti.com           | Industrial                    | www.ti.com/industrial             |
| Power Mgmt                  | power.ti.com           | Medical                       | www.ti.com/medical                |
| Microcontrollers            | microcontroller.ti.com | Security                      | www.ti.com/security               |
| RFID                        | www.ti-rfid.com        | Space, Avionics & Defense     | www.ti.com/space-avionics-defense |
| RF/IF and ZigBee® Solutions | www.ti.com/lprf        | Video and Imaging             | www.ti.com/video                  |
|                             |                        | Wireless                      | www.ti.com/wireless-apps          |

Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265 Copyright © 2010, Texas Instruments Incorporated