

# RZ/N1D Group, RZ/N1S Group, RZ/N1L Group

User's Manual: System Control and Peripheral

RZ Family RZ/N Series

All information contained in these materials, including products and product specifications, represents information on the product at the time of publication and is subject to change by Renesas Electronics Corp. without notice. Please review the latest information published by Renesas Electronics Corp. through various means, including the Renesas Electronics Corp. website (http://www.renesas.com).

#### **Notice**

- Descriptions of circuits, software and other related information in this document are provided only to illustrate the operation of semiconductor products
  and application examples. You are fully responsible for the incorporation or any other use of the circuits, software, and information in the design of your
  product or system. Renesas Electronics disclaims any and all liability for any losses and damages incurred by you or third parties arising from the use of
  these circuits, software, or information.
- Renesas Electronics hereby expressly disclaims any warranties against and liability for infringement or any other claims involving patents, copyrights, or other intellectual property rights of third parties, by or arising from the use of Renesas Electronics products or technical information described in this document, including but not limited to, the product data, drawings, charts, programs, algorithms, and application examples.
- 3. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others.
- 4. You shall be responsible for determining what licenses are required from any third parties, and obtaining such licenses for the lawful import, export, manufacture, sales, utilization, distribution or other disposal of any products incorporating Renesas Electronics products, if required.
- 5. You shall not alter, modify, copy, or reverse engineer any Renesas Electronics product, whether in whole or in part. Renesas Electronics disclaims any and all liability for any losses or damages incurred by you or third parties arising from such alteration, modification, copying or reverse engineering.
- 6. Renesas Electronics products are classified according to the following two quality grades: "Standard" and "High Quality". The intended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below.
  - "Standard": Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment; industrial robots; etc.
  - "High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control (traffic lights); large-scale communication equipment; key financial terminal systems; safety control equipment; etc.

Unless expressly designated as a high reliability product or a product for harsh environments in a Renesas Electronics data sheet or other Renesas Electronics document, Renesas Electronics products are not intended or authorized for use in products or systems that may pose a direct threat to human life or bodily injury (artificial life support devices or systems; surgical implantations; etc.), or may cause serious property damage (space system; undersea repeaters; nuclear power control systems; aircraft control systems; key plant systems; military equipment; etc.). Renesas Electronics disclaims any and all liability for any damages or losses incurred by you or any third parties arising from the use of any Renesas Electronics product that is inconsistent with any Renesas Electronics data sheet, user's manual or other Renesas Electronics document.

- 7. No semiconductor product is absolutely secure. Notwithstanding any security measures or features that may be implemented in Renesas Electronics hardware or software products, Renesas Electronics shall have absolutely no liability arising out of any vulnerability or security breach, including but not limited to any unauthorized access to or use of a Renesas Electronics product or a system that uses a Renesas Electronics product. RENESAS ELECTRONICS DOES NOT WARRANT OR GUARANTEE THAT RENESAS ELECTRONICS PRODUCTS, OR ANY SYSTEMS CREATED USING RENESAS ELECTRONICS PRODUCTS WILL BE INVULNERABLE OR FREE FROM CORRUPTION, ATTACK, VIRUSES, INTERFERENCE, HACKING, DATA LOSS OR THEFT, OR OTHER SECURITY INTRUSION ("Vulnerability Issues"). RENESAS ELECTRONICS DISCLAIMS ANY AND ALL RESPONSIBILITY OR LIABILITY ARISING FROM OR RELATED TO ANY VULNERABILITY ISSUES. FURTHERMORE, TO THE EXTENT PERMITTED BY APPLICABLE LAW, RENESAS ELECTRONICS DISCLAIMS ANY AND ALL WARRANTIES, EXPRESS OR IMPLIED, WITH RESPECT TO THIS DOCUMENT AND ANY RELATED OR ACCOMPANYING SOFTWARE OR HARDWARE, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE.
- 8. When using Renesas Electronics products, refer to the latest product information (data sheets, user's manuals, application notes, "General Notes for Handling and Using Semiconductor Devices" in the reliability handbook, etc.), and ensure that usage conditions are within the ranges specified by Renesas Electronics with respect to maximum ratings, operating power supply voltage range, heat dissipation characteristics, installation, etc. Renesas Electronics disclaims any and all liability for any malfunctions, failure or accident arising out of the use of Renesas Electronics products outside of such specified ranges.
- 9. Although Renesas Electronics endeavors to improve the quality and reliability of Renesas Electronics products, semiconductor products have specific characteristics, such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Unless designated as a high reliability product or a product for harsh environments in a Renesas Electronics data sheet or other Renesas Electronics document, Renesas Electronics products are not subject to radiation resistance design. You are responsible for implementing safety measures to guard against the possibility of bodily injury, injury or damage caused by fire, and/or danger to the public in the event of a failure or malfunction of Renesas Electronics products, such as safety design for hardware and software, including but not limited to redundancy, fire control and malfunction prevention, appropriate treatment for aging degradation or any other appropriate measures. Because the evaluation of microcomputer software alone is very difficult and impractical, you are responsible for evaluating the safety of the final products or systems manufactured by you.
- 10. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. You are responsible for carefully and sufficiently investigating applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive, and using Renesas Electronics products in compliance with all these applicable laws and regulations. Renesas Electronics disclaims any and all liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations.
- 11. Renesas Electronics products and technologies shall not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable domestic or foreign laws or regulations. You shall comply with any applicable export control laws and regulations promulgated and administered by the governments of any countries asserting jurisdiction over the parties or transactions.
- 12. It is the responsibility of the buyer or distributor of Renesas Electronics products, or any other party who distributes, disposes of, or otherwise sells or transfers the product to a third party, to notify such third party in advance of the contents and conditions set forth in this document.
- 13. This document shall not be reprinted, reproduced or duplicated in any form, in whole or in part, without prior written consent of Renesas Electronics.
- 14. Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this document or Renesas Electronics products.
- (Note1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its directly or indirectly controlled subsidiaries.
- (Note2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics.

(Rev.5.0-1 October 2020)

#### **Corporate Headquarters**

TOYOSU FORESIA, 3-2-24 Toyosu, Koto-ku, Tokyo 135-0061, Japan

www.renesas.com

#### Trademarks

Renesas and the Renesas logo are trademarks of Renesas Electronics Corporation. All trademarks and registered trademarks are the property of their respective owners.

#### **Contact information**

For further information on a product, technology, the most up-to-date version of a document, or your nearest sales office, please visit: <a href="https://www.renesas.com/contact/">www.renesas.com/contact/</a>.

# General Precautions in the Handling of Microprocessing Unit and Microcontroller Unit Products

The following usage notes are applicable to all Microprocessing unit and Microcontroller unit products from Renesas. For detailed usage notes on the products covered by this document, refer to the relevant sections of the document as well as any technical updates that have been issued for the products.

- 1. Precaution against Electrostatic Discharge (ESD)
  - A strong electrical field, when exposed to a CMOS device, can cause destruction of the gate oxide and ultimately degrade the device operation. Steps must be taken to stop the generation of static electricity as much as possible, and quickly dissipate it when it occurs. Environmental control must be adequate. When it is dry, a humidifier should be used. This is recommended to avoid using insulators that can easily build up static electricity. Semiconductor devices must be stored and transported in an anti-static container, static shielding bag or conductive material. All test and measurement tools including work benches and floors must be grounded. The operator must also be grounded using a wrist strap. Semiconductor devices must not be touched with bare hands. Similar precautions must be taken for printed circuit boards with mounted semiconductor devices.
- 2. Processing at power-on
  - The state of the product is undefined at the time when power is supplied. The states of internal circuits in the LSI are indeterminate and the states of register settings and pins are undefined at the time when power is supplied. In a finished product where the reset signal is applied to the external reset pin, the states of pins are not guaranteed from the time when power is supplied until the reset process is completed. In a similar way, the states of pins in a product that is reset by an on-chip power-on reset function are not guaranteed from the time when power is supplied until the power reaches the level at which resetting is specified.
- Input of signal during power-off state
   Do not input signals or an I/O pull-up power supply while the device is powered off. The current injection that results from input of such a signal or I/O pull-up power supply may cause malfunction and the abnormal current that passes in the device at this time may cause degradation of internal elements.

Follow the guideline for input signal during power-off state as described in your product documentation.

- 4. Handling of unused pins
  - Handle unused pins in accordance with the directions given under handling of unused pins in the manual. The input pins of CMOS products are generally in the high-impedance state. In operation with an unused pin in the open-circuit state, extra electromagnetic noise is induced in the vicinity of the LSI, an associated shoot-through current flows internally, and malfunctions occur due to the false recognition of the pin state as an input signal become possible.
- 5. Clock signals
  - After applying a reset, only release the reset line after the operating clock signal becomes stable. When switching the clock signal during program execution, wait until the target clock signal is stabilized. When the clock signal is generated with an external resonator or from an external oscillator during a reset, ensure that the reset line is only released after full stabilization of the clock signal. Additionally, when switching to a clock signal produced with an external resonator or by an external oscillator while program execution is in progress, wait until the target clock signal is stable.
- 6. Voltage application waveform at input pin
  - Waveform distortion due to input noise or a reflected wave may cause malfunction. If the input of the CMOS device stays in the area between  $V_{IL}$  (Max.) and  $V_{IH}$  (Min.) due to noise, for example, the device may malfunction. Take care to prevent chattering noise from entering the device when the input level is fixed, and also in the transition period when the input level passes through the area between  $V_{IL}$  (Max.) and  $V_{IH}$  (Min.).
- 7. Prohibition of access to reserved addresses
  - Access to reserved addresses is prohibited. The reserved addresses are provided for possible future expansion of functions. Do not access these addresses as the correct operation of the LSI is not guaranteed.
- 8. Differences between products
  - Before changing from one product to another, for example to a product with a different part number, confirm that the change will not lead to problems. The characteristics of a microprocessing unit or microcontroller unit products in the same group but having a different part number might differ in terms of internal memory capacity, layout pattern, and other factors, which can affect the ranges of electrical characteristics, such as characteristic values, operating margins, immunity to noise, and amount of radiated noise. When changing to a product with a different part number, implement a system-evaluation test for the given product.

# How to Use This Manual

# 1. Objective and Target Users

This manual was written to explain the hardware functions and electrical characteristics of this LSI to the target users, i.e. those who will be using this LSI in the design of application systems. Target users are expected to understand the fundamentals of electrical circuits, logic circuits, and microcomputers.

This manual is organized in the following items: an overview of the product, descriptions of the CPU, system control functions, and peripheral functions, electrical characteristics of the device, and usage notes.

When designing an application system that includes this LSI, take all points to note into account.

Points to note are given in their contexts and at the final part of each section, and in the section giving usage notes.

The list of revisions is a summary of major points of revision or addition for earlier versions. It does not cover all revised items. For details on the revised points, see the actual locations in the manual.

The following documents have been prepared for reference.

#### ■ Documents related to RZ/N1

| Document Name                                                                                                                    | Document Number                  |
|----------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| RZ/N1D Group, RZ/N1S Group, RZ/N1L Group DATASHEET                                                                               | R01DS0323EJ****                  |
| RZ/N1D Group, RZ/N1S Group, RZ/N1L Group User's Manual: System Introduction, Multiplexing, Electrical and Mechanical Information | R01UH0750EJ****                  |
| RZ/N1D Group, RZ/N1S Group, RZ/N1L Group User's Manual: System Control and Peripheral                                            | R01UH0751EJ****<br>(this manual) |
| RZ/N1D Group, RZ/N1S Group, RZ/N1L Group User's Manual: Peripherals                                                              | R01UH0752EJ****                  |
| RZ/N1D Group, RZ/N1S Group, RZ/N1L Group User's Manual: R-IN Engine and Ethernet Peripherals                                     | R01UH0753EJ****                  |
| RZ/N1D Group, RZ/N1S Group, RZ/N1L Group User's Manual: PWMTimer                                                                 | R01UH0913EJ****                  |

# 2. Description of Registers

Each register description includes a bit chart, illustrating the arrangement of bits, and a table of bits, describing the meanings of the bit settings. The standard format and notation for bit charts and tables are described below.



(1) R/W: The bit or field is readable and writable.

R/(W): The bit or field is readable and writable. However, writing to this bit or field has some limitations. For details on the limitations, see the description or notes of respective registers.

R: The bit or field is readable. Writing to this bit or field has no effect.

W: The bit or field is writable. Reading to this bit or field is not guaranteed.

- (2) Reserved. Make sure to use the specified value when writing to this bit or field; otherwise, the correct operation is not guaranteed.
- (3) Setting prohibited. The correct operation is not guaranteed if such a setting is performed.

# 3. List of Abbreviations and Acronyms

| Abbreviation | Full Form                                   |
|--------------|---------------------------------------------|
| AHB          | Arm Advanced High-performance Bus           |
| APB          | Arm Advanced Peripheral Bus                 |
| AXI          | Arm Advanced eXtensible Interface           |
| bps          | bits per second                             |
| CA7          | Arm Cortex-A7 module                        |
| CM3          | Arm Cortex-M3 module                        |
| CRC          | Cyclic Redundancy Check                     |
| DMA          | Direct Memory Access                        |
| DMAC         | Direct Memory Access Controller             |
| Hi-Z         | High Impedance                              |
| HSR          | High-availability Seamless Redundancy       |
| HW-RTOS      | Hard Ware Real Time OS                      |
| I/O          | Input/Output                                |
| INTC         | Interrupt Controller                        |
| LSB          | Least Significant Bit                       |
| MSB          | Most Significant Bit                        |
| NC           | Non-Connect                                 |
| NoC          | Network-on-Chip                             |
| PLL          | Phase Locked Loop                           |
| PWM          | Pulse Width Modulation                      |
| UART         | Universal Asynchronous Receiver/Transmitter |
| OTP          | One Time Programmable                       |
| PTP          | Precision Time Protocol                     |
| PRP          | Parallel Redundancy Protocol                |
| SoC          | System On Chip                              |

# 4. Description of the Access Size

Access size:

8 bits = Byte

16 bits = Halfword

32 bits = Word

# **Table of Contents**

| Section 1 Cl | PU                                                        | 26 |
|--------------|-----------------------------------------------------------|----|
| 1.1 Arm      | Cortex-A7                                                 | 26 |
| 1.1.1        | Overview                                                  | 26 |
| 1.1.2        | Usage Notes                                               | 27 |
| 1.2 Arm      | Cortex-M3                                                 | 28 |
| 1.2.1        | Overview                                                  | 28 |
| 1.2.2        | Signal Interface                                          | 28 |
| 1.2.3        | Usage Notes                                               | 28 |
| 1.           | 2.3.1 Restriction                                         | 28 |
| Section 2 No | etwork-On-Chip                                            | 29 |
| 2.1 Ove      | rview                                                     | 29 |
| 2.2 Fea      | tures                                                     | 29 |
| Section 3 2N | MB SRAM                                                   | 33 |
| 3.1 Ove      | rview                                                     | 33 |
| 3.2 Sigr     | nal Interfaces                                            | 33 |
| _            | ister Map                                                 |    |
| _            | ister Description                                         |    |
| 3.4.1        | RAMPCMD — RAM_SYS Protect Command Register                |    |
| 3.4.2        | RAMEDC — RAM_SYS ECC Decoder Config Register              |    |
| 3.4.3        | RAMEEC — RAM_SYS ECC Encoder Config Register              |    |
| 3.4.4        | RAMDBEST — RAM_SYS Double Bit ECC Error Status Register   | 38 |
| 3.4.5        | RAMDBEAD — RAM_SYS Double Bit ECC Error Address Register  | 40 |
| 3.4.6        | RAMDBECNT — RAM_SYS Double Bit ECC Error Counter Register | 41 |
| 3.5 Ope      | eration                                                   | 42 |
| 3.5.1        | Configuration of Memory Map                               | 42 |
| 3.5.2        | Initializing                                              | 42 |
| 3.5.3        | ECC Error Correction Function                             | 42 |
| 3.5.4        | Self-Testing of the ECC Circuit                           | 43 |
| 3.6 Usa      | ge Notes                                                  | 45 |
| 3.6.1        | Protect Command Register (RAMPCMD)                        | 45 |
| 3.6.2        | ECC Decoder Config Register (RAMEDC)                      | 45 |
| 3.6.3        | ECC Encoder Config Register (RAMEEC)                      | 46 |
| 3.6.4        | Double Bit ECC Error Status Register (RAMDBEST)           | 46 |
| 3.6.5        | Double Bit ECC Error Address Register (RAMDBEAD)          | 46 |
| 3.6.6        | Double Bit ECC Error Counter Register (RAMDBECNT)         | 46 |
| Section 4 4N | MB SRAM                                                   | 47 |
| 4.1 Ove      | rview                                                     | 47 |

| 4.2     | Signa   | al Interfaces                                              |    |  |  |  |  |
|---------|---------|------------------------------------------------------------|----|--|--|--|--|
| 4.3     | Regi    | gister Map                                                 |    |  |  |  |  |
| 4.4     | Regi    | ster Description                                           | 48 |  |  |  |  |
|         | 4.4.1   | SR4PCMD — SRAM 4MB Protect Command Register                | 48 |  |  |  |  |
|         | 4.4.2   | SR4EDC — SRAM 4MB ECC Decoder Config Register              | 48 |  |  |  |  |
|         | 4.4.3   | SR4EEC — SRAM 4MB ECC Encoder Config Register              | 49 |  |  |  |  |
|         | 4.4.4   | SR4DBEST — SRAM 4MB Double Bit ECC Error Status Register   | 50 |  |  |  |  |
|         | 4.4.5   | SR4DBEAD — SRAM 4MB Double Bit ECC Error Address Register  | 51 |  |  |  |  |
|         | 4.4.6   | SR4DBECNT — SRAM 4MB Double Bit ECC Error Counter Register | 51 |  |  |  |  |
| 4.5     | Oper    | ation                                                      | 52 |  |  |  |  |
|         | 4.5.1   | Configuration of Memory Map                                | 52 |  |  |  |  |
|         | 4.5.2   | Initializing                                               | 52 |  |  |  |  |
|         | 4.5.3   | ECC Error Correction Function                              | 52 |  |  |  |  |
|         | 4.5.4   | Self-Testing of the ECC Circuit                            | 53 |  |  |  |  |
| 4.6     | Usag    | e Notes                                                    | 55 |  |  |  |  |
|         | 4.6.1   | SRAM 4MB Protect Command Register (SR4PCMD)                | 55 |  |  |  |  |
|         | 4.6.2   | SRAM 4MB ECC Decoder Config Register (SR4EDC)              | 55 |  |  |  |  |
|         | 4.6.3   | SRAM 4MB ECC Encoder Config Register (SR4EEC)              | 56 |  |  |  |  |
|         | 4.6.4   | SRAM 4MB Double Bit ECC Error Status Register (SR4DBEST)   | 56 |  |  |  |  |
|         | 4.6.5   | SRAM 4MB Double Bit ECC Error Address Register (SR4DBEAD)  | 56 |  |  |  |  |
|         | 4.6.6   | SRAM 4MB Double Bit ECC Error Counter Register (SR4DBECNT) | 56 |  |  |  |  |
| Sectio  | n 5 De  | bugging Interface                                          | 57 |  |  |  |  |
| 5.1     |         | view                                                       |    |  |  |  |  |
| 5.2     |         | 6 Interface                                                |    |  |  |  |  |
| 0.2     | 5.2.1   | Circuit Recommendation of JTAG Interface                   |    |  |  |  |  |
|         | 5.2.1   | Circuit Recommendation of JTAG-Debug Interface             |    |  |  |  |  |
|         | 5.2.3   | Circuit Recommendation of Serial Wire Debug Interface      |    |  |  |  |  |
| 5.3     |         | t Considerations                                           |    |  |  |  |  |
| 5.5     | 5.3.1   | RZ/N1 Reset Signals                                        |    |  |  |  |  |
|         | 5.3.2   | Debugger Reset Signals                                     |    |  |  |  |  |
|         | 5.3.3   | Example Reset Circuit                                      |    |  |  |  |  |
|         |         | ·                                                          |    |  |  |  |  |
| Section | on 6 16 | DDR2/3 Controller                                          | 63 |  |  |  |  |
| 6.1     | Over    | view                                                       | 63 |  |  |  |  |
| 6.2     | Signa   | al Interfaces                                              | 65 |  |  |  |  |
| 6.3     | Regi    | ster Map                                                   | 66 |  |  |  |  |
|         | 6.3.1   | DDR Controller                                             | 66 |  |  |  |  |
|         | 6.3.2   | DDR PHY                                                    | 69 |  |  |  |  |
| 6.4     | Regi    | ster Description                                           | 70 |  |  |  |  |
|         | 6.4.1   | DDR Controller Register Description                        | 70 |  |  |  |  |
|         | 6.4     | .1.1 DDR_CTL_00 — DDR-Controller Status & Control 00       |    |  |  |  |  |

| 6.4.1.2  |                 |                    |             | l 01 |     |
|----------|-----------------|--------------------|-------------|------|-----|
| 6.4.1.3  | DDR_CTL_02 — DD | R-Controller Statu | ıs & Contro | l 02 | 71  |
| 6.4.1.4  | DDR_CTL_03 — DD | R-Controller Statu | ıs & Contro | l 03 | .72 |
| 6.4.1.5  |                 |                    |             | l 04 |     |
| 6.4.1.6  |                 |                    |             | l 05 |     |
| 6.4.1.7  |                 |                    |             | I 06 |     |
| 6.4.1.8  |                 |                    |             | l 07 |     |
| 6.4.1.9  |                 |                    |             | l 08 |     |
| 6.4.1.10 |                 |                    |             | l 09 |     |
| 6.4.1.11 |                 |                    |             | l 10 |     |
| 6.4.1.11 |                 |                    |             |      |     |
| -        |                 |                    |             | l 11 |     |
| 6.4.1.13 |                 |                    |             | l 12 |     |
| 6.4.1.14 |                 |                    |             | l 13 |     |
| 6.4.1.15 |                 |                    |             | l 14 |     |
| 6.4.1.16 |                 |                    |             | l 15 |     |
| 6.4.1.17 |                 |                    |             | I 16 |     |
| 6.4.1.18 |                 |                    |             | l 17 |     |
| 6.4.1.19 |                 |                    |             | l 18 |     |
| 6.4.1.20 | DDR_CTL_19 — DD | R-Controller Statu | is & Contro | l 19 | 81  |
| 6.4.1.21 | DDR_CTL_20 — DD | R-Controller Statu | is & Contro | l 20 | 81  |
| 6.4.1.22 | DDR CTL 21 — DD | R-Controller Statu | ıs & Contro | l 21 | .82 |
| 6.4.1.23 |                 |                    |             | l 22 |     |
| 6.4.1.24 |                 |                    |             | l 23 |     |
| 6.4.1.25 |                 |                    |             | l 24 |     |
| 6.4.1.26 |                 |                    |             | l 25 |     |
| 6.4.1.27 |                 |                    |             | I 26 |     |
| 6.4.1.28 |                 |                    |             | l 27 |     |
| 6.4.1.29 |                 |                    |             | l 28 |     |
| 6.4.1.30 |                 |                    |             | l 29 |     |
| 6.4.1.31 |                 |                    |             | l 30 |     |
|          |                 |                    |             | l 31 |     |
| 6.4.1.32 |                 |                    |             |      |     |
| 6.4.1.33 |                 |                    |             | l 32 |     |
| 6.4.1.34 |                 |                    |             | l 33 |     |
| 6.4.1.35 |                 |                    |             | I 34 |     |
| 6.4.1.36 |                 |                    |             | I 35 |     |
| 6.4.1.37 |                 |                    |             | I 36 |     |
| 6.4.1.38 |                 |                    |             | I 37 |     |
| 6.4.1.39 |                 |                    |             | I 38 |     |
| 6.4.1.40 |                 |                    |             | I 39 |     |
| 6.4.1.41 | DDR_CTL_40 — DD | R-Controller Statu | ıs & Contro | I 40 | 93  |
| 6.4.1.42 | DDR_CTL_41 — DD | R-Controller Statu | ıs & Contro | l 41 | 93  |
| 6.4.1.43 | DDR_CTL_42 — DD | R-Controller Statu | is & Contro | l 42 | 94  |
| 6.4.1.44 |                 |                    |             | l 43 |     |
| 6.4.1.45 |                 |                    |             | l 44 |     |
| 6.4.1.46 |                 |                    |             | l 45 |     |
| 6.4.1.47 |                 |                    |             | l 46 |     |
| 6.4.1.48 |                 |                    |             | l 47 |     |
| 6.4.1.49 |                 |                    |             | l 48 |     |
| 6.4.1.50 |                 |                    |             | l 49 |     |
|          |                 |                    |             |      |     |
| 6.4.1.51 |                 |                    |             | l 50 |     |
| 6.4.1.52 |                 |                    |             | l 51 |     |
| 6.4.1.53 | DDK_CTL_52 — DD | K-Controller Statu | is & Contro | l 52 | 100 |

| 6.4.1.55 | DDR_CTL_54 — DDR-Controller Status & Control 54                       | 102 |
|----------|-----------------------------------------------------------------------|-----|
| 6.4.1.56 | DDR_CTL_55 — DDR-Controller Status & Control 55                       |     |
| 6.4.1.57 | DDR_CTL_56 — DDR-Controller Status & Control 56                       |     |
| 6.4.1.58 | DDR_CTL_57 — DDR-Controller Status & Control 57                       |     |
| 6.4.1.59 | DDR_CTL_58 — DDR-Controller Status & Control 58                       |     |
| 6.4.1.60 | DDR_CTL_59 — DDR-Controller Status & Control 59                       |     |
| 6.4.1.61 | DDR_CTL_60 — DDR-Controller Status & Control 60                       |     |
| 6.4.1.62 | DDR_CTL_61 — DDR-Controller Status & Control 61                       |     |
| 6.4.1.63 | DDR_CTL_62 — DDR-Controller Status & Control 62                       |     |
| 6.4.1.64 | DDR CTL 63 — DDR-Controller Status & Control 63                       |     |
| 6.4.1.65 | DDR_CTL_64 — DDR-Controller Status & Control 64                       |     |
|          |                                                                       |     |
| 6.4.1.66 | DDR_CTL_65 — DDR-Controller Status & Control 65                       |     |
| 6.4.1.67 | DDR_CTL_66 — DDR-Controller Status & Control 66                       |     |
| 6.4.1.68 | DDR_CTL_67 — DDR-Controller Status & Control 67                       |     |
| 6.4.1.69 | DDR_CTL_68 — DDR-Controller Status & Control 68                       |     |
| 6.4.1.70 | DDR_CTL_69 — DDR-Controller Status & Control 69                       |     |
| 6.4.1.71 | DDR_CTL_70 — DDR-Controller Status & Control 70                       |     |
| 6.4.1.72 | DDR_CTL_71 — DDR-Controller Status & Control 71                       |     |
| 6.4.1.73 | DDR_CTL_72 — DDR-Controller Status & Control 72                       |     |
| 6.4.1.74 | DDR_CTL_73 — DDR-Controller Status & Control 73                       |     |
| 6.4.1.75 | DDR_CTL_74 — DDR-Controller Status & Control 74                       | 116 |
| 6.4.1.76 | DDR_CTL_75 — DDR-Controller Status & Control 75                       |     |
| 6.4.1.77 | DDR_CTL_76 — DDR-Controller Status & Control 76                       | 118 |
| 6.4.1.78 | DDR_CTL_77 — DDR-Controller Status & Control 77                       | 118 |
| 6.4.1.79 | DDR_CTL_78 — DDR-Controller Status & Control 78                       | 119 |
| 6.4.1.80 | DDR_CTL_79 — DDR-Controller Status & Control 79                       | 119 |
| 6.4.1.81 | DDR_CTL_80 — DDR-Controller Status & Control 80                       |     |
| 6.4.1.82 | DDR_CTL_81 — DDR-Controller Status & Control 81                       |     |
| 6.4.1.83 | DDR_CTL_82 — DDR-Controller Status & Control 82                       |     |
| 6.4.1.84 | DDR_CTL_83 — DDR-Controller Status & Control 83                       |     |
| 6.4.1.85 | DDR_CTL_84 — DDR-Controller Status & Control 84                       |     |
| 6.4.1.86 | DDR_CTL_85 — DDR-Controller Status & Control 85                       |     |
| 6.4.1.87 | DDR_CTL_86 — DDR-Controller Status & Control 86                       |     |
| 6.4.1.88 | DDR CTL 87 — DDR-Controller Status & Control 87                       |     |
| 6.4.1.89 | DDR_CTL_88 — DDR-Controller Status & Control 88                       |     |
| 6.4.1.90 | DDR_CTL_89 — DDR-Controller Status & Control 89                       |     |
| 6.4.1.91 | DDR_CTL_90 — DDR-Controller Status & Control 90                       |     |
| 6.4.1.92 | DDR_CTL_[k] — Port0 Range[n] Start Address Setting Register (n = 015) | 120 |
| 0.4.1.92 | (k = 91 + n × 2)                                                      | 126 |
| 6 4 1 02 | DDR_CTL_[k] — Port0 Range[n] End Address Setting Register (n = 015)   | 120 |
| 6.4.1.93 |                                                                       | 407 |
| 0.4.4.04 | $(k = 92 + n \times 2)$                                               | 127 |
| 6.4.1.94 | DDR_CTL_[k] — Port1 Range[n] Start Address Setting Register (n = 015) | 407 |
|          | (k = 123 + n × 2)                                                     | 127 |
| 6.4.1.95 | DDR_CTL_[k] — Port1 Range[n] End Address Setting Register (n = 015)   |     |
|          | $(k = 124 + n \times 2)$                                              | 128 |
| 6.4.1.96 | DDR_CTL_[k] — Port2 Range[n] Start Address Setting Register (n = 015) |     |
|          | $(k = 155 + n \times 2)$                                              | 128 |
| 6.4.1.97 | DDR_CTL_[k] — Port2 Range[n] End Address Setting Register (n = 015)   |     |
|          | $(k = 156 + n \times 2)$                                              | 129 |
| 6.4.1.98 | DDR_CTL_[k] — Port3 Range[n] Start Address Setting Register (n = 015) |     |
|          | (k = 187 + n × 2)                                                     | 129 |
| 6.4.1.99 | DDR_CTL_[k] — Port3 Range[n] End Address Setting Register (n = 014)   |     |
|          | (k = 188 + n × 2)                                                     | 130 |
|          |                                                                       |     |

|           | DDR_CTL_218 — Port3 Range15 End Address Setting Register                                                                | 130 |
|-----------|-------------------------------------------------------------------------------------------------------------------------|-----|
| 6.4.1.101 | DDR_CTL_[k] — Port0 Range[n] Protect Setting Register1 (n = 015)                                                        |     |
|           | $(k = 219 + n \times 2)$                                                                                                | 131 |
| 6.4.1.102 | DDR_CTL_[k] — Port0 Range[n] Protect Setting Register2 (n = 014)                                                        |     |
|           | $(k = 220 + n \times 2)$                                                                                                |     |
| 6.4.1.103 | DDR_CTL_250 — Port0 Range15 Protect Setting Register2                                                                   | 133 |
| 6.4.1.104 | DDR_CTL_[k] — Port1 Range[n] Protect Setting Register1 (n = 015)                                                        |     |
|           | $(k = 251 + n \times 2)$                                                                                                | 134 |
| 6.4.1.105 | DDR_CTL_[k] — Port1 Range[n] Protect Setting Register2 (n = 014)                                                        | 405 |
| 0.4.4.400 | $(k = 252 + n \times 2)$                                                                                                |     |
| 6.4.1.106 | DDR_CTL_282 — Port1 Range15 Protect Setting Register2                                                                   | 136 |
| 6.4.1.107 | DDR_CTL_[k] — Port2 Range[n] Protect Setting Register1 (n = 015)                                                        | 407 |
| 0.4.4.400 | (k = 283 + n × 2)                                                                                                       | 137 |
| 6.4.1.108 | DDR_CTL_[k] — Port2 Range[n] Protect Setting Register2 (n = 014)                                                        | 420 |
| 6 4 4 400 | (k = 284 +n × 2)                                                                                                        |     |
| 6.4.1.109 | DDR_CTL_314 — Port2 Range15 Protect Setting Register2  DDR_CTL_[k] — Port3 Range[n] Protect Setting Register1 (n = 015) | 139 |
| 6.4.1.110 | (k = 315 + n × 2)                                                                                                       | 140 |
| 6.4.1.111 | DDR_CTL_[k] — Port3 Range[n] Protect Setting Register2 (n = 014)                                                        | 140 |
| 0.4.1.111 | (k = 316 + n × 2)                                                                                                       | 1/1 |
| 6.4.1.112 | DDR_CTL_346 — Port3 Range15 Protect Setting Register2                                                                   |     |
| 6.4.1.113 | DDR CTL 347 — DDR-Controller Status & Control 347                                                                       |     |
| 6.4.1.114 | DDR_CTL_348 — DDR-Controller Status & Control 348                                                                       |     |
| 6.4.1.115 | DDR_CTL_349 — DDR-Controller Status & Control 349                                                                       |     |
| 6.4.1.116 | DDR_CTL_350 — DDR-Controller Status & Control 350                                                                       |     |
| 6.4.1.117 | DDR CTL 351 — DDR-Controller Status & Control 351                                                                       |     |
| 6.4.1.118 | DDR_CTL_352 — DDR-Controller Status & Control 352                                                                       |     |
| 6.4.1.119 | DDR_CTL_353 — DDR-Controller Status & Control 353                                                                       |     |
| 6.4.1.120 | DDR_CTL_354 — DDR-Controller Status & Control 354                                                                       |     |
| 6.4.1.121 | DDR_CTL_355 — DDR-Controller Status & Control 355                                                                       |     |
| 6.4.1.122 | DDR CTL 356 — DDR-Controller Status & Control 356                                                                       |     |
| 6.4.1.123 | DDR_CTL_357 — DDR-Controller Status & Control 357                                                                       | 151 |
| 6.4.1.124 | DDR_CTL_358 — DDR-Controller Status & Control 358                                                                       | 152 |
| 6.4.1.125 | DDR_CTL_359 — DDR-Controller Status & Control 359                                                                       | 152 |
| 6.4.1.126 | DDR_CTL_360 — DDR-Controller Status & Control 360                                                                       | 153 |
| 6.4.1.127 | DDR_CTL_361 — DDR-Controller Status & Control 361                                                                       | 153 |
| 6.4.1.128 | DDR_CTL_362 — DDR-Controller Status & Control 362                                                                       | 154 |
| 6.4.1.129 | DDR_CTL_363 — DDR-Controller Status & Control 363                                                                       |     |
| 6.4.1.130 | DDR_CTL_364 — DDR-Controller Status & Control 364                                                                       |     |
| 6.4.1.131 | DDR_CTL_365 — DDR-Controller Status & Control 365                                                                       |     |
| 6.4.1.132 | DDR_CTL_366 — DDR-Controller Status & Control 366                                                                       |     |
|           | DDR_CTL_367 — DDR-Controller Status & Control 367                                                                       |     |
| 6.4.1.134 | <b>–</b> –                                                                                                              |     |
| 6.4.1.135 | DDR_CTL_369 — DDR-Controller Status & Control 369                                                                       |     |
| 6.4.1.136 | DDR_CTL_370 — DDR-Controller Status & Control 370                                                                       |     |
| 6.4.1.137 | DDR_CTL_371 — DDR-Controller Status & Control 371                                                                       |     |
| 6.4.1.138 | DDR_CTL_372 — DDR-Controller Status & Control 372                                                                       |     |
| 6.4.1.139 | DDR_CTL_373 — DDR-Controller Status & Control 373                                                                       |     |
| 6.4.1.140 | DDR_CTL_374 — DDR-Controller Status & Control 374                                                                       |     |
|           | PHY Register Description                                                                                                |     |
| 6.4.2.1   | FUNCCTRL — Function Control Register                                                                                    |     |
| 6.4.2.2   | DLLCTRL — MDLL Control Register                                                                                         |     |
| 6.4.2.3   | ZQCALCTRL — ZQ Calibration Control Register                                                                             | 165 |

6.4

|              | 4.2.4         | ZQODTCTRL — ZQODT Control Register               |     |
|--------------|---------------|--------------------------------------------------|-----|
| 6.           | 4.2.5         | RDCTRL — Read Control Register                   |     |
|              | 4.2.6         | RDTMG — READ Timing Control Register             | 169 |
|              | 4.2.7         | FIFOINIT — FIFO Initialization Register          |     |
| 6.           | 4.2.8         | OUTCTRL — Output Control Register                |     |
| 6.           | 4.2.9         | WLCTRL1 — Write Leveling Control Register 1      | 172 |
| 6.           | 4.2.10        | DQCALOFS1 — DQS Offset Setting                   | 173 |
| 6.5 Ope      | ration.       |                                                  | 174 |
| 6.5.1        | Addı          | ress Mapping                                     | 174 |
| 6.           | 5.1.1         | DDR SDRAM Address Mapping Options                | 174 |
| 6.           | 5.1.2         | Maximum Address Space                            | 175 |
| 6.           | 5.1.3         | Memory Mapping to Address Space                  | 176 |
| 6.5.2        | AXI           | Interface Ports                                  | 177 |
| 6.           | 5.2.1         | Arbitration Scheme                               |     |
| 6.           | 5.2.2         | Understanding Round-Robin Arbitration            |     |
| 6.           | 5.2.3         | Understanding Port Priority                      |     |
| 6.           | 5.2.4         | Understanding Port Bandwidth                     |     |
| 6.           | 5.2.5         | Understanding Port Bandwidth Hold-Off            |     |
| 6.           | 5.2.6         | Understanding Port Bandwidth Overflow            |     |
| 6.           | 5.2.7         | Priority Round-Robin Arbitration Summary         |     |
| 6.           | 5.2.8         | Arbitration Examples                             |     |
| 6.           | 5.2.9         | Programming for Priority Round-Robin Arbitration | 189 |
| 6.5.3        | Port          | Protection Option                                | 190 |
| 6.5.4        | Com           | nmand Queue with Placement Logic                 | 192 |
|              | 5.4.1         | Rules of the Placement Algorithm                 |     |
| _            | 5.4.2         | Command Execution Order After Placement          |     |
| _            | 5.4.3         | ACT Request Control                              |     |
| 6.5.5        |               | AM Command Processing                            |     |
| 6.5.6        |               | C Function                                       |     |
|              | 5.6.1         | ECC Error Types                                  |     |
|              | 5.6.2         | Features of the ECC Logic                        |     |
|              | 5.6.3         | ECC Control                                      |     |
|              | 5.6.4         | Syndromes                                        | 004 |
| 6.           | 5.6.5         | Command Processing when ECC is Enabled           |     |
| _            | 5.6.6         | ECC and Read Operations                          |     |
|              | 5.6.7         | ECC and Write Operations                         |     |
|              | 5.6.8         | Automatic ECC Corruption                         |     |
|              | 5.6.9         | Forcing an ECC Error Event                       |     |
|              | 5.6.10        | •                                                |     |
| 6.5.7        | Low           | Power Control Management                         |     |
|              | 5.7.1         | Low Power States                                 |     |
| 0.           | 5.7.2         | Management of the Low Power Control Module       |     |
|              | 5.7.3         | Software Programmable Interface                  |     |
|              | 5.7.4         | Automatic Interface                              |     |
|              |               | es                                               |     |
|              | •             |                                                  |     |
| 6.6.1        |               | plified DDR Initialization                       |     |
| 6.6.2        | אטט           | R Initialization Example                         | 215 |
| Section 7 NA | $\Delta$ ND F | Flash Controller                                 | 218 |
|              |               |                                                  |     |
| 7.1 Ove      | ı view        |                                                  | ∠18 |

| 7.2 | Sign   | al Interfaces                                                 | 219 |
|-----|--------|---------------------------------------------------------------|-----|
| 7.3 | Regi   | ster Map                                                      | 220 |
| 7.4 | Reai   | ster Description                                              | 221 |
|     | 7.4.1  | COMMAND — Command Register                                    |     |
|     | 7.4.2  | CONTROL — CONTROL Register                                    |     |
|     | 7.4.3  | STATUS — STATUS Register                                      |     |
|     | 7.4.4  | STATUS MASK — STATUS MASK Register                            |     |
|     | 7.4.5  | INT_MASK — INT_MASK Register                                  |     |
|     | 7.4.6  | INT_STATUS — INT_STATUS Register                              |     |
|     | 7.4.7  | ECC_CTRL — ECC Control Register                               |     |
|     | 7.4.8  | ECC_OFFSET — ECC Offset Register                              |     |
|     | 7.4.9  | ECC_STAT — ECC Status Register                                |     |
|     | 7.4.10 | ADDR0_COL — Column Address 0 Register                         | 233 |
|     | 7.4.11 | ADDR0_ROW — Row Address 0 Register                            | 233 |
|     | 7.4.12 | ADDR1_COL — Column Address 1 Register                         | 234 |
|     | 7.4.13 | ADDR1_ROW — Row Address 1 Register                            | 234 |
|     | 7.4.14 | PROTECT — Protect Register                                    | 235 |
|     | 7.4.15 | FIFO_DATA — FIFO Data Register                                | 236 |
|     | 7.4.16 | DATA_REG — Data Register                                      | 236 |
|     | 7.4.17 | DATA_REG_SIZE — DATA_REG_SIZE Register                        | 237 |
|     | 7.4.18 | DEV[n]_PTR — Device [n] Remap Pointer Register (n = 03)       | 237 |
|     | 7.4.19 | DMA_ADDR — DMA Address Register                               | 238 |
|     | 7.4.20 | DMA_CNT — DMA Counter Register                                | 238 |
|     | 7.4.21 | DMA_CTRL — DMA Control Register                               | 239 |
|     | 7.4.22 | BBM_CTRL — BBM Control Register                               | 240 |
|     | 7.4.23 | MEM_CTRL — Memory Devices Control Register                    | 241 |
|     | 7.4.24 | DATA_SIZE — Data Size Register                                | 242 |
|     | 7.4.25 | TIMINGS_ASYN — Asynchronous Mode Timings Register             | 243 |
|     | 7.4.26 | TIME_SEQ_0 — Command Sequence Timing Register 0               | 244 |
|     | 7.4.27 | TIME_SEQ_1 — Command Sequence Timing Register 1               | 245 |
|     | 7.4.28 | TIME_GEN_SEQ_0 — Generic Command Sequence Register 0          | 246 |
|     | 7.4.29 | TIME_GEN_SEQ_1 — Generic Command Sequence Register 1          | 247 |
|     | 7.4.30 | TIME_GEN_SEQ_2 — Generic Command Sequence Register 2          | 248 |
|     | 7.4.31 | FIFO_INIT — FIFO Init Register                                | 249 |
|     | 7.4.32 | FIFO_STATE — FIFO Status Register                             | 250 |
|     | 7.4.33 | GEN_SEQ_CTRL — Generic Sequence Register                      | 251 |
|     | 7.4.34 | MLUN — LUN Configuration Register                             | 253 |
|     | 7.4.35 | DEV[n]_SIZE — Device [n] BBM Record Counter Register (n = 03) | 253 |
|     | 7.4.36 | DMA_TLVL — DMA Trigger Level Register                         | 254 |
|     | 7.4.37 | CMD_MARK — CMD ID Initial Value                               | 254 |
|     | 7.4.38 | LUN_STATUS_0 — LUN Status Register                            | 255 |
|     | 7.4.39 | TIME_GEN_SEQ_3 — Generic Command Sequence Register 3          | 256 |
|     | 7.4.40 | INT STAT — Internal Status Register                           | 257 |

|     | 7.4.41 | ECC_CNT — ECC Error Counter           | 258 |
|-----|--------|---------------------------------------|-----|
|     | 7.4.42 | PARAM_REG — PARAMETER Register        | 259 |
| 7.5 | Oper   | ration                                | 261 |
|     | 7.5.1  | Programming the NAND Flash Controller | 261 |
|     | 7.5.2  | Command Generation                    | 261 |
|     | 7.5    | 5.2.1 Instruction Encoding            |     |
|     | _      | 5.2.2 Command Sequence Encoding       |     |
|     |        | 5.2.3 Sequence SEQ_0                  |     |
|     |        | 5.2.4 Sequence SEQ_1                  |     |
|     |        | 5.2.5 Sequence SEQ_2                  |     |
|     |        | 5.2.6 Sequence SEQ_3                  |     |
|     |        | 5.2.7 Sequence SEQ 4                  |     |
|     |        | 5.2.8 Sequence SEQ_5                  |     |
|     |        | 5.2.9 Sequence SEQ_6                  |     |
|     |        | 5.2.10 Sequence SEQ_7                 |     |
|     | 7.5    | 5.2.11 Sequence SEQ_8                 |     |
|     |        | 5.2.12 Sequence SEQ 9                 |     |
|     |        | 5.2.13 Sequence SEQ 10                |     |
|     |        | 5.2.14 Sequence SEQ_11                |     |
|     |        | 5.2.15 Sequence SEQ_12                |     |
|     |        | 5.2.16 Sequence SEQ_13                |     |
|     |        | 5.2.17 Sequence SEQ_14                |     |
|     |        | 5.2.18 Sequence SEQ_15                |     |
|     |        | 5.2.19 Sequence SEQ 17                |     |
|     |        | 5.2.20 Sequence SEQ_18                |     |
|     | 7.5    | 5.2.21 Sequence SEQ_19                |     |
|     | 7.5    | 5.2.22 Sequence SEQ_20                |     |
|     | 7.5    | 5.2.23 Sequence SEQ_21                |     |
|     |        | 5.2.24 Sequence SEQ 22                |     |
|     | 7.5    | 5.2.25 Sequence SEQ 23                |     |
|     | 7.5    | 5.2.26 Sequence SEQ_24                | 273 |
|     | 7.5    | 5.2.27 Sequence SEQ_25                |     |
|     | 7.5.3  | Generic Command Sequence              | 274 |
|     | 7.5.4  | Instructions                          | 278 |
|     | 7.5    | 5.4.1 Instruction Set                 |     |
|     |        | 5.4.2 Instruction Execution           |     |
|     |        | 5.4.3 RESET Command                   |     |
|     |        | 5.4.4 READ ID Command                 |     |
|     |        | 5.4.5 READ PARAMETER PAGE Command     |     |
|     |        | 5.4.6 READ UNIQUE ID Command          |     |
|     |        | 5.4.7 GET FEATURES Command            |     |
|     | 7.5    | 5.4.8 SET FEATURES Command            |     |
|     |        | 5.4.9 READ STATUS Command             |     |
|     | 7.5    | 5.4.10 DEVICE STATUS Command          |     |
|     |        | 5.4.11 VOLUME SELECT Command          |     |
|     |        | 5.4.12 SELECT LUN WITH STATUS Command |     |
|     |        | 5.4.13 LUN STATUS Command             |     |
|     |        | 5.4.14 CHANGE READ COLUMN Command     |     |
|     |        | 5.4.15 SELECT CACHE REGISTER Command  |     |
|     |        | 5.4.16 CHANGE WRITE COLUMN Command    |     |
|     |        | 5.4.17 CHANGE ROW ADDRESS Command     |     |

|     | 7.5.4                                  | 4.18    | READ PAGE Command                                              |     |
|-----|----------------------------------------|---------|----------------------------------------------------------------|-----|
|     | 7.5.4                                  | 4.19    | READ PAGE CACHE Command                                        | 287 |
|     | 7.5.4                                  | 4.20    | READ PAGE CACHE LAST Command                                   | 287 |
|     | 7.5.4                                  | 4.21    | READ MULTIPLANE Command                                        |     |
|     | 7.5.4                                  |         | QUEUE PAGE READ Command                                        |     |
|     | 7.5.4                                  |         | TWO PLANE PAGE READ Command                                    |     |
|     | 7.5.4                                  |         | PROGRAM PAGE Command                                           |     |
|     | 7.5.4                                  |         | PROGRAM PAGE IMMEDIATE Command                                 |     |
|     | 7.5.4<br>7.5.4                         |         | PROGRAM PAGE 1 CommandPROGRAM PAGE 1 Command                   |     |
|     | 7.5. <sup>2</sup><br>7.5. <sup>2</sup> |         | PROGRAM PAGE CACHE Command                                     |     |
|     | 7.5. <sup>2</sup><br>7.5. <sup>2</sup> |         | PROGRAM MULTIPLANE Command                                     |     |
|     | 7.5.4                                  |         | WRITE PAGE Command                                             |     |
|     | 7.5.4                                  |         | WRITE PAGE CACHE Command                                       |     |
|     | 7.5.4                                  |         | WRITE MULTIPLANE Command                                       |     |
|     | 7.5.4                                  |         | ERASE BLOCK Command                                            |     |
|     | 7.5.4                                  | 4.34    | ERASE MULTIPLANE Command                                       | 293 |
|     | 7.5.4                                  | 4.35    | COPYBACK READ Command                                          | 293 |
|     | 7.5.4                                  | 4.36    | COPYBACK PROGRAM Command                                       |     |
|     | 7.5.4                                  | 4.37    | COPYBACK PROGRAM 1 Command                                     |     |
|     | 7.5.4                                  |         | COPYBACK MULTIPLANE Command                                    |     |
|     | 7.5.4                                  |         | PROGRAM OTP Command                                            |     |
|     | 7.5.4                                  |         | DATA PROTECT OTP Command                                       |     |
|     | 7.5.4                                  |         | PAGE READ OTP Command                                          |     |
|     |                                        |         | .UN Work Mode                                                  |     |
|     |                                        |         | pping Mechanism                                                |     |
|     | 7.5.7                                  | Interru | ıpts Mechanism                                                 | 299 |
| 7.6 | Setup                                  | and Co  | onfiguration                                                   | 300 |
|     | 7.6.1                                  | Send I  | Data to NAND Flash via Slave Interface                         | 302 |
|     | 7.6.2                                  | Read I  | Data from NAND Flash via Slave Interface                       | 303 |
|     | 7.6.3                                  | Send I  | Data to NAND Flash via Master Interface (Using DMA)            | 304 |
|     |                                        |         | Vriting and Reading of Several Pages from the Memory Using DMA |     |
|     |                                        |         | g of Data into Two NAND Flash Memory Devices                   |     |
|     | 7.6.6                                  | Readir  | ng Data from Two NAND Flash Memory Devices                     | 309 |
|     |                                        |         | g Data into Four NAND Flash Memory Devices                     |     |
|     |                                        | -       | ng Data from Four NAND Flash Memory Devices                    |     |
|     |                                        |         | g Partial Pages                                                |     |
|     |                                        |         | ng Partial Pages                                               |     |
| 7.7 |                                        |         |                                                                |     |
|     |                                        |         | and Data Location within the Page                              |     |
|     |                                        |         | Algorithm Implementation                                       |     |
| 7.8 |                                        |         |                                                                |     |
|     | •                                      |         |                                                                |     |
|     |                                        |         | [n]_COL and ADDR[n]_ROW Registerst Pagister (PROTECT)          |     |
|     |                                        |         | t Register (PROTECT)                                           |     |
|     |                                        | -       | hronous Mode Timings Register (TIMINGS_ASYN)                   |     |
|     | 7.8.4                                  | Comm    | nand Sequence Timing Register 1 (TIME_SEQ_1)                   | 320 |
|     |                                        |         |                                                                |     |

| Section 8 Quad IO SPI |               |                                                                           |     |  |  |  |  |  |
|-----------------------|---------------|---------------------------------------------------------------------------|-----|--|--|--|--|--|
| 8.1                   | Overview      |                                                                           |     |  |  |  |  |  |
| 8.2                   | Signa         | Signal interfaces                                                         |     |  |  |  |  |  |
| 8.3                   | Regis         | ter Map                                                                   | 323 |  |  |  |  |  |
| 8.4                   | Regis         | ter Description                                                           | 325 |  |  |  |  |  |
|                       | 8.4.1         | config_reg — QSPI Configuration Register                                  |     |  |  |  |  |  |
|                       | 8.4.2         | dev_instr_rd_config_reg — Device Read Instruction Configuration Register  |     |  |  |  |  |  |
|                       | 8.4.3         | dev_instr_wr_config_reg — Device Write Instruction Configuration Register |     |  |  |  |  |  |
|                       | 8.4.4         | dev_delay_reg — QSPI Device Delay Register                                |     |  |  |  |  |  |
|                       | 8.4.5         | rd_data_capture_reg — Read Data Capture Register                          | 331 |  |  |  |  |  |
|                       | 8.4.6         | dev_size_config_reg — Device Size Configuration Register                  | 332 |  |  |  |  |  |
|                       | 8.4.7         | remap_addr_reg — Remap Address Register                                   | 333 |  |  |  |  |  |
|                       | 8.4.8         | mode_bit_config_reg — Mode Bit Configuration Register                     |     |  |  |  |  |  |
|                       | 8.4.9         | tx_thresh_reg — TX Threshold Register                                     | 334 |  |  |  |  |  |
|                       | 8.4.10        | rx_thresh_reg — RX Threshold Register                                     | 334 |  |  |  |  |  |
|                       | 8.4.11        | write_completion_ctrl_reg — Write Completion Control Register             | 335 |  |  |  |  |  |
|                       | 8.4.12        | no_of_polls_bef_exp_reg — Polling Expiration Register                     | 336 |  |  |  |  |  |
|                       | 8.4.13        | irq_status_reg — Interrupt Status Register                                | 337 |  |  |  |  |  |
|                       | 8.4.14        | irq_mask_reg — Interrupt Mask Register                                    | 339 |  |  |  |  |  |
|                       | 8.4.15        | lower_wr_prot_reg — Lower Write Protection Register                       | 340 |  |  |  |  |  |
|                       | 8.4.16        | upper_wr_prot_reg — Upper Write Protection Register                       | 340 |  |  |  |  |  |
|                       | 8.4.17        | wr_prot_ctrl_reg — Write Protection Control Register                      | 341 |  |  |  |  |  |
|                       | 8.4.18        | flash_cmd_ctrl_reg — Flash Command Control Register                       | 342 |  |  |  |  |  |
|                       | 8.4.19        | flash_cmd_addr_reg — Flash Command Address Register                       | 344 |  |  |  |  |  |
|                       | 8.4.20        | flash_rd_data_lower_reg — Flash Command Read Data Register (Lower)        | 344 |  |  |  |  |  |
|                       | 8.4.21        | flash_rd_data_upper_reg — Flash Command Read Data Register (Upper)        | 345 |  |  |  |  |  |
|                       | 8.4.22        | flash_wr_data_lower_reg — Flash Command Write Data Register (Lower)       | 345 |  |  |  |  |  |
|                       | 8.4.23        | flash_wr_data_upper_reg — Flash Command Write Data Register (Upper)       | 346 |  |  |  |  |  |
|                       | 8.4.24        | polling_flash_status_reg — Polling Flash Status Register                  | 346 |  |  |  |  |  |
|                       | 8.4.25        | module_id_reg — Module ID Register                                        | 347 |  |  |  |  |  |
| 8.5                   | Opera         | ation                                                                     | 348 |  |  |  |  |  |
|                       | 8.5.1         | AHB Control Interface                                                     | 348 |  |  |  |  |  |
|                       | 8.5.          | , , ,                                                                     |     |  |  |  |  |  |
|                       | 8.5.          |                                                                           |     |  |  |  |  |  |
|                       | 8.5.2         | Direct Access Controller (DAC)                                            |     |  |  |  |  |  |
|                       | 8.5.3         | Software Triggered Instruction Generator (STIG)                           |     |  |  |  |  |  |
|                       | 8.5.4         | Servicing a STIG request                                                  |     |  |  |  |  |  |
|                       | 8.5.5         |                                                                           |     |  |  |  |  |  |
|                       | 8.5.6         | SPI Command Translation                                                   |     |  |  |  |  |  |
|                       | 8.5.7         | Selecting the Flash Instruction Type                                      |     |  |  |  |  |  |
|                       | 8.5.8         | APB Interface and Register Module                                         |     |  |  |  |  |  |
|                       | 8.5.9<br>8.5. | Read Data Capturing                                                       |     |  |  |  |  |  |

| 8.6    | Progr           | amming Quad SPI Controller                                                                                | 355 |
|--------|-----------------|-----------------------------------------------------------------------------------------------------------|-----|
|        | 8.6.1           | Configuring the Quad SPI Controller for use after reset                                                   | 355 |
|        | 8.6.2           | Configuring the Quad SPI Controller for optimal use                                                       | 355 |
|        | 8.6.3           | Using the Flash Command Control Register (STIG Operation)                                                 | 357 |
|        | 8.6.4           | Using SPI Legacy Mode                                                                                     | 357 |
|        | 8.6.5           | Entering and Exiting NoCMD mode                                                                           |     |
|        |                 | .5.1 Entering NoCMD mode                                                                                  |     |
|        |                 | .5.2 Exiting NoCMD mode                                                                                   |     |
| 0.7    | 8.6.6           | Using the Write Protection Registers                                                                      |     |
| 8.7    | _               | e Notes                                                                                                   |     |
|        | 8.7.1           | 4-byte Address Output                                                                                     |     |
|        | 8.7.2           | Write Protection Area                                                                                     |     |
|        | 8.7.3           | Automatically Polling for Write Complete                                                                  |     |
|        | 8.7.4           | Chip Select Output                                                                                        | 359 |
| Sectio | n 9 SD          | IO/SD/eMMC Controller                                                                                     | 360 |
| 9.1    | Overv           | /iew                                                                                                      | 360 |
| 9.2    |                 | I Interfaces                                                                                              |     |
| 9.3    | J               | ter Map                                                                                                   |     |
| 9.5    | 9.3.1           | Register Map (SDIO1)                                                                                      |     |
|        | 9.3.1           | Register Map (SDIO2)                                                                                      |     |
| 0.4    |                 | ter Description                                                                                           |     |
| 9.4    | 9.4.1           | ·                                                                                                         |     |
|        | 9.4.1           | reg_sdmasysaddrlo — SDMA System Address Register Lowreg_sdmasysaddrhi — SDMA System Address Register High |     |
|        | 9.4.2           | ,                                                                                                         |     |
|        | 9.4.3           | reg_blocksize — Block Size Register                                                                       |     |
|        | 9.4.4           | reg_blockcount — Block Count Register                                                                     |     |
|        |                 | reg_argument1lo — Argument1 Register Low                                                                  |     |
|        | 9.4.6<br>9.4.7  | reg_argument1hi — Argument1 Register High                                                                 |     |
|        |                 | reg_transfermode — Transfer Mode Register                                                                 |     |
|        | 9.4.8           | reg_command — Command Register                                                                            |     |
|        | 9.4.9<br>9.4.10 | reg_response[n] — Response Register [n] (n = 07)                                                          |     |
|        |                 | reg_dataport — Buffer Data Port Register                                                                  |     |
|        | 9.4.11          | reg_presentstate — Present State Register                                                                 |     |
|        | 9.4.12          | reg_hostcontrol1 — Host Control 1 Register                                                                |     |
|        | 9.4.13          | reg_powercontrol — Power Control Register                                                                 |     |
|        | 9.4.14          | reg_blockgapcontrol — Block Gap Control Register                                                          |     |
|        | 9.4.15          | reg_wakeupcontrol — Wake-up Control Register                                                              |     |
|        | 9.4.16          | reg_clockcontrol — Clock Control Register                                                                 |     |
|        | 9.4.17          | reg_timeoutcontrol — Timeout Control Register                                                             |     |
|        | 9.4.18          | reg_softwarereset — Software Reset Register                                                               |     |
|        | 9.4.19          | reg_normalintrsts — Normal Interrupt Status Register                                                      |     |
|        | 9.4.20          | reg_errorintrsts — Error Interrupt Status Register                                                        |     |
|        | 9.4.21          | reg_normalintrstsena — Normal Interrupt Status Enable Register                                            | 393 |

| 9.4.22       | reg_errorintrstsena — Error Interrupt Status Enable Register                         | 394 |
|--------------|--------------------------------------------------------------------------------------|-----|
| 9.4.23       | reg_normalintrsigena — Normal Interrupt Signal Enable Register                       | 395 |
| 9.4.24       | reg_errorintrsigena — Error Interrupt Signal Enable Register                         | 396 |
| 9.4.25       | reg_autocmderrsts — Auto CMD Error Status Register                                   | 397 |
| 9.4.26       | reg_hostcontrol2 — Host Control 2 Register                                           | 398 |
| 9.4.27       | reg_capabilities — Capabilities Register                                             | 399 |
| 9.4.28       | reg_capabilities_cont — Capabilities Register (Continue)                             | 401 |
| 9.4.29       | reg_maxcurrentcap — Maximum Current Capabilities Register                            | 402 |
|              | reg_ForceEventforAUTOCMDErrorStatus — Force Event for Auto CMD Error Status Register | 403 |
|              | reg_forceeventforerrintsts — Force Event for Error Interrupt Status Register         |     |
|              | reg_admaerrsts — ADMA Error Status Register                                          |     |
|              | reg_admasysaddr0 — ADMA System Address Register Low                                  |     |
|              | reg_admasysaddr1 — ADMA System Address Register High                                 |     |
|              | reg_presetvalue0 — Preset Value Register for Initialization                          |     |
|              | reg_presetvalue1 — Preset Value Register for Default Speed                           |     |
|              | reg_presetvalue2 — Preset Value Register for High Speed                              |     |
|              | reg_slotintrsts — Slot Interrupt Status Register                                     |     |
|              | reg_hostcontrollerver — Host Controller Version Register                             |     |
|              | mming the SDIO                                                                       |     |
| •            | Non-DMA Transaction                                                                  |     |
|              | DMA Transaction                                                                      |     |
|              | ADMA Transactions                                                                    |     |
| 9.5.4        | Abort Transaction                                                                    | 416 |
| 9.5.4        |                                                                                      |     |
| 9.5.4        | 1.2 Asynchronous Abort                                                               | 418 |
|              | JSB 2.0 HS Host/Function Controller (USBh/USBf)                                      |     |
|              | ew                                                                                   |     |
| 10.2 Signal  | Interfaces                                                                           | 422 |
| 10.3 USBPL   | L Features                                                                           | 423 |
| 10.4 Registe | er Map                                                                               | 424 |
| 10.4.1       | OHCl Operation Register Map                                                          | 424 |
| 10.4.2       | EHCI Operation Register Map                                                          | 425 |
| 10.4.3       | OHCI (PCI Configuration Space) Register Map                                          | 425 |
| 10.4.4       | EHCI (PCI Configuration Space) Register Map                                          | 426 |
| 10.4.5       | AHB-PCI Bridge (PCI Configuration Space) Register Map                                | 426 |
| 10.4.6       | AHB-PCI Bridge (PCI Communication Space) Register Map                                | 427 |
| 10.4.7       | EPC Register Map                                                                     | 427 |
| 10.4.8       | AHB-EPC Bridge Register Map                                                          | 428 |
| 10.5 Registe | er Description                                                                       | 429 |
| 10.5.1       | OHCI Operation Register Description                                                  | 429 |
| 10.5         | .1.1 HCREVISION — HcRevision Register                                                | 429 |

|      | 10.5.1.2  | HCCONTROL — HcControl Register                                            | 430 |
|------|-----------|---------------------------------------------------------------------------|-----|
|      | 10.5.1.3  | HCCOMMANDSTATUS — HcCommandStatus Register                                | 432 |
|      | 10.5.1.4  | HCINTERRUPTSTATUS — HcInterruptStatus Register                            | 433 |
|      | 10.5.1.5  | HCINTERRUPTENABLE — HcInterruptEnable Register                            | 435 |
|      | 10.5.1.6  | HCINTERRUPTDISABLE — HcInterruptDisable Register                          | 436 |
|      | 10.5.1.7  | HCHCCA — HcHCCA Register                                                  | 437 |
|      | 10.5.1.8  | HCPERIODCURRENTED — HcPeriodicCurrentED Register                          | 437 |
|      | 10.5.1.9  | HCCONTROLHEADED — HcControlHeadED Register                                | 438 |
|      | 10.5.1.10 | HCCONTROLCURRENTED — HcControlCurrentED Register                          | 438 |
|      | 10.5.1.11 | HCBULKHEADED — HcBulkHeadED Register                                      | 439 |
|      | 10.5.1.12 | HCBULKCURRENTED — HcBulkCurrentED Register                                | 439 |
|      | 10.5.1.13 | HCDONEHEAD — HcDoneHead Register                                          | 440 |
|      | 10.5.1.14 | HCFMINTERVAL — HcFrameInterval Register                                   | 441 |
|      | 10.5.1.15 | HCFMREMAINING — HcFrameRemaining Register                                 | 442 |
|      | 10.5.1.16 | HCFMNUMBER — HcFrameNumber Register                                       | 442 |
|      | 10.5.1.17 | HCPERIODICSTART — HcPeriodicStart Register                                | 443 |
|      | 10.5.1.18 | HCLSTHRESHOLD — HcLSThreshold Register                                    | 443 |
|      | 10.5.1.19 | HCRHDESCRIPTORA — HcRhDescriptorA Register                                | 444 |
|      | 10.5.1.20 | HCRHDESCRIPTORB — HcRhDescriptorB Register                                | 445 |
|      | 10.5.1.21 | HCRHSTATUS — HcRhStatus Register                                          | 446 |
|      | 10.5.1.22 | HCRHPORTSTATUS1/ HCRHPORTSTATUS2 — HcRhPortStatus1/                       |     |
|      |           | HcRhPortStatus2 Register                                                  | 448 |
| 10.5 | .2 EHCI   | Operation Register Description                                            | 451 |
|      | 10.5.2.1  | CAPL_VERSION — HCIVERSION and CAPLENGTH Register (EHCI)                   |     |
|      | 10.5.2.2  | HCSPARAMS — HCSPARAMS Register                                            |     |
|      | 10.5.2.3  | HCCPARAMS — HCCPARAMS Register                                            |     |
|      | 10.5.2.4  | HCSP_PORTROUTE — HCSP_PORTROUTE Register                                  |     |
|      | 10.5.2.5  | USBCMD — USBCMD Register                                                  |     |
|      | 10.5.2.6  | USBSTS — USBSTS Register                                                  | 457 |
|      | 10.5.2.7  | USBINTR — USBINTR Register                                                | 459 |
|      | 10.5.2.8  | FRINDEX — Frame Index Register                                            | 460 |
|      | 10.5.2.9  | CTRLDSSEGMENT — CTRLDSSEGMENT Register                                    | 460 |
|      | 10.5.2.10 | PERIODICLISTBASE — PERIODICLISTBASE Register                              | 461 |
|      | 10.5.2.11 | ASYNCLISTADDR — ASYNCLISTADDR Register                                    | 461 |
|      | 10.5.2.12 | CONFIGFLAG — CONFIGFLAG Register                                          | 462 |
|      | 10.5.2.13 | PORTSC1/PORTSC2 — PORTSC1/PORTSC2 Register                                | 463 |
| 10.5 | .3 OHCI   | (PCI Configuration Space) Register Description                            | 466 |
|      | 10.5.3.1  | VID_DID — Device ID - Vendor ID (OHCI)                                    |     |
|      | 10.5.3.2  | CMND STS — Status - Command (OHCI)                                        |     |
|      | 10.5.3.3  | REVID_CC — Class Code - Revision ID (OHCI)                                |     |
|      | 10.5.3.4  | CLS_LT_HT_BIST — BIST - Header Type - Latency Timer - Cache Line Size     |     |
|      |           | (OHCI)                                                                    | 469 |
|      | 10.5.3.5  | BASEAD — OHCI Base Address                                                |     |
|      | 10.5.3.6  | SSVID_SSID — Subsystem ID - Subsystem Vendor ID (OHCI)                    | 471 |
|      | 10.5.3.7  | EROM_BASEAD — Expansion ROM Base Address (OHCI)                           |     |
|      | 10.5.3.8  | CAPPTR — Capability Pointer (OHCI)                                        |     |
|      | 10.5.3.9  | INTR_LINE_PIN — Max_Lat - Min_Gnt - Interrupt Pin - Interrupt Line (OHCI) |     |
|      | 10.5.3.10 | CAPID_NIP_PMCAP — Capability Identifier - Next Item Pointer - Power       |     |
|      |           | Management Capabilities (OHCI)                                            | 473 |
|      | 10.5.3.11 | PMC_STS_PMCSR — Power Management Control and Status - PMCSR Bridg         |     |
|      |           | Support Extensions (OHCI)                                                 | 474 |
|      | 10.5.3.12 | EXT1 — EXT1 Register (OHCI)                                               | 475 |
|      |           |                                                                           |     |

|        |                    | EXT2 — EXT2 Register (OHCI)                                               |      |
|--------|--------------------|---------------------------------------------------------------------------|------|
| 10.5.4 | EHCI (             | (PCI Configuration Space) Register Description                            | .478 |
|        | 0.5.4.1            | VID_DID — Device ID - Vendor ID (EHCI)                                    |      |
|        | 0.5.4.2            | CMND_STS — Status - Command (EHCI)                                        |      |
|        |                    | REVID_CC — Class Code - Revision ID (EHCI)                                |      |
|        | 0.5.4.4            | CLS_LT_HT_BIST — BIST - Header Type - Latency Timer - Cache Line Size     |      |
|        |                    | (EHCI)                                                                    | .481 |
| 10     | 0.5.4.5            | BASEAD — EHCI Base Address                                                |      |
| 10     | 0.5.4.6            | SSVID SSID — Subsystem ID - Subsystem Vendor ID (EHCI)                    | .482 |
| 10     | 0.5.4.7            | EROM_BASEAD — Expansion ROM Base Address (EHCI)                           | .483 |
| 10     |                    | CAPPTR — Capability Pointer (EHCI)                                        |      |
| 10     |                    | INTR_LINE_PIN — Max_Lat - Min_Gnt - Interrupt Pin - Interrupt Line (EHCI) |      |
| 10     |                    | CAPID_NIP_PMCAP — Capability Identifier - Next Item Pointer - Power       |      |
|        |                    | Management Capabilities (EHCI)                                            | .485 |
| 10     | 0.5.4.11           | PMC_STS_PMCSR — Power Management Control and Status - PMCSR Bridge        |      |
|        |                    | Support Extensions (EHCI)                                                 | .486 |
| 10     | 0.5.4.12           | SBRN_FLADJ_PW — SBRN - FLADJ - PORTWAKECAP                                | .487 |
|        |                    | EXT1 — EXT1 Register (EHCI)                                               |      |
| 10     | 0.5.4.14           | EXT2 — EXT2 Register (EHCI)                                               | .487 |
| 10     | 0.5.4.15           | UTMICTRL — USBPHY Operation Mode Control Register (EHCI)                  | .487 |
| 10.5.5 | AHB-P              | PCI Bridge (PCI Configuration Space) Register Description                 | .488 |
|        |                    | VID DID — Device ID - Vendor ID (AHB-PCI Bridge)                          |      |
|        |                    | CMND_STS — Status - Command (AHB-PCI Bridge)                              |      |
|        | 0.5.5.3            | REVID_CC — Class Code - Revision ID (AHB-PCI Bridge)                      |      |
|        | 0.5.5.4            | CLS LT HT BIST — BIST - Header Type - Latency Timer - Cache Line Size     |      |
| _      |                    | (AHB-PCI Bridge)                                                          | .491 |
| 10     | 0.5.5.5            | BASEAD — AHB-PCI Bridge Registers Base Address                            |      |
|        |                    | WIN1 BASEAD — PCI-AHB Window1 Base Address                                |      |
|        |                    | WIN2 BASEAD — PCI-AHB Window2 Base Address                                |      |
|        | 0.5.5.8            | SSVID_SSID — Subsystem ID - Subsystem Vendor ID (AHB-PCI Bridge)          |      |
|        | 0.5.5.9            | INTR LINE PIN — Max Lat - Min Gnt - Interrupt Pin - Interrupt Line        |      |
|        |                    | (AHB-PCI Bridge)                                                          | .495 |
| 10.5.6 | AHR-P              | CI Bridge (PCI Communication Space) Register Description                  |      |
|        |                    | PCIAHB WIN1 CTR — PCIAHB Window1 Control Register                         |      |
|        |                    | PCIAHB_WIN2_CTR — PCIAHB Window2 Control Register                         |      |
|        |                    | AHBPCI_WIN1_CTR — AHBPCI Window1 Control Register                         |      |
|        |                    | AHBPCI_WIN2_CTR — AHBPCI Window2 Control Register                         |      |
|        | 0.5.6.5            | PCI INT ENABLE — PCI Interrupt Enable Register                            |      |
|        | 0.5.6.6            | PCI_INT_STATUS — PCI Interrupt Status Register                            |      |
|        |                    | AHB BUS CTR — AHB Bus Control Register                                    |      |
|        | 0.5.6.8            | USBCTR — USB Control Register                                             |      |
|        | 0.5.6.9            | PCI_ARBITER_CTR — PCI Arbiter Control Register                            |      |
| 10.5.7 |                    | Register Description                                                      |      |
|        |                    | · ·                                                                       |      |
|        | 0.5.7.1            | USB_CONTROL — USB Control Register                                        |      |
|        |                    |                                                                           |      |
|        |                    | USB_ADDRESS — Frame Number & USB Address Register                         |      |
|        | 0.5.7.4            | TEST_CONTROL — Test Control Register                                      |      |
|        | 0.5.7.5<br>0.5.7.6 | SETUP_DATA1 Setup Data1 Register                                          |      |
|        | 0.5.7.6<br>0.5.7.7 | SETUP_DATA1 — Setup Data1 Register                                        |      |
|        |                    | USB_INT_ENA — USB Interrupt Enable Register                               |      |
| 11     | 0.0.1.0            | OOD_IIAI_FIAV — OOD IIITEITÜPE EHADIE VERISTEI                            | .014 |

| 10.5.    | .7.9    | EP0_CONTROL — EP0 Control Register                                 | .515 |
|----------|---------|--------------------------------------------------------------------|------|
| 10.5.    | .7.10   | EP0_STATUS — EP0 Status Register                                   | .517 |
| 10.5.    | .7.11   | EP0_INT_ENA — EP0 Interrupt Enable Register                        | .520 |
| 10.5.    | .7.12   | EP0_LENGTH — EP0 OUT Data Length Register                          | .522 |
| 10.5.    | .7.13   | EP0_READ — EP0 Read Register                                       | .522 |
| 10.5.    | .7.14   | EP0_WRITE — EP0 Write Register                                     | .523 |
| 10.5.    | .7.15   | EP[m]_CONTROL — EP[m] Control Register (m = 115)                   | .524 |
| 10.5.    | .7.16   | EP[m]_STATUS — EP[m] Status Register (m = 115)                     | .527 |
| 10.5.    | .7.17   | EP[m]_INT_ENA — EP[m] Interrupt Enable Register (m = 115)          | .531 |
| 10.5.    | .7.18   | EP[m]_DMA_CTRL — EP[m] DMA Control Register (m = 115)              | .532 |
| 10.5.    | .7.19   | EP[m]_PCKT_ADRS — EP[m] MaxPacket & BaseAddress Register (m = 115) | .534 |
| 10.5.    | .7.20   | EP[m]_LEN_DCNT — EP[m] Length & DMA Count Register (m = 115)       | .535 |
| 10.5.    | .7.21   | EP[m]_READ — EP[m] Read Register (m = 115)                         | .536 |
| 10.5.    | .7.22   | EP[m]_WRITE — EP[m] Write Register (m = 115)                       | .536 |
| 10.5.8   | AHB-E   | PC Bridge Register Description                                     | .537 |
| 10.5.    |         | AHBSCTR — AHB Slave Controller Configuration Register              |      |
| 10.5.    |         | AHBMCTR — AHB Master Controller Configuration Register             |      |
| 10.5.    |         | AHBBINT — AHB-EPC Bridge Interrupt Source Register                 |      |
| 10.5.    |         | AHBBINTEN — AHB-EPC Bridge Interrupt Enable Register               |      |
| 10.5.    |         | EPCTR — EPC and Transceiver Control Register                       |      |
| 10.5.    |         | USBSVER — USBf Version Register                                    |      |
| 10.5.    |         | USBSSCONF — Endpoint Configuration Register                        |      |
| 10.5.    |         | EP[m]DCR1 — Endpoint[m] DMA Setting Register1 (m = 115)            |      |
| 10.5.    |         | EP[m]DCR2 — Endpoint[m] DMA Setting Register2 (m = 115)            |      |
|          |         | EP[m]TADR — Endpoint[m] DMA Start Address Register (m = 115)       |      |
|          |         |                                                                    |      |
| -        |         |                                                                    |      |
|          |         | sing Function Controller Registers                                 |      |
| 10.6.    |         | Notes on Accessing EPC Registers                                   |      |
| 10.6.    | .1.2    | Notes on Accessing a Reserved Area                                 | .546 |
| 10.6.2   | Access  | sing Host Controller Registers                                     | .547 |
| 10.6.    | .2.1    | Accessing PCI Configuration Registers                              | .552 |
| 10.6.    | .2.2    | Accessing OHCI/EHCI Operational Registers                          | .552 |
| 10.6.3 F | Reset ( | Control                                                            | .553 |
|          |         | Reset Configuration                                                |      |
| 10.6.    |         | Reset System Diagram                                               |      |
|          |         | pts                                                                |      |
| 10.0.4   |         | Interrupt Control Registers                                        |      |
| 10.6.    |         | Interrupt Signal Overview                                          |      |
| 10.6.    |         | Interrupt Signal Clear Time                                        |      |
|          |         | , -                                                                |      |
|          |         | urrent Control and VBUS Control                                    |      |
| 10.6.    |         | Overcurrent Control                                                |      |
| 10.6.    |         | VBUS Control                                                       |      |
| 10.6.    |         | Overcurrent Detection Using PPON                                   |      |
| 10.6.    |         | PPON Setting Flow                                                  |      |
| 10.6.6   |         | Detection                                                          |      |
| 10.6.    |         | External Circuit for VBUS Detection                                |      |
| 10.6.    |         | VBUS Detection Part                                                |      |
| 10.6.    | .6.3    | VBUS Detection Flow                                                | .565 |
| 10.6.7 F | Power   | Management                                                         | .566 |
| 10.6.    |         | Power Management in the Host Controller                            |      |
|          |         | Power Management in the Function Controller                        |      |

|         | 10.    | .6.7.3 Direct Power-Down Feature                                          | 574 |
|---------|--------|---------------------------------------------------------------------------|-----|
|         | 10.    | .6.7.4 Notes on Suspend state transition                                  | 578 |
| 1       | 0.6.8  | USB Function Endpoints Configuration                                      |     |
|         |        | .6.8.1 Specifying the Base Address                                        |     |
| 1       | 0.6.9  | Operating Procedures                                                      |     |
|         |        | .6.9.1 Reset Sequence                                                     |     |
|         |        | .6.9.3 USB Host Transfer Flow                                             |     |
|         | 10.    | .6.9.4 Function Transfer Overview                                         |     |
| Costion | 11     | DMA Controller                                                            | 614 |
| Section |        | DMA Controller                                                            |     |
| 11.1    |        | view                                                                      |     |
| 11.2    | Ū      | al Interfaces                                                             |     |
| 11.3    | Basic  | Definitions                                                               | 616 |
| 11.4    | Regis  | ster Map                                                                  | 619 |
| 1       | 1.4.1  | Register Map of DMAC1                                                     | 619 |
| 1       | 1.4.2  | Register Map of DMAC2                                                     | 620 |
| 11.5    | Regis  | ster Description                                                          | 621 |
| 1       | 1.5.1  | SAR[n] — Source Address Register for Channel [n] (n = 07)                 | 621 |
| 1       | 1.5.2  | DAR[n] — Destination Address Register for Channel [n] (n = 07)            | 622 |
| 1       | 1.5.3  | LLP[n] — Linked List Pointer Register for Channel [n] (n = 07)            | 623 |
| 1       | 1.5.4  | CTL[n] — Control Register for Channel [n] (n = 07)                        | 624 |
| 1       | 1.5.5  | SSTAT[n] — Source Status Register for Channel [n] (n = 07)                | 627 |
| 1       | 1.5.6  | DSTAT[n] — Destination Status Register for Channel [n] (n = 07)           | 628 |
| 1       | 1.5.7  | SSTATAR[n] — Source Status Address Register for Channel [n] (n = 07)      | 629 |
| 1       | 1.5.8  | DSTATAR[n] — Destination Status Address Register for Channel [n] (n = 07) | 630 |
| 1       | 1.5.9  | CFG[n] — Configuration Register for Channel [n] (n = 07)                  | 631 |
| 1       | 1.5.10 | SGR[n] — Source Gather Register for Channel [n] (n = 07)                  | 634 |
| 1       | 1.5.11 | DSR[n] — Destination Scatter Register for Channel [n] (n = 07)            | 635 |
| 1       | 1.5.12 | RawTfr — Raw Status for IntTfr Interrupt Register                         | 636 |
| 1       | 1.5.13 | RawBlock — Raw Status for IntBlock Interrupt Register                     | 637 |
| 1       | 1.5.14 | RawSrcTran — Raw Status for IntSrcTran Interrupt Register                 | 638 |
| 1       | 1.5.15 | RawDstTran — Raw Status for IntDstTran Interrupt Register                 | 639 |
| 1       | 1.5.16 | RawErr — Raw Status for IntErr Interrupt Register                         | 640 |
| 1       | 1.5.17 | StatusTfr — Status for IntTfr Interrupt Register                          | 641 |
| 1       | 1.5.18 | StatusBlock — Status for IntBlock Interrupt Register                      | 642 |
| 1       | 1.5.19 | StatusSrcTran — Status for IntSrcTran Interrupt Register                  | 643 |
| 1       | 1.5.20 | StatusDstTran — Status for IntDstTran Interrupt Register                  | 644 |
| 1       | 1.5.21 | StatusErr — Status for IntErr Interrupt Register                          | 645 |
| 1       | 1.5.22 | MaskTfr — Mask for IntTfr Interrupt Register                              | 646 |
| 1       | 1.5.23 | MaskBlock — Mask for IntBlock Interrupt Register                          | 647 |
| 1       | 1.5.24 | MaskSrcTran — Mask for IntSrcTran Interrupt Register                      | 648 |
| 1       | 1.5.25 | MaskDstTran — Mask for IntDstTran Interrupt Register                      | 649 |
| 1       | 1.5.26 | MaskErr — Mask for IntErr Interrupt Register                              | 650 |

| 11.5.27    | ClearTfr — Clear for IntTfr Interrupt Register                | 651 |
|------------|---------------------------------------------------------------|-----|
| 11.5.28    | ClearBlock — Clear for IntBlock Interrupt Register            | 652 |
| 11.5.29    | ClearSrcTran — Clear for IntSrcTran Interrupt Register        | 653 |
| 11.5.30    | ClearDstTran — Clear for IntDstTran Interrupt Register        | 654 |
| 11.5.31    | ClearErr — Clear for IntErr Interrupt Register                | 655 |
| 11.5.32    | StatusInt — Combined Interrupt Status Register                | 656 |
| 11.5.33    | ReqSrcReg — Source Software Transaction Request Register      | 657 |
| 11.5.34    | ReqDstReg — Destination Software Transaction Request Register | 658 |
| 11.5.35    | SglRqSrcReg — Single Source Transaction Request Register      | 659 |
| 11.5.36    | SglRqDstReg — Single Destination Transaction Request Register | 660 |
| 11.5.37    | LstSrcReg — Last Source Transaction Request Register          | 661 |
| 11.5.38    | LstDstReg — Last Destination Transaction Request Register     | 662 |
| 11.5.39    | DmaCfgReg — DMA Configuration Register                        | 663 |
| 11.5.40    | ChEnReg — DMA Controller Channel Enable Register              | 664 |
| 11.5.41    | DmaldReg — DMA ID Register                                    | 665 |
| 11.5.42    | DmaTestReg — DMA Controller Test Register                     | 666 |
| 11.6 Oper  | ation                                                         | 667 |
| 11.6.1     | DMA Transfer Mode                                             | 667 |
|            | .6.1.1 Flow Controller and Transfer Type                      |     |
|            | .6.1.2 Block Chaining Using Linked Lists                      |     |
|            | .6.1.3 Basic Interface Definitions                            |     |
|            | .6.1.4 Transaction Examples                                   |     |
| 11.6.2     | DMA Request Allocation                                        |     |
| 11.6.3     | Illegal Register Access                                       |     |
| 11.0.0     | mogal register, recode                                        |     |
| Section 12 | RTC                                                           | 682 |
| 12.1 Over  | view                                                          | 682 |
| 12.2 Signa | al Interfaces                                                 | 683 |
| ŭ          | ster Map                                                      |     |
| J          | ster Description                                              |     |
| 12.4 Regis | RTCA0CTL0 — RTC Control Register 0                            |     |
| 12.4.1     | RTCA0CTL0 — RTC Control Register 1                            |     |
| 12.4.2     | RTCA0CTL1 — RTC Control Register 2                            |     |
| 12.4.3     | RTCA0SUBC — RTC Sub Count Register                            |     |
| 12.4.4     | RTCA0SRBU — RTC Sub Count Register Read Buffer                |     |
| 12.4.6     | RTCA0SEC — RTC Sec Count Buffer Register                      |     |
| 12.4.7     | RTCA0MIN — RTC Min Count Buffer Register                      |     |
| 12.4.7     | RTCA0HOUR — RTC Hour Count Buffer Register                    |     |
| 12.4.6     | RTCA0WEEK — RTC Hour Count Buffer Register                    |     |
| 12.4.9     | RTCA0DAY — RTC Day Count Buffer Register                      |     |
|            |                                                               |     |
| 12.4.11    | RTCA0WFAR BTC Voor Count Buffer Register                      |     |
| 12.4.12    | RTCA0YEAR — RTC Year Count Buffer Register                    | 694 |

| 12.4.13 RTCA0TIME — RTC Time Set Register                                                | 695 |
|------------------------------------------------------------------------------------------|-----|
| 12.4.14 RTCA0CAL — RTC Calendar Set Register                                             | 695 |
| 12.4.15 RTCA0SUBU — RTC Clock Error Correction Register                                  | 696 |
| 12.4.16 RTCA0SCMP — RTC Sub Count Compare Register                                       | 697 |
| 12.4.17 RTCA0ALM — RTC Alarm Min Set Register                                            | 698 |
| 12.4.18 RTCA0ALH — RTC Alarm Hour Set Register                                           | 698 |
| 12.4.19 RTCA0ALW — RTC Alarm Week Set Register                                           |     |
| 12.4.20 RTCA0SECC — RTC Second Count Register                                            | 700 |
| 12.4.21 RTCA0MINC — RTC Minute Count Register                                            | 700 |
| 12.4.22 RTCA0HOURC — RTC Hour Count Register                                             | 701 |
| 12.4.23 RTCA0WEEKC — RTC Week Count Register                                             | 701 |
| 12.4.24 RTCA0DAYC — RTC Day Count Register                                               | 702 |
| 12.4.25 RTCA0MONC — RTC Month Count Register                                             | 702 |
| 12.4.26 RTCA0YEARC — RTC Year Count Register                                             | 703 |
| 12.4.27 RTCA0TIMEC — RTC Time Count Register                                             | 703 |
| 12.4.28 RTCA0CALC — RTC Calendar Count Register                                          | 704 |
| 12.4.29 RTCA0TCR — RTC Test Register                                                     | 704 |
| 12.5 Operation                                                                           | 705 |
| 12.5.1 Programming RTC                                                                   |     |
| 12.5.1.1 Initial Setting                                                                 |     |
| 12.5.1.2 Writing to Clock Counters While Clock Counter Operation is Enabled              |     |
| 12.5.1.3 Reading Clock Counters While Clock Counter Operation is Enabled                 |     |
| 12.5.1.4 Reading RTCA0SRBU While Clock Counter Operation is Enabled                      |     |
| 12.5.1.6 Writing to RTCA0SUBU Clock Counter Operation                                    |     |
| 12.5.1.7 Writing to RTCA0SCMP During Clock Counter Operation                             |     |
| 12.5.1.8 Changing the Setting of Fixed Interval Interrupt During Clock Counter Operation |     |
| 12.5.1.9 Changing Alarm Setting During Clock Counter Operation                           |     |
| 12.5.2 RTC Backup Mode                                                                   |     |
| 12.5.3 Clock Error Correction                                                            | 717 |
| Section 13 Watchdog                                                                      | 710 |
| •                                                                                        |     |
| 13.1 Overview                                                                            |     |
| 13.2 Signal Interfaces                                                                   | 719 |
| 13.3 Register Map                                                                        | 720 |
| 13.3.1 Register Map CA7 Processor0 Watchdog                                              | 720 |
| 13.3.2 Register Map CA7 Processsor1 Watchdog                                             | 720 |
| 13.3.3 Register Map CM3 Watchdog                                                         | 720 |
| 13.4 Register Description                                                                | 721 |
| 13.4.1 CTRL_RETRIGGER — Control and Retrigger Register                                   | 721 |
| 13.5 Operation                                                                           | 722 |
|                                                                                          |     |
| Section 14 Mailbox (IPCM)                                                                | 723 |
| 14.1 Overview                                                                            | 723 |

| 14.2 | Sig    | nal Interfaces                                                   | 723 |
|------|--------|------------------------------------------------------------------|-----|
| 14.3 | Reg    | gister Map                                                       | 724 |
| 14.4 | Reg    | gister Description                                               | 725 |
|      | 14.4.1 | IPCM[n]SOURCE — Mailbox[n] Source Register (n = 02)              | 725 |
|      | 14.4.2 | IPCM[n]DSET — Mailbox[n] Destination Set Register (n = 02)       | 726 |
|      | 14.4.3 | IPCM[n]DCLEAR — Mailbox[n] Destination Clear Register (n = 02)   | 727 |
|      | 14.4.4 | IPCM[n]DSTATUS — Mailbox[n] Destination Status Register (n = 02) | 728 |
|      | 14.4.5 | IPCM[n]MODE — Mailbox[n] Mode Register (n = 02)                  | 729 |
|      | 14.4.6 | IPCM[n]MSET — Mailbox[n] Mask Set Register (n = 02)              | 729 |
|      | 14.4.7 | IPCM[n]MCLEAR — Mailbox[n] Mask Clear Register (n = 02)          | 730 |
|      | 14.4.8 | IPCM[n]MSTATUS — Mailbox[n] Mask Status Register (n = 02)        | 730 |
|      | 14.4.9 | IPCM[n]SEND — Mailbox[n] Send Register (n = 02)                  | 731 |
|      | 14.4.1 | D IPCM[n]DR[k] — Mailbox[n] Data Register [k] (n = 02) (k = 06)  | 732 |
|      | 14.4.1 | 1 IPCMMIS[n] — Masked Interrupt[n] Status Register (n = 02)      | 732 |
|      | 14.4.1 | 2 IPCMRIS[n] — Raw Interrupt[n] Status Register (n = 02)         | 733 |
|      | 14.4.1 | 3 IPCMCFGSTAT — Configuration Status Register                    | 733 |
|      | 14.4.1 | 4 IPCMTCR — Integration Test Control Register                    | 734 |
|      | 14.4.1 | 5 IPCMTOR — Integration Test Output Register                     | 734 |
| 14.5 | Оре    | eration                                                          | 735 |
|      | 14.5.1 | Channel ID                                                       | 735 |
|      | 14.5.2 | Defining Source Core                                             | 735 |
|      | 14.5.3 | Defining Destination Core                                        | 735 |
|      | 14.5.4 | Using the Mailbox Mask Register                                  | 736 |
|      | 14.5.5 | Using the Mailbox Send Register                                  | 736 |
|      | 14.5.6 | Mailbox Data Registers                                           | 736 |
|      | 14.5.7 | Setting Mode                                                     | 736 |
|      | 14.5.8 | Interrupts and Status Registers                                  | 737 |
|      | 14.5.9 | Configuration Status Register                                    | 738 |
|      | 14.5.1 | ) Usage Constraints                                              | 738 |

#### Section 1 CPU

#### 1.1 Arm Cortex-A7

#### 1.1.1 Overview

Cortex®-A7 processors in RZ/N1 coupled with subsystem composed of FPU, ETM, debug function, L1 cache, L2 cache, and GIC are integrated inside "Cortex-A7 Core Subsystem".

More information of Cortex-A7 can be obtained from:

https://developer.arm.com/products/processors/cortex-a/cortex-a7

The figures below show the interfaces of the Arm® Cortex-A7 core and its connections to other blocks.



Figure 1.1 Arm Cortex-A7 Core Interfaces and Connections

The Cortex-A7 processors are configured with following features:

- Arm Cortex-A7 revision: r0p5
- L1 cache 16 KB (instruction)/16 KB (data)
- L2 cache (RZ/N1D: 256 KB, RZ/N1S: 128 KB)
- FPU revision VFPv4-D16
- MMU
- Integrated GIC
- Hardware coherent caches
  - The cache coherency is not going down to the NoC.
- Frequency: up to 500 MHz

- Target Frequency depends on NoC frequency
  - Can be dynamically changed by PWRCTRL\_CA7DIV register
  - Clkin variation with NoC (x1): Up to 125 MHz
  - Clkin variation with NoC (x2): Up to 250 MHz
  - Clkin variation with NoC (x4): Up to 500 MHz

See more detail in Section 3.5, Clock Frequency Scaling in the RZ/N1D Group, RZ/N1S Group, RZ/N1L Group User's Manual: System Introduction, Multiplexing, Electrical and Mechanical Information.

- Generic timer: 6.25 MHz
- Configuration Base Address Register (CBAR) value: 4410\_0000h
- Not support for TrustZone

Only secure world (default) is available.

# 1.1.2 Usage Notes

Cortex-A7 frequency can be 1 or 2 or 4 times of NoC frequency. The PWRCTRL\_CA7DIV register controls the divider setting value and it can be written by Cortex-A7.

Ex.) Changing the divider setting value from 2 (default) to 4 (= NoC frequency)

Step 1: Wait if PWRCTRL CA7DIV.BUSY = 1

Step 2: Write 8000 0004h to PWRCTRL CA7DIV

Step 3: Wait if PWRCTRL\_CA7DIV.BUSY = 1

#### 1.2 Arm Cortex-M3

#### 1.2.1 Overview

The Cortex-M3 is a low-power processor that features low interrupt latency, and low-cost debug. It is optimal for deeply embedded applications that require optimal interrupt response features and supports Armv7-M Thumb<sup>®</sup> instruction set.

More information of Cortex-M3 can be obtained from:

https://developer.arm.com/products/processors/cortex-m/cortex-m3

The Cortex-M3 processors is configured with following features:

- Arm Cortex-M3 revision: r2p1
- ITM, TPIU, FPB, DWT, ETM debug function supported
- Target Frequency depends on NoC frequency

Clkin variation: From 15.625 MHz (Divider: 16) to 125 MHz (Divider: 2)

• Memory Protection Unit (MPU) supported

#### 1.2.2 Signal Interface

|                 | Input  |                                                                                           |
|-----------------|--------|-------------------------------------------------------------------------------------------|
| Signal Name     | Output | Description                                                                               |
| Clock           |        |                                                                                           |
| CM3_FCLK        | Input  | Cortex-M3 core clock                                                                      |
| CM3_HCLK        | Input  | Cortex-M3 core and AHB clock                                                              |
| CM3_STCLK       | Input  | Systick clock. Fixed 6.25MHz, no clock gating                                             |
| Related Clock   |        |                                                                                           |
| RINBUS_HCLK     | _      | R-IN Engine clock. Since Cortex-M3 belongs to R-IN Engine, this clock should be supplied. |
| External Signal |        |                                                                                           |
| NMI_CORTEXM3    | input  | Non-maskable Interrupt, active high                                                       |

#### 1.2.3 Usage Notes

In case of accessing registers, please set the "Device" or "Strongly Ordered" memory attribute. Otherwise, a register which has a read-clear bit may result in being cleared unintentionally by prefetch operation.

Following function area can be accessed from Cortex-M3 only.

• HW-RTOS resource

#### 1.2.3.1 Restriction

Since NoC (Network-on-Chip) does not support Lock access, the "bit-banding" feature of Cortex-M3 via NoC does not result in real atomic accesses. Software is responsible for the consequences.

For details of the restrictions on Cortex-M3 core, please refer to above Arm website.

# Section 2 Network-On-Chip

#### 2.1 Overview

On-chip connectivity for SoC function blocks implementing combinations of internal bus protocols and Clock gating management.

#### 2.2 Features

Network-On-Chip has the following features:

- Clock gating is built around NoC and Clock Controller allowing the following when it is possible:
  - Disconnect & Connect services
  - Bus error management on disconnect port.
  - Clock gating
- Can be dynamically changed by dedicated integer divider
  - Clkin variation: From 15.625 MHz (Divider: 16) to 125 MHz (Divider: 2)
- Secure/Not Secure Access management
- · Priority/Round Robin Arbitration Combination scheme to ensure high memory bandwidth utilization

#### **CAUTION**

- The cache coherency is not going down to the NoC. This feature is only managed between L1 & L2 cache of Cortex-A7
- No LOCKED access supported:

Therefore the "bit-banding" feature of Cortex-M3 via NoC does not result in real atomic accesses. Software is responsible for the consequences.

Table 2.1 RZ/N1D Bus Connection Map

| Bus Master                                                          | Cortex-  | Cortex-  | NAND  | SDIO1 | USBh |          |          | GMAC1    | MSEBI |      | Core<br>Sight | Core<br>Sight |
|---------------------------------------------------------------------|----------|----------|-------|-------|------|----------|----------|----------|-------|------|---------------|---------------|
| Bus Slave                                                           | A7       | M3       | Flash | SDIO1 | USBf | DMAC1    | DMAC2    | GMAC2    | Slave | LCDC | AHB           | ETR           |
| DDR2/3 (mem) port0*1                                                | ✓        |          |       |       | ✓    |          |          |          |       |      | ✓             | ✓             |
| DDR2/3 (mem) port1*1                                                |          |          |       |       |      |          |          | <b>✓</b> | ✓     |      |               |               |
| DDR2/3 (mem) port2*1                                                |          |          | ✓     | ✓     |      | <b>√</b> |          |          |       |      |               |               |
| DDR2/3 (mem) port3*1                                                |          | ✓        |       |       |      |          | <b>√</b> |          |       | ✓    |               |               |
| DDR2/3 (reg)                                                        | ✓        | ✓        |       |       |      |          |          |          |       |      | ✓             |               |
| 2MB SRAM (mem)*2                                                    | ✓        | ✓        | ✓     | ✓     | ✓    | ✓        | ✓        | ✓        | ✓     | ✓    | ✓             | ✓             |
| QSPI1 (mem)                                                         | ✓        | ✓        |       |       |      |          | ✓        |          |       |      | ✓             |               |
| QSPI1 (reg)                                                         | ✓        | ✓        |       |       |      |          |          |          |       |      | ✓             |               |
| NAND Flash                                                          | ✓        | ✓        |       |       |      |          |          |          |       |      | ✓             |               |
| SDIO1/SDIO2                                                         | ✓        | ✓        |       |       |      |          |          |          |       |      | ✓             |               |
| USBh/USBf                                                           | ✓        | ✓        |       |       |      |          |          |          |       |      | ✓             |               |
| DMAC1/DMAC2                                                         | ✓        | ✓        |       |       |      |          |          |          |       |      | ✓             |               |
| R-IN Engine Accessory<br>Register<br>Ethernet Accessory<br>Register | <b>~</b> | <b>√</b> |       |       |      |          |          |          |       |      | <b>*</b>      |               |
| GMAC1/GMAC2                                                         | ✓        | ✓        |       |       |      |          |          |          |       |      | ✓             |               |
| A5PSW                                                               | ✓        | ✓        |       |       |      |          |          |          |       |      | ✓             |               |
| HSR                                                                 | ✓        | ✓        |       |       |      |          |          |          |       |      | ✓             |               |
| ETHERCAT/SERCOSIII                                                  | ✓        | ✓        |       |       |      | ✓        | ✓        |          |       |      | ✓             |               |
| MSEBIM/MSEBIS                                                       | ✓        | ✓        |       |       |      |          | ✓        |          |       |      | ✓             |               |
| Peripheral Group1/2/3/4                                             | ✓        | ✓        |       |       |      | <b>√</b> | ✓        |          | ✓     |      | <b>√</b>      |               |
| Mailbox                                                             | ✓        | ✓        |       |       |      |          |          |          |       |      | <b>√</b>      |               |
| Peripheral Group0                                                   | ✓        | ✓        |       |       |      |          | ✓        |          |       |      | <b>√</b>      |               |
| System Control<br>Watchdog for CA7/CM3                              | <b>√</b> | <b>√</b> |       |       |      |          |          |          |       |      | ~             |               |
| RTC                                                                 | ✓        | ✓        |       |       |      |          |          |          |       |      | ✓             |               |
| ROM                                                                 | ✓        |          |       |       |      |          |          |          |       |      |               |               |
| CoreSight                                                           | ✓        | ✓        |       |       |      |          |          |          |       |      | ✓             |               |

Note 1. Each port can access the same address area (Up to 2 GB address space).

Note 2. There is a port for instruction and data respectively.

Table 2.2 RZ/N1S Bus Connection Map

| Bus Master                                                          |               |               |               | 00104          | LIGHT        |       |       | 011101         | MOEDI          |      | Core         | Core         |
|---------------------------------------------------------------------|---------------|---------------|---------------|----------------|--------------|-------|-------|----------------|----------------|------|--------------|--------------|
| Bus Slave                                                           | Cortex-<br>A7 | Cortex-<br>M3 | NAND<br>Flash | SDIO1<br>SDIO2 | USBh<br>USBf | DMAC1 | DMAC2 | GMAC1<br>GMAC2 | MSEBI<br>Slave | LCDC | Sight<br>AHB | Sight<br>ETR |
| 4MB SRAM (mem)*1                                                    | ✓             | ✓             | ✓             | ✓              | ✓            | ✓     | ✓     | ✓              | ✓              | ✓    | ✓            | ✓            |
| 4MB SRAM_CTRL (reg)                                                 | ✓             | ✓             |               |                |              |       |       |                |                |      | ✓            |              |
| 2MB SRAM (mem)*2                                                    | ✓             | ✓             | ✓             | ✓              | ✓            | ✓     | ✓     | ✓              | ✓              | ✓    | ✓            | ✓            |
| QSPI1/QSPI2 (mem)                                                   | ✓             | ✓             |               |                |              |       | ✓     |                |                |      | ✓            |              |
| QSPI1/QSPI2 (reg)                                                   | ✓             | ✓             |               |                |              |       |       |                |                |      | ✓            |              |
| NAND Flash                                                          | ✓             | ✓             |               |                |              |       |       |                |                |      | ✓            |              |
| SDIO1/SDIO2                                                         | ✓             | ✓             |               |                |              |       |       |                |                |      | ✓            |              |
| USBh/USBf                                                           | ✓             | ✓             |               |                |              |       |       |                |                |      | ✓            |              |
| DMAC1/DMAC2                                                         | ✓             | ✓             |               |                |              |       |       |                |                |      | ✓            |              |
| R-IN Engine Accessory<br>Register<br>Ethernet Accessory<br>Register | ✓             | <b>√</b>      |               |                |              |       |       |                |                |      | <b>~</b>     |              |
| GMAC1/GMAC2                                                         | ✓             | ✓             |               |                |              |       |       |                |                |      | ✓            |              |
| A5PSW                                                               | ✓             | <b>✓</b>      |               |                |              |       |       |                |                |      | <b>✓</b>     |              |
| ETHERCAT/SERCOSIII                                                  | ✓             | ✓             |               |                |              | ✓     | ✓     |                |                |      | ✓            |              |
| MSEBIM/MSEBIS                                                       | ✓             | ✓             |               |                |              |       | ✓     |                |                |      | ✓            |              |
| Peripheral Group1/2/3/4                                             | ✓             | ✓             |               |                |              | ✓     | ✓     |                | <b>✓</b>       |      | <b>✓</b>     |              |
| Mailbox                                                             | ✓             | ✓             |               |                |              |       |       |                |                |      | ✓            |              |
| Peripheral Group0                                                   | ✓             | ✓             |               |                |              |       | ✓     |                |                |      | ✓            |              |
| System Control<br>Watchdog for CA7/CM3                              | <b>√</b>      | <b>✓</b>      |               |                |              |       |       |                |                |      | <b>*</b>     |              |
| RTC                                                                 | ✓             | ✓             |               |                |              |       |       |                |                |      | ✓            |              |
| ROM                                                                 | ✓             |               |               |                |              |       |       |                |                |      |              |              |
| CoreSight                                                           | ✓             | ✓             |               |                |              |       |       |                |                |      | ✓            |              |

Note 1. There is a memory bank with independent port every 1 MB.

Note 2. There is a port for instruction and data respectively.

Table 2.3 RZ/N1L Bus Connection Map

| Bus Master Bus Slave                                                | Cortex-<br>M3 | NAND<br>Flash | SDIO1 | USBh<br>USBf | DMAC1    | DMAC2    | GMAC1 | MSEBI<br>Slave | Core<br>Sight<br>AHB | Core<br>Sight<br>ETR |
|---------------------------------------------------------------------|---------------|---------------|-------|--------------|----------|----------|-------|----------------|----------------------|----------------------|
| 4MB SRAM (mem)*1                                                    | ✓             | ✓             | ✓     | ✓            | ✓        | ✓        | ✓     | ✓              | ✓                    | ✓                    |
| 4MB SRAM_CTRL (reg)                                                 | ✓             |               |       |              |          |          |       |                | <b>✓</b>             |                      |
| 2MB SRAM (mem)*2                                                    | ✓             | ✓             | ✓     | ✓            | ✓        | ✓        | ✓     | ✓              | ✓                    | ✓                    |
| QSPI1 (mem)                                                         | ✓             |               |       |              |          | <b>✓</b> |       |                | <b>✓</b>             |                      |
| QSPI1 (reg)                                                         | ✓             |               |       |              |          |          |       |                | <b>✓</b>             |                      |
| NAND Flash                                                          | ✓             |               |       |              |          |          |       |                | ✓                    |                      |
| SDIO1/SDIO2                                                         | ✓             |               |       |              |          |          |       |                | <b>✓</b>             |                      |
| USBh/USBf                                                           | ✓             |               |       |              |          |          |       |                | ✓                    |                      |
| DMAC1/DMAC2                                                         | ✓             |               |       |              |          |          |       |                | ✓                    |                      |
| R-IN Engine Accessory<br>Register<br>Ethernet Accessory<br>Register | <b>~</b>      |               |       |              |          |          |       |                | <b>✓</b>             |                      |
| GMAC1<br>GMAC2                                                      | <b>√</b>      |               |       |              |          |          |       |                | <b>V</b>             |                      |
| A5PSW                                                               | ✓             |               |       |              |          |          |       |                | ✓                    |                      |
| ETHERCAT/SERCOSIII                                                  | ✓             |               |       |              | ✓        | ✓        |       |                | ✓                    |                      |
| MSEBIS                                                              | ✓             |               |       |              |          | ✓        |       |                | ✓                    |                      |
| Peripheral Group1/2/3/4                                             | ✓             |               |       |              | <b>✓</b> | ✓        |       | <b>✓</b>       | ✓                    |                      |
| Peripheral Group0                                                   | ✓             |               |       |              |          | ✓        |       |                | ✓                    |                      |
| System Control<br>Watchdog for CM3                                  | ✓             |               |       |              |          |          |       |                | <b>√</b>             |                      |
| CoreSight                                                           | ✓             |               |       |              |          |          |       |                | <b>✓</b>             |                      |

Note 1. There is a memory bank with independent port every 1 MB.

Note 2. There is a port for instruction and data respectively.

# Section 3 2MB SRAM

All RZ/N1 have 2MB SRAM in R-IN Engine block. It consists of 2 of 1MB SRAMs with ECC function and can be accessed from CPU and some circuits.

#### 3.1 Overview

Table 3.1 2MB SRAM Summary

| Item           | Description                                              |  |  |  |  |
|----------------|----------------------------------------------------------|--|--|--|--|
| RAM capacity   | 2 Mbytes (Instruction RAM: 1 Mbyte, Data RAM: 1 Mbyte)   |  |  |  |  |
| RAM address    | Instruction RAM                                          |  |  |  |  |
|                | 0400 0000h to 040F FFFFh                                 |  |  |  |  |
|                | Data RAM                                                 |  |  |  |  |
|                | 2000 0000h to 200F FFFFh                                 |  |  |  |  |
| Error checking | Correction of single error and detection of double error |  |  |  |  |
|                | Self-Testing of the ECC Circuit                          |  |  |  |  |
|                | Interrupt management                                     |  |  |  |  |

# 3.2 Signal Interfaces

|              | Input  |                                                                                                   |
|--------------|--------|---------------------------------------------------------------------------------------------------|
| Signal Name  | Output | Description                                                                                       |
| Clock        |        |                                                                                                   |
| SRAM2MB_HCLK | Input  | Internal bus clock (AHB), no clock gating                                                         |
| RINBUS_HCLK  | Input  | R-IN Engine local bus clock, commonly used for Cortex-M3, HW-RTOS, R-IN Engine Accessory register |
| Interrupt    |        |                                                                                                   |
| ECC_2MB_Int  | Output | Pulse sensitive interrupt, Active High                                                            |

# 3.3 Register Map

2MB SRAM registers can be accessed by 32-bit units.

For accessing this module registers, RINBUS\_HCLK must be enabled and RIN BUS sub system must not have been reset. The detail is described on Register Description of PWRCTRL\_RINCTRL.

#### NOTE

RAMEDC and RAMEEC registers are write protected by RAMPCMD.

Table 3.2 2MB SRAM Control Register List

| Address    | Register Symbol | Register Name                                 |
|------------|-----------------|-----------------------------------------------|
| 400F 3000h | RAMPCMD         | RAM_SYS Protect Command Register              |
| 400F 3100h | RAMEDC          | RAM_SYS ECC Decoder Config Register           |
| 400F 3104h | RAMEEC          | RAM_SYS ECC Encoder Config Register           |
| 400F 3108h | RAMDBEST        | RAM_SYS Double Bit ECC Error Status Register  |
| 400F 310Ch | RAMDBEAD        | RAM_SYS Double Bit ECC Error Address Register |
| 400F 3110h | RAMDBECNT       | RAM_SYS Double Bit ECC Error Counter Register |

# 3.4 Register Description

# 3.4.1 RAMPCMD — RAM\_SYS Protect Command Register

Please refer to **Section 3.6, Usage Notes**, for more detail.

Address: 400F 3000h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16         |
|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-------------|
|                   | _   | _   | -   | _   | -   | _   | -   | _   | -   | _   | -   | -   | -   | _   |     | _           |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0           |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0          |
|                   | _   |     | ı   | ı   | -   |     | -   |     |     | _   | ı   |     | ı   |     |     | PROTR<br>EL |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0           |

Table 3.3 RAMPCMD Register Contents

| Bit Position | Bit Name | Function                                                   | R/W |
|--------------|----------|------------------------------------------------------------|-----|
| b31 to b1    | Reserved |                                                            | R   |
| b0           | PROTREL  | Write access to protection registers are permitted.        | R/W |
|              |          | 1: Write access to protection registers are permitted.     |     |
|              |          | 0: Write access to protection registers are not permitted. |     |

# 3.4.2 RAMEDC — RAM\_SYS ECC Decoder Config Register

RAMECC register is write protected by RAMPCMD.

Please refer to **Section 3.6, Usage Notes**, for more detail.

Address: 400F 3100h



Table 3.4 RAMEDC Register Contents

| Bit Position | Bit Name   | Function            | R/W |
|--------------|------------|---------------------|-----|
| b31 to b1    | Reserved   |                     | R   |
| b0           | ECC_ENABLE | ECC decoder enable. | R/W |
|              |            | 0: Disable          |     |
|              |            | 1: Enable           |     |

# 3.4.3 RAMEEC — RAM\_SYS ECC Encoder Config Register

RAMEEC register is write protected by RAMPCMD.

Please refer to **Section 3.6, Usage Notes**, for more detail.

Address: 400F 3104h



Table 3.5 RAMEEC Register Contents (1/2)

| Bit Position | Bit Name   | Function                                                                                   | R/W |
|--------------|------------|--------------------------------------------------------------------------------------------|-----|
| b31 to b20   | Reserved   |                                                                                            | R   |
| b19 to b16   | Reserved   | Keep the initial value.                                                                    | R/W |
| b15          | DBE_DIST15 | ECC error injection enable of Data RAM BANK1 WAY3.  0: Disable  1: Enable                  | R/W |
| b14          | DBE_DIST14 | ECC error injection enable of Data RAM BANK1 WAY2.  Same bit function as DBE_DIST15        | R/W |
| b13          | DBE_DIST13 | ECC error injection enable of Data RAM BANK1 WAY1.  Same bit function as DBE_DIST15        | R/W |
| b12          | DBE_DIST12 | ECC error injection enable of Data RAM BANK1 WAY0.  Same bit function as DBE_DIST15        | R/W |
| b11          | DBE_DIST11 | ECC error injection enable of Data RAM BANK0 WAY3.  Same bit function as DBE_DIST15        | R/W |
| b10          | DBE_DIST10 | ECC error injection enable of Data RAM BANK0 WAY2.  Same bit function as DBE_DIST15        | R/W |
| b9           | DBE_DIST9  | ECC error injection enable of Data RAM BANK0 WAY1.  Same bit function as DBE_DIST15        | R/W |
| b8           | DBE_DIST8  | ECC error injection enable of Data RAM BANK0 WAY0.  Same bit function as DBE_DIST15        | R/W |
| b7           | DBE_DIST7  | ECC error injection enable of Instruction RAM BANK1 WAY3.  Same bit function as DBE_DIST15 | R/W |
| b6           | DBE_DIST6  | ECC error injection enable of Instruction RAM BANK1 WAY2.  Same bit function as DBE_DIST15 | R/W |
| b5           | DBE_DIST5  | ECC error injection enable of Instruction RAM BANK1 WAY1.  Same bit function as DBE_DIST15 | R/W |
| b4           | DBE_DIST4  | ECC error injection enable of Instruction RAM BANK1 WAY0.  Same bit function as DBE_DIST15 | R/W |
| b3           | DBE_DIST3  | ECC error injection enable of Instruction RAM BANK0 WAY3.  Same bit function as DBE_DIST15 | R/W |
| b2           | DBE_DIST2  | ECC error injection enable of Instruction RAM BANK0 WAY2.  Same bit function as DBE_DIST15 | R/W |

Table 3.5 RAMEEC Register Contents (2/2)

| Bit Position | Bit Name  | Function                                                                                   | R/W |
|--------------|-----------|--------------------------------------------------------------------------------------------|-----|
| b1           | DBE_DIST1 | ECC error injection enable of Instruction RAM BANK0 WAY1.  Same bit function as DBE_DIST15 | R/W |
| b0           | DBE_DIST0 | ECC error injection enable of Instruction RAM BANK0 WAY0.  Same bit function as DBE_DIST15 | R/W |

# 3.4.4 RAMDBEST — RAM\_SYS Double Bit ECC Error Status Register

Please refer to Section 3.6, Usage Notes, for more detail.

Address: 400F 3108h



Table 3.6 RAMDBEST Register Contents (1/2)

| Bit Position | Bit Name  | Function                                                                                              | R/W |
|--------------|-----------|-------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | Reserved  |                                                                                                       | R   |
| b15          | DBE_RAM15 | ECC double bit error detection flag of Data RAM BANK1 WAY3.  0: Error not occurred  1: Error occurred | R   |
| b14          | DBE_RAM14 | ECC double bit error detection flag of Data RAM BANK1 WAY2.  Same bit function as DBE_RAM15           | R   |
| b13          | DBE_RAM13 | ECC double bit error detection flag of Data RAM BANK1 WAY1.  Same bit function as DBE_RAM15           | R   |
| b12          | DBE_RAM12 | ECC double bit error detection flag of Data RAM BANK1 WAY0.  Same bit function as DBE_RAM15           | R   |
| b11          | DBE_RAM11 | ECC double bit error detection flag of Data RAM BANK0 WAY3.  Same bit function as DBE_RAM15           | R   |
| b10          | DBE_RAM10 | ECC double bit error detection flag of Data RAM BANK0 WAY2.  Same bit function as DBE_RAM15           | R   |
| b9           | DBE_RAM9  | ECC double bit error detection flag of Data RAM BANK0 WAY1.  Same bit function as DBE_RAM15           | R   |
| b8           | DBE_RAM8  | ECC double bit error detection flag of Data RAM BANK0 WAY0.  Same bit function as DBE_RAM15           | R   |
| b7           | DBE_RAM7  | ECC double bit error detection flag of Instruction RAM BANK1 WAY3.  Same bit function as DBE_RAM15    | R   |
| b6           | DBE_RAM6  | ECC double bit error detection flag of Instruction RAM BANK1 WAY2.  Same bit function as DBE_RAM15    | R   |
| b5           | DBE_RAM5  | ECC double bit error detection flag of Instruction RAM BANK1 WAY1.  Same bit function as DBE_RAM15    | R   |
| b4           | DBE_RAM4  | ECC double bit error detection flag of Instruction RAM BANK1 WAY0.  Same bit function as DBE_RAM15    | R   |
| b3           | DBE_RAM3  | ECC double bit error detection flag of Instruction RAM BANK0 WAY3.  Same bit function as DBE_RAM15    | R   |
| b2           | DBE_RAM2  | ECC double bit error detection flag of Instruction RAM BANK0 WAY2.  Same bit function as DBE_RAM15    | R   |

Table 3.6 RAMDBEST Register Contents (2/2)

| Bit Position | Bit Name | Function                                                                                           | R/W |
|--------------|----------|----------------------------------------------------------------------------------------------------|-----|
| b1           | DBE_RAM1 | ECC double bit error detection flag of Instruction RAM BANK0 WAY1.  Same bit function as DBE_RAM15 | R   |
| b0           | DBE_RAM0 | ECC double bit error detection flag of Instruction RAM BANK0 WAY0.  Same bit function as DBE_RAM15 | R   |

# 3.4.5 RAMDBEAD — RAM\_SYS Double Bit ECC Error Address Register

Please refer to **Section 3.6, Usage Notes**, for more detail.

Address: 400F 310Ch



Table 3.7 RAMDBEAD Register Contents

| Bit Position | Bit Name | Function                                                                         | R/W |
|--------------|----------|----------------------------------------------------------------------------------|-----|
| b31 to b21   | Reserved |                                                                                  | R   |
| b20, b19     | BANK     | ECC double bit Error BANK                                                        | R   |
|              |          | These bits indicate a bank number where an ECC double bit error was encountered. |     |
|              |          | 00b: Instruction RAM BANK0                                                       |     |
|              |          | 01b: Instruction RAM BANK1                                                       |     |
|              |          | 10b: Data RAM BANK0                                                              |     |
|              |          | 11b: Data RAM BANK1                                                              |     |
| b18 to b2    | ADDRESS  | ECC double bit Error Address                                                     | R   |
|              |          | The double bit ECC error address is retained.                                    |     |
| b1           | Reserved |                                                                                  | R   |
| b0           | LOCK     | Lock Enable                                                                      | R   |
|              |          | 0: Register unlocked (Double bit ECC error address can be captured.)             |     |
|              |          | Register locked (Double bit ECC error address cannot be captured.)               |     |
|              |          | Read this register to unlock the registers.                                      |     |

# 3.4.6 RAMDBECNT — RAM\_SYS Double Bit ECC Error Counter Register

Please refer to **Section 3.6, Usage Notes**, for more detail.

Address: 400F 3110h



Table 3.8 RAMDBECNT Register Contents

| Bit Position | Bit Name | Function                      | R/W |
|--------------|----------|-------------------------------|-----|
| b31 to b4    | Reserved |                               | R   |
| b3 to b0     | ERRCOUNT | Double bit ECC error counter. | R   |

# 3.5 Operation

# 3.5.1 Configuration of Memory Map

The instruction RAM and data RAM consist of 512-Kbyte RAMs, each having a two-bank four-way configuration.



Figure 3.1 Configuration of Memory

#### 3.5.2 Initializing

For normal operation of the ECC circuit, it is necessary to initialize the instruction RAM and data RAM. (When the boot of RZ/N1, CPU (Cortex-A7 or Cortex-M3) uses the instruction RAM and data RAM. At the time, ECC error protection is not started.) For accessing this module registers, RINBUS\_HCLK must be enabled and RIN BUS sub system must not have been reset. The detail is described on Register Description of PWRCTRL RINCTRL.

#### **RAM** initialize:

ECC error correction cannot be enabled before initializing the instruction RAM and data RAM. After the initializing sequence below, set RAMEDC.ECC\_ENABLE register to 1 to enable ECC error correction.

Initialize from 0x04000000 to 0x040FFFFF and 0x20000000 to 0x200FFFFF.

- 1. Disable cache in case of Cortex-A7, disable NMI in case of Cortex-M3
- 2. Mask the ECC interrupt
- 3. Read the data from the initialize area.
- 4. Write the Read data to the same address.

#### 3.5.3 ECC Error Correction Function

RAMEDC register enables or disables ECC error correction in the 2-Mbyte space. ECCs can be used to correct single error and detect double error. Cortex-A7 and Cortex-M3 detects the sources of double errors, and RAMDBEST register is used to check the WAY in which an error was found. Moreover, RAMDBEAD register can be used to identify the address where a double error was found, and RAMDBECNT indicates the number of double errors that have been encountered.

# 3.5.4 Self-Testing of the ECC Circuit

Self-testing of the ECC circuit proceeds in way units. RAMEEC register sets the target area for each way. The following shows an example of the procedure for self-testing of the ECC circuit.



Figure 3.2 Example of ECC Error-Injection Setting Procedure



Figure 3.3 Procedure for Checking ECC Operation

# 3.6 Usage Notes

#### 3.6.1 Protect Command Register (RAMPCMD)

RAMPCMD register is used to provide write protection for registers that might seriously affect the system in order to prevent the application system from inadvertently stopping due to, for example, runaway of a program. Writing to the protected registers is disabled unless the PROTREL bit is set to 1.

To set the PROTREL bit of RAMPCMD register to 1, the sequence shown below must be used. No special sequence is required to clear this bit to 0 or to read the register.

| (1) | Write | 0000_00A5h | to RAMPCMD register as a specific value |
|-----|-------|------------|-----------------------------------------|
| (2) | Write | 0000_0001h | to RAMPCMD register                     |
| (3) | Write | 0000_FFFEh | to RAMPCMD register                     |
| (4) | Write | 0000 0001h | to RAMPCMD register                     |

#### **CAUTIONS**

- 1. In steps 1, 2, and 3, nothing is written to the register.
- 2. Be sure to clear the PROTREL bit to 0 after writing to target registers is completed.

#### RAMPCMD bit clear procedure:

(1) Write 0b to PROTREL of RAMPCMD register. (Write protect enabled.)

#### 3.6.2 ECC Decoder Config Register (RAMEDC)

RAMEDC register controls the ECC decoders for instruction RAM and data RAM.

When RAMEDC.ECC\_ENABLE bit is set to 1, ECC decoder logic for instruction RAM and data RAM is enabled, and the following functions are enabled, and this is conveyed to interrupt controller (Cortex-A7, Cortex-M3).

- For single ECC error: Correct the read data.
- For double ECC error: Generate a double bit ECC error interrupt from the instruction RAM and data RAM, and convey the interrupt signal to interrupt controller (Cortex-A7, Cortex-M3).

When RAMEDC.ECC\_ENABLE bit is set to 0 (the "disabled" setting), even if an ECC error occurs, read data is not corrected and the error signal is not conveyed to interrupt controller. Therefore, retention of the status in RAMDBEST register, capturing an error address in RAMDBEAD register, and error count in RAMDBECNT register are disabled.

#### **CAUTIONS**

- 1. Switch this register while no masters are accessing the RAM.
- 2. Writing to this register is disabled unless the write-protection is canceled by RAMPCMD register.

#### 3.6.3 ECC Encoder Config Register (RAMEEC)

RAMEEC register controls the self-test for the ECC circuit of the instruction RAM and data RAM. If RAMEEC.DBE\_DIST[n] (n = 0..15) bit is set to 1, the Syndrome value (ECC redundancy bit data) is latched when the RAM corresponding to each bit is accessed. Then, when the RAM is accessed the next time, the latched Syndrome value is written to the RAM to inject an ECC error. If RAMEEC.DBE\_DIST[n] (n = 0..15) bit is set to 0, the normal Syndrome value is always written to the RAM corresponding to each bit.

#### **CAUTIONS**

- 1. Switch this register while no masters are accessing the RAM.
- 2. Writing to this register is disabled unless the write-protection is canceled by RAMPCMD register.

### 3.6.4 Double Bit ECC Error Status Register (RAMDBEST)

RAMDBEST register indicates the double bit ECC error status for the instruction RAM and data RAM. After a double bit ECC error interrupt is generated from instruction RAM and data RAM, read this register to identify the BANK and WAY in which a double bit ECC error occurred.

#### **CAUTION**

This register is read-clear.

## 3.6.5 Double Bit ECC Error Address Register (RAMDBEAD)

RAMDBEAD register is a read-only register that holds the address where a double bit ECC error was found. When a double bit ECC error is detected, the ECC error address is captured with the detection signal as a trigger, and then is stored in the ADDRESS[16:0] bits. The register in which an ECC error address has been captured cannot retain the next ECC error address unless the register is read and the LOCK bit is cleared. Therefore, if you want to capture a new ECC error address, you must first read this register.

#### **CAUTION**

If double bit ECC errors occur at the same time in different WAYs, the priority of captured addresses is as follows:

Instruction RAM BANK0 WAY0 > Instruction RAM BANK0 WAY1 >

Instruction RAM BANK0 WAY2 > Instruction RAM BANK0 WAY3 >

Instruction RAM BANK1 WAY0 > Instruction RAM BANK1 WAY1 >

Instruction RAM BANK1 WAY2 > Instruction RAM BANK1 WAY3 >

Data RAM BANK0 WAY0 > Data RAM BANK0 WAY1 >

Data RAM BANK0 WAY2 > Data RAM BANK0 WAY3 >

Data RAM BANK1 WAY0 > Data RAM BANK1 WAY1 >

Data RAM BANK1 WAY2 > Data RAM BANK1 WAY3

#### 3.6.6 Double Bit ECC Error Counter Register (RAMDBECNT)

RAMDBECNT register is a read-only register that retains the double bit ECC error count. If a double bit ECC error is detected, the error counter is incremented with the detection signal as a trigger. If the counter value exceeds the maximum (Fh), it is cleared to 0h.



# Section 4 4MB SRAM

RZ/N1S and RZ/N1L have on-chip 4MB RAM with ECC function. There are 4 NoC access ports for each 1MB area.

# 4.1 Overview

Table 4.1 4MB SRAM Summary

| Item                                        | Description                                              | Description |  |  |
|---------------------------------------------|----------------------------------------------------------|-------------|--|--|
| RAM capacity                                | 4 Mbytes                                                 | Mbytes      |  |  |
| RAM address Area0: 8000 0000h to 800F FFFFh |                                                          |             |  |  |
|                                             | Area1: 8010 0000h to 801F FFFFh                          |             |  |  |
|                                             | Area2: 8020 0000h to 802F FFFFh                          |             |  |  |
|                                             | Area3: 8030 0000h to 803F FFFFh                          |             |  |  |
| Error checking                              | Correction of single error and detection of double error |             |  |  |
|                                             | Self-Testing of the ECC Circuit                          |             |  |  |
|                                             | Interrupt management                                     |             |  |  |

# 4.2 Signal Interfaces

|              | Input  |                                           |  |  |
|--------------|--------|-------------------------------------------|--|--|
| Signal Name  | Output | Description                               |  |  |
| Clock        | Clock  |                                           |  |  |
| SRAM4MB_HCLK | Input  | Internal bus clock (AHB), no clock gating |  |  |
| Interrupt    |        |                                           |  |  |
| ECC_4MB_Int  | Output | Pulse sensitive interrupt, Active High    |  |  |

# 4.3 Register Map

4MB SRAM registers can be accessed by 32-bit units.

NOTE

SR4EDC and SR4EEC registers are write protected by SR4PCMD.

Table 4.2 4MB SRAM Control Register List

| Address    | Register Symbol | Register Name                                  |
|------------|-----------------|------------------------------------------------|
| 8040 0000h | SR4PCMD         | SRAM 4MB Protect Command Register              |
| 8040 0100h | SR4EDC          | SRAM 4MB ECC Decoder Config Register           |
| 8040 0104h | SR4EEC          | SRAM 4MB ECC Encoder Config Register           |
| 8040 0108h | SR4DBEST        | SRAM 4MB Double Bit ECC Error Status Register  |
| 8040 010Ch | SR4DBEAD        | SRAM 4MB Double Bit ECC Error Address Register |
| 8040 0110h | SR4DBECNT       | SRAM 4MB Double Bit ECC Error Counter Register |

# 4.4 Register Description

# 4.4.1 SR4PCMD — SRAM 4MB Protect Command Register

Please refer to **Section 4.6, Usage Notes**, for more detail.

Address: 8040 0000h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16         |
|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-------------|
|                   | _   | _   | -   | _   | -   | -   | -   | -   | -   | _   | -   | -   | -   | -   | _   |             |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0           |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0          |
|                   | _   | l   | l   | l   | ı   | ı   | ı   | ı   | l   |     | l   | l   | l   | l   |     | PROTR<br>EL |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0           |

Table 4.3 SR4PCMD Register Contents

| Bit Position | Bit Name | Function                                                   | R/W |
|--------------|----------|------------------------------------------------------------|-----|
| b31 to b1    | Reserved |                                                            | R   |
| b0           | PROTREL  | Write access to protection registers are permitted.        | R/W |
|              |          | 1: Write access to protection registers are permitted.     |     |
|              |          | 0: Write access to protection registers are not permitted. |     |

# 4.4.2 SR4EDC — SRAM 4MB ECC Decoder Config Register

SR4EDC register is write protected by SR4PCMD.

Please refer to **Section 4.6, Usage Notes**, for more detail.

**Address:** 8040 0100h



Table 4.4 SR4EDC Register Contents

| Bit Position | Bit Name   | Function            | R/W |
|--------------|------------|---------------------|-----|
| b31 to b1    | Reserved   |                     | R   |
| b0           | ECC_ENABLE | ECC decoder enable. | R/W |
|              |            | 0: Disable          |     |
|              |            | 1: Enable           |     |

# 4.4.3 SR4EEC — SRAM 4MB ECC Encoder Config Register

SR4EEC register is write protected by SR4PCMD.

Please refer to **Section 4.6, Usage Notes**, for more detail.

Address: 8040 0104h



Table 4.5 SR4EEC Register Contents

| Bit Position | Bit Name  | Function                                                                                                 | R/W |
|--------------|-----------|----------------------------------------------------------------------------------------------------------|-----|
| b31 to b4    | Reserved  |                                                                                                          | R   |
| b3           | DBE_DIST3 | ECC error injection enable of 4MB SRAM Area3 (8030 0000h to 803F FFFFh).  0: Disable  1: Enable          | R/W |
| b2           | DBE_DIST2 | ECC error injection enable of 4MB SRAM Area2 (8020 0000h to 802F FFFFh).  Same bit function as DBE_DIST3 | R/W |
| b1           | DBE_DIST1 | ECC error injection enable of 4MB SRAM Area1 (8010 0000h to 801F FFFFh).  Same bit function as DBE_DIST3 | R/W |
| b0           | DBE_DIST0 | ECC error injection enable of 4MB SRAM Area0 (8000 0000h to 800F FFFFh).  Same bit function as DBE_DIST3 | R/W |

# 4.4.4 SR4DBEST — SRAM 4MB Double Bit ECC Error Status Register

Please refer to **Section 4.6, Usage Notes**, for more detail.

Address: 8040 0108h



Table 4.6 SR4DBEST Register Contents

| Bit Position | Bit Name | Function                                                                          | R/W |
|--------------|----------|-----------------------------------------------------------------------------------|-----|
| b31 to b4    | Reserved |                                                                                   | R   |
| b3           | DBE_RAM3 | ECC double bit error detection flag of 4MB SRAM Area3 (8030 0000h to 803F FFFFh). | R   |
|              |          | 0: Error not occurred                                                             |     |
|              |          | 1: Error occurred                                                                 |     |
| b2           | DBE_RAM2 | ECC double bit error detection flag of 4MB SRAM Area2 (8020 0000h to 802F FFFFh). | R   |
|              |          | Same bit function as DBE_RAM3                                                     |     |
| b1           | DBE_RAM1 | ECC double bit error detection flag of 4MB SRAM Area1 (8010 0000h to 801F FFFFh). | R   |
|              |          | Same bit function as DBE_RAM3                                                     |     |
| b0           | DBE_RAM0 | ECC double bit error detection flag of 4MB SRAM Area0 (8000 0000h to 800F FFFFh). | R   |
|              |          | Same bit function as DBE_RAM3                                                     |     |

# 4.4.5 SR4DBEAD — SRAM 4MB Double Bit ECC Error Address Register

Please refer to **Section 4.6, Usage Notes**, for more detail.

Address: 8040 010Ch

| Bit               | b31 | b30 | b29 | b28 | b27 | b26  | b25  | b24 | b23 | b22 | b21 | b20 | b19 | b18  | b17 | b16  |
|-------------------|-----|-----|-----|-----|-----|------|------|-----|-----|-----|-----|-----|-----|------|-----|------|
|                   | _   | _   | _   | _   | _   | _    | _    | _   | _   | _   |     |     | ADD | RESS |     |      |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0    | 0    | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0   | 0    |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10  | b9   | b8  | b7  | b6  | b5  | b4  | b3  | b2   | b1  | b0   |
|                   |     |     |     |     |     | ADDI | RESS |     |     |     |     |     | _   | _    | _   | LOCK |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0    | 0    | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0   | 0    |

Table 4.7 SR4DBEAD Register Contents

| Bit Position | Bit Name | Function                                                              | R/W |
|--------------|----------|-----------------------------------------------------------------------|-----|
| b31 to b22   | Reserved |                                                                       | R   |
| b21 to b4    | ADDRESS  | ECC double bit Error Address                                          | R   |
|              |          | The double bit ECC error address is retained.                         |     |
| b3 to b1     | Reserved |                                                                       | R   |
| b0           | LOCK     | Lock Enable                                                           | R   |
|              |          | 0: Register unlocked (Double bit ECC error address can be captured.)  |     |
|              |          | 1: Register locked (Double bit ECC error address cannot be captured.) |     |
|              |          | Read this register to unlock the registers.                           |     |

# 4.4.6 SR4DBECNT — SRAM 4MB Double Bit ECC Error Counter Register

Please refer to **Section 4.6, Usage Notes**, for more detail.

Address: 8040 0110h



Table 4.8 SR4DBECNT Register Contents

| Bit Position | Bit Name | Function                      | R/W |
|--------------|----------|-------------------------------|-----|
| b31 to b4    | Reserved |                               | R   |
| b3 to b0     | ERRCOUNT | Double bit ECC error counter. | R   |

# 4.5 Operation

## 4.5.1 Configuration of Memory Map

The 4MB SRAM have 4 separated 1-Mbyte RAMs.



Figure 4.1 Configuration of Memory

## 4.5.2 Initializing

For normal operation of the ECC circuit, it is necessary to initialize the 4MB SRAM.

#### **RAM** initialize:

ECC error correction cannot be enabled before initializing the 4MB SRAM. After the initializing sequence below, set SR4EDC.ECC\_ENABLE register to 1 to enable ECC error correction.

Initialize from 0x80000000 to 0x803FFFFF.

- 1. Disable cache in case of Cortex-A7, Disable NMI in case of Cortex-M3
- 2. Mask the ECC interrupt
- 3. Read the data from the initialize area.
- 4. Write the Read data to the same address.

#### 4.5.3 ECC Error Correction Function

SR4EDC register enables or disables ECC error correction in the 4-Mbyte space. ECCs can be used to correct single error and detect double error. Cortex-A7 and Cortex-M3 detects the sources of double errors, and SR4DBEST register is used to check the area in which an error was found. Moreover, SR4DBEAD register can be used to identify the address where a double error was found, and SR4DBECNT indicates the number of double errors that have been encountered.

# 4.5.4 Self-Testing of the ECC Circuit

Self-testing of the ECC circuit proceeds in area units. Use only 32-bit accesses. SR4EEC register sets the target area. The following shows an example of the procedure for self-testing of the ECC circuit.



Figure 4.2 Example of ECC Error-Injection Setting Procedure



Figure 4.3 Procedure for Checking ECC Operation

# 4.6 Usage Notes

#### 4.6.1 SRAM 4MB Protect Command Register (SR4PCMD)

SR4PCMD register is used to provide write protection for registers that might seriously affect the system in order to prevent the application system from inadvertently stopping due to, for example, runaway of a program. Writing to the protected registers is disabled unless PROTREL bit is set to 1.

To set PROTREL bit of SR4PCMD register to 1, the sequence shown below must be used. No special sequence is required to clear this bit to 0 or to read the register.

| (1) | Write  | 0000_00A5h | to SR4PCMD register as a specific value |
|-----|--------|------------|-----------------------------------------|
| (0) | TT7 *. | 0000 00011 | CD (DC) (D                              |

(2) Write 0000\_0001h to SR4PCMD register
 (3) Write 0000\_FFFEh to SR4PCMD register
 (4) Write 0000\_0001h to SR4PCMD register

#### **CAUTIONS**

- 1. In steps 1, 2, and 3, nothing is written to the register.
- 2. Be sure to clear the PROTREL bit to 0 after writing to target registers is completed

SR4PCMD bit clear procedure:

(1) Write 0b to PROTREL of SR4PCMD register. (Write protect enabled.)

## 4.6.2 SRAM 4MB ECC Decoder Config Register (SR4EDC)

SR4EDC register controls the ECC decoders for 4MB SRAM.

When SR4EDC.ECC\_ENABLE bit is set to 1, ECC decoder logic for 4MB SRAM is enabled, and the following functions are enabled, and this is conveyed to interrupt controller (Cortex-A7, Cortex-M3).

- For single ECC error: Correct the read data.
- For double ECC error: Generate a double bit ECC error interrupt from the 4MB SRAM and convey the interrupt signal to interrupt controller (Cortex-A7, Cortex-M3).

When SR4EDC.ECC\_ENABLE bit is set to 0 (the "disabled" setting), even if an ECC error occurs, read data is not corrected and the error signal is not conveyed to interrupt controller. Therefore, retention of the status in SR4DBEST register, capturing an error address in SR4DBEAD register, and error count in SR4DBECNT register are disabled.

#### **CAUTIONS**

- 1. Switch this register while no masters are accessing the RAM.
- 2. Writing to this register is disabled unless the write-protection is canceled by SR4PCMD register.

#### 4.6.3 SRAM 4MB ECC Encoder Config Register (SR4EEC)

SR4EEC register controls the self-test for the ECC circuit of the 4MB SRAM. If SR4EEC.DBE\_DIST[n] (n = 0.. 3) bit is set to 1, the Syndrome value (ECC redundancy bit data) is latched when the RAM corresponding to each bit is accessed. Then, when the RAM is accessed the next time, the latched Syndrome value is written to the RAM to inject an ECC error. If  $SR4EEC.DBE\_DIST[n]$  (n = 0..3) bit is set to 0, the normal Syndrome value is always written to the RAM corresponding to each bit.

#### **CAUTIONS**

- 1. Switch this register while no masters are accessing the RAM.
- 2. Writing to this register is disabled unless the write-protection is canceled by SR4PCMD register.

### 4.6.4 SRAM 4MB Double Bit ECC Error Status Register (SR4DBEST)

SR4DBEST register indicates the double bit ECC error status for the 4MB SRAM. After a double bit ECC error interrupt is generated from 4MB SRAM, read this register to identify the area in which a double bit ECC error occurred.

#### **CAUTION**

This register is read-clear.

## 4.6.5 SRAM 4MB Double Bit ECC Error Address Register (SR4DBEAD)

SR4DBEAD register is a read-only register that holds the address where a double bit ECC error was found. When a double bit ECC error is detected, the ECC error address is captured with the detection signal as a trigger, and then is stored in the ADDRESS[17:0] bits. The register in which an ECC error address has been captured cannot retain the next ECC error address unless the register is read and the LOCK bit is cleared. Therefore, if you want to capture a new ECC error address, you must first read this register.

#### **CAUTION**

If double bit ECC errors occur at the same time in different areas, the priority of captured addresses is as follows:

4MB SRAM Area0 (8000 0000h to 800F FFFFh) >

4MB SRAM Area1 (8010 0000h to 801F FFFFh) >

4MB SRAM Area2 (8020 0000h to 802F FFFFh) >

4MB SRAM Area3 (8030 0000h to 803F FFFFh)

#### 4.6.6 SRAM 4MB Double Bit ECC Error Counter Register (SR4DBECNT)

SR4DBECNT register is a read-only register that retains the double bit ECC error count. If a double bit ECC error is detected, the error counter is incremented with the detection signal as a trigger. If the counter value exceeds the maximum (Fh), it is cleared to 0h.

# Section 5 Debugging Interface

### 5.1 Overview

The On-chip Debug and Trace Unit shall include CoreSight<sup>™</sup>-compliant logic to provide the whole infrastructure for multi-core debug and trace to debug, monitor and optimize the performance of the Arm Cortex-A7 Core and Arm Cortex-M3 processors.

- 32 KB Embedded Trace Buffer (ETB)
  - On-chip storage of trace data
  - The ETB accepts trace data from either ETM components connected to the Arm Cortex-A7 Core or Arm Cortex-M3 Core or ITM
- Embedded Trace Router (ETR)
  - For large storage capability of the trace data across to the internal RAM (2 MB or 4 MB) and DDR2/3
- Embedded Trace Macrocell (ETM)
  - Real-time trace module providing instruction and data tracing of a processor
- SWJ-DP debug port
  - A combined JTAG-DP and SW-DP that enables to connect either a SWD or JTAG probe to a target



Figure 5.1 High-level Block Diagram of the On-chip Debug & Trace Unit

#### 5.2 JTAG Interface

#### 5.2.1 Circuit Recommendation of JTAG Interface

If the JTAG interface is unused, the JTAG\_TRST\_N input should be connected to digital GND via a  $4.7k\Omega$  resistor. The circuit recommendation for the interface looks as follows.



Figure 5.2 Unused JTAG Interface

If it uses the JTAG interface for boundary scan test, it is necessary to check whether the boundary scan tool has specific requirements with respect to the JTAG\_TRST\_N circuit in the target system. If the boundary scan tool has specific requirements, the circuit in the target system must be made configurable. The below figure shows the situation, that the boundary scan tool requires a pull-up at the JTAG\_TRST\_N input of the chip.



Figure 5.3 JTAG Interface Usable for Boundary Scan

## 5.2.2 Circuit Recommendation of JTAG-Debug Interface

The following figure shows example of JTAG-Debug connection scheme (according to standard JTAG IEEE 1149.1 mode).



Figure 5.4 Example of PCB / JTAG Connection

The following items should be considered:

- Signals TDI, TMS, TCK, RTCK and TDO are typically pulled up on the target board to keep them stable when the debug equipment is not connected.
- DBGRQ and DBGACK are typically pulled down on the target board as RZ/N1 doesn't support these.

There is no RTCK signal provided on the RZ/N1, therefore it can either be pulled to a fixed logic level or connected to the TCK signal to provide a direct loop-back.

# 5.2.3 Circuit Recommendation of Serial Wire Debug Interface

The following figure shows example of Serial Wire Debug (SWD) connection scheme.



Figure 5.5 Example of SWD Connection

The following items should be considered:

- SWDIO, SWCLK and SWO signals are typically pulled up on the target board to keep them stable when the debug equipment is not connected.
- Other JTAG signals are not used in Serial Wire Debug (SWD) mode.

#### 5.3 Reset Considerations

## 5.3.1 RZ/N1 Reset Signals

The RZ/N1 has a reset called MRESET\_N (resets the entire CPU core, debug logic and peripherals). The RZ/N1 device includes the JTAG interface and has a second reset input called JTAG\_TRST\_N (TAP reset). This resets the Debug Access Port (DAP) (JTAG Debug Port (JTAG-DP) / Serial Wire Debug Port (SW-DP)) and the boundary scan cells.

It is strongly recommended that both signals are separately available on the JTAG connector. If the MRESET\_N and JTAG TRST N signals are linked together, resetting the system also resets the TAP controller. This means that:

- It is not possible to debug a system from reset, because any breakpoints previously set are lost
- You might have to start the debug session from the beginning, because the debugger (e.g. DSTREAM) might not recover when the TAP controller state is changed.

### 5.3.2 Debugger Reset Signals

Most of the debug units have two reset signals connected to the RZ/N1:

- nTRST drives the JTAG\_TRST\_N signal on the Arm processor of RZ/N1. It is an output that is activated whenever the debug software has to re-initialize the debug interface in the target system.
- nSRST is a bidirectional signal that both drives and senses the system reset signals of RZ/N1 (MRESET\_N, MRESET\_OUT). By default, this output is driven LOW by the debugger to re-initialize the RZ/N1 system.

JTAG\_TRST\_N should be pulled-up to assure normal operation when the JTAG interface is disconnected. For further information, please refer to the corresponding debug tool vendor.

### 5.3.3 Example Reset Circuit

The circuit in the following figure shows example of reset circuit logic for the RZ/N1 reset signals and the debug unit reset signals.



Figure 5.6 Example of Reset Circuit

It should be noted that the MRESET\_OUT output signal reflects the MRESET\_N input signal. Therefore, the MRESET\_OUT must not be connected to nSRST (open drain system reset) together with MRESET\_N input to avoid a "deadlock" connection.

The external debugger can cause a system hang-up by issuing a system reset when nSRST is connected to MRESET\_N, due to the fact that the MRESET\_N resets entire debug logic of RZ/N1. An internal system reset (e.g. issued by watchdog or software bit) will be seen by the debugger, if the MRESET\_OUT is connected to nSRST, as an internal system reset will not reset the debug logic.

# Section 6 16b DDR2/3 Controller

Portions © Copyright Cadence Design System Inc 2012 to 2016. All right reserved worldwide. Used with permission.

## 6.1 Overview

RZ/N1D integrates DDR2/3 Controller, and it is able to support DDR2 and DDR3 double data rate memory devices with fixed operating frequencies. The multi ports architecture ensures that memory is shared efficiently among different high-bandwidth client modules.

• DDR2 & 3 Memory controllers with fixed frequency, asynchronous to NoC

DDR3-1000

(1) DDR controller: 250 MHz(2) DDR PHY: 500 MHz

DDR2-500

(1) DDR controller: 125 MHz(2) DDR PHY: 250 MHz

- DQ/DQS Ratio 8/1
- 2 Chip Select
- 2 ODT
- 16-bit Address Bus A0..15
- Maximum 2 GB address space
- Programmable memory data path size of full memory 16-bit data width or half memory 8-bit data width
  - 16 bits, 8 bits, 8+ECC bits
- ECC function software configurable (enable/disable)
  - 2 bits ECC by byte access
  - ECC scheme: 7 check bits over 32 data bits (this will result in 2 bits adder for 8 data bits)
  - Single-bit Error correction (SEC) and double-bit Error Detection (DED) error reporting and automatic correction of single-bit error events.
  - Programmable reporting and correction
  - Programmable removal of ECC storage.
- Flexible priority scheme software configurable
- Configurable DQ/DQS output impedance/slope and on die termination.
- DDR2/DDR3 Low power control management (by software)
  - Active Power-Down
  - Pre-Charge Power-Down
  - Self-Refresh
  - Self-Refresh with Memory Clock Gating
  - Self-Refresh with Memory and Controller Clock Gating
  - Optimized command scheduling with Activate/Pre-charging support
  - Support for Refresh Per Chip Select, to avoid peak current when refreshing.



- Port Address Protection Check
  - Incoming addresses and instruction type for each port are verified according to register setting.
  - Up to 16 address protection regions per port



Figure 6.1 DDR Controller Interfaces and Connections

# 6.2 Signal Interfaces

|                                      |        | 1                                                          |
|--------------------------------------|--------|------------------------------------------------------------|
|                                      | Input  |                                                            |
| Signal Name                          | Output | Description                                                |
| Clock                                |        |                                                            |
| DDR_XCLK                             | Input  | Internal bus clock (AXI)                                   |
| DDR_HCLK                             | Input  | Internal bus clock (AHB, APB), no clock gating             |
| DDR_DFICLK                           | Input  | Clock for DDR PHY interface                                |
| Interrupt                            |        |                                                            |
| DDRC_Int                             | Output | Level sensitive interrupt, Active High                     |
| External signal (dedicated pin only) |        |                                                            |
| DDR_CLKP<br>DDR_CLKN                 | Output | Differential clock                                         |
| DDR_CLKEN                            | Output | Clock enable, high active                                  |
| DDR_RESET_N                          | Output | DDR Reset, low active                                      |
| DDR_ADDR[15:0]                       | Output | Address bus                                                |
| DDR_BA[2:0]                          | Output | Bank address                                               |
| DDR_DQ[15:0]                         | I/O    | Data bus                                                   |
| DDR_DM[1:0]                          | Output | Data mask                                                  |
| DDR_DQS1<br>DDR_DQS_N1               | I/O    | Differential bidirectional data strobe for upper byte lane |
| DDR_DQS0<br>DDR_DQS_N0               | I/O    | Differential bidirectional data strobe for lower byte lane |
| DDR_WE                               | Output | Write enable, low active                                   |
| DDR_RAS                              | Output | Row Address Strobe, low active                             |
| DDR_CAS                              | Output | Column Address Strobe, low active                          |
| DDR_CS[1:0]                          | Output | Chip Select, low active                                    |
| DDR_ODT[1:0]                         | Output | ODT control                                                |
|                                      |        |                                                            |

# 6.3 Register Map

# 6.3.1 DDR Controller

Table 6.1 DDR Controller Register Map (1/4)

| Address      | Pogister Symbol |                                    |
|--------------|-----------------|------------------------------------|
| Address      | Register Symbol | Register Name                      |
| 4000 D000h   | DDR_CTL_00      | DDR-Controller Status & Control 00 |
| 4000 D004h   | DDR_CTL_01      | DDR-Controller Status & Control 01 |
| 4000 D008h   | DDR_CTL_02      | DDR-Controller Status & Control 02 |
| 4000 D00Ch   | DDR_CTL_03      | DDR-Controller Status & Control 03 |
| 4000 D010h   | DDR_CTL_04      | DDR-Controller Status & Control 04 |
| 4000 D014h   | DDR_CTL_05      | DDR-Controller Status & Control 05 |
| 4000 D018h   | DDR_CTL_06      | DDR-Controller Status & Control 06 |
| 4000 D01Ch   | DDR_CTL_07      | DDR-Controller Status & Control 07 |
| 4000 D020h   | DDR_CTL_08      | DDR-Controller Status & Control 08 |
| 4000 D024h   | DDR_CTL_09      | DDR-Controller Status & Control 09 |
| 4000 D028h   | DDR_CTL_10      | DDR-Controller Status & Control 10 |
| 4000 D02Ch   | DDR_CTL_11      | DDR-Controller Status & Control 11 |
| 4000 D030h   | DDR_CTL_12      | DDR-Controller Status & Control 12 |
| 4000 D034h   | DDR_CTL_13      | DDR-Controller Status & Control 13 |
| 4000 D038h   | DDR_CTL_14      | DDR-Controller Status & Control 14 |
| 4000 D03Ch   | DDR_CTL_15      | DDR-Controller Status & Control 15 |
| 4000 D040h   | DDR_CTL_16      | DDR-Controller Status & Control 16 |
| 4000 D044h   | DDR_CTL_17      | DDR-Controller Status & Control 17 |
| 4000 D048h   | DDR_CTL_18      | DDR-Controller Status & Control 18 |
| 4000 D04Ch   | DDR_CTL_19      | DDR-Controller Status & Control 19 |
| 4000 D050h   | DDR_CTL_20      | DDR-Controller Status & Control 20 |
| 4000 D054h   | DDR_CTL_21      | DDR-Controller Status & Control 21 |
| 4000 D058h   | DDR_CTL_22      | DDR-Controller Status & Control 22 |
| 4000 D05Ch   | DDR_CTL_23      | DDR-Controller Status & Control 23 |
| 4000 D060h   | DDR_CTL_24      | DDR-Controller Status & Control 24 |
| 4000 D064h   | DDR_CTL_25      | DDR-Controller Status & Control 25 |
| 4000 D068h   | DDR_CTL_26      | DDR-Controller Status & Control 26 |
| 4000 D06Ch   | DDR_CTL_27      | DDR-Controller Status & Control 27 |
| 4000 D070h   | DDR_CTL_28      | DDR-Controller Status & Control 28 |
| 4000 D074h   | DDR_CTL_29      | DDR-Controller Status & Control 29 |
| 4000 D078h   | DDR_CTL_30      | DDR-Controller Status & Control 30 |
| 4000 D07Ch   | DDR_CTL_31      | DDR-Controller Status & Control 31 |
| 4000 D080h   | DDR_CTL_32      | DDR-Controller Status & Control 32 |
| 4000 D084h   | DDR_CTL_33      | DDR-Controller Status & Control 33 |
| 4000 D088h   | DDR_CTL_34      | DDR-Controller Status & Control 34 |
| 4000 D08Ch   | DDR_CTL_35      | DDR-Controller Status & Control 35 |
| 4000 D090h   | DDR_CTL_36      | DDR-Controller Status & Control 36 |
| 4000 D094h   | DDR_CTL_37      | DDR-Controller Status & Control 37 |
| 4000 D098h   | DDR_CTL_38      | DDR-Controller Status & Control 38 |
| 4000 D09Ch   | DDR_CTL_39      | DDR-Controller Status & Control 39 |
| 4000 D0A0h   | <br>DDR_CTL_40  | DDR-Controller Status & Control 40 |
| 4000 D0A4h   | DDR_CTL_41      | DDR-Controller Status & Control 41 |
| .300 20,(11) | 220.1_1.        | 52.1 00.1101.01 01.1101.11         |

Table 6.1 DDR Controller Register Map (2/4)

| rable 6.1  | DDR Controller Register Map (2/4) |                                    |
|------------|-----------------------------------|------------------------------------|
| Address    | Register Symbol                   | Register Name                      |
| 4000 D0A8h | DDR_CTL_42                        | DDR-Controller Status & Control 42 |
| 4000 D0ACh | DDR_CTL_43                        | DDR-Controller Status & Control 43 |
| 4000 D0B0h | DDR_CTL_44                        | DDR-Controller Status & Control 44 |
| 4000 D0B4h | DDR_CTL_45                        | DDR-Controller Status & Control 45 |
| 4000 D0B8h | DDR_CTL_46                        | DDR-Controller Status & Control 46 |
| 4000 D0BCh | DDR_CTL_47                        | DDR-Controller Status & Control 47 |
| 4000 D0C0h | DDR_CTL_48                        | DDR-Controller Status & Control 48 |
| 4000 D0C4h | DDR_CTL_49                        | DDR-Controller Status & Control 49 |
| 4000 D0C8h | DDR_CTL_50                        | DDR-Controller Status & Control 50 |
| 4000 D0CCh | DDR_CTL_51                        | DDR-Controller Status & Control 51 |
| 4000 D0D0h | DDR_CTL_52                        | DDR-Controller Status & Control 52 |
| 4000 D0D4h | DDR_CTL_53                        | DDR-Controller Status & Control 53 |
| 4000 D0D8h | DDR_CTL_54                        | DDR-Controller Status & Control 54 |
| 4000 D0DCh | DDR_CTL_55                        | DDR-Controller Status & Control 55 |
| 4000 D0E0h | DDR_CTL_56                        | DDR-Controller Status & Control 56 |
| 4000 D0E4h | DDR_CTL_57                        | DDR-Controller Status & Control 57 |
| 4000 D0E8h | DDR_CTL_58                        | DDR-Controller Status & Control 58 |
| 4000 D0ECh | DDR_CTL_59                        | DDR-Controller Status & Control 59 |
| 4000 D0F0h | DDR_CTL_60                        | DDR-Controller Status & Control 60 |
| 4000 D0F4h | DDR_CTL_61                        | DDR-Controller Status & Control 61 |
| 4000 D0F8h | DDR_CTL_62                        | DDR-Controller Status & Control 62 |
| 4000 D0FCh | DDR_CTL_63                        | DDR-Controller Status & Control 63 |
| 4000 D100h | DDR_CTL_64                        | DDR-Controller Status & Control 64 |
| 4000 D104h | DDR_CTL_65                        | DDR-Controller Status & Control 65 |
| 4000 D108h | DDR_CTL_66                        | DDR-Controller Status & Control 66 |
| 4000 D10Ch | DDR_CTL_67                        | DDR-Controller Status & Control 67 |
| 4000 D110h | DDR_CTL_68                        | DDR-Controller Status & Control 68 |
| 4000 D114h | DDR_CTL_69                        | DDR-Controller Status & Control 69 |
| 4000 D118h | DDR_CTL_70                        | DDR-Controller Status & Control 70 |
| 4000 D11Ch | DDR_CTL_71                        | DDR-Controller Status & Control 71 |
| 4000 D120h | DDR_CTL_72                        | DDR-Controller Status & Control 72 |
| 4000 D124h | DDR_CTL_73                        | DDR-Controller Status & Control 73 |
| 4000 D128h | DDR_CTL_74                        | DDR-Controller Status & Control 74 |
| 4000 D12Ch | DDR_CTL_75                        | DDR-Controller Status & Control 75 |
| 4000 D130h | DDR_CTL_76                        | DDR-Controller Status & Control 76 |
| 4000 D134h | DDR_CTL_77                        | DDR-Controller Status & Control 77 |
| 4000 D138h | DDR_CTL_78                        | DDR-Controller Status & Control 78 |
| 4000 D13Ch | DDR_CTL_79                        | DDR-Controller Status & Control 79 |
| 4000 D140h | DDR_CTL_80                        | DDR-Controller Status & Control 80 |
| 4000 D144h | DDR_CTL_81                        | DDR-Controller Status & Control 81 |
| 4000 D148h | DDR_CTL_82                        | DDR-Controller Status & Control 82 |
| 4000 D14Ch | DDR_CTL_83                        | DDR-Controller Status & Control 83 |
| 4000 D150h | DDR_CTL_84                        | DDR-Controller Status & Control 84 |
| 4000 D154h | DDR_CTL_85                        | DDR-Controller Status & Control 85 |
| 4000 D158h | DDR_CTL_86                        | DDR-Controller Status & Control 86 |
|            |                                   |                                    |

Table 6.1 DDR Controller Register Map (3/4)

|                        | 3 7                                                |                                                |
|------------------------|----------------------------------------------------|------------------------------------------------|
| Address                | Register Symbol                                    | Register Name                                  |
| 4000 D15Ch             | DDR_CTL_87                                         | DDR-Controller Status & Control 87             |
| 4000 D160h             | DDR_CTL_88                                         | DDR-Controller Status & Control 88             |
| 4000 D164h             | DDR_CTL_89                                         | DDR-Controller Status & Control 89             |
| 4000 D168h             | DDR_CTL_90                                         | DDR-Controller Status & Control 90             |
| 4000 D16Ch             | DDR_CTL_[k]                                        | Port0 Range[n] Start Address Setting Register  |
| + 8h × n               | $(n = 015) (k = 91 + n \times 2)$                  |                                                |
| 4000 D170h<br>+ 8h × n | DDR_CTL_[k]<br>(n = 015) (k = $92 + n \times 2$ )  | Port0 Range[n] End Address Setting Register    |
| 4000 D1ECh             | DDR_CTL_[k]                                        | Port1 Range[n] Start Address Setting Register  |
| + 8h × n               | $(n = 015) (k = 123 + n \times 2)$                 | Total Nange[ii] Staft Address Setting Negister |
| 4000 D1F0h             | DDR_CTL_[k]                                        | Port1 Range[n] End Address Setting Register    |
| + 8h × n               | $(n = 015) (k = 124 + n \times 2)$                 |                                                |
| 4000 D26Ch             | DDR_CTL_[k]                                        | Port2 Range[n] Start Address Setting Register  |
| + 8h × n<br>4000 D270h | $(n = 015) (k = 155 + n \times 2)$<br>DDR_CTL_[k]  | Port? Pangalal End Addraga Sotting Pagister    |
| + 8h × n               | $(n = 015) (k = 156 + n \times 2)$                 | Port2 Range[n] End Address Setting Register    |
| 4000 D2ECh             | DDR_CTL_[k]                                        | Port3 Range[n] Start Address Setting Register  |
| + 8h × n               | $(n = 015) (k = 187 + n \times 2)$                 |                                                |
| 4000 D2F0h             | DDR_CTL_[k]                                        | Port3 Range[n] End Address Setting Register    |
| + 8h × n<br>4000 D368h | (n = 014) (k = 188 + n x 2)                        | Darka Dangari E Find Address Catting Degister  |
| 4000 D366h             | DDR_CTL_218  DDR_CTL_[k]                           | Port3 Range15 End Address Setting Register     |
| + 8h × n               | $(n = 015) (k = 219 + n \times 2)$                 | Port0 Range[n] Protect Setting Register1       |
| 4000 D370h<br>+ 8h × n | DDR_CTL_[k]<br>(n = 014) (k = $220 + n \times 2$ ) | Port0 Range[n] Protect Setting Register2       |
| 4000 D3E8h             | DDR_CTL_250                                        | Port0 Range15 Protect Setting Register2        |
| 4000 D3ECh<br>+ 8h × n | DDR_CTL_[k]<br>(n = 015) (k = 251 + n × 2)         | Port1 Range[n] Protect Setting Register1       |
| 4000 D3F0h<br>+ 8h × n | DDR_CTL_[k]<br>(n = 014) (k = 252 + n × 2)         | Port1 Range[n] Protect Setting Register2       |
| 4000 D468h             | DDR_CTL_282                                        | Port1 Range15 Protect Setting Register2        |
| 4000 D46Ch<br>+ 8h × n | DDR_CTL_[k] $(n = 015) (k = 283 + n \times 2)$     | Port2 Range[n] Protect Setting Register1       |
| 4000 D470h             | DDR_CTL_[k]                                        | Port2 Range[n] Protect Setting Register2       |
| + 8h × n               | $(n = 014) (k = 284 + n \times 2)$                 |                                                |
| 4000 D4E8h             | DDR_CTL_314                                        | Port2 Range15 Protect Setting Register2        |
| 4000 D4ECh<br>+ 8h × n | DDR_CTL_[k]<br>(n = 015) (k = 315 + n × 2)         | Port3 Range[n] Protect Setting Register1       |
| 4000 D4F0h             | DDR_CTL_[k]                                        | Port3 Range[n] Protect Setting Register2       |
| + 8h × n               | $(n = 014) (k = 316 + n \times 2)$                 | r one range[n] r retest estang register2       |
| 4000 D568h             | DDR_CTL_346                                        | Port3 Range15 Protect Setting Register2        |
| 4000 D56Ch             | DDR_CTL_347                                        | DDR-Controller Status & Control 347            |
| 4000 D570h             | DDR_CTL_348                                        | DDR-Controller Status & Control 348            |
| 4000 D574h             | DDR_CTL_349                                        | DDR-Controller Status & Control 349            |
| 4000 D578h             | DDR_CTL_350                                        | DDR-Controller Status & Control 350            |
| 4000 D57Ch             | DDR_CTL_351                                        | DDR-Controller Status & Control 351            |
| 4000 D580h             | DDR_CTL_352                                        | DDR-Controller Status & Control 352            |
| 4000 D584h             | DDR_CTL_353                                        | DDR-Controller Status & Control 353            |
| 4000 D588h             | DDR_CTL_354                                        | DDR-Controller Status & Control 354            |
| 4000 D58Ch             | DDR_CTL_355                                        | DDR-Controller Status & Control 355            |

Table 6.1 DDR Controller Register Map (4/4)

| Address    | Register Symbol | Register Name                       |
|------------|-----------------|-------------------------------------|
| 4000 D590h | DDR_CTL_356     | DDR-Controller Status & Control 356 |
| 4000 D594h | DDR_CTL_357     | DDR-Controller Status & Control 357 |
| 4000 D598h | DDR_CTL_358     | DDR-Controller Status & Control 358 |
| 4000 D59Ch | DDR_CTL_359     | DDR-Controller Status & Control 359 |
| 4000 D5A0h | DDR_CTL_360     | DDR-Controller Status & Control 360 |
| 4000 D5A4h | DDR_CTL_361     | DDR-Controller Status & Control 361 |
| 4000 D5A8h | DDR_CTL_362     | DDR-Controller Status & Control 362 |
| 4000 D5ACh | DDR_CTL_363     | DDR-Controller Status & Control 363 |
| 4000 D5B0h | DDR_CTL_364     | DDR-Controller Status & Control 364 |
| 4000 D5B4h | DDR_CTL_365     | DDR-Controller Status & Control 365 |
| 4000 D5B8h | DDR_CTL_366     | DDR-Controller Status & Control 366 |
| 4000 D5BCh | DDR_CTL_367     | DDR-Controller Status & Control 367 |
| 4000 D5C0h | DDR_CTL_368     | DDR-Controller Status & Control 368 |
| 4000 D5C4h | DDR_CTL_369     | DDR-Controller Status & Control 369 |
| 4000 D5C8h | DDR_CTL_370     | DDR-Controller Status & Control 370 |
| 4000 D5CCh | DDR_CTL_371     | DDR-Controller Status & Control 371 |
| 4000 D5D0h | DDR_CTL_372     | DDR-Controller Status & Control 372 |
| 4000 D5D4h | DDR_CTL_373     | DDR-Controller Status & Control 373 |
| 4000 D5D8h | DDR_CTL_374     | DDR-Controller Status & Control 374 |

## **6.3.2** DDR PHY

Table 6.2 DDR PHY Register Map

| Address    | Register Symbol | Register Name                     |
|------------|-----------------|-----------------------------------|
| 4000 E000h | FUNCCTRL        | Function Control Register         |
| 4000 E004h | DLLCTRL         | MDLL Control Register             |
| 4000 E008h | ZQCALCTRL       | ZQ Calibration Control Register   |
| 4000 E00Ch | ZQODTCTRL       | ZQODT Control Register            |
| 4000 E010h | RDCTRL          | Read Control Register             |
| 4000 E014h | RDTMG           | READ Timing Control Register      |
| 4000 E018h | FIFOINIT        | FIFO Initialization Register      |
| 4000 E01Ch | OUTCTRL         | Output Control Register           |
| 4000 E040h | WLCTRL1         | Write Leveling Control Register 1 |
| 4000 E0E8h | DQCALOFS1       | DQS Offset Setting                |

# 6.4 Register Description

# 6.4.1 DDR Controller Register Description

# 6.4.1.1 DDR\_CTL\_00 — DDR-Controller Status & Control 00

Address: 4000 D000h

| Bit               | b31 | b30     | b29 | b28 | b27        | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16   |
|-------------------|-----|---------|-----|-----|------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-------|
|                   |     | VERSION |     |     |            |     |     |     |     |     |     |     |     |     |     |       |
| Value after reset | 0   | 0       | 1   | 0   | 0          | 0   | 0   | 0   | 0   | 1   | 0   | 0   | 0   | 0   | 0   | 1     |
| Bit               | b15 | b14     | b13 | b12 | b11        | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0    |
|                   | _   | 1       | -   | -   | DRAM_CLASS |     |     |     | _   | 1   | _   | _   | -   | -   | _   | START |
| Value after reset | 0   | 0       | 0   | 0   | 0          | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0     |

Table 6.3 DDR\_CTL\_00 Register Contents

| Bit Position | Bit Name   | Function                                                                                                                               | R/W |
|--------------|------------|----------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | VERSION    | Holds the controller version number.                                                                                                   | R   |
| b15 to b12   | Reserved   | NA                                                                                                                                     | R   |
| b11 to b8    | DRAM_CLASS | Defines the mode of operation of the controller.  3'b0100 = DDR2  3'b0110 = DDR3  All other settings are reserved and must not be set. | R/W |
| b7 to b1     | Reserved   | NA                                                                                                                                     | R   |
| b0           | START      | Initiate command processing in the controller. Set to 1 to initiate.                                                                   | R/W |

## 6.4.1.2 DDR\_CTL\_01 — DDR-Controller Status & Control 01

Address: 4000 D004h

| Bit               | b31                  | b30 | b29 | b28 | b27         | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19    | b18   | b17   | b16 |
|-------------------|----------------------|-----|-----|-----|-------------|-----|-----|-----|-----|-----|-----|-----|--------|-------|-------|-----|
|                   | READ_DATA_FIFO_DEPTH |     |     |     |             |     |     | _   | _   | _   | _   | _   | _      | MAX_C | S_REG |     |
| Value after reset | 0                    | 0   | 0   | 1   | 0           | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0     | 1     | 0   |
| Bit               | b15                  | b14 | b13 | b12 | b11         | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3     | b2    | b1    | b0  |
|                   | _                    | _   | _   | _   | MAX_COL_REG |     |     | _   | _   | _   |     | MAX | (_ROW_ | REG   |       |     |
| Value after reset | 0                    | 0   | 0   | 0   | 1           | 0   | 1   | 1   | 0   | 0   | 0   | 1   | 0      | 0     | 0     | 0   |

Table 6.4 DDR\_CTL\_01 Register Contents

| Bit Position | Bit Name                 | Function                                             | R/W |
|--------------|--------------------------|------------------------------------------------------|-----|
| b31 to b24   | READ_DATA_FIFO_<br>DEPTH | Reports the depth of the controller read data queue. | R   |
| b23 to b18   | Reserved                 | NA                                                   | R   |
| b17, b16     | MAX_CS_REG               | Holds the maximum number of chip selects available.  | R   |
| b15 to b12   | Reserved                 | NA                                                   | R   |
| b11 to b8    | MAX_COL_REG              | Holds the maximum width of column address in DRAMs.  | R   |
| b7 to b5     | Reserved                 | NA                                                   | R   |
| b4 to b0     | MAX_ROW_REG              | Holds the maximum width of memory address bus.       | R   |

### 6.4.1.3 DDR\_CTL\_02 — DDR-Controller Status & Control 02

Address: 4000 D008h



Table 6.5 DDR\_CTL\_02 Register Contents

| Bit Position | Bit Name                      | Function                                                              | R/W |
|--------------|-------------------------------|-----------------------------------------------------------------------|-----|
| b31 to b24   | ASYNC_CDC_STAG<br>ES          | Reports the number of stages used for synchronizer.                   | R   |
| b23 to b16   | WRITE_DATA_FIFO_<br>PTR_WIDTH | Reports the width of the controller write data latency queue pointer. | R   |
| b15 to b8    | WRITE_DATA_FIFO_<br>DEPTH     | Reports the depth of the controller write data latency queue.         | R   |
| b7 to b0     | READ_DATA_FIFO_<br>PTR_WIDTH  | Reports the width of the controller read data queue pointer.          | R   |

## 6.4.1.4 DDR\_CTL\_03 — DDR-Controller Status & Control 03

Address: 4000 D00Ch

| Bit               | b31                             | b30 | b29 | b28 | b27 | b26 | b25 | b24                    | b23 | b22    | b21    | b20    | b19    | b18 | b17 | b16 |
|-------------------|---------------------------------|-----|-----|-----|-----|-----|-----|------------------------|-----|--------|--------|--------|--------|-----|-----|-----|
|                   | AXI0_WRCMD_PROC_FIFO_LOG2_DEPTH |     |     |     |     |     |     | AXI0_WRFIFO_LOG2_DEPTH |     |        |        |        |        |     |     |     |
| Value after reset | 0                               | 0   | 0   | 0   | 0   | 0   | 1   | 1                      | 0   | 0      | 0      | 0      | 0      | 1   | 0   | 0   |
| Bit               | b15                             | b14 | b13 | b12 | b11 | b10 | b9  | b8                     | b7  | b6     | b5     | b4     | b3     | b2  | b1  | b0  |
|                   | AXI0_RDFIFO_LOG2_DEPTH          |     |     |     |     |     |     |                        |     | AXI0_C | MDFIFC | _LOG2_ | _DEPTH |     |     |     |
| Value after reset | 0                               | 0   | 0   | 0   | 0   | 0   | 1   | 1                      | 0   | 0      | 0      | 0      | 0      | 0   | 1   | 1   |

Table 6.6 DDR\_CTL\_03 Register Contents

| Bit Position | Bit Name                                | Function                                                                                                 | R/W |
|--------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | AXI0_WRCMD_PRO<br>C_FIFO_LOG2_DEP<br>TH | Reports the depth of the AXI port 0 Write Command Processing FIFO. Value is the log2 value of the depth. | R   |
| b23 to b16   | AXI0_WRFIFO_LOG2<br>_DEPTH              | Reports the depth of the AXI port 0 Write Data FIFO. Value is the log2 value of the depth.               | R   |
| b15 to b8    | AXI0_RDFIFO_LOG2<br>_DEPTH              | Reports the depth of the AXI port 0 Read Data FIFO. Value is the log2 value of the depth.                | R   |
| b7 to b0     | AXI0_CMDFIFO_LO<br>G2_DEPTH             | Reports the depth of the AXI port 0 Command FIFO. Value is the log2 value of the depth.                  | R   |

#### 6.4.1.5 DDR\_CTL\_04 — DDR-Controller Status & Control 04

Address: 4000 D010h



Table 6.7 DDR\_CTL\_04 Register Contents

| Bit Position | Bit Name                                | Function                                                                                                 | R/W |
|--------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | AXI1_WRCMD_PRO<br>C_FIFO_LOG2_DEP<br>TH | Reports the depth of the AXI port 1 Write Command Processing FIFO. Value is the log2 value of the depth. | R   |
| b23 to b16   | AXI1_WRFIFO_LOG2<br>_DEPTH              | Reports the depth of the AXI port 1 Write Data FIFO. Value is the log2 value of the depth.               | R   |
| b15 to b8    | AXI1_RDFIFO_LOG2<br>_DEPTH              | Reports the depth of the AXI port 1 Read Data FIFO. Value is the log2 value of the depth.                | R   |
| b7 to b0     | AXI1_CMDFIFO_LO<br>G2_DEPTH             | Reports the depth of the AXI port 1 Command FIFO. Value is the log2 value of the depth.                  | R   |

### 6.4.1.6 DDR\_CTL\_05 — DDR-Controller Status & Control 05

Address: 4000 D014h

| Bit               | b31 | b30  | b29   | b28     | b27     | b26    | b25  | b24 | b23 | b22 | b21    | b20     | b19     | b18   | b17 | b16 |
|-------------------|-----|------|-------|---------|---------|--------|------|-----|-----|-----|--------|---------|---------|-------|-----|-----|
|                   |     | AXI2 | _WRCM | D_PROC  | _FIFO_I | LOG2_D | EPTH |     |     |     | AXI2_\ | WRFIFO. | _LOG2_l | DEPTH |     |     |
| Value after reset | 0   | 0    | 0     | 0       | 0       | 0      | 1    | 1   | 0   | 0   | 0      | 0       | 0       | 1     | 0   | 0   |
| Bit               | b15 | b14  | b13   | b12     | b11     | b10    | b9   | b8  | b7  | b6  | b5     | b4      | b3      | b2    | b1  | b0  |
|                   |     |      | AXI2_ | RDFIFO_ | _LOG2_I | DEPTH  |      |     |     |     | AXI2_C | MDFIFC  | _LOG2_  | DEPTH |     |     |
| Value after reset | 0   | 0    | 0     | 0       | 0       | 0      | 1    | 1   | 0   | 0   | 0      | 0       | 0       | 0     | 1   | 1   |

Table 6.8 DDR\_CTL\_05 Register Contents

| Bit Position | Bit Name                                | Function                                                                                                 | R/W |
|--------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | AXI2_WRCMD_PRO<br>C_FIFO_LOG2_DEP<br>TH | Reports the depth of the AXI port 2 Write Command Processing FIFO. Value is the log2 value of the depth. | R   |
| b23 to b16   | AXI2_WRFIFO_LOG2<br>_DEPTH              | Reports the depth of the AXI port 2 Write Data FIFO. Value is the log2 value of the depth.               | R   |
| b15 to b8    | AXI2_RDFIFO_LOG2<br>_DEPTH              | Reports the depth of the AXI port 2 Read Data FIFO. Value is the log2 value of the depth.                | R   |
| b7 to b0     | AXI2_CMDFIFO_LO<br>G2_DEPTH             | Reports the depth of the AXI port 2 Command FIFO. Value is the log2 value of the depth.                  | R   |

#### 6.4.1.7 DDR\_CTL\_06 — DDR-Controller Status & Control 06

Address: 4000 D018h



Table 6.9 DDR\_CTL\_06 Register Contents

| Bit Position | Bit Name                                | Function                                                                                                 | R/W |
|--------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | AXI3_WRCMD_PRO<br>C_FIFO_LOG2_DEP<br>TH | Reports the depth of the AXI port 3 Write Command Processing FIFO. Value is the log2 value of the depth. | R   |
| b23 to b16   | AXI3_WRFIFO_LOG2<br>_DEPTH              | Reports the depth of the AXI port 3 Write Data FIFO. Value is the log2 value of the depth.               | R   |
| b15 to b8    | AXI3_RDFIFO_LOG2<br>_DEPTH              | Reports the depth of the AXI port 3 Read Data FIFO. Value is the log2 value of the depth.                | R   |
| b7 to b0     | AXI3_CMDFIFO_LO<br>G2_DEPTH             | Reports the depth of the AXI port 3 Command FIFO. Value is the log2 value of the depth.                  | R   |

#### 6.4.1.8 DDR\_CTL\_07 — DDR-Controller Status & Control 07

Address: 4000 D01Ch



Table 6.10 DDR\_CTL\_07 Register Contents

| Bit Position | Bit Name | Function                               | R/W |
|--------------|----------|----------------------------------------|-----|
| b31 to b24   | Reserved | NA                                     | R   |
| b23 to b0    | TINIT    | DRAM TINIT value (memory clock cycles) | R/W |

#### 6.4.1.9 DDR\_CTL\_08 — DDR-Controller Status & Control 08

Address: 4000 D020h



Table 6.11 DDR\_CTL\_08 Register Contents

| Bit Position | Bit Name   | Function                                                                      | R/W |
|--------------|------------|-------------------------------------------------------------------------------|-----|
| b31 to b0    | TRST_PWRON | Duration of memory reset during power-on initialization (memory clock cycles) | R/W |

# 6.4.1.10 DDR\_CTL\_09 — DDR-Controller Status & Control 09

Address: 4000 D024h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24    | b23    | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|--------|--------|-----|-----|-----|-----|-----|-----|-----|
|                   |     |     |     |     |     |     |     | CKE_IN | ACTIVE |     |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8     | b7     | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                   |     |     |     |     |     |     |     | CKE_IN | ACTIVE |     |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 6.12 DDR\_CTL\_09 Register Contents

| Bit Position | Bit Name     | Function                                                                     | R/W |
|--------------|--------------|------------------------------------------------------------------------------|-----|
| b31 to b0    | CKE_INACTIVE | Number of cycles after reset before CKE will be active (memory clock cycles) | R/W |

#### 6.4.1.11 DDR\_CTL\_10 — DDR-Controller Status & Control 10

Address: 4000 D028h



Table 6.13 DDR\_CTL\_10 Register Contents

| Bit Position | Bit Name | Function                                                               | R/W |
|--------------|----------|------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved | NA                                                                     | R   |
| b23 to b8    | TCPD     | DRAM TCPD value (memory clock cycles)                                  | R/W |
| b7 to b4     | Reserved | NA                                                                     | R   |
| b3 to b0     | INITAREF | Number of auto-refresh commands to execute during DRAM initialization. | R/W |

## 6.4.1.12 DDR\_CTL\_11 — DDR-Controller Status & Control 11

Address: 4000 D02Ch

| Bit               | b31 | b30 | b29 | b28 | b27  | b26    | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16             |
|-------------------|-----|-----|-----|-----|------|--------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----------------|
|                   | _   | _   |     |     | CASL | AT_LIN |     |     | _   | _   | _   | _   | _   | _   | _   | NO_CM<br>D_INIT |
| Value after reset | 0   | 0   | 0   | 0   | 0    | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0               |
| Bit               | b15 | b14 | b13 | b12 | b11  | b10    | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0              |
|                   |     |     |     |     |      |        |     | TC  | DLL |     |     |     |     |     |     |                 |
| Value after reset | 0   | 0   | 0   | 0   | 0    | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0               |

Table 6.14 DDR\_CTL\_11 Register Contents

| Bit Position | Bit Name    | Function                                                                                                                                                                                  | R/W |
|--------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31, b30     | Reserved    | NA                                                                                                                                                                                        | R   |
| b29 to b24   | CASLAT_LIN  | Sets latency from read command send to data receive from/to controller. The upper bits [5:1] define memory CAS latency for the controller.  The bit [0] should be kept the initial value. | R/W |
| b23 to b17   | Reserved    | NA                                                                                                                                                                                        | R   |
| b16          | NO_CMD_INIT | Disable DRAM commands until the TDLL parameter has expired during initialization. Set to 1 to disable.                                                                                    | R/W |
| b15 to b0    | TDLL        | DRAM TDLL value (memory clock cycles)                                                                                                                                                     | R/W |

#### 6.4.1.13 DDR\_CTL\_12 — DDR-Controller Status & Control 12

Address: 4000 D030h



Table 6.15 DDR\_CTL\_12 Register Contents

| Bit Position | Bit Name              | Function                                                  | R/W |
|--------------|-----------------------|-----------------------------------------------------------|-----|
| b31 to b29   | Reserved              | NA                                                        | R   |
| b28 to b24   | TCCD                  | DRAM CAS-to-CAS value (memory clock cycles)               | R/W |
| b23 to b19   | Reserved              | NA                                                        | R   |
| b18 to b16   | TBST_INT_INTERVA<br>L | DRAM burst interrupt interval value (memory clock cycles) | R/W |
| b15 to b13   | Reserved              | NA                                                        | R   |
| b12 to b8    | ADDITIVE_LAT          | DRAM additive latency value (memory clock cycles)         | R/W |
| b7 to b5     | Reserved              | NA                                                        | R   |
| b4 to b0     | WRLAT                 | DRAM WRLAT value (memory clock cycles)                    | R/W |

# 6.4.1.14 DDR\_CTL\_13 — DDR-Controller Status & Control 13

Address: 4000 D034h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20  | b19   | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|------|-------|-----|-----|-----|
|                   | _   | _   |     |     | TW  | /TR |     |     |     |     |     | TRAS | S_MIN |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0     | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4   | b3    | b2  | b1  | b0  |
|                   |     |     |     | TF  | RC  |     |     |     |     |     |     | TR   | RD    |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0     | 0   | 0   | 0   |

Table 6.16 DDR\_CTL\_13 Register Contents

| Bit Position | Bit Name | Function                                  | R/W |
|--------------|----------|-------------------------------------------|-----|
| b31, b30     | Reserved | NA                                        | R   |
| b29 to b24   | TWTR     | DRAM TWTR value (memory clock cycles)     | R/W |
| b23 to b16   | TRAS_MIN | DRAM TRAS_MIN value (memory clock cycles) | R/W |
| b15 to b8    | TRC      | DRAM TRC value (memory clock cycles)      | R/W |
| b7 to b0     | TRRD     | DRAM TRRD value (memory clock cycles)     | R/W |

### 6.4.1.15 DDR\_CTL\_14 — DDR-Controller Status & Control 14

Address: 4000 D038h



Table 6.17 DDR\_CTL\_14 Register Contents

| Bit Position | Bit Name | Function                              | R/W |
|--------------|----------|---------------------------------------|-----|
| b31 to b29   | Reserved | NA                                    | R   |
| b28 to b24   | TMRD     | DRAM TMRD value (memory clock cycles) | R/W |
| b23 to b20   | Reserved | NA                                    | R   |
| b19 to b16   | TRTP     | DRAM TRTP value (memory clock cycles) | R/W |
| b15, b14     | Reserved | NA                                    | R   |
| b13 to b8    | TFAW     | DRAM TFAW value (memory clock cycles) | R/W |
| b7 to b5     | Reserved | NA                                    | R   |
| b4 to b0     | TRP      | DRAM TRP value (memory clock cycles)  | R/W |

## 6.4.1.16 DDR\_CTL\_15 — DDR-Controller Status & Control 15

Address: 4000 D03Ch

| Bit               | b31      | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20    | b19 | b18 | b17 | b16 |
|-------------------|----------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|--------|-----|-----|-----|-----|
|                   | _        | _   | _   | _   | _   | _   | _   |     |     |     | Т   | RAS_MA | ΑX  |     |     |     |
| Value after reset | 0        | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0   | 0   | 0   | 0   |
| Bit               | b15      | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4     | b3  | b2  | b1  | b0  |
|                   | TRAS_MAX |     |     |     |     |     |     |     |     |     |     | TM     | IOD |     |     |     |
| Value after reset | 0        | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0   | 0   | 0   | 0   |

Table 6.18 DDR\_CTL\_15 Register Contents

| Bit Position | Bit Name | Function                                                                              | R/W |
|--------------|----------|---------------------------------------------------------------------------------------|-----|
| b31 to b25   | Reserved | NA                                                                                    | R   |
| b24 to b8    | TRAS_MAX | DRAM TRAS_MAX value (memory clock cycles)                                             | R/W |
| b7 to b0     | TMOD     | Number of cycles after MRS command and before any other command (memory clock cycles) | R/W |

## 6.4.1.17 DDR\_CTL\_16 — DDR-Controller Status & Control 16

Address: 4000 D040h



Table 6.19 DDR\_CTL\_16 Register Contents

| Bit Position | Bit Name    | Function                                                                                                      | R/W |
|--------------|-------------|---------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | TRCD        | DRAM TRCD value (memory clock cycles)                                                                         | R/W |
| b23 to b17   | Reserved    | NA                                                                                                            | R   |
| b16          | WRITEINTERP | Allow controller to interrupt a write burst to the DRAMs with a read command. Set to 1 to allow interruption. | R/W |
| b15 to b8    | TCKESR      | Minimum CKE low pulse width during a self-refresh (memory clock cycles)                                       | R/W |
| b7 to b3     | Reserved    | NA                                                                                                            | R   |
| b2 to b0     | TCKE        | Minimum CKE pulse width (memory clock cycles)                                                                 | R/W |

## 6.4.1.18 DDR\_CTL\_17 — DDR-Controller Status & Control 17

Address: 4000 D044h



Table 6.20 DDR\_CTL\_17 Register Contents

| Bit Name     | Function                                                                                                            | R/W                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|---------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved     | NA                                                                                                                  | R                                                                                                                                                                                                                                                                                                                                                                            |
| TRAS_LOCKOUT | Allow the controller to execute auto pre-charge commands before the TRAS_MIN parameter expires. Set to 1 to enable. | R/W                                                                                                                                                                                                                                                                                                                                                                          |
| Reserved     | NA                                                                                                                  | R                                                                                                                                                                                                                                                                                                                                                                            |
| CONCURRENTAP | Allow controller to issue commands to other banks while a bank is in auto pre-charge. Set to 1 to enable.           | R/W                                                                                                                                                                                                                                                                                                                                                                          |
| Reserved     | NA                                                                                                                  | R                                                                                                                                                                                                                                                                                                                                                                            |
| AP           | Enable auto pre-charge mode of controller. Set to 1 to enable.                                                      | R/W                                                                                                                                                                                                                                                                                                                                                                          |
| Reserved     | NA                                                                                                                  | R                                                                                                                                                                                                                                                                                                                                                                            |
| TWR          | DRAM TWR value (memory clock cycles)                                                                                | R/W                                                                                                                                                                                                                                                                                                                                                                          |
|              | Reserved TRAS_LOCKOUT  Reserved CONCURRENTAP  Reserved AP Reserved                                                  | Reserved NA TRAS_LOCKOUT Allow the controller to execute auto pre-charge commands before the TRAS_MIN parameter expires. Set to 1 to enable.  Reserved NA CONCURRENTAP Allow controller to issue commands to other banks while a bank is in auto pre-charge. Set to 1 to enable.  Reserved NA AP Enable auto pre-charge mode of controller. Set to 1 to enable.  Reserved NA |

## 6.4.1.19 DDR\_CTL\_18 — DDR-Controller Status & Control 18

Address: 4000 D048h



Table 6.21 DDR\_CTL\_18 Register Contents

| Bit Position | Bit Name        | Function                                                                                                           | R/W |
|--------------|-----------------|--------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b25   | Reserved        | NA                                                                                                                 | R   |
| b24          | REG_DIMM_ENABLE | Enable registered DIMM operation of the controller. Set to 1 to enable.                                            | R/W |
| b23 to b21   | Reserved        | NA                                                                                                                 | R   |
| b20 to b16   | TRP_AB          | DRAM TRP all bank value (memory clock cycles)                                                                      | R/W |
| b15 to b11   | Reserved        | NA                                                                                                                 | R   |
| b10 to b8    | BSTLEN          | Encoded burst length sent to DRAMs during initialization. Set to 1 for BL2, set to 2 for BL4, or set to 3 for BL8. | R/W |
| b7, b6       | Reserved        | NA                                                                                                                 | R   |
| b5 to b0     | TDAL            | DRAM TDAL value (memory clock cycles)                                                                              | R/W |

# 6.4.1.20 DDR\_CTL\_19 — DDR-Controller Status & Control 19

Address: 4000 D04Ch

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24                 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16            |
|-------------------|-----|-----|-----|-----|-----|-----|-----|---------------------|-----|-----|-----|-----|-----|-----|-----|----------------|
|                   | _   | _   | _   | _   |     |     | _   | TREF_<br>ENABL<br>E | _   |     | ı   | ı   |     |     | _   | _              |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0              |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8                  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0             |
|                   | _   | _   | _   | _   | _   | _   | _   | AREFR<br>ESH        | _   | _   | _   | _   | _   | _   |     | SS_MIR<br>RING |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0              |

Table 6.22 DDR\_CTL\_19 Register Contents

| Bit Position | Bit Name              | Function                                                                                                                              | R/W |
|--------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b25   | Reserved              | NA                                                                                                                                    | R   |
| b24          | TREF_ENABLE           | Issue auto-refresh commands to the DRAMs at the interval defined in the TREF parameter. Set to 1 to enable.                           | R/W |
| b23 to b17   | Reserved              | NA                                                                                                                                    | R   |
| b16          | Reserved              | Reserved for future use. It should be kept the initial value.                                                                         | R/W |
| b15 to b9    | Reserved              | NA                                                                                                                                    | R   |
| b8           | AREFRESH              | Initiate auto-refresh at the end of the current burst boundary. Set to 1 to trigger.                                                  | W   |
| b7 to b2     | Reserved              | NA                                                                                                                                    | R   |
| b1, b0       | ADDRESS_MIRRORI<br>NG | Indicates which chip selects support address mirroring. Bit (0) controls cs0, bit (1) controls cs1, etc. Set each bit to 1 to enable. | R/W |

#### 6.4.1.21 DDR\_CTL\_20 — DDR-Controller Status & Control 20

Address: 4000 D050h



Table 6.23 DDR\_CTL\_20 Register Contents

| Bit Position | Bit Name | Function                              | R/W |
|--------------|----------|---------------------------------------|-----|
| b31, b30     | Reserved | NA                                    | R   |
| b29 to b16   | TREF     | DRAM TREF value (memory clock cycles) | R/W |
| b15 to b10   | Reserved | NA                                    | R   |
| b9 to b0     | TRFC     | DRAM TRFC value (memory clock cycles) | R/W |

### 6.4.1.22 DDR\_CTL\_21 — DDR-Controller Status & Control 21

Address: 4000 D054h



Table 6.24 DDR\_CTL\_21 Register Contents

| Bit Position | Bit Name      | Function                                                                             | R/W |
|--------------|---------------|--------------------------------------------------------------------------------------|-----|
| b31 to b16   | Reserved      | NA                                                                                   | R   |
| b15, b14     | Reserved      | NA                                                                                   | R   |
| b13 to b0    | TREF_INTERVAL | Defines the cycles between refreshes to different chip selects (memory clock cycles) | R/W |

## 6.4.1.23 DDR\_CTL\_22 — DDR-Controller Status & Control 22

Address: 4000 D058h



Table 6.25 DDR\_CTL\_22 Register Contents

| Bit Position | Bit Name | Function                                | R/W |
|--------------|----------|-----------------------------------------|-----|
| b31 to b16   | TXPDLL   | DRAM TXPDLL value (memory clock cycles) | R/W |
| b15 to b0    | TPDEX    | DRAM TPDEX value (memory clock cycles)  | R/W |

# 6.4.1.24 DDR\_CTL\_23 — DDR-Controller Status & Control 23

Address: 4000 D05Ch

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
|                   |     |     |     |     |     |     |     | TXA | RDS |     |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                   |     |     |     |     |     |     |     | TX  | ARD |     |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 6.26 DDR\_CTL\_23 Register Contents

| Bit Position | Bit Name | Function                                | R/W |
|--------------|----------|-----------------------------------------|-----|
| b31 to b16   | TXARDS   | DRAM TXARDS value (memory clock cycles) | R/W |
| b15 to b0    | TXARD    | DRAM TXARD value (memory clock cycles)  | R/W |

### 6.4.1.25 DDR\_CTL\_24 — DDR-Controller Status & Control 24

**Address:** 4000 D060h



Table 6.27 DDR\_CTL\_24 Register Contents

| Bit Position | Bit Name | Function                               | R/W |
|--------------|----------|----------------------------------------|-----|
| b31 to b16   | TXSNR    | DRAM TXSNR value (memory clock cycles) | R/W |
| b15 to b0    | TXSR     | DRAM TXSR value (memory clock cycles)  | R/W |

# 6.4.1.26 DDR\_CTL\_25 — DDR-Controller Status & Control 25

Address: 4000 D064h



Table 6.28 DDR\_CTL\_25 Register Contents

| Bit Position | Bit Name                     | Function                                                                                                  | R/W |
|--------------|------------------------------|-----------------------------------------------------------------------------------------------------------|-----|
| b31 to b27   | Reserved                     | NA                                                                                                        | R   |
| b26 to b24   | CKE_DELAY                    | Additional cycles to delay CKE for status reporting (DFICLK clock cycles)                                 | R/W |
| b23 to b17   | Reserved                     | NA                                                                                                        | R   |
| b16          | ENABLE_QUICK_SR<br>EFRESH    | Allow user to interrupt memory initialization to enter self-refresh mode. Set to 1 to allow interruption. | R/W |
| b15 to b9    | Reserved                     | NA                                                                                                        | R   |
| b8           | SREFRESH_EXIT_N<br>O_REFRESH | Disables the automatic refresh request associated with self-refresh exit. Set to 1 to disable.            | R/W |
| b7 to b1     | Reserved                     | NA                                                                                                        | R   |
| b0           | PWRUP_SREFRESH<br>_EXIT      | Allow power up via self-refresh instead of full memory initialization. Set to 1 to enable.                | R/W |

#### DDR\_CTL\_26 — DDR-Controller Status & Control 26 6.4.1.27

Address: 4000 D068h

| Bit               | b31 | b30 | b29 | b28  | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17           | b16                  |
|-------------------|-----|-----|-----|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---------------|----------------------|
|                   |     |     |     | LP_0 | CMD |     |     |     |     |     |     | CK  | SRX |     |               |                      |
| Value after reset | 0   | 0   | 0   | 0    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0             | 0                    |
| Bit               | b15 | b14 | b13 | b12  | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1            | b0                   |
|                   |     |     |     | CKS  | SRE |     |     |     | _   | _   | _   | _   | _   | _   | <b>EFRESI</b> | WER_R<br>H_ENAB<br>E |
| Value after reset | 0   | 0   | 0   | 0    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0             | 0                    |

| Table 6.29   | DDR_CTL_26 Reg              | ster Contents                                                                                                                                                                                                                                                                                                                                             |     |  |  |  |  |  |  |  |
|--------------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|--|--|
| Bit Position | Bit Name                    | Function                                                                                                                                                                                                                                                                                                                                                  | R/W |  |  |  |  |  |  |  |
| b31 to b24   | LP_CMD                      | Defines the low power command requested through the software programmable interface. When this command is completed, the low power command complete interrupt (bit 9) in the INT_STATUS parameter will be set to 1. Re-programming attempts to this parameter until the interrupt is set will be ignored. The bits are defined as follows:  Bit[7] = Lock | W   |  |  |  |  |  |  |  |
|              |                             | 1'b0 = No action                                                                                                                                                                                                                                                                                                                                          |     |  |  |  |  |  |  |  |
|              |                             | 1'b1 = Lock command                                                                                                                                                                                                                                                                                                                                       |     |  |  |  |  |  |  |  |
|              |                             | Bit[6] = Controller clock gating                                                                                                                                                                                                                                                                                                                          |     |  |  |  |  |  |  |  |
|              |                             | 1'b0 = No action                                                                                                                                                                                                                                                                                                                                          |     |  |  |  |  |  |  |  |
|              |                             | 1'b1 = Gate the controller clock                                                                                                                                                                                                                                                                                                                          |     |  |  |  |  |  |  |  |
|              |                             | Bit[5] = Memory clock gating                                                                                                                                                                                                                                                                                                                              |     |  |  |  |  |  |  |  |
|              |                             | 1'b0 = No action                                                                                                                                                                                                                                                                                                                                          |     |  |  |  |  |  |  |  |
|              |                             | 1'b1 = Gate the memory clock                                                                                                                                                                                                                                                                                                                              |     |  |  |  |  |  |  |  |
|              |                             | Bits[4:2] = Low power state                                                                                                                                                                                                                                                                                                                               |     |  |  |  |  |  |  |  |
|              |                             | 3'b000 = Active power-down                                                                                                                                                                                                                                                                                                                                |     |  |  |  |  |  |  |  |
|              |                             | 3'b001 = Pre-charge power-down                                                                                                                                                                                                                                                                                                                            |     |  |  |  |  |  |  |  |
|              |                             | 3'b010 = Self-refresh                                                                                                                                                                                                                                                                                                                                     |     |  |  |  |  |  |  |  |
|              |                             | All other settings are Reserved                                                                                                                                                                                                                                                                                                                           |     |  |  |  |  |  |  |  |
|              |                             | Bit[1] = Entry command                                                                                                                                                                                                                                                                                                                                    |     |  |  |  |  |  |  |  |
|              |                             | 1'b0 = No action                                                                                                                                                                                                                                                                                                                                          |     |  |  |  |  |  |  |  |
|              |                             | 1'b1 = Enter the specified state                                                                                                                                                                                                                                                                                                                          |     |  |  |  |  |  |  |  |
|              |                             | Bit[0] = Exit command                                                                                                                                                                                                                                                                                                                                     |     |  |  |  |  |  |  |  |
|              |                             | 1'b0 = No action                                                                                                                                                                                                                                                                                                                                          |     |  |  |  |  |  |  |  |
|              |                             | 1'b1 = Exit any low power                                                                                                                                                                                                                                                                                                                                 |     |  |  |  |  |  |  |  |
| b23 to b16   | CKSRX                       | Clock stable delay on self-refresh exit (memory clock cycles)                                                                                                                                                                                                                                                                                             | R/W |  |  |  |  |  |  |  |
| b15 to b8    | CKSRE                       | Clock hold delay on self-refresh entry (memory clock cycles)                                                                                                                                                                                                                                                                                              | R/W |  |  |  |  |  |  |  |
| b7 to b2     | Reserved                    | NA                                                                                                                                                                                                                                                                                                                                                        | R   |  |  |  |  |  |  |  |
| b1, b0       | LOWPOWER_REFR<br>ESH_ENABLE | NA. It should be kept the initial value.                                                                                                                                                                                                                                                                                                                  | R/W |  |  |  |  |  |  |  |

## 6.4.1.28 DDR\_CTL\_27 — DDR-Controller Status & Control 27

Address: 4000 D06Ch

| Bit               | b31 | b30 | b29 | b28 | b27 | b26    | b25     | b24   | b23 | b22 | b21 | b20 | b19  | b18   | b17    | b16   |
|-------------------|-----|-----|-----|-----|-----|--------|---------|-------|-----|-----|-----|-----|------|-------|--------|-------|
|                   | _   | _   | _   | _   | _   | LP_AI  | UTO_EX  | IT_EN | _   | _   | _   | _   | _    | LP_AU | TO_ENT | RY_EN |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0      | 0       | 0     | 0   | 0   | 0   | 0   | 0    | 0     | 0      | 0     |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10    | b9      | b8    | b7  | b6  | b5  | b4  | b3   | b2    | b1     | b0    |
|                   | _   | _   | _   | _   |     | LP_ARB | S_STATE |       | _   | _   |     |     | LP_S | STATE |        |       |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0      | 0       | 0     | 0   | 0   | 1   | 0   | 0    | 0     | 0      | 0     |

Table 6.30 DDR\_CTL\_27 Register Contents

| Bit Position       | Bit Name             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R/W |  |
|--------------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|
| b31 to b27         | Reserved             | NA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R   |  |
| b26 to b24         | LP_AUTO_EXIT_EN      | Enable auto exit from each of the low power states when a read or write command enters the command queue. Bit (0) controls power-down, bit (1) controls self-refresh, and bit (2) controls self-refresh with memory and controller clock gating. Set each bit to 1 to enable.                                                                                                                                                                                                                                                                                                                                                      | R/W |  |
| b23 to b19         | Reserved             | NA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R   |  |
| b18 to b16         | LP_AUTO_ENTRY_E<br>N | Enable auto entry into each of the low power states when the associated idle timer expires. Bit (0) controls power-down, bit (1) controls self-refresh, and bit (2) controls self-refresh with memory and controller clock gating. Set each bit to 1 to enable.                                                                                                                                                                                                                                                                                                                                                                    | R/W |  |
| b15 to b12         | Reserved             | NA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R   |  |
| b11 to b8          | LP_ARB_STATE         | Reports on the state of the arbiter. Bits (2:0) indicate which interface has control of the low power control module and bit (3) indicates if the software programmable interface has an active lock on the arbiter. For bits (2:0), value of 0 indicates module is idle, value of 1 indicates software programmable interface is in control, value of 3 indicates automatic interface is in control, value of 4 indicates dynamic power control per chip select interface is in control, and value of 5 indicates that the controller is in control.                                                                              | R   |  |
| b7, b6             | Reserved             | NA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R   |  |
| b7, b6<br>b5 to b0 | LP_STATE             | Holds the state of the DRAM memories:  Bit[5] = Valid status. This bit will be cleared to 1'b0 when a command is accepted on the software programmable interfaces, and remain at 1'b0 until the command has completed.  1'b0 = Invalid, low power state currently in transition  1'b1 = Valid, stable low power state  Bits [4:0] = Low power state  5'b00000 = Idle  5'b00001 = Active Power-Down  5'b00011 = Pre-Charge Power-Down  5'b00101 = Self-Refresh  5'b00110 = Self-Refresh with Memory Clock Gating  5'b00111 = Self-Refresh with Memory and Controller Clock Gating  All other settings are Reserved, must not be set | R   |  |
|                    |                      | <b>Note)</b> If an active power-down was requested, this parameter will reflect the requested active power-down state even if pre-charge power-down is used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |  |

# 6.4.1.29 DDR\_CTL\_28 — DDR-Controller Status & Control 28

Address: 4000 D070h

| Bit               | b31             | b30 | b29 | b28    | b27     | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18             | b17 | b16           |  |
|-------------------|-----------------|-----|-----|--------|---------|-----|-----|-----|-----|-----|-----|-----|-----|-----------------|-----|---------------|--|
|                   |                 |     | LI  | P_AUTO | _SR_IDI | _E  |     |     | _   | _   | _   | _   | LI  | LP_AUTO_PD_IDLE |     |               |  |
| Value after reset | 0               | 0   | 0   | 0      | 0       | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0               | 0   | 0             |  |
| Bit               | b15             | b14 | b13 | b12    | b11     | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2              | b1  | b0            |  |
|                   | LP_AUTO_PD_IDLE |     |     |        |         |     |     |     | _   | _   | _   | _   | _   | _               |     | O_MEM<br>E_EN |  |
| Value after reset | 0               | 0   | 0   | 0      | 0       | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0               | 0   | 0             |  |

Table 6.31 DDR\_CTL\_28 Register Contents

| Bit Position | Bit Name                | Function                                                                                                                                                                                 | R/W |
|--------------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | LP_AUTO_SR_IDLE         | Number of long count sequences until the controller will place memory in self-refresh.                                                                                                   | R/W |
| b23 to b20   | Reserved                | NA                                                                                                                                                                                       | R   |
| b19 to b8    | LP_AUTO_PD_IDLE         | Defines the idle time until the controller will place memory in active power-down. (DFICLK clock cycles)                                                                                 | R/W |
| b7 to b2     | Reserved                | NA                                                                                                                                                                                       | R   |
| b1, b0       | LP_AUTO_MEM_GA<br>TE_EN | Enable memory clock gating when entering a low power state via the auto low power counters. Bit (0) controls power-down, and bit (1) controls self-refresh. Set each bit to 1 to enable. | R/W |

#### 6.4.1.30 DDR\_CTL\_29 — DDR-Controller Status & Control 29

Address: 4000 D074h



Table 6.32 DDR\_CTL\_29 Register Contents

| Bit Position | Bit Name                    | Function                                                                                                                       | R/W |
|--------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b15   | Reserved                    | NA                                                                                                                             | R   |
| b14 to b8    | Reserved                    | Reserved for future use. It should be kept the initial value.                                                                  | R/W |
| b7 to b0     | LP_AUTO_SR_MC_<br>GATE_IDLE | Number of long count sequences until the controller will place memory in self-refresh with controller and memory clock gating. | R/W |

## 6.4.1.31 DDR\_CTL\_30 — DDR-Controller Status & Control 30

**Address:** 4000 D078h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24     | b23   | b22 | b21     | b20   | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|---------|-------|-----|---------|-------|-----|-----|-----|-----|
|                   | _   | _   | _   | _   | _   | _   |     |         |       | ٧   | VRITE_M | ODERE | G   |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0       | 0     | 0   | 0       | 0     | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8      | b7    | b6  | b5      | b4    | b3  | b2  | b1  | b0  |
|                   |     |     |     |     |     |     | ٧   | VRITE_M | ODERE | G   |         |       |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0       | 0     | 0   | 0       | 0     | 0   | 0   | 0   | 0   |

Table 6.33 DDR\_CTL\_30 Register Contents

| Bit Position | Bit Name      | Function                                                             | R/W |
|--------------|---------------|----------------------------------------------------------------------|-----|
| b31 to b26   | Reserved      | NA                                                                   | R   |
| b25 to b0    | WRITE_MODEREG | Write memory mode register data to the DRAMs.                        | R/W |
|              |               | Bits (7:0) define the memory mode register number if bit (23) is set |     |
|              |               | bits (15:8) define the chip select if bit (24) is clear              |     |
|              |               | bits (23:16) define which memory mode register/s to write            |     |
|              |               | bit (24) defines whether all chip selects will be written            |     |
|              |               | bit (25) triggers the write.                                         |     |
|              |               | Writeable but may also be changed by the internal logic.             |     |

#### 6.4.1.32 DDR\_CTL\_31 — DDR-Controller Status & Control 31

Address: 4000 D07Ch



Table 6.34 DDR\_CTL\_31 Register Contents

| Bit Position | Bit Name   | Function                                                                                                 | R/W |
|--------------|------------|----------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved   | NA                                                                                                       | R   |
| b23 to b8    | MR0_DATA_0 | Data to program into memory mode register 0 for chip select 0.                                           | R/W |
| b7 to b0     | MRW_STATUS | Status of Write memory mode register. Bit (0) set indicates a WRITE_MODEREG parameter programming error. | R   |

## 6.4.1.33 DDR\_CTL\_32 — DDR-Controller Status & Control 32

Address: 4000 D080h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24   | b23    | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|-------|--------|-----|-----|-----|-----|-----|-----|-----|
|                   |     |     |     |     |     |     |     | MR2_D | DATA_0 |     |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8    | b7     | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                   |     |     |     |     |     |     |     | MR1_E | DATA_0 |     |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 6.35 DDR\_CTL\_32 Register Contents

| Bit Position | Bit Name   | Function                                                       | R/W |
|--------------|------------|----------------------------------------------------------------|-----|
| b31 to b16   | MR2_DATA_0 | Data to program into memory mode register 2 for chip select 0. | R/W |
| b15 to b0    | MR1_DATA_0 | Data to program into memory mode register 1 for chip select 0. | R/W |

### 6.4.1.34 DDR\_CTL\_33 — DDR-Controller Status & Control 33

Address: 4000 D084h



Table 6.36 DDR\_CTL\_33 Register Contents

| Bit Position | Bit Name        | Function                                                                 | R/W |
|--------------|-----------------|--------------------------------------------------------------------------|-----|
| b31 to b16   | MR3_DATA_0      | Data to program into memory mode register 3 for chip select 0.           | R/W |
| b15 to b0    | MRSINGLE_DATA_0 | Data to program into memory mode register single write to chip select 0. | R/W |

# 6.4.1.35 DDR\_CTL\_34 — DDR-Controller Status & Control 34

Address: 4000 D088h

| Bit                    | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24   | b23   | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|------------------------|-----|-----|-----|-----|-----|-----|-----|-------|-------|-----|-----|-----|-----|-----|-----|-----|
|                        |     |     |     |     |     |     |     | MR1_C | ATA_1 |     |     |     |     |     |     |     |
| Value after reset      | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit                    | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8    | b7    | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                        |     |     |     |     |     |     |     | MR0_D | ATA_1 |     |     |     |     |     |     |     |
| L<br>Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 6.37 DDR\_CTL\_34 Register Contents

| Bit Position | Bit Name   | Function                                                       | R/W |
|--------------|------------|----------------------------------------------------------------|-----|
| b31 to b16   | MR1_DATA_1 | Data to program into memory mode register 1 for chip select 1. | R/W |
| b15 to b0    | MR0_DATA_1 | Data to program into memory mode register 0 for chip select 1. | R/W |

### 6.4.1.36 DDR\_CTL\_35 — DDR-Controller Status & Control 35

Address: 4000 D08Ch



Table 6.38 DDR\_CTL\_35 Register Contents

| Bit Position | Bit Name        | Function                                                                 | R/W |
|--------------|-----------------|--------------------------------------------------------------------------|-----|
| b31 to b16   | MRSINGLE_DATA_1 | Data to program into memory mode register single write to chip select 1. | R/W |
| b15 to b0    | MR2_DATA_1      | Data to program into memory mode register 2 for chip select 1.           | R/W |

### 6.4.1.37 DDR\_CTL\_36 — DDR-Controller Status & Control 36

Address: 4000 D090h



Table 6.39 DDR\_CTL\_36 Register Contents

| Bit Position | Bit Name   | Function                                                                                                                                                                                               | R/W |
|--------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b25   | Reserved   | NA                                                                                                                                                                                                     | R   |
| b24          | FWC        | Force a write check. Xor the XOR_CHECK_BITS parameter with the ECC code and write to memory. Set to 1 to trigger.                                                                                      | W   |
| b23 to b17   | Reserved   | NA                                                                                                                                                                                                     | R   |
| b16          | ECC_EN     | ECC error checking and correcting control. Set to 0 to disable ECC or set to 1 for ECC reporting and correcting. To enable the ECC function, set the "REDUC" to 1 to enable the half datapath feature. | R/W |
| b15 to b0    | MR3_DATA_1 | Data to program into memory mode register 3 for chip select 1.                                                                                                                                         | R/W |

#### 6.4.1.38 DDR\_CTL\_37 — DDR-Controller Status & Control 37

Address: 4000 D094h



Table 6.40 DDR\_CTL\_37 Register Contents

| Bit Position | Bit Name                 | Function                                                                                                                          | R/W |
|--------------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved                 | NA                                                                                                                                | R   |
| b23 to b17   | Reserved                 | NA                                                                                                                                | R   |
| b16          | ECC_DISABLE_W_U<br>C_ERR | Controls auto-corruption of ECC when un-correctable errors occur in read/modify/write operations. Set to 1 to disable corruption. | R/W |
| b15, b14     | Reserved                 | NA                                                                                                                                | R   |
| b13 to b0    | XOR_CHECK_BITS           | Value to xor with generated ECC codes for forced write check.                                                                     | R/W |

### 6.4.1.39 DDR\_CTL\_38 — DDR-Controller Status & Control 38

Address: 4000 D098h



Table 6.41 DDR\_CTL\_38 Register Contents

| Bit Position | Bit Name   | Function                            | R/W |
|--------------|------------|-------------------------------------|-----|
| b31 to b0    | ECC_U_ADDR | Address of uncorrectable ECC event. | R   |

#### 6.4.1.40 DDR\_CTL\_39 — DDR-Controller Status & Control 39

Address: 4000 D09Ch



Table 6.42 DDR\_CTL\_39 Register Contents

| Bit Position | Bit Name   | Function                              | R/W |
|--------------|------------|---------------------------------------|-----|
| b31 to b8    | Reserved   | NA                                    | R   |
| b7           | Reserved   | NA                                    | R   |
| b6 to b0     | ECC_U_SYND | Syndrome for uncorrectable ECC event. | R   |

#### 6.4.1.41 DDR\_CTL\_40 — DDR-Controller Status & Control 40

Address: 4000 D0A0h



Table 6.43 DDR\_CTL\_40 Register Contents

| Bit Position | Bit Name   | Function                                      | R/W |
|--------------|------------|-----------------------------------------------|-----|
| b31 to b0    | ECC_U_DATA | Data associated with uncorrectable ECC event. | R   |

#### 6.4.1.42 DDR\_CTL\_41 — DDR-Controller Status & Control 41

Address: 4000 D0A4h



Table 6.44 DDR\_CTL\_41 Register Contents

| Bit Position | Bit Name   | Function                          | R/W |
|--------------|------------|-----------------------------------|-----|
| b31 to b0    | ECC_C_ADDR | Address of correctable ECC event. | R   |

### 6.4.1.43 DDR\_CTL\_42 — DDR-Controller Status & Control 42

Address: 4000 D0A8h



Table 6.45 DDR\_CTL\_42 Register Contents

| Bit Position | Bit Name   | Function                            | R/W |
|--------------|------------|-------------------------------------|-----|
| b31 to b8    | Reserved   | NA                                  | R   |
| b7           | Reserved   | NA                                  | R   |
| b6 to b0     | ECC_C_SYND | Syndrome for correctable ECC event. | R   |

## 6.4.1.44 DDR\_CTL\_43 — DDR-Controller Status & Control 43

Address: 4000 D0ACh



Table 6.46 DDR\_CTL\_43 Register Contents

| Bit Position | Bit Name   | Function                                    | R/W |
|--------------|------------|---------------------------------------------|-----|
| b31 to b0    | ECC_C_DATA | Data associated with correctable ECC event. | R   |

### 6.4.1.45 DDR\_CTL\_44 — DDR-Controller Status & Control 44

Address: 4000 D0B0h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19   | b18   | b17   | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-------|-------|-------|-----|
|                   | _   | _   | _   | _   | _   | _   | _   | _   | _   | _   | _   |     | LONG_ | COUNT | _MASK |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0     | 0     | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3    | b2    | b1    | b0  |
|                   | _   | _   | _   | _   | _   | _   | _   | _   | _   | _   | _   | _   | _     | _     | _     | _   |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0     | 0     | 0   |

Table 6.47 DDR\_CTL\_44 Register Contents

| Bit Position | Bit Name            | Function                                                                                                                                                                                                   | R/W |
|--------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved            | NA                                                                                                                                                                                                         | R   |
| b23 to b21   | Reserved            | NA                                                                                                                                                                                                         | R   |
| b20 to b16   | LONG_COUNT_MAS<br>K | Reduces the length of the long counter from 1024 cycles. The only supported values are 0x00 (1024 cycles), 0x10 (512 clocks), 0x18 (256 clocks), 0x1C (128 clocks), 0x1E (64 clocks) and 0x1F (32 clocks). | R/W |
| b15 to b0    | Reserved            | NA                                                                                                                                                                                                         | R   |

## 6.4.1.46 DDR\_CTL\_45 — DDR-Controller Status & Control 45

Address: 4000 D0B4h



Table 6.48 DDR\_CTL\_45 Register Contents

| Bit Position | Bit Name | Function                                                           | R/W |
|--------------|----------|--------------------------------------------------------------------|-----|
| b31 to b28   | Reserved | NA                                                                 | R   |
| b27 to b16   | ZQCL     | Number of cycles needed for a ZQCL command (memory clock cycles)   | R/W |
| b15 to b12   | Reserved | NA                                                                 | R   |
| b11 to b0    | ZQINIT   | Number of cycles needed for a ZQINIT command (memory clock cycles) | R/W |

# 6.4.1.47 DDR\_CTL\_46 — DDR-Controller Status & Control 46

Address: 4000 D0B8h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25         | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|
|                   | _   | _   | _   | _   | _   | _   | ZQ_ON<br>E> |     | _   | _   | _   | _   | _   | _   | ZQ_ | REQ |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0           | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9          | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                   | _   | _   | _   | _   |     |     |             |     |     | ZQ  | CS  |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0           | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 6.49 DDR\_CTL\_46 Register Contents

| Bit Position | Bit Name        | Function                                                                                                                                         | R/W |
|--------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b26   | Reserved        | NA                                                                                                                                               | R   |
| b25, b24     | ZQ_ON_SREF_EXIT | Defines the type of ZQ calibration performed at self-refresh exit. Bit (0) selects ZQCS and bit (1) selects ZQCL. Set either bit to 1 to enable. | R/W |
| b23 to b18   | Reserved        | NA                                                                                                                                               | R   |
| b17, b16     | ZQ_REQ          | User request to initiate a ZQ calibration. Bit (0) controls ZQCS and bit (1) controls ZQCL. Set either bit to 1 to trigger.                      | W   |
| b15 to b12   | Reserved        | NA                                                                                                                                               | R   |
| b11 to b0    | ZQCS            | Number of cycles needed for a ZQCS command (memory clock cycles)                                                                                 | R/W |

#### 6.4.1.48 DDR\_CTL\_47 — DDR-Controller Status & Control 47

Address: 4000 D0BCh



Table 6.50 DDR\_CTL\_47 Register Contents

| Bit Position | Bit Name    | Function                                                                | R/W |
|--------------|-------------|-------------------------------------------------------------------------|-----|
| b31 to b0    | ZQ_INTERVAL | Number of long count sequences allowed between automatic ZQCS commands. | R/W |

## 6.4.1.49 DDR\_CTL\_48 — DDR-Controller Status & Control 48

Address: 4000 D0C0h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25   | b24                 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16                    |
|-------------------|-----|-----|-----|-----|-----|-----|-------|---------------------|-----|-----|-----|-----|-----|-----|-----|------------------------|
|                   | _   | _   | _   | _   | _   | R   | OW_DI | FF                  | _   | _   | l   | ı   | _   | _   | BAN | K_DIFF                 |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0                   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                      |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9    | b8                  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0                     |
|                   | _   | _   | _   | _   | _   | _   | _     | ZQCS_<br>ROTAT<br>E | _   | _   | ı   | ı   | _   | _   |     | ZQ_IN_<br>PROGR<br>ESS |
| Value after reset | Λ   | ٥   | Λ   | 0   | Λ   | Λ   | 0     | 0                   | Λ   | 0   | Λ   | Λ   | 0   | 0   | ٥   | 0                      |

Table 6.51 DDR\_CTL\_48 Register Contents

| Bit Position | Bit Name       | Function                                                                                                          | R/W |
|--------------|----------------|-------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b27   | Reserved       | NA                                                                                                                | R   |
| b26 to b24   | ROW_DIFF       | Difference between number of address pins available (16) and number being used.                                   | R/W |
| b23 to b18   | Reserved       | NA                                                                                                                | R   |
| b17, b16     | BANK_DIFF      | Encoded number of banks on the DRAM(s).  2'b00 = 8 banks  2'b01 = 4 banks  2'b10 = 2 banks  2'b11 = Reserved      | R/W |
| b15 to b9    | Reserved       | NA                                                                                                                | R   |
| b8           | ZQCS_ROTATE    | Selects whether a ZQCS command will calibrate just one chip select or all chip selects. Set to 1 for rotating CS. | R/W |
| b7 to b1     | Reserved       | NA                                                                                                                | R   |
| b0           | ZQ_IN_PROGRESS | Indicates that a ZQ command is currently in progress. Value of 1 indicates command in progress.                   | R   |
|              |                |                                                                                                                   |     |

### 6.4.1.50 DDR\_CTL\_49 — DDR-Controller Status & Control 49

Address: 4000 D0C4h

| Bit               | b31 | b30 | b29 | b28    | b27    | b26     | b25 | b24 | b23 | b22 | b21 | b20   | b19   | b18  | b17   | b16 |
|-------------------|-----|-----|-----|--------|--------|---------|-----|-----|-----|-----|-----|-------|-------|------|-------|-----|
|                   |     |     | COM | IMAND_ | AGE_CC | DUNT    |     |     |     |     |     | AGE_C | COUNT |      |       |     |
| Value after reset | 0   | 0   | 0   | 0      | 0      | 0       | 0   | 0   | 0   | 0   | 0   | 0     | 0     | 0    | 0     | 0   |
| Bit               | b15 | b14 | b13 | b12    | b11    | b10     | b9  | b8  | b7  | b6  | b5  | b4    | b3    | b2   | b1    | b0  |
|                   | _   | _   | _   | _      |        | APREBIT |     |     |     | _   | _   | _     |       | COL_ | _DIFF |     |
| Value after reset | 0   | 0   | 0   | 0      | 1      | 0       | 1   | 0   | 0   | 0   | 0   | 0     | 0     | 0    | 0     | 0   |

Table 6.52 DDR\_CTL\_49 Register Contents

| Bit Position | Bit Name              | Function                                                                                   | R/W |
|--------------|-----------------------|--------------------------------------------------------------------------------------------|-----|
| b31 to b24   | COMMAND_AGE_C<br>OUNT | Initial value of individual command aging counters for command aging (DFICLK clock cycles) | R/W |
| b23 to b16   | AGE_COUNT             | Initial value of master aging-rate counter for command aging (DFICLK clock cycles)         | R/W |
| b15 to b12   | Reserved              | NA                                                                                         | R   |
| b11 to b8    | APREBIT               | Location of the auto pre-charge bit in the DRAM address.                                   | R/W |
| b7 to b4     | Reserved              | NA                                                                                         | R   |
| b3 to b0     | COL_DIFF              | Difference between number of column pins available (11) and number being used.             | R/W |

#### 6.4.1.51 DDR\_CTL\_50 — DDR-Controller Status & Control 50

Address: 4000 D0C8h



Table 6.53 DDR\_CTL\_50 Register Contents

| Bit Position | Bit Name      | Function                                                                                      | R/W |
|--------------|---------------|-----------------------------------------------------------------------------------------------|-----|
| b31 to b25   | Reserved      | NA                                                                                            | R   |
| b24          | PLACEMENT_EN  | Enable placement logic for command queue. Set to 1 to enable.                                 | R/W |
| b23 to b17   | Reserved      | NA                                                                                            | R   |
| b16          | BANK_SPLIT_EN | Enable bank splitting as a rule for command queue placement. Set to 1 to enable.              | R/W |
| b15 to b9    | Reserved      | NA                                                                                            | R   |
| b8           | Reserved      | Reserved for future use. It should be set to 1.                                               | R/W |
| b7 to b1     | Reserved      | NA                                                                                            | R   |
| b0           | ADDR_CMP_EN   | Enable address collision detection as a rule for command queue placement. Set to 1 to enable. | R/W |

## 6.4.1.52 DDR\_CTL\_51 — DDR-Controller Status & Control 51

Address: 4000 D0CCh

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24            | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16                     |
|-------------------|-----|-----|-----|-----|-----|-----|-----|----------------|-----|-----|-----|-----|-----|-----|-----|-------------------------|
|                   | _   | _   | _   | _   |     | _   |     | CS_SA<br>ME_EN | _   |     | ı   | ı   |     | ı   | _   | RW_SA<br>ME_PA<br>GE_EN |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0              | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                       |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8             | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0                      |
|                   | _   | _   | _   | _   | ı   | _   | 1   | RW_SA<br>ME_EN | _   |     | 1   | l   |     | l   |     | PRIORI<br>TY_EN         |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0              | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                       |

Table 6.54 DDR\_CTL\_51 Register Contents

| Bit Position | Bit Name            | Function                                                                                                                                                                 | R/W |
|--------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b25   | Reserved            | NA                                                                                                                                                                       | R   |
| b24          | CS_SAME_EN          | Enable chip select grouping when read/write grouping as a rule for command queue placement. This is only valid when the RW_SAME_EN parameter is set. Set to 1 to enable. | R/W |
| b23 to b17   | Reserved            | NA                                                                                                                                                                       | R   |
| b16          | RW_SAME_PAGE_E<br>N | Enable page grouping when read/write grouping as a rule for command queue placement. This is only valid when the RW_SAME_EN parameter is set. Set to 1 to enable.        | R/W |
| b15 to b9    | Reserved            | NA                                                                                                                                                                       | R   |
| b8           | RW_SAME_EN          | Enable read/write grouping as a rule for command queue placement. Set to 1 to enable.                                                                                    | R/W |
| b7 to b1     | Reserved            | NA                                                                                                                                                                       | R   |
| b0           | PRIORITY_EN         | Enable priority as a rule for command queue placement. Set to 1 to enable.                                                                                               | R/W |

## 6.4.1.53 DDR\_CTL\_52 — DDR-Controller Status & Control 52

Address: 4000 D0D0h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25   | b24                        | b23 | b22 | b21 | b20 | b19 | b18 | b17             | b16                  |
|-------------------|-----|-----|-----|-----|-----|-----|-------|----------------------------|-----|-----|-----|-----|-----|-----|-----------------|----------------------|
|                   | _   | _   | _   | _   | _   | _   | _     | SWAP_<br>EN                | _   | _   | _   | _   | _   |     | _ENTR<br>_DISAB | IES_ACT<br>LE        |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0                          | 0   | 0   | 0   | 0   | 0   | 0   | 0               | 0                    |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9    | b8                         | b7  | b6  | b5  | b4  | b3  | b2  | b1              | b0                   |
|                   | _   | _   | -   | _   | _   | _   | GROUP | _E_RW_<br>P_W_BN<br>NFLICT | _   | _   | _   | _   | _   | _   | _               | W2R_S<br>PLIT_E<br>N |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0                          | 0   | 0   | 0   | 0   | 0   | 0   | 0               | 0                    |

Table 6.55 DDR\_CTL\_52 Register Contents

| Bit Position | Bit Name                                | Function                                                                                                                                                                                                                                | R/W |
|--------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b25   | Reserved                                | NA                                                                                                                                                                                                                                      | R   |
| b24          | SWAP_EN                                 | Enable command swapping logic in execution unit. Set to 1 to enable.                                                                                                                                                                    | R/W |
| b23 to b19   | Reserved                                | NA                                                                                                                                                                                                                                      | R   |
| b18 to b16   | NUM_Q_ENTRIES_A<br>CT_DISABLE           | Number of queue entries in which ACT requests will be disabled. Setting to X will disable ACT requests from the X entries lowest in the command queue.                                                                                  | R/W |
| b15 to b10   | Reserved                                | NA                                                                                                                                                                                                                                      | R   |
| b9, b8       | DISABLE_RW_GRO<br>UP_W_BNK_CONFLI<br>CT | Disables placement to read/write group when grouping creates a bank collision. Bit (0) controls placement next to bank conflict command and bit (1) controls placement 2 away from bank conflict command. Set each bit to 1 to disable. | R/W |
| b7 to b1     | Reserved                                | NA                                                                                                                                                                                                                                      | R   |
| b0           | W2R_SPLIT_EN                            | Enable splitting of commands to the same chip select from a write to a read command as a rule for command queue placement. Set to 1 to enable.                                                                                          | R/W |

## 6.4.1.54 DDR\_CTL\_53 — DDR-Controller Status & Control 53

Address: 4000 D0D4h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26     | b25    | b24                      | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16                               |
|-------------------|-----|-----|-----|-----|-----|---------|--------|--------------------------|-----|-----|-----|-----|-----|-----|-----|-----------------------------------|
|                   | _   | _   | _   | _   | Bl  | JRST_OI | N_FLY_ | BIT                      | _   | _   | _   | _   | _   | _   | cs  | _MAP                              |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0       | 0      | 0                        | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                                 |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10     | b9     | b8                       | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0                                |
|                   | _   |     |     | _   |     | _       | _      | INHIBIT<br>_DRAM<br>_CMD |     | _   |     |     |     |     | _   | DISABL<br>E_RD_I<br>NTERL<br>EAVE |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0       | 0      | 0                        | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                                 |

Table 6.56 DDR\_CTL\_53 Register Contents

| Bit Position | Bit Name                  | Function                                                                                                                            | R/W |
|--------------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b28   | Reserved                  | NA                                                                                                                                  | R   |
| b27 to b24   | BURST_ON_FLY_BI<br>T      | Identifies the burst-on-fly bit in the memory mode registers.                                                                       | R/W |
| b23 to b18   | Reserved                  | NA                                                                                                                                  | R   |
| b17, b16     | CS_MAP                    | Defines which chip selects are active.                                                                                              | R/W |
| b15 to b9    | Reserved                  | NA                                                                                                                                  | R   |
| b8           | INHIBIT_DRAM_CMD          | Inhibit read/write command traffic and associated bank commands. Set to 1 to inhibit.                                               | R/W |
| b7 to b1     | Reserved                  | NA                                                                                                                                  | R   |
| b0           | DISABLE_RD_INTER<br>LEAVE | Disable read data interleaving for commands from the same port.  0: Allow read data interleaving  1: Disable read data interleaving | R/W |

## 6.4.1.55 DDR\_CTL\_54 — DDR-Controller Status & Control 54

Address: 4000 D0D8h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25    | b24                     | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16                     |
|-------------------|-----|-----|-----|-----|-----|-----|--------|-------------------------|-----|-----|-----|-----|-----|-----|-----|-------------------------|
|                   | _   |     |     |     |     | _   | _      | CONTR<br>OLLER<br>_BUSY | _   | _   |     |     | _   |     | _   | IN_OR<br>DER_A<br>CCEPT |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0                       | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                       |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9     | b8                      | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0                      |
|                   | _   | _   | _   | _   | _   | Q_  | FULLNI | ESS                     | _   | _   | _   | _   | _   | _   | _   | REDUC                   |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0                       | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                       |

Table 6.57 DDR\_CTL\_54 Register Contents

| Table 0.51   | DDI\_OTE_5+ Regi    | ister contents                                                                                                                                 |     |
|--------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Bit Position | Bit Name            | Function                                                                                                                                       | R/W |
| b31 to b25   | Reserved            | NA                                                                                                                                             | R   |
| b24          | CONTROLLER_BUS<br>Y | Indicator that the controller is processing a command. Evaluates all ports for outstanding transactions. Value of 1 indicates controller busy. | R   |
| b23 to b17   | Reserved            | NA                                                                                                                                             | R   |
| b16          | IN_ORDER_ACCEPT     | Forces the controller to accept commands in the order in which they are placed in the command queue.                                           | R/W |
|              |                     | 0: Uses the selection logic to select the ideal command for execution                                                                          |     |
|              |                     | 1: Disables the selection logic and executes commands in order                                                                                 |     |
| b15 to b11   | Reserved            | NA                                                                                                                                             | R   |
| b10 to b8    | Q_FULLNESS          | Quantity that determines command queue full.                                                                                                   | R/W |
| b7 to b1     | Reserved            | NA                                                                                                                                             | R   |
| b0           | REDUC               | Enable the half datapath feature of the controller. Set to 1 to enable. Data is transmitted on the lower datapath.                             | R/W |
|              |                     |                                                                                                                                                |     |

## 6.4.1.56 DDR\_CTL\_55 — DDR-Controller Status & Control 55

Address: 4000 D0DCh



Table 6.58 DDR\_CTL\_55 Register Contents

| Bit Position | Bit Name                    | Function                                                                                                   | R/W |
|--------------|-----------------------------|------------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | Reserved                    | NA                                                                                                         | R   |
| b15 to b9    | Reserved                    | NA                                                                                                         | R   |
| b8           | CTRLUPD_REQ_PE<br>R_AREF_EN | Enable an automatic controller-initiated update (dfi_ctrlupd_req) after every refresh. Set to 1 to enable. | R/W |
| b7 to b1     | Reserved                    | NA                                                                                                         | R   |
| b0           | CTRLUPD_REQ                 | Assert the DFI controller-initiated update request signal dfi_ctrlupd_req. Set to 1 to trigger.            | W   |

#### 6.4.1.57 DDR\_CTL\_56 — DDR-Controller Status & Control 56

Address: 4000 D0E0h

| Bit               | b31        | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19    | b18 | b17 | b16 |
|-------------------|------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|--------|-----|-----|-----|
|                   | _          | _   | _   | _   | _   | _   | _   | _   | _   |     |     | IN  | T_STAT | US  |     |     |
| Value after reset | 0          | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0   | 0   | 0   |
| Bit               | b15        | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3     | b2  | b1  | b0  |
|                   | INT_STATUS |     |     |     |     |     |     |     |     |     |     |     |        |     |     |     |
| Value after reset | 0          | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0   | 0   | 0   |

Table 6.59 DDR\_CTL\_56 Register Contents

| Bit Position | Bit Name   | Function                                            | R/W |
|--------------|------------|-----------------------------------------------------|-----|
| b31 to b24   | Reserved   | NA                                                  | R   |
| b23          | Reserved   | NA                                                  | R   |
| b22 to b0    | INT_STATUS | The INT_STATUS bits correspond to these interrupts: | R   |

Bit [22] = Logical OR of all lower bits.

Bit [21] = The user-initiated DLL resync has completed.

Bit [20] = A state change has been detected on the dfi\_init\_complete signal after initialization.

Bit [19] = The assertion of the INHIBIT\_DRAM\_CMD parameter has successfully inhibited the command gueue.

Bit [18] = The register interface-initiated mode register write has completed and another mode register write may be issued.

Bit [17:16] = Reserved

Bit [15] = A DFI update error has occurred.

Error information can be found in the UPDATE\_ERROR\_STATUS parameter.

Bit [14:12] = Reserved

Bit [11] = The user has programmed an invalid setting associated with 64-bit-defined-word per burst.

Bit [10] = Wrap cycle crossing a DRAM page has been detected.

This is unsupported & may result in memory data corruption.

Bit [9] = The low power operation has been completed.

Bit [8] = The memory controller initialization has been completed.

Bit [7] = An error occurred on the port command channel.

Bit [6] = Multiple uncorrectable ECC events have been detected.

Bit [5] = An uncorrectable ECC event has been detected.

Bit [4] = Multiple correctable ECC events have been detected.

Bit [3] = A correctable ECC event has been detected.

Bit [2] = Multiple accesses outside the defined PHYSICAL memory space have occurred.

Bit [1] = A memory access outside the defined PHYSICAL memory space has occurred.

Bit [0] = The memory reset is valid on the DFI bus.

### 6.4.1.58 DDR\_CTL\_57 — DDR-Controller Status & Control 57

Address: 4000 D0E4h

| Bit               | b31     | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19  | b18 | b17 | b16 |
|-------------------|---------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|------|-----|-----|-----|
|                   | _       | _   | _   | _   | _   | _   | _   | _   | _   | _   |     |     | INT_ | ACK |     |     |
| Value after reset | 0       | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0   | 0   | 0   |
| Bit               | b15     | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3   | b2  | b1  | b0  |
|                   | INT_ACK |     |     |     |     |     |     |     |     |     |     |     |      |     |     |     |
| Value after reset | 0       | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0   | 0   | 0   |

Table 6.60 DDR\_CTL\_57 Register Contents

| Bit Position | Bit Name | Function                                       | R/W |
|--------------|----------|------------------------------------------------|-----|
| b31 to b24   | Reserved | NA                                             | R   |
| b23, b22     | Reserved | NA                                             | R   |
| b21 to b0    | INT_ACK  | Clear bit of the INT_STATUS parameter.         | W   |
|              |          | 0: No effect                                   |     |
|              |          | 1: Clears the associated bit in the INT_STATUS |     |

#### 6.4.1.59 DDR\_CTL\_58 — DDR-Controller Status & Control 58

Address: 4000 D0E8h



Table 6.61 DDR\_CTL\_58 Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                                                                                                                                  | R/W |
|--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved | NA                                                                                                                                                                                                                                                                        | R   |
| b23          | Reserved | NA                                                                                                                                                                                                                                                                        | R   |
| b22 to b0    | INT_MASK | Mask for DDRC_Int signals from the INT_STATUS parameter.  Bit [22]  0: Mask interrupts individually based on the settings of bits [21:0].  1: Mask all interrupts. The settings in bits [21:0] are not relevant.  Bit [21:0]  0: Do not mask interrupt  1: Mask interrupt | R/W |

### 6.4.1.60 DDR\_CTL\_59 — DDR-Controller Status & Control 59

Address: 4000 D0ECh

| Bit               | b31               | b30               | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-------------------|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
|                   |                   | OUT_OF_RANGE_ADDR |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Value after reset | 0                 | 0                 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15               | b14               | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                   | OUT_OF_RANGE_ADDR |                   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Value after reset | 0                 | 0                 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 6.62 DDR\_CTL\_59 Register Contents

| Bit Position | Bit Name              | Function                                                  | R/W |
|--------------|-----------------------|-----------------------------------------------------------|-----|
| b31 to b0    | OUT_OF_RANGE_A<br>DDR | Address of command that caused an out-of-range interrupt. | R   |

#### 6.4.1.61 DDR\_CTL\_60 — DDR-Controller Status & Control 60

Address: 4000 D0F0h



Table 6.63 DDR\_CTL\_60 Register Contents

| Bit Position | Bit Name                | Function                                                 | R/W |
|--------------|-------------------------|----------------------------------------------------------|-----|
| b31 to b14   | Reserved                | NA                                                       | R   |
| b13 to b8    | OUT_OF_RANGE_T<br>YPE   | Type of command that caused an out-of-range interrupt.   | R   |
| b7           | Reserved                | NA                                                       | R   |
| b6 to b0     | OUT_OF_RANGE_L<br>ENGTH | Length of command that caused an out-of-range interrupt. | R   |

### 6.4.1.62 DDR\_CTL\_61 — DDR-Controller Status & Control 61

Address: 4000 D0F4h

| Bit               | b31                 | b30 | b29 | b28 | b27 | b26 | b25  | b24    | b23    | b22  | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|---------------------|-----|-----|-----|-----|-----|------|--------|--------|------|-----|-----|-----|-----|-----|-----|
|                   |                     |     |     |     |     |     | PORT | _CMD_I | ERROR_ | ADDR |     |     |     |     |     |     |
| Value after reset | 0                   | 0   | 0   | 0   | 0   | 0   | 0    | 0      | 0      | 0    | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15                 | b14 | b13 | b12 | b11 | b10 | b9   | b8     | b7     | b6   | b5  | b4  | b3  | b2  | b1  | b0  |
|                   | PORT_CMD_ERROR_ADDR |     |     |     |     |     |      |        |        |      |     |     |     |     |     |     |
| Value after reset | 0                   | 0   | 0   | 0   | 0   | 0   | 0    | 0      | 0      | 0    | 0   | 0   | 0   | 0   | 0   | 0   |

Table 6.64 DDR\_CTL\_61 Register Contents

| Bit Position | Bit Name                | Function                                               | R/W |
|--------------|-------------------------|--------------------------------------------------------|-----|
| b31 to b0    | PORT_CMD_ERROR<br>_ADDR | Address of command that caused the PORT command error. | R   |

#### 6.4.1.63 DDR\_CTL\_62 — DDR-Controller Status & Control 62

Address: 4000 D0F8h



Table 6.65 DDR\_CTL\_62 Register Contents

| Bit Position | Bit Name                | Function                                                                                                                                                    | R/W |
|--------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b26   | Reserved                | NA                                                                                                                                                          | R   |
| b25, b24     | ODT_WR_MAP_CS0          | Determines which chip(s) will have termination when a write occurs on chip select 0. Set bit X to enable termination on csX when cs0 is performing a write. | R/W |
| b23 to b18   | Reserved                | NA                                                                                                                                                          | R   |
| b17, b16     | ODT_RD_MAP_CS0          | Determines which chip(s) will have termination when a read occurs on chip select 0. Set bit X to enable termination on csX when cs0 is performing a read.   | R/W |
| b15 to b11   | Reserved                | NA                                                                                                                                                          | R   |
| b10 to b8    | PORT_CMD_ERROR<br>_TYPE | Type of error and access type that caused the PORT command error.                                                                                           | R   |
| b7 to b0     | Reserved                | NA                                                                                                                                                          | R   |

## 6.4.1.64 DDR\_CTL\_63 — DDR-Controller Status & Control 63

Address: 4000 D0FCh

| Bit               | b31 | b30 | b29 | b28 | b27 | b26  | b25  | b24          | b23 | b22 | b21 | b20   | b19   | b18 | b17    | b16 |
|-------------------|-----|-----|-----|-----|-----|------|------|--------------|-----|-----|-----|-------|-------|-----|--------|-----|
|                   | _   | _   | _   | _   |     | TODT | H_WR |              |     |     |     | TODTL | _2CMD |     |        |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0    | 0    | 0            | 0   | 0   | 0   | 0     | 0     | 0   | 0      | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10  | b9   | b8           | b7  | b6  | b5  | b4    | b3    | b2  | b1     | b0  |
|                   | _   | _   | _   | _   | _   | _    |      | /R_MAP<br>S1 | _   | -   | _   | _     | _     | -   | ODT_RI |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0    | 0    | 0            | 0   | 0   | 0   | 0     | 0     | 0   | 0      | 0   |

Table 6.66 DDR\_CTL\_63 Register Contents

| Bit Position | Bit Name       | Function                                                                                                                                                    | R/W |
|--------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b28   | Reserved       | NA                                                                                                                                                          | R   |
| b27 to b24   | TODTH_WR       | Defines the DRAM minimum ODT high time after an ODT assertion for a write command (memory clock cycles)                                                     | R/W |
| b23 to b16   | TODTL_2CMD     | Defines the DRAM delay from an ODT de-assertion to the next non-write, non-read command (memory clock cycles)                                               | R/W |
| b15 to b10   | Reserved       | NA                                                                                                                                                          | R   |
| b9, b8       | ODT_WR_MAP_CS1 | Determines which chip(s) will have termination when a write occurs on chip select 1. Set bit X to enable termination on csX when cs1 is performing a write. | R/W |
| b7 to b2     | Reserved       | NA                                                                                                                                                          | R   |
| b1, b0       | ODT_RD_MAP_CS1 | Determines which chip(s) will have termination when a read occurs on chip select 1. Set bit X to enable termination on csX when cs1 is performing a read.   | R/W |

### 6.4.1.65 DDR\_CTL\_64 — DDR-Controller Status & Control 64

Address: 4000 D100h

| Bit               | b31 | b30 | b29 | b28 | b27    | b26 | b25 | b24        | b23 | b22 | b21 | b20 | b19    | b18  | b17  | b16 |
|-------------------|-----|-----|-----|-----|--------|-----|-----|------------|-----|-----|-----|-----|--------|------|------|-----|
|                   | _   |     |     | RD  | _TO_OE | TH  |     |            | _   |     |     | WR  | _TO_OI | DTH  |      |     |
| Value after reset | 0   | 0   | 0   | 0   | 0      | 0   | 0   | 0          | 0   | 0   | 0   | 0   | 0      | 0    | 0    | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11    | b10 | b9  | b8         | b7  | b6  | b5  | b4  | b3     | b2   | b1   | b0  |
|                   | _   | _   | _   | _   | _      | _   | _   | ODT_E<br>N | _   | _   | _   | _   |        | TODT | H_RD |     |
| Value after reset | 0   | 0   | 0   | 0   | 0      | 0   | 0   | 0          | 0   | 0   | 0   | 0   | 0      | 0    | 0    | 0   |

Table 6.67 DDR\_CTL\_64 Register Contents

| Bit Position | Bit Name   | Function                                                                                                                         | R/W |
|--------------|------------|----------------------------------------------------------------------------------------------------------------------------------|-----|
| b31          | Reserved   | NA                                                                                                                               | R   |
| b30 to b24   | RD_TO_ODTH | Defines the delay from a read command to ODT assertion (memory clock cycles)                                                     | R/W |
| b23          | Reserved   | NA                                                                                                                               | R   |
| b22 to b16   | WR_TO_ODTH | Defines the delay from a write command to ODT assertion (memory clock cycles)                                                    | R/W |
| b15 to b9    | Reserved   | NA                                                                                                                               | R   |
| b8           | ODT_EN     | Enable support of DRAM ODT. When enabled, controller will assert and de-assert ODT output to DRAM as needed. Set to 1 to enable. | R/W |
| b7 to b4     | Reserved   | NA                                                                                                                               | R   |
| b3 to b0     | TODTH_RD   | Defines the DRAM minimum ODT high time after an ODT assertion for a read command (memory clock cycles)                           | R/W |

### 6.4.1.66 DDR\_CTL\_65 — DDR-Controller Status & Control 65

Address: 4000 D104h



Table 6.68 DDR\_CTL\_65 Register Contents

| Bit Position | Bit Name  | Function | R/W |
|--------------|-----------|----------|-----|
| b31 to b0    | OBSOLETE0 | NA       | R   |

### 6.4.1.67 DDR\_CTL\_66 — DDR-Controller Status & Control 66

Address: 4000 D108h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26     | b25     | b24  | b23 | b22 | b21 | b20 | b19 | b18  | b17     | b16   |
|-------------------|-----|-----|-----|-----|-----|---------|---------|------|-----|-----|-----|-----|-----|------|---------|-------|
|                   | _   | _   | _   | _   | W   | /2W_DIF | FCS_DL  | Υ.   | _   | _   | _   | _   | _   | W2R  | _DIFFCS | S_DLY |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0       | 0       | 1    | 0   | 0   | 0   | 0   | 0   | 0    | 0       | 1     |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10     | b9      | b8   | b7  | b6  | b5  | b4  | b3  | b2   | b1      | b0    |
|                   | _   | _   | _   | _   | _   | R2W_    | _DIFFCS | _DLY | _   | -   | _   | _   | _   | R2R_ | DIFFCS  | _DLY  |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0       | 0       | 1    | 0   | 0   | 0   | 0   | 0   | 0    | 0       | 1     |

Table 6.69 DDR\_CTL\_66 Register Contents

| Bit Position | Bit Name       | Function                                                                                                                                             | R/W |
|--------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b28   | Reserved       | NA                                                                                                                                                   | R   |
| b27 to b24   | W2W_DIFFCS_DLY | Additional delay to insert between writes to different chip selects. Program to a non-zero value. (memory clock cycles)                              | R/W |
| b23 to b19   | Reserved       | NA                                                                                                                                                   | R   |
| b18 to b16   | W2R_DIFFCS_DLY | Additional delay to insert between writes and reads to different chip selects. Allowed programming dependent on memory system. (memory clock cycles) | R/W |
| b15 to b11   | Reserved       | NA                                                                                                                                                   | R   |
| b10 to b8    | R2W_DIFFCS_DLY | Additional delay to insert between reads and writes to different chip selects. Program to a non-zero value. (memory clock cycles)                    | R/W |
| b7 to b3     | Reserved       | NA                                                                                                                                                   | R   |
| b2 to b0     | R2R_DIFFCS_DLY | Additional delay to insert between reads to different chip selects. Program to a non-zero value. (memory clock cycles)                               | R/W |

### 6.4.1.68 DDR\_CTL\_67 — DDR-Controller Status & Control 67

Address: 4000 D10Ch

| Bit               | b31 | b30 | b29 | b28 | b27 | b26  | b25    | b24   | b23 | b22 | b21 | b20 | b19 | b18  | b17    | b16   |
|-------------------|-----|-----|-----|-----|-----|------|--------|-------|-----|-----|-----|-----|-----|------|--------|-------|
|                   | _   | _   | _   | _   | _   | W2W_ | SAMEC  | S_DLY | _   | _   | _   | _   | _   | W2R_ | SAMEC  | S_DLY |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0    | 0      | 0     | 0   | 0   | 0   | 0   | 0   | 0    | 0      | 0     |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10  | b9     | b8    | b7  | b6  | b5  | b4  | b3  | b2   | b1     | b0    |
|                   | _   | _   | _   | _   | _   | R2W_ | SAMECS | S_DLY | -   | _   | -   | -   | _   | R2R_ | SAMECS | 3_DLY |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0    | 1      | 0     | 0   | 0   | 0   | 0   | 0   | 0    | 0      | 0     |

Table 6.70 DDR\_CTL\_67 Register Contents

| Bit Position | Bit Name       | Function                                                                                                                        | R/W |
|--------------|----------------|---------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b27   | Reserved       | NA                                                                                                                              | R   |
| b26 to b24   | W2W_SAMECS_DLY | Additional delay to insert between two writes to the same chip select. Any value including 0x0 supported. (memory clock cycles) | R/W |
| b23 to b19   | Reserved       | NA                                                                                                                              | R   |
| b18 to b16   | W2R_SAMECS_DLY | Additional delay to insert between writes and reads to the same chip select (memory clock cycles)                               | R/W |
| b15 to b11   | Reserved       | NA                                                                                                                              | R   |
| b10 to b8    | R2W_SAMECS_DLY | Additional delay to insert between reads and writes to the same chip select. Program to a non-zero value. (memory clock cycles) | R/W |
| b7 to b3     | Reserved       | NA                                                                                                                              | R   |
| b2 to b0     | R2R_SAMECS_DLY | Additional delay to insert between two reads to the same chip select. Any value including 0x0 supported. (memory clock cycles)  | R/W |

### 6.4.1.69 DDR\_CTL\_68 — DDR-Controller Status & Control 68

Address: 4000 D110h

| Bit               | b31 | b30 | b29 | b28 | b27    | b26    | b25    | b24            | b23 | b22 | b21 | b20 | b19    | b18    | b17    | b16           |
|-------------------|-----|-----|-----|-----|--------|--------|--------|----------------|-----|-----|-----|-----|--------|--------|--------|---------------|
|                   | _   | _   | _   | _   | _      | _      | _      | SWLVL<br>_LOAD | _   | _   | _   | _   | _      | _      |        | VELING<br>DDE |
| Value after reset | 0   | 0   | 0   | 0   | 0      | 0      | 0      | 0              | 0   | 0   | 0   | 0   | 0      | 0      | 0      | 0             |
| Bit               | b15 | b14 | b13 | b12 | b11    | b10    | b9     | b8             | b7  | b6  | b5  | b4  | b3     | b2     | b1     | b0            |
|                   | _   | _   | _   | (   | OCD_AD | JUST_P | UP_CS_ | _0             | _   | _   | -   | C   | OCD_AD | JUST_P | DN_CS_ | 0             |
| Value after reset | 0   | 0   | 0   | 0   | 0      | 0      | 0      | 0              | 0   | 0   | 0   | 0   | 0      | 0      | 0      | 0             |

Table 6.71 DDR\_CTL\_68 Register Contents

| Bit Position | Bit Name                | Function                                      | R/W |
|--------------|-------------------------|-----------------------------------------------|-----|
| b31 to b25   | Reserved                | NA                                            | R   |
| b24          | SWLVL_LOAD              | NA                                            | W   |
| b23 to b18   | Reserved                | NA                                            | R   |
| b17, b16     | SW_LEVELING_MO<br>DE    | NA. The bit should be kept the initial value. | R/W |
| b15 to b13   | Reserved                | NA                                            | R   |
| b12 to b8    | OCD_ADJUST_PUP_<br>CS_0 | NA. The bit should be kept the initial value. | R/W |
| b7 to b5     | Reserved                | NA                                            | R   |
| b4 to b0     | OCD_ADJUST_PDN_<br>CS_0 | NA. The bit should be kept the initial value. | R/W |

### 6.4.1.70 DDR\_CTL\_69 — DDR-Controller Status & Control 69

Address: 4000 D114h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26   | b25   | b24            | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16                   |
|-------------------|-----|-----|-----|-----|-----|-------|-------|----------------|-----|-----|-----|-----|-----|-----|-----|-----------------------|
|                   | _   | _   | _   | _   |     | LVL_S | TATUS |                | _   | _   | _   | _   | _   | _   | _   | SWLVL<br>_OP_D<br>ONE |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0     | 0     | 0              | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                     |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10   | b9    | b8             | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0                    |
|                   | _   | _   | _   | _   | _   | _     | _     | SWLVL<br>_EXIT | _   | _   | _   | _   | _   | _   | _   | SWLVL<br>_STAR<br>T   |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0     | 0     | 0              | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                     |

Table 6.72 DDR\_CTL\_69 Register Contents

| Bit Position | Bit Name      | Function | R/W |
|--------------|---------------|----------|-----|
| b31 to b28   | Reserved      | NA       | R   |
| b27 to b24   | LVL_STATUS    | NA       | R   |
| b23 to b17   | Reserved      | NA       | R   |
| b16          | SWLVL_OP_DONE | NA       | R   |
| b15 to b9    | Reserved      | NA       | R   |
| b8           | SWLVL_EXIT    | NA       | W   |
| b7 to b1     | Reserved      | NA       | R   |
| b0           | SWLVL_START   | NA       | W   |

### 6.4.1.71 DDR\_CTL\_70 — DDR-Controller Status & Control 70

Address: 4000 D118h

| Bit               | b31 | b30 | b29 | b28    | b27    | b26 | b25 | b24           | b23 | b22 | b21    | b20     | b19     | b18 | b17 | b16 |
|-------------------|-----|-----|-----|--------|--------|-----|-----|---------------|-----|-----|--------|---------|---------|-----|-----|-----|
|                   | _   | _   | _   | _      | _      | _   | _   | WRLVL<br>_REQ |     |     |        | SWLVL_  | _RESP_2 | !   |     |     |
| Value after reset | 0   | 0   | 0   | 0      | 0      | 0   | 0   | 0             | 0   | 0   | 0      | 0       | 0       | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12    | b11    | b10 | b9  | b8            | b7  | b6  | b5     | b4      | b3      | b2  | b1  | b0  |
|                   |     |     |     | SWLVL_ | RESP_1 |     |     |               |     |     | SWLVL_ | _RESP_0 | )       |     |     |     |
| Value after reset | 0   | 0   | 0   | 0      | 0      | 0   | 0   | 0             | 0   | 0   | 0      | 0       | 0       | 0   | 0   | 0   |

Table 6.73 DDR\_CTL\_70 Register Contents

| Bit Position | Bit Name     | Function | R/W |
|--------------|--------------|----------|-----|
| b31 to b25   | Reserved     | NA       | R   |
| b24          | WRLVL_REQ    | NA       | W   |
| b23 to b16   | SWLVL_RESP_2 | NA       | R   |
| b15 to b8    | SWLVL_RESP_1 | NA       | R   |
| b7 to b0     | SWLVL_RESP_0 | NA       | R   |

### 6.4.1.72 DDR\_CTL\_71 — DDR-Controller Status & Control 71

Address: 4000 D11Ch



Table 6.74 DDR\_CTL\_71 Register Contents

| Bit Position | Bit Name | Function                                      | R/W |
|--------------|----------|-----------------------------------------------|-----|
| b31 to b25   | Reserved | NA                                            | R   |
| b24          | WRLVL_EN | NA. The bit should be kept the initial value. | R/W |
| b23, b22     | Reserved | NA                                            | R   |
| b21 to b16   | WLMRD    | NA. The bit should be kept the initial value. | R/W |
| b15, b14     | Reserved | NA                                            | R   |
| b13 to b8    | WLDQSEN  | NA. The bit should be kept the initial value. | R/W |
| b7 to b1     | Reserved | NA                                            | R   |
| b0           | WRLVL_CS | NA. The bit should be kept the initial value. | R/W |

### 6.4.1.73 DDR\_CTL\_72 — DDR-Controller Status & Control 72

Address: 4000 D120h

| Bit               | b31            | b30 | b29 | b28     | b27    | b26  | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|----------------|-----|-----|---------|--------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
|                   |                |     | WRL | .VL_ERR | OR_STA | ATUS |     |     | _   | _   | _   | _   | _   | _   | _   | _   |
| Value after reset | 0              | 0   | 0   | 0       | 0      | 0    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15            | b14 | b13 | b12     | b11    | b10  | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                   | WRLVL_INTERVAL |     |     |         |        |      |     |     |     |     |     |     |     |     |     |     |
| Value after reset | 0              | Λ   | 0   | 0       | Λ      | Λ    | Λ   | 0   | Λ   | Λ   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 6.75 DDR\_CTL\_72 Register Contents

| Bit Position | Bit Name               | Function                                                      | R/W |
|--------------|------------------------|---------------------------------------------------------------|-----|
| b31 to b24   | WRLVL_ERROR_ST<br>ATUS | NA                                                            | R   |
| b23 to b19   | Reserved               | NA                                                            | R   |
| b18 to b16   | Reserved               | Reserved for future use. It should be kept the initial value. | R/W |
| b15 to b0    | WRLVL_INTERVAL         | NA. The bit should be kept the initial value.                 | R/W |

### 6.4.1.74 DDR\_CTL\_73 — DDR-Controller Status & Control 73

Address: 4000 D124h



Table 6.76 DDR\_CTL\_73 Register Contents

| Bit Position | Bit Name      | Function                                      | R/W |
|--------------|---------------|-----------------------------------------------|-----|
| b31 to b24   | Reserved      | NA                                            | R   |
| b23 to b8    | WRLVL_DELAY_0 | NA. The bit should be kept the initial value. | R/W |
| b7 to b1     | Reserved      | NA                                            | R   |
| b0           | WRLVL_REG_EN  | NA. The bit should be kept the initial value. | R/W |

### 6.4.1.75 DDR\_CTL\_74 — DDR-Controller Status & Control 74

Address: 4000 D128h



Table 6.77 DDR\_CTL\_74 Register Contents

| Bit Position | Bit Name      | Function                                      | R/W |
|--------------|---------------|-----------------------------------------------|-----|
| b31 to b16   | WRLVL_DELAY_2 | NA. The bit should be kept the initial value. | R/W |
| b15 to b0    | WRLVL_DELAY_1 | NA. The bit should be kept the initial value. | R/W |

### 6.4.1.76 DDR\_CTL\_75 — DDR-Controller Status & Control 75

Address: 4000 D12Ch



Table 6.78 DDR\_CTL\_75 Register Contents

| Bit Position | Bit Name       | Function                                      | R/W |
|--------------|----------------|-----------------------------------------------|-----|
| b31 to b25   | Reserved       | NA                                            | R   |
| b24          | RDLVL_EDGE     | NA. The bit should be kept the initial value. | R/W |
| b23 to b17   | Reserved       | NA                                            | R   |
| b16          | RDLVL_CS       | NA. The bit should be kept the initial value. | R/W |
| b15 to b9    | Reserved       | NA                                            | R   |
| b8           | RDLVL_GATE_REQ | NA                                            | W   |
| b7 to b1     | Reserved       | NA                                            | R   |
| b0           | RDLVL_REQ      | NA                                            | W   |

### 6.4.1.77 DDR\_CTL\_76 — DDR-Controller Status & Control 76

Address: 4000 D130h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24                  | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16                          |
|-------------------|-----|-----|-----|-----|-----|-----|-----|----------------------|-----|-----|-----|-----|-----|-----|-----|------------------------------|
|                   | _   | _   | _   | _   | _   | _   | _   | _                    | _   | _   | _   | _   | _   | _   | _   | RDLVL_G<br>ATE_RE<br>G_EN    |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                            |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8                   | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0                           |
|                   | _   | _   | _   | _   | _   | _   | _   | RDLVL<br>_REG_<br>EN | _   | _   | _   | _   | _   | _   | _   | RDLVL_B<br>EGIN_DE<br>LAY_EN |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                            |

Table 6.79 DDR\_CTL\_76 Register Contents

| Bit Position   | Bit Name              | Function                                          | R/W      |
|----------------|-----------------------|---------------------------------------------------|----------|
| b31 to b24     | Reserved              | NA                                                | R        |
| b23 to b17     | Reserved              | NA                                                | R        |
| b16            | RDLVL_GATE_REG_<br>EN | NA. The bit should be kept the initial value.     | R/W      |
| b15 to b9      | Reserved              | NA                                                | R        |
|                |                       |                                                   |          |
| b8             | RDLVL_REG_EN          | NA. The bit should be kept the initial value.     | R/W      |
| b8<br>b7 to b1 | RDLVL_REG_EN Reserved | NA. The bit should be kept the initial value.  NA | R/W<br>R |

### 6.4.1.78 DDR\_CTL\_77 — DDR-Controller Status & Control 77

Address: 4000 D134h



Table 6.80 DDR\_CTL\_77 Register Contents

| Bit Position | Bit Name                | Function | R/W |
|--------------|-------------------------|----------|-----|
| b31 to b16   | RDLVL_END_DELAY<br>_0   | NA       | R   |
| b15 to b0    | RDLVL_BEGIN_DEL<br>AY_0 | NA       | R   |

### 6.4.1.79 DDR\_CTL\_78 — DDR-Controller Status & Control 78

Address: 4000 D138h

| Bit               | b31 | b30                    | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|------------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
|                   |     | RDLVL_OFFSET_DELAY_0   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Value after reset | 0   | 0                      | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14                    | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                   |     | RDLVL_MIDPOINT_DELAY_0 |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Value after reset | 0   | 0                      | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 6.81 DDR\_CTL\_78 Register Contents

| Bit Position | Bit Name                   | Function                                      | R/W |
|--------------|----------------------------|-----------------------------------------------|-----|
| b31 to b16   | RDLVL_OFFSET_DE<br>LAY_0   | NA. The bit should be kept the initial value. | R/W |
| b15 to b0    | RDLVL_MIDPOINT_<br>DELAY_0 | NA                                            | R   |

### 6.4.1.80 DDR\_CTL\_79 — DDR-Controller Status & Control 79

Address: 4000 D13Ch



Table 6.82 DDR\_CTL\_79 Register Contents

| Bit Position | Bit Name               | Function                                      | R/W |
|--------------|------------------------|-----------------------------------------------|-----|
| b31 to b24   | Reserved               | NA                                            | R   |
| b23 to b8    | RDLVL_DELAY_0          | NA. The bit should be kept the initial value. | R/W |
| b7 to b1     | Reserved               | NA                                            | R   |
| b0           | RDLVL_OFFSET_DI<br>R_0 | NA. The bit should be kept the initial value. | R/W |

### 6.4.1.81 DDR\_CTL\_80 — DDR-Controller Status & Control 80

Address: 4000 D140h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24     | b23    | b22  | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|---------|--------|------|-----|-----|-----|-----|-----|-----|
|                   |     |     |     |     |     |     | RDL | VL_BEG  | IN_DEL | AY_1 |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0       | 0      | 0    | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8      | b7     | b6   | b5  | b4  | b3  | b2  | b1  | b0  |
|                   |     |     |     |     |     |     | RDL | .VL_GAT | E_DELA | AY_0 |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0       | 0      | 0    | 0   | 0   | 0   | 0   | 0   |     |

Table 6.83 DDR\_CTL\_80 Register Contents

| Bit Position | Bit Name                | Function                                      | R/W |
|--------------|-------------------------|-----------------------------------------------|-----|
| b31 to b16   | RDLVL_BEGIN_DEL<br>AY_1 | NA                                            | R   |
| b15 to b0    | RDLVL_GATE_DELA<br>Y_0  | NA. The bit should be kept the initial value. | R/W |

### 6.4.1.82 DDR\_CTL\_81 — DDR-Controller Status & Control 81

**Address:** 4000 D144h



Table 6.84 DDR\_CTL\_81 Register Contents

| Bit Position | Bit Name                   | Function | R/W |
|--------------|----------------------------|----------|-----|
| b31 to b16   | RDLVL_MIDPOINT_<br>DELAY_1 | NA       | R   |
| b15 to b0    | RDLVL_END_DELAY<br>_1      | NA       | R   |

### 6.4.1.83 DDR\_CTL\_82 — DDR-Controller Status & Control 82

Address: 4000 D148h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25  | b24    | b23     | b22   | b21 | b20 | b19 | b18 | b17 | b16                        |
|-------------------|-----|-----|-----|-----|-----|-----|------|--------|---------|-------|-----|-----|-----|-----|-----|----------------------------|
|                   | _   | _   |     |     |     |     | _    |        |         | _     |     |     | _   | _   | _   | RDLVL_O<br>FFSET_D<br>IR_1 |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0      | 0       | 0     | 0   | 0   | 0   | 0   | 0   | 0                          |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9   | b8     | b7      | b6    | b5  | b4  | b3  | b2  | b1  | b0                         |
|                   |     |     |     |     |     |     | RDLV | L_OFFS | SET_DEL | _AY_1 |     |     |     |     |     |                            |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0      | 0       | 0     | 0   | 0   | 0   | 0   | 0   | 0                          |

Table 6.85 DDR\_CTL\_82 Register Contents

| Bit Position | Bit Name                 | Function                                      | R/W |
|--------------|--------------------------|-----------------------------------------------|-----|
| b31 to b24   | Reserved                 | NA                                            | R   |
| b23 to b17   | Reserved                 | NA                                            | R   |
| b16          | RDLVL_OFFSET_DI<br>R_1   | NA. The bit should be kept the initial value. | R/W |
| b15 to b0    | RDLVL_OFFSET_DE<br>LAY_1 | NA. The bit should be kept the initial value. | R/W |

### 6.4.1.84 DDR\_CTL\_83 — DDR-Controller Status & Control 83

Address: 4000 D14Ch



Table 6.86 DDR\_CTL\_83 Register Contents

| Bit Position | Bit Name               | Function                                      | R/W |
|--------------|------------------------|-----------------------------------------------|-----|
| b31 to b16   | RDLVL_GATE_DELA<br>Y_1 | NA. The bit should be kept the initial value. | R/W |
| b15 to b0    | RDLVL_DELAY_1          | NA. The bit should be kept the initial value. | R/W |

### 6.4.1.85 DDR\_CTL\_84 — DDR-Controller Status & Control 84

Address: 4000 D150h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24    | b23    | b22  | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|--------|--------|------|-----|-----|-----|-----|-----|-----|
|                   |     |     |     |     |     |     | RD  | LVL_EN | D_DELA | Y_2  |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0      | 0    | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8     | b7     | b6   | b5  | b4  | b3  | b2  | b1  | b0  |
|                   |     |     |     |     |     |     | RDL | VL_BEG | IN_DEL | AY_2 |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0      | 0    | 0   | 0   | 0   | 0   | 0   | 0   |

Table 6.87 DDR\_CTL\_84 Register Contents

| Bit Position | Bit Name                | Function | R/W |
|--------------|-------------------------|----------|-----|
| b31 to b16   | RDLVL_END_DELAY _2      | NA       | R   |
| b15 to b0    | RDLVL_BEGIN_DEL<br>AY_2 | NA       | R   |

### 6.4.1.86 DDR\_CTL\_85 — DDR-Controller Status & Control 85

Address: 4000 D154h



Table 6.88 DDR\_CTL\_85 Register Contents

| Bit Position | Bit Name                   | Function                                      | R/W |
|--------------|----------------------------|-----------------------------------------------|-----|
| b31 to b16   | RDLVL_OFFSET_DE<br>LAY_2   | NA. The bit should be kept the initial value. | R/W |
| b15 to b0    | RDLVL_MIDPOINT_<br>DELAY_2 | NA                                            | R   |

### 6.4.1.87 DDR\_CTL\_86 — DDR-Controller Status & Control 86

Address: 4000 D158h

| Bit               | b31 | b30 | b29 | b28     | b27     | b26 | b25 | b24 | b23 | b22 | b21 | b20     | b19     | b18 | b17 | b16                        |
|-------------------|-----|-----|-----|---------|---------|-----|-----|-----|-----|-----|-----|---------|---------|-----|-----|----------------------------|
|                   | _   | _   | _   | _       | _       | _   | _   | _   |     |     | l   | RDLVL_I | DELAY_2 | 2   |     |                            |
| Value after reset | 0   | 0   | 0   | 0       | 0       | 0   | 0   | 0   | 0   | 0   | 0   | 0       | 0       | 0   | 0   | 0                          |
| Bit               | b15 | b14 | b13 | b12     | b11     | b10 | b9  | b8  | b7  | b6  | b5  | b4      | b3      | b2  | b1  | b0                         |
|                   |     |     | 1   | RDLVL_I | DELAY_2 | 2   |     |     | _   |     | l   | _       | _       | l   | _   | RDLVL_O<br>FFSET_D<br>IR_2 |
| Value after reset | 0   | 0   | 0   | 0       | 0       | 0   | 0   | 0   | 0   | 0   | 0   | 0       | 0       | 0   | 0   | 0                          |

Table 6.89 DDR\_CTL\_86 Register Contents

| Bit Position | Bit Name               | Function                                      | R/W |
|--------------|------------------------|-----------------------------------------------|-----|
| b31 to b24   | Reserved               | NA                                            | R   |
| b23 to b8    | RDLVL_DELAY_2          | NA. The bit should be kept the initial value. | R/W |
| b7 to b1     | Reserved               | NA                                            | R   |
| b0           | RDLVL_OFFSET_DI<br>R_2 | NA. The bit should be kept the initial value. | R/W |

### 6.4.1.88 DDR\_CTL\_87 — DDR-Controller Status & Control 87

Address: 4000 D15Ch



Table 6.90 DDR\_CTL\_87 Register Contents

| Bit Position | Bit Name               | Function                                                               | R/W |
|--------------|------------------------|------------------------------------------------------------------------|-----|
| b31 to b26   | Reserved               | NA                                                                     | R   |
| b25, b24     | AXI0_W_PRIORITY        | Priority of write commands from AXI port 0. 0 is the highest priority. | R/W |
| b23 to b18   | Reserved               | NA                                                                     | R   |
| b17, b16     | AXI0_R_PRIORITY        | Priority of read commands from AXI port 0. 0 is the highest priority.  | R/W |
| b15 to b0    | RDLVL_GATE_DELA<br>Y_2 | NA. The bit should be kept the initial value.                          | R/W |

### 6.4.1.89 DDR\_CTL\_88 — DDR-Controller Status & Control 88

Address: 4000 D160h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25            | b24           | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16           |
|-------------------|-----|-----|-----|-----|-----|-----|----------------|---------------|-----|-----|-----|-----|-----|-----|-----|---------------|
|                   | _   | _   | _   | _   | _   | _   | AXI1_FI<br>E_F | FO_TYP<br>REG | _   | _   | _   | -   | _   | -   |     | _PRIOR<br>TY  |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0              | 0             | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0             |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9             | b8            | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0            |
|                   | _   | _   | _   | _   | _   | _   | AXI1_R<br>T    |               | _   | _   |     |     | _   |     |     | FO_TYP<br>REG |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0              | 0             | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0             |

Table 6.91 DDR\_CTL\_88 Register Contents

| Bit Position | Bit Name               | Function                                                                           | R/W |
|--------------|------------------------|------------------------------------------------------------------------------------|-----|
| b31 to b26   | Reserved               | NA                                                                                 | R   |
| b25, b24     | AXI1_FIFO_TYPE_R<br>EG | Clock domain relativity between AXI port 1 and the controller. Should be set to 0. | R/W |
| b23 to b18   | Reserved               | NA                                                                                 | R   |
| b17, b16     | AXI1_W_PRIORITY        | Priority of write commands from AXI port 1. 0 is the highest priority.             | R/W |
| b15 to b10   | Reserved               | NA                                                                                 | R   |
| b9, b8       | AXI1_R_PRIORITY        | Priority of read commands from AXI port 1. 0 is the highest priority.              | R/W |
| b7 to b2     | Reserved               | NA                                                                                 | R   |
| b1, b0       | AXI0_FIFO_TYPE_R<br>EG | Clock domain relativity between AXI port 0 and the controller. Should be set to 0. | R/W |

### 6.4.1.90 DDR\_CTL\_89 — DDR-Controller Status & Control 89

Address: 4000 D164h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24           | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16           |
|-------------------|-----|-----|-----|-----|-----|-----|-----|---------------|-----|-----|-----|-----|-----|-----|-----|---------------|
|                   | _   | _   | _   | _   | ı   | _   |     | _PRIORI<br>'Y | _   | _   | _   | _   | _   | _   |     | FO_TYP<br>REG |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0             | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0             |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8            | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0            |
|                   | _   | _   | _   | _   | _   | _   |     | _PRIOR<br>Y   | _   | _   | _   | _   | _   | _   |     | _PRIORI<br>Y  |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0             | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0             |

Table 6.92 DDR\_CTL\_89 Register Contents

| Bit Position | Bit Name               | Function                                                                           | R/W |
|--------------|------------------------|------------------------------------------------------------------------------------|-----|
| b31 to b26   | Reserved               | NA                                                                                 | R   |
| b25, b24     | AXI3_R_PRIORITY        | Priority of read commands from AXI port 3. 0 is the highest priority.              | R/W |
| b23 to b18   | Reserved               | NA                                                                                 | R   |
| b17, b16     | AXI2_FIFO_TYPE_R<br>EG | Clock domain relativity between AXI port 2 and the controller. Should be set to 0. | R/W |
| b15 to b10   | Reserved               | NA                                                                                 | R   |
| b9, b8       | AXI2_W_PRIORITY        | Priority of write commands from AXI port 2. 0 is the highest priority.             | R/W |
| b7 to b2     | Reserved               | NA                                                                                 | R   |
| b1, b0       | AXI2_R_PRIORITY        | Priority of read commands from AXI port 2. 0 is the highest priority.              | R/W |

### 6.4.1.91 DDR\_CTL\_90 — DDR-Controller Status & Control 90

Address: 4000 D168h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24                                 | b23 | b22 | b21 | b20 | b19 | b18 | b17          | b16         |
|-------------------|-----|-----|-----|-----|-----|-----|-----|-------------------------------------|-----|-----|-----|-----|-----|-----|--------------|-------------|
|                   | _   | l   | l   | l   | ı   | l   | _   | PORT_A<br>DDR_PR<br>OTECTIO<br>N_EN | _   | 1   | 1   | l   | l   | l   | _            | _           |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                                   | 0   | 0   | 0   | 0   | 0   | 0   | 0            | 0           |
|                   |     |     |     |     |     |     |     |                                     |     |     |     |     |     |     |              |             |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8                                  | b7  | b6  | b5  | b4  | b3  | b2  | b1           | b0          |
|                   |     | l   | l   | l   | ı   | l   |     | IFO_TYP<br>REG                      | _   | l   | l   | l   | l   | l   | AXI3_W<br>IT | _PRIOR<br>Y |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                                   | 0   | 0   | 0   | 0   | 0   | 0   | 0            | 0           |

Table 6.93 DDR\_CTL\_90 Register Contents

| Bit Position | Bit Name                    | Function                                                                                 | R/W |
|--------------|-----------------------------|------------------------------------------------------------------------------------------|-----|
| b31 to b25   | Reserved                    | NA                                                                                       | R   |
| b24          | PORT_ADDR_PROT<br>ECTION_EN | Enable port address range protection logic and interrupt generation. Set to 1 to enable. | R/W |
| b23 to b16   | Reserved                    | NA                                                                                       | R   |
| b15 to b10   | Reserved                    | NA                                                                                       | R   |
| b9, b8       | AXI3_FIFO_TYPE_R<br>EG      | Clock domain relativity between AXI port 3 and the controller. Should be set to 0.       | R/W |
| b7 to b2     | Reserved                    | NA                                                                                       | R   |
| b1, b0       | AXI3_W_PRIORITY             | Priority of write commands from AXI port 3. 0 is the highest priority.                   | R/W |

## 6.4.1.92 DDR\_CTL\_[k] — Port0 Range[n] Start Address Setting Register (n = 0..15) (k = 91 + n × 2)

**Address:** 4000 D16Ch + 8h × n



Table 6.94 DDR\_CTL\_[k] Register Contents

| Bit Position | Bit Name                | Function                                  | R/W |
|--------------|-------------------------|-------------------------------------------|-----|
| b31 to b24   | Reserved                | NA                                        | R   |
| b23 to b18   | Reserved                | NA                                        | R   |
| b17 to b0    | AXIO_START_ADDR<br>_[n] | Start address of port 0 address range [n] | R/W |

### 6.4.1.93 DDR\_CTL\_[k] — Port0 Range[n] End Address Setting Register (n = 0..15) (k = 92 + n × 2)

Address: 4000 D170h + 8h × n

| Bit                    | b31               | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16            |
|------------------------|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----------------|
|                        | _                 | _   | _   | _   | 1   | l   | _   | l   |     |     |     | _   | _   | _   |     | ND_ADD<br>_[n] |
| Value after reset      | 0                 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0              |
| Bit<br>r               | b15               | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0             |
|                        | AXI0_END_ADDR_[n] |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                |
| ا<br>Value after reset | 0                 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0              |

Table 6.95 DDR\_CTL\_[k] Register Contents

| Bit Position | Bit Name          | Function                                | R/W |
|--------------|-------------------|-----------------------------------------|-----|
| b31 to b24   | Reserved          | NA                                      | R   |
| b23 to b18   | Reserved          | NA                                      | R   |
| b17 to b0    | AXI0_END_ADDR_[n] | End address of port 0 address range [n] | R/W |

## 6.4.1.94 DDR\_CTL\_[k] — Port1 Range[n] Start Address Setting Register (n = 0..15) (k = 123 + n × 2)

Address:  $4000 D1ECh + 8h \times n$ 



Table 6.96 DDR\_CTL\_[k] Register Contents

| Bit Position | Bit Name                | Function                                  | R/W |
|--------------|-------------------------|-------------------------------------------|-----|
| b31 to b24   | Reserved                | NA                                        | R   |
| b23 to b18   | Reserved                | NA                                        | R   |
| b17 to b0    | AXI1_START_ADDR<br>_[n] | Start address of port 1 address range [n] | R/W |

### 6.4.1.95 DDR\_CTL\_[k] — Port1 Range[n] End Address Setting Register (n = 0..15) $(k = 124 + n \times 2)$

Address: 4000 D1F0h + 8h x n

| Bit               | b31               | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16            |
|-------------------|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----------------|
|                   | _                 |     | _   | l   | 1   | 1   | _   | 1   |     |     |     | _   | _   | _   |     | ND_ADD<br>_[n] |
| Value after reset | 0                 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0              |
| Bit<br>r          | b15               | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0             |
|                   | AXI1_END_ADDR_[n] |     |     |     |     |     |     |     |     |     |     |     |     |     |     |                |
| Value after reset | 0                 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0              |

Table 6.97 DDR\_CTL\_[k] Register Contents

| Bit Position | Bit Name          | Function                                | R/W |
|--------------|-------------------|-----------------------------------------|-----|
| b31 to b24   | Reserved          | NA                                      | R   |
| b23 to b18   | Reserved          | NA                                      | R   |
| b17 to b0    | AXI1_END_ADDR_[n] | End address of port 1 address range [n] | R/W |

## 6.4.1.96 DDR\_CTL\_[k] — Port2 Range[n] Start Address Setting Register (n = 0..15) (k = 155 + n × 2)

Address:  $4000 D26Ch + 8h \times n$ 



Table 6.98 DDR\_CTL\_[k] Register Contents

| Bit Position | Bit Name                | Function                                  | R/W |
|--------------|-------------------------|-------------------------------------------|-----|
| b31 to b24   | Reserved                | NA                                        | R   |
| b23 to b18   | Reserved                | NA                                        | R   |
| b17 to b0    | AXI2_START_ADDR<br>_[n] | Start address of port 2 address range [n] | R/W |

## 6.4.1.97 DDR\_CTL\_[k] — Port2 Range[n] End Address Setting Register (n = 0..15) $(k = 156 + n \times 2)$

**Address:** 4000 D270h + 8h × n

| Bit               | b31               | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16           |
|-------------------|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---------------|
|                   | _                 | -   | _   | -   | I   | _   | _   | _   | _   | _   | _   | -   | _   | _   |     | ND_ADD<br>[n] |
| Value after reset | 0                 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0             |
| Bit<br>г          | b15               | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0            |
|                   | AXI2_END_ADDR_[n] |     |     |     |     |     |     |     |     |     |     |     |     |     |     |               |
| Value after reset | 0                 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0             |

Table 6.99 DDR\_CTL\_[k] Register Contents

| Bit Position | Bit Name          | Function                                | R/W |
|--------------|-------------------|-----------------------------------------|-----|
| b31 to b24   | Reserved          | NA                                      | R   |
| b23 to b18   | Reserved          | NA                                      | R   |
| b17 to b0    | AXI2_END_ADDR_[n] | End address of port 2 address range [n] | R/W |

## 6.4.1.98 DDR\_CTL\_[k] — Port3 Range[n] Start Address Setting Register (n = 0..15) $(k = 187 + n \times 2)$

Address:  $4000 D2ECh + 8h \times n$ 



Table 6.100 DDR\_CTL\_[k] Register Contents

| Bit Position | Bit Name                | Function                                  | R/W |
|--------------|-------------------------|-------------------------------------------|-----|
| b31 to b24   | Reserved                | NA                                        | R   |
| b23 to b18   | Reserved                | NA                                        | R   |
| b17 to b0    | AXI3_START_ADDR<br>_[n] | Start address of port 3 address range [n] | R/W |

## 6.4.1.99 DDR\_CTL\_[k] — Port3 Range[n] End Address Setting Register (n = 0..14) $(k = 188 + n \times 2)$

**Address:** 4000 D2F0h + 8h × n

| Bit               | b31               | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16           |
|-------------------|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---------------|
|                   | _                 | _   | _   | _   | l   | l   | _   | l   | l   | l   | _   | _   | _   | _   |     | ND_ADD<br>[n] |
| Value after reset | 0                 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0             |
| Bit<br>r          | b15               | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0            |
|                   | AXI3_END_ADDR_[n] |     |     |     |     |     |     |     |     |     |     |     |     |     |     |               |
| Value after reset | 0                 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0             |

Table 6.101 DDR\_CTL\_[k] Register Contents

| Bit Position | Bit Name          | Function                                | R/W |
|--------------|-------------------|-----------------------------------------|-----|
| b31 to b24   | Reserved          | NA                                      | R   |
| b23 to b18   | Reserved          | NA                                      | R   |
| b17 to b0    | AXI3_END_ADDR_[n] | End address of port 3 address range [n] | R/W |

### 6.4.1.100 DDR\_CTL\_218 — Port3 Range15 End Address Setting Register

Address: 4000 D368h



Table 6.102 DDR\_CTL\_218 Register Contents

| Bit Position | Bit Name                   | Function                                                                                                                                                                                                                        | R/W |
|--------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b26   | Reserved                   | NA                                                                                                                                                                                                                              | R   |
| b25, b24     | AXIO_RANGE_PROT<br>_BITS_0 | Allowed transaction types for port 0 address range 0. Set to 0 for privileged and secure only, set to 1 for secure (with or without privileged), set to 2 for privileged (with or without secure), or set to 3 for full access. | R/W |
| b23 to b18   | Reserved                   | NA                                                                                                                                                                                                                              | R   |
| b17 to b0    | AXI3_END_ADDR_15           | End address of port 3 address range 15.                                                                                                                                                                                         | R/W |

## 6.4.1.101 DDR\_CTL\_[k] — Port0 Range[n] Protect Setting Register1 (n = 0..15) $(k = 219 + n \times 2)$

**Address:** 4000 D36Ch + 8h × n

| Bit                    | b31 | b30                           | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|------------------------|-----|-------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
|                        |     | AXI0_RANGE_WID_CHECK_BITS_[n] |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Value after reset      | 0   | 0                             | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit                    | b15 | b14                           | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                        |     | AXI0_RANGE_RID_CHECK_BITS_[n] |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| L<br>Value after reset | 0   | 0                             | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 6.103 DDR\_CTL\_[k] Register Contents

| Bit Position | Bit Name                          | Function                                                                                                 | R/W |
|--------------|-----------------------------------|----------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | AXI0_RANGE_WID_<br>CHECK_BITS_[n] | ID check is not supported.  Write 0xFFFF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port. | R/W |
| b15 to b0    | AXIO_RANGE_RID_C<br>HECK_BITS_[n] | ID check is not supported.  Write 0xFFFF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port. | R/W |

### 6.4.1.102 DDR\_CTL\_[k] — Port0 Range[n] Protect Setting Register2 (n = 0..14) $(k = 220 + n \times 2)$

**Address:** 4000 D370h + 8h × n



Table 6.104 DDR\_CTL\_[k] Register Contents

| Bit Position | Bit Name                                        | Function                                                                                                                                                                                                                            | R/W |
|--------------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved                                        | NA                                                                                                                                                                                                                                  | R   |
| b23 to b18   | Reserved                                        | NA                                                                                                                                                                                                                                  | R   |
| b17, b16     | AXI0_RANGE_PROT<br>_BITS_[n+1]                  | Allowed transaction types for port 0 address range [n+1]. Set to 0 for privileged and secure only, set to 1 for secure (with or without privileged), set to 2 for privileged (with or without secure), or set to 3 for full access. | R/W |
| b15 to b12   | Reserved                                        | NA                                                                                                                                                                                                                                  | R   |
| b11 to b8    | AXI0_RANGE_WID_<br>CHECK_BITS_ID_LO<br>OKUP_[n] | ID check is not supported.  Write 0xF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port.                                                                                                                               | R/W |
| b7 to b4     | Reserved                                        | NA                                                                                                                                                                                                                                  | R   |
| b3 to b0     | AXI0_RANGE_RID_C<br>HECK_BITS_ID_LOO<br>KUP_[n] | ID check is not supported.  Write 0xF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port.                                                                                                                               | R/W |

### 6.4.1.103 DDR\_CTL\_250 — Port0 Range15 Protect Setting Register2

Address: 4000 D3E8h



Table 6.105 DDR\_CTL\_250 Register Contents

| Bit Position | Bit Name                                       | Function                                                                                                                                                                                                                        | R/W |
|--------------|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved                                       | NA                                                                                                                                                                                                                              | R   |
| b23 to b18   | Reserved                                       | NA                                                                                                                                                                                                                              | R   |
| b17, b16     | AXI1_RANGE_PROT<br>_BITS_0                     | Allowed transaction types for port 1 address range 0. Set to 0 for privileged and secure only, set to 1 for secure (with or without privileged), set to 2 for privileged (with or without secure), or set to 3 for full access. | R/W |
| b15 to b12   | Reserved                                       | NA                                                                                                                                                                                                                              | R   |
| b11 to b8    | AXI0_RANGE_WID_<br>CHECK_BITS_ID_LO<br>OKUP_15 | ID check is not supported.  Write 0xF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port.                                                                                                                           | R/W |
| b7 to b4     | Reserved                                       | NA                                                                                                                                                                                                                              | R   |
| b3 to b0     | AXI0_RANGE_RID_C<br>HECK_BITS_ID_LOO<br>KUP_15 | ID check is not supported.  Write 0xF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port.                                                                                                                           | R/W |

## 6.4.1.104 DDR\_CTL\_[k] — Port1 Range[n] Protect Setting Register1 (n = 0..15) $(k = 251 + n \times 2)$

Address: 4000 D3ECh + 8h × n

| Bit               | b31 | b30                           | b29 | b28 | b27 | b26 | b25     | b24     | b23   | b22     | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-------------------------------|-----|-----|-----|-----|---------|---------|-------|---------|-----|-----|-----|-----|-----|-----|
|                   |     |                               |     |     |     | AX  | KI1_RAN | IGE_WIE | _CHEC | K_BITS_ | [n] |     |     |     |     |     |
|                   |     |                               |     |     |     |     |         |         |       |         |     |     |     |     |     |     |
| Value after reset | 0   | 0                             | 0   | 0   | 0   | 0   | 0       | 0       | 0     | 0       | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14                           | b13 | b12 | b11 | b10 | b9      | b8      | b7    | b6      | b5  | b4  | b3  | b2  | b1  | b0  |
|                   |     | AXI1_RANGE_RID_CHECK_BITS_[n] |     |     |     |     |         |         |       |         |     |     |     |     |     |     |
| Value after reset | 0   | 0                             | 0   | 0   | 0   | 0   | 0       | 0       | 0     | 0       | 0   | 0   | 0   | 0   | 0   | 0   |

Table 6.106 DDR\_CTL\_[k] Register Contents

| Bit Position | Bit Name                          | Function                                                                                                 | R/W |
|--------------|-----------------------------------|----------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | AXI1_RANGE_WID_<br>CHECK_BITS_[n] | ID check is not supported.  Write 0xFFFF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port. | R/W |
| b15 to b0    | AXI1_RANGE_RID_C<br>HECK_BITS_[n] | ID check is not supported.  Write 0xFFFF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port. | R/W |

## 6.4.1.105 DDR\_CTL\_[k] — Port1 Range[n] Protect Setting Register2 (n = 0..14) $(k = 252 + n \times 2)$

**Address:** 4000 D3F0h + 8h × n



Table 6.107 DDR\_CTL\_[k] Register Contents

| Bit Position | Bit Name                                        | Function                                                                                                                                                                                                                            | R/W |
|--------------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved                                        | NA                                                                                                                                                                                                                                  | R   |
| b23 to b18   | Reserved                                        | NA                                                                                                                                                                                                                                  | R   |
| b17, b16     | AXI1_RANGE_PROT<br>_BITS_[n+1]                  | Allowed transaction types for port 1 address range [n+1]. Set to 0 for privileged and secure only, set to 1 for secure (with or without privileged), set to 2 for privileged (with or without secure), or set to 3 for full access. | R/W |
| b15 to b12   | Reserved                                        | NA                                                                                                                                                                                                                                  | R   |
| b11 to b8    | AXI1_RANGE_WID_<br>CHECK_BITS_ID_LO<br>OKUP_[n] | ID check is not supported.  Write 0xF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port.                                                                                                                               | R/W |
| b7 to b4     | Reserved                                        | NA                                                                                                                                                                                                                                  | R   |
| b3 to b0     | AXI1_RANGE_RID_C<br>HECK_BITS_ID_LOO<br>KUP_[n] | ID check is not supported.  Write 0xF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port.                                                                                                                               | R/W |

### 6.4.1.106 DDR\_CTL\_282 — Port1 Range15 Protect Setting Register2

Address: 4000 D468h



Table 6.108 DDR\_CTL\_282 Register Contents

| Bit Position | Bit Name                                       | Function                                                                                                                                                                                                                        | R/W |
|--------------|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved                                       | NA                                                                                                                                                                                                                              | R   |
| b23 to b18   | Reserved                                       | NA                                                                                                                                                                                                                              | R   |
| b17, b16     | AXI2_RANGE_PROT<br>_BITS_0                     | Allowed transaction types for port 2 address range 0. Set to 0 for privileged and secure only, set to 1 for secure (with or without privileged), set to 2 for privileged (with or without secure), or set to 3 for full access. | R/W |
| b15 to b12   | Reserved                                       | NA                                                                                                                                                                                                                              | R   |
| b11 to b8    | AXI1_RANGE_WID_<br>CHECK_BITS_ID_LO<br>OKUP_15 | ID check is not supported.  Write 0xF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port.                                                                                                                           | R/W |
| b7 to b4     | Reserved                                       | NA                                                                                                                                                                                                                              | R   |
| b3 to b0     | AXI1_RANGE_RID_C<br>HECK_BITS_ID_LOO<br>KUP_15 | ID check is not supported.  Write 0xF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port.                                                                                                                           | R/W |

# 6.4.1.107 DDR\_CTL\_[k] — Port2 Range[n] Protect Setting Register1 (n = 0..15) $(k = 283 + n \times 2)$

**Address:** 4000 D46Ch + 8h × n

| Bit                    | b31 | b30                           | b29 | b28 | b27 | b26 | b25     | b24     | b23   | b22     | b21 | b20 | b19 | b18 | b17 | b16 |
|------------------------|-----|-------------------------------|-----|-----|-----|-----|---------|---------|-------|---------|-----|-----|-----|-----|-----|-----|
|                        |     |                               |     |     |     | A   | XI2_RAN | IGE_WIE | _CHEC | K_BITS_ | [n] |     |     |     |     |     |
| Value after reset      | 0   | 0                             | 0   | 0   | 0   | 0   | 0       | 0       | 0     | 0       | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit                    | b15 | b14                           | b13 | b12 | b11 | b10 | b9      | b8      | b7    | b6      | b5  | b4  | b3  | b2  | b1  | b0  |
|                        |     | AXI2_RANGE_RID_CHECK_BITS_[n] |     |     |     |     |         |         |       |         |     |     |     |     |     |     |
| L<br>Value after reset | 0   | 0                             | 0   | 0   | 0   | 0   | 0       | 0       | 0     | 0       | 0   | 0   | 0   | 0   | 0   | 0   |

Table 6.109 DDR\_CTL\_[k] Register Contents

| Bit Position | Bit Name                          | Function                                                                                                 | R/W |
|--------------|-----------------------------------|----------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | AXI2_RANGE_WID_<br>CHECK_BITS_[n] | ID check is not supported.  Write 0xFFFF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port. | R/W |
| b15 to b0    | AXI2_RANGE_RID_C<br>HECK_BITS_[n] | ID check is not supported.  Write 0xFFFF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port. | R/W |

## 6.4.1.108 DDR\_CTL\_[k] — Port2 Range[n] Protect Setting Register2 (n = 0..14) $(k = 284 + n \times 2)$

**Address:** 4000 D470h + 8h × n



Table 6.110 DDR\_CTL\_[k] Register Contents

| Bit Position | Bit Name                                        | Function                                                                                                                                                                                                                            | R/W |
|--------------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved                                        | NA                                                                                                                                                                                                                                  | R   |
| b23 to b18   | Reserved                                        | NA                                                                                                                                                                                                                                  | R   |
| b17, b16     | AXI2_RANGE_PROT<br>_BITS_[n+1]                  | Allowed transaction types for port 2 address range [n+1]. Set to 0 for privileged and secure only, set to 1 for secure (with or without privileged), set to 2 for privileged (with or without secure), or set to 3 for full access. | R/W |
| b15 to b12   | Reserved                                        | NA                                                                                                                                                                                                                                  | R   |
| b11 to b8    | AXI2_RANGE_WID_<br>CHECK_BITS_ID_LO<br>OKUP_[n] | ID check is not supported.  Write 0xF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port.                                                                                                                               | R/W |
| b7 to b4     | Reserved                                        | NA                                                                                                                                                                                                                                  | R   |
| b3 to b0     | AXI2_RANGE_RID_C<br>HECK_BITS_ID_LOO<br>KUP_[n] | ID check is not supported.  Write 0xF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port.                                                                                                                               | R/W |

### 6.4.1.109 DDR\_CTL\_314 — Port2 Range15 Protect Setting Register2

Address: 4000 D4E8h



Table 6.111 DDR\_CTL\_314 Register Contents

| Bit Position | Bit Name                                       | Function                                                                                                                                                                                                                        | R/W |
|--------------|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved                                       | NA                                                                                                                                                                                                                              | R   |
| b23 to b18   | Reserved                                       | NA                                                                                                                                                                                                                              | R   |
| b17, b16     | AXI3_RANGE_PROT<br>_BITS_0                     | Allowed transaction types for port 3 address range 0. Set to 0 for privileged and secure only, set to 1 for secure (with or without privileged), set to 2 for privileged (with or without secure), or set to 3 for full access. | R/W |
| b15 to b12   | Reserved                                       | NA                                                                                                                                                                                                                              | R   |
| b11 to b8    | AXI2_RANGE_WID_<br>CHECK_BITS_ID_LO<br>OKUP_15 | ID check is not supported.  Write 0xF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port.                                                                                                                           | R/W |
| b7 to b4     | Reserved                                       | NA                                                                                                                                                                                                                              | R   |
| b3 to b0     | AXI2_RANGE_RID_C<br>HECK_BITS_ID_LOO<br>KUP_15 | ID check is not supported.  Write 0xF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port.                                                                                                                           | R/W |

# 6.4.1.110 DDR\_CTL\_[k] — Port3 Range[n] Protect Setting Register1 (n = 0..15) $(k = 315 + n \times 2)$

Address: 4000 D4ECh + 8h × n

| Bit               | b31 | b30                           | b29 | b28 | b27 | b26 | b25     | b24     | b23  | b22     | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-------------------------------|-----|-----|-----|-----|---------|---------|------|---------|-----|-----|-----|-----|-----|-----|
|                   |     |                               |     |     |     | A   | XI3_RAN | IGE_WIE | CHEC | K_BITS_ | [n] |     |     |     |     |     |
| Value after reset | 0   | 0                             | 0   | 0   | 0   | 0   | 0       | 0       | 0    | 0       | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14                           | b13 | b12 | b11 | b10 | b9      | b8      | b7   | b6      | b5  | b4  | b3  | b2  | b1  | b0  |
|                   |     | AXI3_RANGE_RID_CHECK_BITS_[n] |     |     |     |     |         |         |      |         |     |     |     |     |     |     |
| Value after reset | 0   | 0                             | 0   | 0   | 0   | 0   | 0       | 0       | 0    | 0       | 0   | 0   | 0   | 0   | 0   | 0   |

Table 6.112 DDR\_CTL\_[k] Register Contents

| Bit Position | Bit Name                          | Function                                                                                                 | R/W |
|--------------|-----------------------------------|----------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | AXI3_RANGE_WID_<br>CHECK_BITS_[n] | ID check is not supported.  Write 0xFFFF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port. | R/W |
| b15 to b0    | AXI3_RANGE_RID_C<br>HECK_BITS_[n] | ID check is not supported.  Write 0xFFFF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port. | R/W |

### 6.4.1.111 DDR\_CTL\_[k] — Port3 Range[n] Protect Setting Register2 (n = 0..14) $(k = 316 + n \times 2)$

Address:  $4000 D4F0h + 8h \times n$ 



Table 6.113 DDR\_CTL\_[k] Register Contents

| Bit Position | Bit Name                                        | Function                                                                                                                                                                                                                            | R/W |
|--------------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved                                        | NA                                                                                                                                                                                                                                  | R   |
| b23 to b18   | Reserved                                        | NA                                                                                                                                                                                                                                  | R   |
| b17, b16     | AXI3_RANGE_PROT<br>_BITS_[n+1]                  | Allowed transaction types for port 3 address range [n+1]. Set to 0 for privileged and secure only, set to 1 for secure (with or without privileged), set to 2 for privileged (with or without secure), or set to 3 for full access. | R/W |
| b15 to b12   | Reserved                                        | NA                                                                                                                                                                                                                                  | R   |
| b11 to b8    | AXI3_RANGE_WID_<br>CHECK_BITS_ID_LO<br>OKUP_[n] | ID check is not supported.  Write 0xF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port.                                                                                                                               | R/W |
| b7 to b4     | Reserved                                        | NA                                                                                                                                                                                                                                  | R   |
| b3 to b0     | AXI3_RANGE_RID_C<br>HECK_BITS_ID_LOO<br>KUP_[n] | ID check is not supported.  Write 0xF when applying PORT_ADDR_PROTECTION_EN to Range[n] of this port.                                                                                                                               | R/W |

### 6.4.1.112 DDR\_CTL\_346 — Port3 Range15 Protect Setting Register2

Address: 4000 D568h



Table 6.114 DDR\_CTL\_346 Register Contents

| Bit Position | Bit Name                                       | Function                                                                                             | R/W |
|--------------|------------------------------------------------|------------------------------------------------------------------------------------------------------|-----|
| b31          | Reserved                                       | NA                                                                                                   | R   |
| b30 to b24   | AXI0_BDW                                       | Maximum bandwidth percentage for port 0.                                                             | R/W |
| b23 to b19   | Reserved                                       | NA                                                                                                   | R   |
| b18 to b16   | ARB_CMD_Q_THRE<br>SHOLD                        | Threshold for command queue fullness related to overflow.                                            | R/W |
| b15 to b12   | Reserved                                       | NA                                                                                                   | R   |
| b11 to b8    | AXI3_RANGE_WID_<br>CHECK_BITS_ID_LO<br>OKUP_15 | ID check is not supported.  Write 0xF when applying PORT_ADDR_PROTECTION_EN to Range15 of this port. | R/W |
| b7 to b4     | Reserved                                       | NA                                                                                                   | R   |
| b3 to b0     | AXI3_RANGE_RID_C<br>HECK_BITS_ID_LOO<br>KUP_15 | ID check is not supported.  Write 0xF when applying PORT_ADDR_PROTECTION_EN to Range15 of this port. | R/W |

### 6.4.1.113 DDR\_CTL\_347 — DDR-Controller Status & Control 347

Address: 4000 D56Ch



Table 6.115 DDR\_CTL\_347 Register Contents

| Bit Position | Bit Name             | Function                                                              | R/W |
|--------------|----------------------|-----------------------------------------------------------------------|-----|
| b31 to b25   | Reserved             | NA                                                                    | R   |
| b24          | AXI1_BDW_OVFLO<br>W  | Port 1 behavior when bandwidth maximized. Set to 1 to allow overflow. | R/W |
| b23          | Reserved             | NA                                                                    | R   |
| b22 to b16   | AXI1_BDW             | Maximum bandwidth percentage for port 1.                              | R/W |
| b15          | Reserved             | NA                                                                    | R   |
| b14 to b8    | AXI0_CURRENT_BD<br>W | Current bandwidth usage percentage for port 0.                        | R   |
| b7 to b1     | Reserved             | NA                                                                    | R   |
| b0           | AXI0_BDW_OVFLO<br>W  | Port 0 behavior when bandwidth maximized. Set to 1 to allow overflow. | R/W |

### 6.4.1.114 DDR\_CTL\_348 — DDR-Controller Status & Control 348

Address: 4000 D570h

| Bit               | b31 | b30 | b29      | b28    | b27   | b26   | b25 | b24 | b23 | b22              | b21 | b20 | b19 | b18 | b17 | b16                     |
|-------------------|-----|-----|----------|--------|-------|-------|-----|-----|-----|------------------|-----|-----|-----|-----|-----|-------------------------|
|                   | _   |     |          | AXI2_C | URREN | T_BDW |     |     | _   |                  |     | _   | _   |     | _   | AXI2_B<br>DW_OV<br>FLOW |
| Value after reset | 0   | 0   | 0        | 0      | 0     | 0     | 0   | 0   | 0   | 0                | 0   | 0   | 0   | 0   | 0   | 0                       |
| Bit               | b15 | b14 | b13      | b12    | b11   | b10   | b9  | b8  | b7  | b6               | b5  | b4  | b3  | b2  | b1  | b0                      |
|                   | _   |     | AXI2_BDW |        |       |       |     |     | _   | AXI1_CURRENT_BDW |     |     |     |     |     |                         |
| Value after reset | 0   | 0   | 0        | 0      | 0     | 0     | 0   | 0   | 0   | 0                | 0   | 0   | 0   | 0   | 0   | 0                       |

Table 6.116 DDR\_CTL\_348 Register Contents

| Bit Position | Bit Name             | Function                                                              | R/W |
|--------------|----------------------|-----------------------------------------------------------------------|-----|
| b31          | Reserved             | NA                                                                    | R   |
| b30 to b24   | AXI2_CURRENT_BD<br>W | Current bandwidth usage percentage for port 2.                        | R   |
| b23 to b17   | Reserved             | NA                                                                    | R   |
| b16          | AXI2_BDW_OVFLO<br>W  | Port 2 behavior when bandwidth maximized. Set to 1 to allow overflow. | R/W |
| b15          | Reserved             | NA                                                                    | R   |
| b14 to b8    | AXI2_BDW             | Maximum bandwidth percentage for port 2.                              | R/W |
| b7           | Reserved             | NA                                                                    | R   |
| b6 to b0     | AXI1_CURRENT_BD<br>W | Current bandwidth usage percentage for port 1.                        | R   |

# 6.4.1.115 DDR\_CTL\_349 — DDR-Controller Status & Control 349

Address: 4000 D574h



Table 6.117 DDR\_CTL\_349 Register Contents

| Bit Position | Bit Name             | Function                                                              | R/W |
|--------------|----------------------|-----------------------------------------------------------------------|-----|
| b31 to b26   | Reserved             | NA                                                                    | R   |
| b25, b24     | CKE_STATUS           | The value of cke_status internal signal.                              | R   |
|              |                      | Bit [0] is for CS0 and bit [1] is for CS1.                            |     |
|              |                      | 0: The memory is in power-down or self-refresh.                       |     |
|              |                      | 1: The memory is active.                                              |     |
| b23          | Reserved             | NA                                                                    | R   |
| b22 to b16   | AXI3_CURRENT_BD<br>W | Current bandwidth usage percentage for port 3.                        | R   |
| b15 to b9    | Reserved             | NA                                                                    | R   |
| b8           | AXI3_BDW_OVFLO<br>W  | Port 3 behavior when bandwidth maximized. Set to 1 to allow overflow. | R/W |
| b7           | Reserved             | NA                                                                    | R   |
| b6 to b0     | AXI3_BDW             | Maximum bandwidth percentage for port 3.                              | R/W |

# 6.4.1.116 DDR\_CTL\_350 — DDR-Controller Status & Control 350

Address: 4000 D578h

| Bit               | b31 | b30 | b29 | b28     | b27     | b26      | b25 | b24 | b23 | b22 | b21 | b20     | b19    | b18 | b17 | b16    |
|-------------------|-----|-----|-----|---------|---------|----------|-----|-----|-----|-----|-----|---------|--------|-----|-----|--------|
|                   |     |     |     |         |         |          |     |     |     |     |     |         |        |     |     |        |
|                   |     |     | D   | LL_RST  | VD I DI | V        |     |     |     |     |     | DLL_RS  | L DELV | ,   |     |        |
|                   |     |     | D   | LL_I\SI | _ADJ_DI | _ '      |     |     |     |     |     | DLL_ING | _DLLA  | ı   |     |        |
|                   |     |     |     |         |         |          |     |     |     |     |     |         |        |     |     |        |
| Value after reset | 0   | 0   | 0   | 0       | 0       | 0        | 0   | 0   | 0   | 0   | 0   | 0       | 0      | 0   | 0   | 0      |
|                   |     |     |     |         |         |          |     |     |     |     |     |         |        |     |     |        |
| <b>5</b> 1        |     |     |     |         |         |          |     |     |     |     |     |         |        |     |     |        |
| Bit               | b15 | b14 | b13 | b12     | b11     | b10      | b9  | b8  | b7  | b6  | b5  | b4      | b3     | b2  | b1  | b0     |
|                   |     |     |     |         |         |          |     |     |     |     |     |         |        |     |     | MEM_R  |
|                   |     |     |     | DLL_RS  | L DELA  | <b>v</b> |     |     |     |     | _   |         |        |     |     | ST_VAL |
|                   |     |     |     | DLL_ING | _DLLA   |          |     |     |     |     |     |         |        |     | _   | ID     |
|                   |     |     |     |         |         |          |     |     |     |     |     |         |        |     |     | ID     |
| Value after reset | 0   | 0   | 0   | 0       | 0       | 0        | 0   | 0   | 0   | 0   | 0   | 0       | 0      | 0   | 0   | 0      |

Table 6.118 DDR\_CTL\_350 Register Contents

| Bit Position | Bit Name        | Function                                                                                                                                       | R/W |
|--------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | DLL_RST_ADJ_DLY | This parameter is invalid.                                                                                                                     | R/W |
| b23 to b8    | DLL_RST_DELAY   | This parameter is invalid.                                                                                                                     | R/W |
| b7 to b1     | Reserved        | NA                                                                                                                                             | R   |
| b0           | MEM_RST_VALID   | The value of mem_rst_valid internal signal.  If this bit is set, the controller is able to regain control of the memory reset and cke signals. | R   |

## 6.4.1.117 DDR\_CTL\_351 — DDR-Controller Status & Control 351

Address: 4000 D57Ch



Table 6.119 DDR\_CTL\_351 Register Contents

| Bit Position | Bit Name                | Function                                                                                                                                                                 | R/W |
|--------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31, b30     | Reserved                | NA                                                                                                                                                                       | R   |
| b29 to b24   | TDFI_RDDATA_EN          | Holds the calculated DFI tRDDATA_EN timing parameter (in memory clock cycles), the maximum cycles between a read command and a dfi_rddata_en assertion.                  | R   |
| b23, b22     | Reserved                | NA                                                                                                                                                                       | R   |
| b21 to b16   | TDFI_PHY_RDLAT          | Defines the DFI tPHY_RDLAT timing parameter (in memory clock cycles), the maximum cycles between a dfi_rddata_en assertion and a dfi_rddata_valid assertion.             | R/W |
| b15          | Reserved                | NA                                                                                                                                                                       | R   |
| b14 to b8    | UPDATE_ERROR_S<br>TATUS | Identifies the source of any DFI memory-controller-initiated or PHY-initiated update errors. Value of 1 indicates a timing violation of the associated timing parameter. | R   |
| b7, b6       | Reserved                | NA                                                                                                                                                                       | R   |
| b5 to b0     | TDFI_PHY_WRLAT          | Holds the calculated DFI tPHY_WRLAT timing parameter (in memory clock cycles), the maximum cycles between a write command and a dfi_wrdata_en assertion.                 | R   |

## 6.4.1.118 DDR\_CTL\_352 — DDR-Controller Status & Control 352

Address: 4000 D580h



Table 6.120 DDR\_CTL\_352 Register Contents

| Bit Position | Bit Name             | Function                                                                                                                                                                                                                                                       | R/W |
|--------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31, b30     | Reserved             | NA                                                                                                                                                                                                                                                             | R   |
| b29 to b16   | TDFI_CTRLUPD_MA<br>X | Defines the DFI tCTRLUPD_MAX timing parameter (in DFICLK clock cycles), the maximum cycles that dfi_ctrlupd_req can be asserted. If programmed to a non-zero, a timing violation will cause an interrupt and bit (1) set in the UPDATE_ERROR_STATUS parameter. | R/W |
| b15 to b12   | Reserved             | NA NA                                                                                                                                                                                                                                                          | R   |
| b11 to b8    | TDFI_CTRLUPD_MIN     | Reports the DFI tCTRLUPD_MIN timing parameter (in DFICLK clock cycles), the minimum cycles that dfi_ctrlupd_req must be asserted.                                                                                                                              | R   |
| b7 to b2     | Reserved             | NA NA                                                                                                                                                                                                                                                          | R   |
| b1, b0       | DRAM_CLK_DISABL<br>E | Set value for the dfi_dram_clk_disable signal. Bit (0) controls cs0, bit (1) controls cs1, etc. Set each bit to 1 to disable.                                                                                                                                  | R/W |

# 6.4.1.119 DDR\_CTL\_353 — DDR-Controller Status & Control 353

Address: 4000 D584h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24     | b23     | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|---------|---------|-----|-----|-----|-----|-----|-----|-----|
|                   |     |     |     |     |     |     | TD  | FI_PHYL | JPD_TYI | PE1 |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0       | 0       | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8      | b7      | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                   |     |     |     |     |     |     | TD  | FI_PHYU | JPD_TYI | PE0 |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0       | 0       | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 6.121 DDR\_CTL\_353 Register Contents

| Bit Position | Bit Name              | Function                                                                                                                                                                                                                                                                                             | R/W |
|--------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | TDFI_PHYUPD_TYP<br>E1 | Defines the DFI tPHYUPD_TYPE1 timing parameter (in DFICLK clock cycles), the maximum cycles that dfi_phyupd_req can assert after dfi_phyupd_ack for dfi_phyupd_type 1. If programmed to a non-zero, a timing violation will cause an interrupt and bit (3) set in the UPDATE_ERROR_STATUS parameter. | R/W |
| b15 to b0    | TDFI_PHYUPD_TYP<br>E0 | Defines the DFI tPHYUPD_TYPE0 timing parameter (in DFICLK clock cycles), the maximum cycles that dfi_phyupd_req can assert after dfi_phyupd_ack for dfi_phyupd_type 0. If programmed to a non-zero, a timing violation will cause an interrupt and bit (2) set in the UPDATE_ERROR_STATUS parameter. | R/W |

# 6.4.1.120 DDR\_CTL\_354 — DDR-Controller Status & Control 354

Address: 4000 D588h



Table 6.122 DDR\_CTL\_354 Register Contents

| Bit Position | Bit Name              | Function                                                                                                                                                                                                                                                                                             | R/W |
|--------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | TDFI_PHYUPD_TYP<br>E3 | Defines the DFI tPHYUPD_TYPE3 timing parameter (in DFICLK clock cycles), the maximum cycles that dfi_phyupd_req can assert after dfi_phyupd_ack for dfi_phyupd_type 3. If programmed to a non-zero, a timing violation will cause an interrupt and bit (5) set in the UPDATE_ERROR_STATUS parameter. | R/W |
| b15 to b0    | TDFI_PHYUPD_TYP<br>E2 | Defines the DFI tPHYUPD_TYPE2 timing parameter (in DFICLK clock cycles), the maximum cycles that dfi_phyupd_req can assert after dfi_phyupd_ack for dfi_phyupd_type 2. If programmed to a non-zero, a timing violation will cause an interrupt and bit (4) set in the UPDATE_ERROR_STATUS parameter. | R/W |

## 6.4.1.121 DDR\_CTL\_355 — DDR-Controller Status & Control 355

Address: 4000 D58Ch

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23    | b22    | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|--------|--------|-----|-----|-----|-----|-----|-----|
|                   | _   | _   | _   | _   | _   | _   | _   | _   | _      | _      | _   | _   | _   | _   | _   | _   |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0      | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7     | b6     | b5  | b4  | b3  | b2  | b1  | b0  |
|                   | _   | _   |     |     |     |     |     | TD  | FI_PHY | UPD_RE | SP  |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0      | 0   | 0   | 0   | 0   | 0   | 0   |

Table 6.123 DDR\_CTL\_355 Register Contents

| Bit Position | Bit Name             | Function                                                                                                                                                                                                                                                                                    | R/W |
|--------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | Reserved             | NA                                                                                                                                                                                                                                                                                          | R   |
| b15, b14     | Reserved             | NA                                                                                                                                                                                                                                                                                          | R   |
| b13 to b0    | TDFI_PHYUPD_RES<br>P | Defines the DFI tPHYUPD_RESP timing parameter (in DFICLK clock cycles), the maximum cycles between a dfi_phyupd_req assertion and a dfi_phyupd_ack assertion. If programmed to a non-zero, a timing violation will cause an interrupt and bit (6) set in the UPDATE_ERROR_STATUS parameter. | R/W |

## 6.4.1.122 DDR\_CTL\_356 — DDR-Controller Status & Control 356

Address: 4000 D590h



Table 6.124 DDR\_CTL\_356 Register Contents

| Bit Position | Bit Name                  | Function                                                                                                                                                                                                                                                          | R/W |
|--------------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b0    | TDFI_CTRLUPD_INT<br>ERVAL | Defines the DFI tCTRLUPD_INTERVAL timing parameter (in DFICLK clock cycles), the maximum cycles between dfi_ctrlupd_req assertions. If programmed to a non-zero, a timing violation will cause an interrupt and bit (0) set in the UPDATE_ERROR_STATUS parameter. | R/W |

# 6.4.1.123 DDR\_CTL\_357 — DDR-Controller Status & Control 357

Address: 4000 D594h

| Bit               | b31 | b30 | b29 | b28 | b27   | b26    | b25     | b24   | b23 | b22 | b21 | b20 | b19  | b18     | b17     | b16 |
|-------------------|-----|-----|-----|-----|-------|--------|---------|-------|-----|-----|-----|-----|------|---------|---------|-----|
|                   | _   | _   | _   | _   | TDFI_ | _DRAM_ | CLK_DIS | SABLE | _   | _   | _   | _   | Т    | DFI_CTF | RL_DEL# | 4Y  |
| Value after reset | 0   | 0   | 0   | 0   | 0     | 0      | 0       | 0     | 0   | 0   | 0   | 0   | 0    | 0       | 1       | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11   | b10    | b9      | b8    | b7  | b6  | b5  | b4  | b3   | b2      | b1      | b0  |
|                   | _   | -   |     |     | WRLA  | T_ADJ  |         |       | _   | -   |     |     | RDLA | T_ADJ   |         |     |
| Value after reset | 0   | 0   | 0   | 0   | 0     | 0      | 0       | 0     | 0   | 0   | 0   | 0   | 0    | 0       | 0       | 0   |

Table 6.125 DDR\_CTL\_357 Register Contents

| Bit Position | Bit Name                  | Function                                                                                                                                                        | R/W |
|--------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b28   | Reserved                  | NA                                                                                                                                                              | R   |
| b27 to b24   | TDFI_DRAM_CLK_DI<br>SABLE | Defines the DFI tDRAM_CLK_DISABLE timing parameter (in DFICLK clock cycles), the delay between a dfi_dram_clock_disable assertion and the memory clock disable. | R/W |
| b23 to b20   | Reserved                  | NA                                                                                                                                                              | R   |
| b19 to b16   | TDFI_CTRL_DELAY           | Defines the DFI tCTRL_DELAY timing parameter (in DFICLK clock cycles), the delay between a DFI command change and a memory command.                             | R/W |
| b15, b14     | Reserved                  | NA                                                                                                                                                              | R   |
| b13 to b8    | WRLAT_ADJ                 | Adjustment value for PHY write timing (memory clock cycles)                                                                                                     | R/W |
| b7, b6       | Reserved                  | NA                                                                                                                                                              | R   |
| b5 to b0     | RDLAT_ADJ                 | Adjustment value for PHY read timing (memory clock cycles)                                                                                                      | R/W |

## 6.4.1.124 DDR\_CTL\_358 — DDR-Controller Status & Control 358

Address: 4000 D598h

| Bit               | b31 | b30 | b29 | b28     | b27     | b26 | b25 | b24 | b23 | b22 | b21    | b20    | b19   | b18    | b17    | b16  |
|-------------------|-----|-----|-----|---------|---------|-----|-----|-----|-----|-----|--------|--------|-------|--------|--------|------|
|                   | _   | _   | _   | _       | _       | _   |     |     |     | T   | DFI_WR | LVL_W\ | V     |        |        |      |
| Value after reset | 0   | 0   | 0   | 0       | 0       | 0   | 0   | 0   | 0   | 0   | 0      | 0      | 0     | 0      | 0      | 0    |
| Bit               | b15 | b14 | b13 | b12     | b11     | b10 | b9  | b8  | b7  | b6  | b5     | b4     | b3    | b2     | b1     | b0   |
|                   |     |     |     | TDFI_WF | RLVL_EN | ١   |     |     | _   | _   | _      | _      | TDFI_ | _DRAM_ | CLK_EN | ABLE |
| Value after reset | 0   | 0   | 0   | 0       | 0       | 0   | 0   | 0   | 0   | 0   | 0      | 0      | 0     | 0      | 0      | 0    |

Table 6.126 DDR\_CTL\_358 Register Contents

| Bit Position | Bit Name                 | Function                                                                                                                                                       | R/W |
|--------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b26   | Reserved                 | NA                                                                                                                                                             | R   |
| b25 to b16   | TDFI_WRLVL_WW            | NA. The bit should be kept the initial value.                                                                                                                  | R/W |
| b15 to b8    | TDFI_WRLVL_EN            | NA. The bit should be kept the initial value.                                                                                                                  | R/W |
| b7 to b4     | Reserved                 | NA                                                                                                                                                             | R   |
| b3 to b0     | TDFI_DRAM_CLK_E<br>NABLE | Defines the DFI tDRAM_CLK_ENABLE timing parameter (in DFICLK clock cycles), the delay between a dfi_dram_clk_disable de-assertion and the memory clock enable. | R/W |

## 6.4.1.125 DDR\_CTL\_359 — DDR-Controller Status & Control 359

Address: 4000 D59Ch



Table 6.127 DDR\_CTL\_359 Register Contents

| Bit Position | Bit Name        | Function                                      | R/W |
|--------------|-----------------|-----------------------------------------------|-----|
| b31 to b0    | TDFI_WRLVL_RESP | NA. The bit should be kept the initial value. | R/W |

## 6.4.1.126 DDR\_CTL\_360 — DDR-Controller Status & Control 360

Address: 4000 D5A0h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24    | b23    | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|--------|--------|-----|-----|-----|-----|-----|-----|-----|
|                   |     |     |     |     |     |     | Т   | DFI_WR | LVL_MA | λX  |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8     | b7     | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                   |     |     |     |     |     |     | Т   | DFI_WR | LVL_MA | λX  |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 6.128 DDR\_CTL\_360 Register Contents

| Bit Position | Bit Name       | Function                                      | R/W |
|--------------|----------------|-----------------------------------------------|-----|
| b31 to b0    | TDFI_WRLVL_MAX | NA. The bit should be kept the initial value. | R/W |

## 6.4.1.127 DDR\_CTL\_361 — DDR-Controller Status & Control 361

Address: 4000 D5A4h



Table 6.129 DDR\_CTL\_361 Register Contents

| Bit Position | Bit Name                | Function                                      | R/W |
|--------------|-------------------------|-----------------------------------------------|-----|
| b31 to b24   | TDFI_WRLVL_RESP<br>LAT  | NA. The bit should be kept the initial value. | R/W |
| b23 to b16   | TDFI_WRLVL_DLL          | NA. The bit should be kept the initial value. | R/W |
| b15 to b0    | DFI_WRLVL_MAX_D<br>ELAY | NA. The bit should be kept the initial value. | R/W |

## 6.4.1.128 DDR\_CTL\_362 — DDR-Controller Status & Control 362

Address: 4000 D5A8h

| Bit               | b31 | b30 | b29 | b28     | b27     | b26 | b25 | b24 | b23 | b22 | b21 | b20     | b19    | b18       | b17 | b16 |
|-------------------|-----|-----|-----|---------|---------|-----|-----|-----|-----|-----|-----|---------|--------|-----------|-----|-----|
|                   |     |     | Т   | DFI_RDI | _VL_LOA | AD  |     |     |     |     |     | TDFI_RD | LVL_DL | L         |     |     |
| Value after reset | 0   | 0   | 0   | 0       | 0       | 0   | 0   | 0   | 0   | 0   | 0   | 0       | 0      | 0         | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12     | b11     | b10 | b9  | b8  | b7  | b6  | b5  | b4      | b3     | b2        | b1  | b0  |
|                   |     |     |     | TDFI_R  | DLVL_EN | ١   |     |     |     |     | Т   | DFI_WRI | _VL_LO | <b>AD</b> |     |     |
| Value after reset | 0   | 0   | 0   | 0       | 0       | 0   | 0   | 0   | 0   | 0   | 0   | 0       | 0      | 0         | 0   | 0   |

Table 6.130 DDR\_CTL\_362 Register Contents

| Bit Position | Bit Name        | Function                                      | R/W |
|--------------|-----------------|-----------------------------------------------|-----|
| b31 to b24   | TDFI_RDLVL_LOAD | NA. The bit should be kept the initial value. | R/W |
| b23 to b16   | TDFI_RDLVL_DLL  | NA. The bit should be kept the initial value. | R/W |
| b15 to b8    | TDFI_RDLVL_EN   | NA. The bit should be kept the initial value. | R/W |
| b7 to b0     | TDFI_WRLVL_LOAD | NA. The bit should be kept the initial value. | R/W |

## 6.4.1.129 DDR\_CTL\_363 — DDR-Controller Status & Control 363

Address: 4000 D5ACh



Table 6.131 DDR\_CTL\_363 Register Contents

| Bit Position | Bit Name               | Function                                      | R/W |
|--------------|------------------------|-----------------------------------------------|-----|
| b31 to b24   | Reserved               | NA                                            | R   |
| b23 to b8    | RDLVL_MAX_DELAY        | NA. The bit should be kept the initial value. | R/W |
| b7 to b0     | TDFI_RDLVL_RESPL<br>AT | NA. The bit should be kept the initial value. | R/W |

## 6.4.1.130 DDR\_CTL\_364 — DDR-Controller Status & Control 364

Address: 4000 D5B0h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25  | b24    | b23    | b22  | b21     | b20     | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|------|--------|--------|------|---------|---------|-----|-----|-----|-----|
|                   | _   | _   | _   | _   | _   | _   |      |        |        | -    | TDFI_RD | DLVL_RF | 1   |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0      | 0      | 0    | 0       | 0       | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9   | b8     | b7     | b6   | b5      | b4      | b3  | b2  | b1  | b0  |
|                   |     |     |     |     |     |     | RDLV | L_GATE | _MAX_C | ELAY |         |         |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0      | 0      | 0    | 0       | 0       | 0   | 0   | 0   | 0   |

Table 6.132 DDR\_CTL\_364 Register Contents

| Bit Position | Bit Name                 | Function                                      | R/W |
|--------------|--------------------------|-----------------------------------------------|-----|
| b31 to b26   | Reserved                 | NA                                            | R   |
| b25 to b16   | TDFI_RDLVL_RR            | NA. The bit should be kept the initial value. | R/W |
| b15 to b0    | RDLVL_GATE_MAX_<br>DELAY | NA. The bit should be kept the initial value. | R/W |

# 6.4.1.131 DDR\_CTL\_365 — DDR-Controller Status & Control 365

Address: 4000 D5B4h



Table 6.133 DDR\_CTL\_365 Register Contents

| Bit Position | Bit Name        | Function                                      | R/W |
|--------------|-----------------|-----------------------------------------------|-----|
| b31 to b0    | TDFI_RDLVL_RESP | NA. The bit should be kept the initial value. | R/W |

## 6.4.1.132 DDR\_CTL\_366 — DDR-Controller Status & Control 366

Address: 4000 D5B8h



Table 6.134 DDR\_CTL\_366 Register Contents

| Bit Position | Bit Name        | Function                                      | R/W |
|--------------|-----------------|-----------------------------------------------|-----|
| b31 to b24   | Reserved        | NA                                            | R   |
| b23 to b20   | Reserved        | NA                                            | R   |
| b19 to b0    | RDLVL_RESP_MASK | NA. The bit should be kept the initial value. | R/W |

## 6.4.1.133 DDR\_CTL\_367 — DDR-Controller Status & Control 367

Address: 4000 D5BCh



Table 6.135 DDR\_CTL\_367 Register Contents

| Bit Position | Bit Name                 | Function                                      | R/W |
|--------------|--------------------------|-----------------------------------------------|-----|
| b31 to b25   | Reserved                 | NA                                            | R   |
| b24          | RDLVL_EN                 | NA. The bit should be kept the initial value. | R/W |
| b23 to b20   | Reserved                 | NA                                            | R   |
| b19 to b0    | RDLVL_GATE_RESP<br>_MASK | NA. The bit should be kept the initial value. | R/W |

## 6.4.1.134 DDR\_CTL\_368 — DDR-Controller Status & Control 368

Address: 4000 D5C0h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24                                          | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16                   |
|-------------------|-----|-----|-----|-----|-----|-----|-----|----------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----------------------|
|                   | _   | _   | _   | _   | _   | _   | _   | _                                            | _   | _   | _   | _   | _   | _   | _   | _                     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                                            | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                     |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8                                           | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0                    |
|                   | _   | _   | _   | _   | _   | _   | _   | RDLVL_G<br>ATE_PRE<br>AMBLE_<br>CHECK_<br>EN | _   | _   | ı   | ı   | _   | _   | _   | RDLVL<br>_GATE<br>_EN |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                                            | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                     |

Table 6.136 DDR\_CTL\_368 Register Contents

| Bit Position | Bit Name                         | Function                                      | R/W |
|--------------|----------------------------------|-----------------------------------------------|-----|
| b31 to b16   | Reserved                         | NA                                            | R   |
| b15 to b9    | Reserved                         | NA                                            | R   |
| b8           | RDLVL_GATE_PREA<br>MBLE_CHECK_EN | NA. The bit should be kept the initial value. | R/W |
| b7 to b1     | Reserved                         | NA                                            | R   |
| b0           | RDLVL_GATE_EN                    | NA. The bit should be kept the initial value. | R/W |

## 6.4.1.135 DDR\_CTL\_369 — DDR-Controller Status & Control 369

Address: 4000 D5C4h



Table 6.137 DDR\_CTL\_369 Register Contents

| Bit Position | Bit Name       | Function                                      | R/W |
|--------------|----------------|-----------------------------------------------|-----|
| b31 to b0    | TDFI_RDLVL_MAX | NA. The bit should be kept the initial value. | R/W |

# 6.4.1.136 DDR\_CTL\_370 — DDR-Controller Status & Control 370

Address: 4000 D5C8h

| Bit               | b31 | b30 | b29 | b28                                    | b27 | b26 | b25 | b24 | b23    | b22    | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|----------------------------------------|-----|-----|-----|-----|--------|--------|-----|-----|-----|-----|-----|-----|
|                   | _   | _   |     |                                        |     |     |     | RDL | VL_ERR | OR_STA | TUS |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0                                      | 0   | 0   | 0   | 0   | 0      | 0      | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12                                    | b11 | b10 | b9  | b8  | b7     | b6     | b5  | b4  | b3  | b2  | b1  | b0  |
|                   | _   | _   | _   | RDLVL_GATE_DQ_0_COUNT RDLVL_DQ_0_COUNT |     |     |     |     |        |        |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0                                      | 0   | 0   | 0   | 0   | 0      | 0      | 0   | 0   | 0   | 0   | 0   | 0   |

Table 6.138 DDR\_CTL\_370 Register Contents

| Bit Position | Bit Name                  | Function                                      | R/W |
|--------------|---------------------------|-----------------------------------------------|-----|
| b31, b30     | Reserved                  | NA                                            | R   |
| b29 to b16   | RDLVL_ERROR_STA<br>TUS    | NA                                            | R   |
| b15 to b12   | Reserved                  | NA                                            | R   |
| b11 to b8    | RDLVL_GATE_DQ_0<br>_COUNT | NA. The bit should be kept the initial value. | R/W |
| b7 to b4     | Reserved                  | NA                                            | R   |
| b3 to b0     | RDLVL_DQ_0_COUN<br>T      | NA. The bit should be kept the initial value. | R/W |

## 6.4.1.137 DDR\_CTL\_371 — DDR-Controller Status & Control 371

Address: 4000 D5CCh



Table 6.139 DDR\_CTL\_371 Register Contents

| Bit Position | Bit Name                | Function                                      | R/W |
|--------------|-------------------------|-----------------------------------------------|-----|
| b31 to b16   | RDLVL_GATE_INTE<br>RVAL | NA. The bit should be kept the initial value. | R/W |
| b15 to b0    | RDLVL_INTERVAL          | NA. The bit should be kept the initial value. | R/W |

# 6.4.1.138 DDR\_CTL\_372 — DDR-Controller Status & Control 372

Address: 4000 D5D0h

| Bit               | b31                            | b30 | b29 | b28 | b27 | b26 | b25 | b24                      | b23 | b22 | b21    | b20   | b19     | b18    | b17    | b16   |
|-------------------|--------------------------------|-----|-----|-----|-----|-----|-----|--------------------------|-----|-----|--------|-------|---------|--------|--------|-------|
|                   | _                              |     | _   |     |     |     | _   | OPTIMAL<br>_RMODW<br>_EN |     | ME  | EMCD_R | MODW_ | _FIFO_P | TR_WID | TH     |       |
| Value after reset | 0                              | 0   | 0   | 0   | 0   | 0   | 0   | 0                        | 0   | 0   | 0      | 0     | 0       | 1      | 0      | 1     |
| Bit               | b15                            | b14 | b13 | b12 | b11 | b10 | b9  | b8                       | b7  | b6  | b5     | b4    | b3      | b2     | b1     | b0    |
|                   | MEMCD_RMODW_FIFO_DEPTH — — — — |     |     |     |     |     |     |                          |     |     |        |       | _       | TDFI_  | PHY_WF | RDATA |
| Value after reset | 0                              | 0   | 0   | 1   | 0   | 1   | 0   | 0                        | 0   | 0   | 0      | 0     | 0       | 0      | 0      | 0     |

Table 6.140 DDR\_CTL\_372 Register Contents

| Bit Position | Bit Name                       | Function                                                                                                                                             | R/W |
|--------------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b25   | Reserved                       | NA                                                                                                                                                   | R   |
| b24          | OPTIMAL_RMODW_<br>EN           | NA. It should be kept the initial value.                                                                                                             | R/W |
| b23 to b16   | MEMCD_RMODW_FI<br>FO_PTR_WIDTH | Reports the width of the controller read/modify/write FIFO pointer.                                                                                  | R   |
| b15 to b8    | MEMCD_RMODW_FI<br>FO_DEPTH     | Reports the depth of the controller read/modify/write FIFO.                                                                                          | R   |
| b7 to b3     | Reserved                       | NA                                                                                                                                                   | R   |
| b2 to b0     | TDFI_PHY_WRDATA                | Defines the DFI tPHY_WRDATA timing parameter (in memory clock cycles), the maximum cycles between a dfi_wrdata_en assertion and a dfi_wrdata signal. | R/W |

# 6.4.1.139 DDR\_CTL\_373 — DDR-Controller Status & Control 373

Address: 4000 D5D4h



Table 6.141 DDR\_CTL\_373 Register Contents

| Bit Position | Bit Name | Function                                                      | R/W |
|--------------|----------|---------------------------------------------------------------|-----|
| b31 to b25   | Reserved | NA                                                            | R   |
| b24          | Reserved | Reserved for future use. It should be kept the initial value. | R/W |
| b23 to b21   | Reserved | NA                                                            | R   |
| b20 to b16   | Reserved | Reserved for future use. It should be kept the initial value. | R/W |
| b15 to b9    | Reserved | NA                                                            | R   |
| b8           | Reserved | Reserved for future use. It should be kept the initial value. | R/W |
| b7 to b1     | Reserved | NA                                                            | R   |
| b0           | Reserved | Reserved for future use. It should be set to 1.               | R/W |

## 6.4.1.140 DDR\_CTL\_374 — DDR-Controller Status & Control 374

Address: 4000 D5D8h



Table 6.142 DDR\_CTL\_374 Register Contents

| Bit Position | Bit Name                         | Function                                                                | R/W |
|--------------|----------------------------------|-------------------------------------------------------------------------|-----|
| b31 to b25   | Reserved                         | NA                                                                      | R   |
| b24          | AXI3_ALL_STROBES<br>_USED_ENABLE | Enables use of the AWALLSTRB signal for AXI port 3. Set to 1 to enable. | R/W |
| b23 to b17   | Reserved                         | NA                                                                      | R   |
| b16          | AXI2_ALL_STROBES<br>_USED_ENABLE | Enables use of the AWALLSTRB signal for AXI port 2. Set to 1 to enable. | R/W |
| b15 to b9    | Reserved                         | NA                                                                      | R   |
| b8           | AXI1_ALL_STROBES<br>_USED_ENABLE | Enables use of the AWALLSTRB signal for AXI port 1. Set to 1 to enable. | R/W |
| b7 to b1     | Reserved                         | NA                                                                      | R   |
| b0           | AXIO_ALL_STROBES<br>_USED_ENABLE | Enables use of the AWALLSTRB signal for AXI port 0. Set to 1 to enable. | R/W |

# 6.4.2 DDR PHY Register Description

## 6.4.2.1 FUNCCTRL — Function Control Register

Address: 4000 E000h



Table 6.143 FUNCCTRL Register Contents

| Bit Position | Bit Name   | Function                                                                                     | R/W |
|--------------|------------|----------------------------------------------------------------------------------------------|-----|
| b31 to b23   | Reserved   | NA                                                                                           | R   |
| b22 to b16   | MASKSDLOFS | Hi-Z mask circuit setting register.                                                          | R/W |
| b15 to b10   | Reserved   | NA                                                                                           | R   |
| b9, b8       | IFSEL      | Voltage setting of interface.                                                                | R/W |
|              |            | 2'b00: DVDDQ 1.8 V                                                                           |     |
|              |            | 2'b01: DVDDQ 1.5 V                                                                           |     |
|              |            | 2'b10: (Prohibited)                                                                          |     |
|              |            | 2'b11: (Prohibited)                                                                          |     |
| b7 to b1     | Reserved   | NA                                                                                           | R   |
| b0           | FUNCRSTB   | Reset setting in functional block.                                                           | R/W |
|              |            | When resetting it, it is the same state as "PWRCTRL_DDRC.RSTN_B = 0" excluding the register. |     |
|              |            | 0: Reset state                                                                               |     |
|              |            | 1: State of operation                                                                        |     |

## 6.4.2.2 DLLCTRL — MDLL Control Register

Address: 4000 E004h



Table 6.144 DLLCTRL Register Contents (1/2)

| Bit Position | Bit Name | Function                                                                                                                                                                                                                                                                                                                        | R/W |
|--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b27   | Reserved | NA                                                                                                                                                                                                                                                                                                                              | R   |
| b26          | ASDLLOCK | Lock signal of Mater DLL. 1'b0: Unlock<br>1'b1: Lock                                                                                                                                                                                                                                                                            | R   |
| b25          | MDLLOCK  | Lock signal of Mater DLL. Do not use this bit, please use ASDLLOCK bit.                                                                                                                                                                                                                                                         | R   |
| b24          | MSATFG   | Master DLL Saturation Flag 1'b0: No Saturate State (Delay Line control within the range) 1'b1: Saturate State (Maximum/Minimum control of Delay Line)                                                                                                                                                                           | R   |
| b23          | Reserved | NA                                                                                                                                                                                                                                                                                                                              | R   |
| b22          | MDACNTM  | Write of control code of Master DLL.  When "1" is written, the control code of Master DLL is memorized in MDACNT. "0" is returned when reading it. It has high priority than a value written directly in MDACNT. (don't write simultaneously with bit 20)                                                                       | W   |
| b21          | SDLYCTRL | Control selection of Slave DLL 1'b0: Controlled by Master DLL (default) 1'b1: Controlled by MDACNT                                                                                                                                                                                                                              | R/W |
| b20          | DACNTUPD | Update of control code of Slave Delay.  In case of SDLYCTRL = "1", the value of MDACNT is reflected in Slave Delay. When "1" is written, the control code is reflected in Slave Delay. "0" is returned when reading it. It is necessary to update it in case of the control by MDACNT. (don't write simultaneously with bit 22) | W   |
| b19, b18     | Reserved | NA                                                                                                                                                                                                                                                                                                                              | R   |
| b17 to b8    | MDACNT   | Master DLL code monitor signal.  When "1" is written in MDACNTM, DACNT [9:0] from Master DLL is memorized.                                                                                                                                                                                                                      | R/W |
| b7, b6       | Reserved | NA                                                                                                                                                                                                                                                                                                                              | R   |
| b5           | HSLMODE  | High-speed Lock Up mode setting. (reserved: Unimplemented) 1'b0: Detailed Lock Up mode (default) 1'b1: High-speed Lock Up mode (prohibited)                                                                                                                                                                                     | R/W |
| b4           | MSATMODE | Saturate mode setting. 1'b0: OFF (self-reset mode) 1'b1: ON (Saturate mode: The delay control value stops at max/min value).                                                                                                                                                                                                    | R/W |
| b3           | DDMODE   | Double Delay mode setting 1'b0: DDR3 1'b1: DDR2                                                                                                                                                                                                                                                                                 | R/W |

Table 6.144 DLLCTRL Register Contents (2/2)

| Bit Position | Bit Name | Function                                                          | R/W |
|--------------|----------|-------------------------------------------------------------------|-----|
| b2, b1       | MFSL     | Frequency band setting. It should be set to 2'b10.                | R/W |
| b0           | MDLLSTBY | Master DLLSTBY setting                                            | R/W |
|              |          | After the frequency is changed, it is necessary to execute reset. |     |
|              |          | 1'b0: Operation usually                                           |     |
|              |          | 1'b1: Reset (default)                                             |     |

## 6.4.2.3 ZQCALCTRL — ZQ Calibration Control Register

Address: 4000 E008h



Table 6.145 ZQCALCTRL Register Contents

| Bit Position | Bit Name  | Function                                                                                 | R/W |
|--------------|-----------|------------------------------------------------------------------------------------------|-----|
| b31          | ZQCALRUN  | Signal that indicates the state of ZQ calibration                                        | R   |
|              |           | 1'b0: State of stop (default)                                                            |     |
|              |           | 1'b1: The calibration is being executed.                                                 |     |
| b30          | ZQCALEND  | Signal that indicates the state of ZQ calibration end                                    | R   |
|              |           | 1'b0: Calibration unfinished (default)                                                   |     |
|              |           | 1'b1: Calibration end                                                                    |     |
| b29          | ZQCALGAP  | Signal that indicates there is difference between ZQ calibration result and control code | R   |
|              |           | 1'b0: No difference (default)                                                            |     |
|              |           | 1'b1: There is a difference.                                                             |     |
| b28 to b26   | ZQCALPC   | Pch calibration rough adjustment code output                                             | R   |
| b25 to b22   | ZQCALPF   | Pch calibration fine-tuning code output                                                  | R   |
| b21 to b19   | ZQCALNC   | Nch calibration rough adjustment code output                                             | R   |
| b18 to b15   | ZQCALNF   | Nch calibration fine-tuning code output                                                  | R   |
| b14          | ZQCALINIT | ZQ calibration initialization end output                                                 | R   |
|              |           | 1'b0: Calibration unexecution (default)                                                  |     |
|              |           | 1'b1: Calibration initialization end                                                     |     |
| b13 to b10   | Reserved  | NA                                                                                       | R   |
| b9, b8       | ZQCALFREQ | Setting sampling intervals of ZQ calibration. It should be set to 2'b01.                 | R/W |
| b7 to b4     | ZQCALITVL | Setting ZQ calibration execution intervals                                               | R/W |
|              |           | 4'h0: Finished at one time.                                                              |     |
|              |           | 2 <sup>^</sup> (ZQCALITVL+16) DFICLK clock cycle.                                        |     |
|              |           | The setting range is 4'h0 to 4'hA. Other setting is prohibited.                          |     |
| b3           | Reserved  | NA                                                                                       | R   |
| b2           | ZQCALMODE | ZQ calibration initial code setting                                                      | R/W |
|              |           | 1'b0: No termination (default)                                                           |     |
|              |           | 1'b1: Termination is used.                                                               |     |
| b1           | ZQCALSTRV | ZQ calibration initial value setting                                                     | R/W |
|              |           | 1'b0: Center value                                                                       |     |
|              |           | 1'b1: Last result (default)                                                              |     |
| b0           | ZQCALRSTB | ZQ calibration circuit reset setting                                                     | R/W |
|              |           | 1'b0: Reset (default)                                                                    |     |
|              |           | 1'b1: Reset release                                                                      |     |

## 6.4.2.4 ZQODTCTRL — ZQODT Control Register

Address: 4000 E00Ch



Table 6.146 ZQODTCTRL Register Contents (1/2)

| Bit Position | Bit Name   | Function                                                                                                       | R/W |
|--------------|------------|----------------------------------------------------------------------------------------------------------------|-----|
| b31, b30     | CAPHASE    | Command/Address Output Phase setting                                                                           | R/W |
|              |            | The output phase of command/Address to DDR memory clock is set.                                                |     |
|              |            | 2'b10: 2/4 tCK setup                                                                                           |     |
|              |            | else: Reserved (Prohibited)                                                                                    |     |
| b29          | WRFIFOEN   | I/F FIFO mode setting                                                                                          | R/W |
|              |            | 1'b0: Prohibited                                                                                               |     |
|              |            | 1'b1: FIFO use (default)                                                                                       |     |
| b28, b27     | FIFORPINIT | I/F FIFO read pointer initializing.                                                                            | R/W |
|              |            | Setting to absorb the clock phase difference in DFICLK and PHY.                                                |     |
|              |            | 2'b01: ±1 DFICLK clock cycle                                                                                   |     |
|              |            | else: Reserved                                                                                                 |     |
| b26 to b23   | ZQDATA     | PHY Driver Impedance setting for Data (DQ,DM,DQS).                                                             | R/W |
|              |            | It becomes ZDQ/{ZQDATA}.                                                                                       |     |
|              |            | Range that can be set                                                                                          |     |
|              |            | DDR3: 3 to 6                                                                                                   |     |
|              |            | DDR2: 3 to 7                                                                                                   |     |
|              |            | else: Reserved                                                                                                 |     |
|              |            | default=5                                                                                                      |     |
|              |            | ZDQ is decided by ZQ automatic calibration and external resistance (DDR2 = $150\Omega$ , DDR3 = $120\Omega$ ). |     |
|              |            | The target value is DDR2:ZDQ = $300\Omega$ , and DDR3:ZDQ = $240\Omega$ .                                      |     |
| b22 to b19   | ZQCK       | PHY Driver Impedance setting for CK.                                                                           | R/W |
|              |            | It becomes ZDQ/{ZQCK}.                                                                                         |     |
|              |            | Range that can be set                                                                                          |     |
|              |            | DDR3: 3 to 8                                                                                                   |     |
|              |            | DDR2: 3 to 10                                                                                                  |     |
|              |            | else: Reserved                                                                                                 |     |
|              |            | default = 5                                                                                                    |     |
| b18 to b15   | ZQCMDAD    | PHY Driver Impedance setting for Command/Address.                                                              | R/W |
|              |            | It becomes ZDQ/{ZQCMDAD}.                                                                                      |     |
|              |            | Range that can be set                                                                                          |     |
|              |            | DDR3: 3 to 8                                                                                                   |     |
|              |            | DDR2: 3 to 10                                                                                                  |     |
|              |            | else: Reserved                                                                                                 |     |
|              |            | default = 5                                                                                                    |     |
|              |            | delauit – 3                                                                                                    |     |

Table 6.146 ZQODTCTRL Register Contents (2/2)

| Bit Position | Bit Name | Function                                                                                                        | R/W |
|--------------|----------|-----------------------------------------------------------------------------------------------------------------|-----|
| b13, b12     | SRDQ     | Slew Rate setting for Data and DQS                                                                              | R/W |
|              |          | 2'b00: High (default)                                                                                           |     |
|              |          | 2'b11: Low (prohibited)                                                                                         |     |
|              |          | 2'b01: DQS signal mask circuit stop                                                                             |     |
|              |          | 2'b10: DQS signal mask circuit stop (prohibited)                                                                |     |
| b11, b10     | SRCK     | Slew Rate setting for CK                                                                                        | R/W |
|              |          | The setting method is same as SRDQ.                                                                             |     |
| b9, b8       | SRCMDAD  | Slew Rate setting for Command/Address                                                                           | R/W |
|              |          | The setting method is same as SRDQ.                                                                             |     |
| b7           | Reserved | NA                                                                                                              | R   |
| b6, b5       | PHYODT   | PHY ODT resistance setting                                                                                      | R/W |
|              |          | 2'b00: OFF (Prohibited)                                                                                         |     |
|              |          | 2'b01: Rtt_RD/1                                                                                                 |     |
|              |          | 2'b10: Rtt_RD/2 (default)                                                                                       |     |
|              |          | 2'b11: Rtt_RD/3                                                                                                 |     |
|              |          | Rtt_RD is determined by ZQ auto calibration and external resistance (DDR2 = $150\Omega$ , DDR3 = $120\Omega$ ). |     |
|              |          | The target value is DDR2:Rtt_RD = 150 $\Omega$ , and DDR3:Rtt_RD = 120 $\Omega$ .                               |     |
| b4           | PHYODTEN | PHY ODT use setting                                                                                             | R/W |
|              |          | 1'b0: ODT unused (prohibited)                                                                                   |     |
|              |          | 1'b1: ODT use (default)                                                                                         |     |
| b3, b2       | Reserved | NA                                                                                                              | R   |
| b1, b0       | DRAMIF   | DRAM I/F setting                                                                                                | R/W |
|              |          | 2'b00: DDR2                                                                                                     |     |
|              |          | 2'b01: DDR3 (default)                                                                                           |     |
|              |          | 2'b10: Prohibited                                                                                               |     |
|              |          | 2'b11: Prohibited                                                                                               |     |

## 6.4.2.5 RDCTRL — Read Control Register

Address: 4000 E010h



Table 6.147 RDCTRL Register Contents

| 1 able 6.147 | KDC I KL Kegisi | or contonic                                                                                                                                                         |     |
|--------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Bit Position | Bit Name        | Function                                                                                                                                                            | R/W |
| b31 to b28   | PHYODTONT       | PHY DQS ODT ON Timing setting                                                                                                                                       | R/W |
|              |                 | Effective at PHYODTEN = 1. The on timing of PHY ODT can be set at 0.5 tCK step (0 delay conditions).                                                                |     |
|              |                 | (PHYODTONT - 4) × 0.5 tCK before preamble                                                                                                                           |     |
|              |                 | 4'hE: 5.0 tCK before preamble (default)                                                                                                                             |     |
| b27 to b24   | PHYODTOFT       | PHY DQS ODT OFF Timing setting                                                                                                                                      | R/W |
|              |                 | Effective at PHYODTEN = 1. The turning off timing of PHY ODT can be set at 0.5 tCK step (0 delay conditions).                                                       |     |
|              |                 | (PHYODTOFT + 2) × 0.5 tCK after postamble                                                                                                                           |     |
|              |                 | 4'h7: 4.5 tCK after postamble (default)                                                                                                                             |     |
|              |                 | The setting range can set 4'h0 to 4'hC. Other setting is prohibited.                                                                                                |     |
| b23 to b20   | PDQODTONT       | PHY DQ ODT ON Timing setting                                                                                                                                        | R/W |
|              |                 | The setting method is same as PHYODTONT.                                                                                                                            |     |
| b19 to b16   | PDQODTOFT       | PHY DQ ODT OFF Timing setting.                                                                                                                                      | R/W |
|              |                 | The setting method is same as PHYODTOFT.                                                                                                                            |     |
| b15 to b12   | PHYBENONT       | PHY DQS and DQ BEN ON Timing setting.                                                                                                                               | R/W |
|              |                 | ON timing of the bias enable of the receiver can be set at 0.5 tCK steps (0 delay conditions).                                                                      |     |
|              |                 | (PHYBENONT - 4) × 0.5 tCK before preamble: DDR2/DDR3                                                                                                                |     |
|              |                 | 4'hE: 5.0 tCK before preamble (DDR3: default)                                                                                                                       |     |
| b11 to b8    | PHYBENOFT       | PHY DQS and DQ BEN OFF Timing setting.                                                                                                                              | R/W |
|              |                 | The turning off timing of an enable bias of the receiver can be set at 0.5 tCK steps (0 delay conditions).                                                          |     |
|              |                 | (PHYBENOFT + 2) × 0.5 tCK after postamble: DDR2/DDR3.                                                                                                               |     |
|              |                 | 4'h7: 4.5 tCK after postamble (DDR3: default)                                                                                                                       |     |
|              |                 | The setting range can set 4'h0 to 4'hC. Other setting is prohibited.                                                                                                |     |
| b7 to b4     | PHYIENONT       | PHY DQS and DQ Input enable ON Timing setting.                                                                                                                      | R/W |
|              |                 | Inputting enable ON timing of the receiver can be set at 0.5 tCK step (0 delay conditions). It is necessary to turn on more than 1 ns ahead of the 1st rise of DQS. |     |
|              |                 | (PHYIENONT - 4) x 0.5 tCK before preamble: DDR2/DDR3.                                                                                                               |     |
|              |                 | 4'h4: Simultaneous with preamble (DDR3: default)                                                                                                                    |     |
| b3 to b0     | PHYIENOFT       | PHY DQS and DQ Input enable OFF Timing setting.                                                                                                                     | R/W |
|              |                 | Enable turning off timing for the input of the receiver can be set at 0.5 tCK step. (0 delay conditions). It is necessary to consider Flight Time.                  |     |
|              |                 | (PHYIENOFT + 2) × 0.5 tCK after postamble: DDR2/DDR3.                                                                                                               |     |
|              |                 | 4'h6: 4.0 tCK after postamble (default).                                                                                                                            |     |
|              |                 | The setting range can set 4'h0 to 4'hC. Other setting is prohibited.                                                                                                |     |

# 6.4.2.6 RDTMG — READ Timing Control Register

Address: 4000 E014h



Table 6.148 RDTMG Register Contents

| Bit Position | Bit Name  | Function                                                                                                                                                                                                                                       | R/W |
|--------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b8    | Reserved  | NA                                                                                                                                                                                                                                             | R   |
| b7 to b4     | RDENVALID | Read Data transfer setting.  Waiting time (DFICLK) from RDDATAEN = "1" to RDDATAVALID = "1" is set. It is necessary to match tphy_rdlat.  RDENVALID+4 DFICLK  4'hB: 15 DFICLK (default) (WRFIFOEN=1'b1, FIFORPINIT=2'b01) 0 set is prohibited. | R/W |
| b3, b2       | Reserved  | NA                                                                                                                                                                                                                                             | R   |
| b1, b0       | WDOMODE   | Command DQ output mode setting 2'b00: Normal mode (default). Others: Reserved (prohibited)                                                                                                                                                     | R/W |

## 6.4.2.7 FIFOINIT — FIFO Initialization Register

**Address:** 4000 E018h



Table 6.149 FIFOINIT Register Contents

| Bit Position | Bit Name    | Function                                                                    | R/W |
|--------------|-------------|-----------------------------------------------------------------------------|-----|
| b31 to b9    | Reserved    | NA                                                                          | R   |
| b8           | RDPTINITEXE | Read FIFO pointer initialization.                                           | W   |
|              |             | The initialization of the FIFO pointer of Read is executed.                 |     |
|              |             | Initialization is executed by writing "1". "0" is returned when reading it. |     |
| b7 to b1     | Reserved    | NA                                                                          | R   |
| b0           | WRPTINITEXE | Write FIFO pointer initialization.                                          | W   |
|              |             | The initialization of the pointer of the value of FIFORPINIT is executed.   |     |
|              |             | Initialization is executed by writing "1". "0" is returned when reading it. |     |

## 6.4.2.8 OUTCTRL — Output Control Register

Address: 4000 E01Ch



Table 6.150 OUTCTRL Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                    | R/W |
|--------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b26   | Reserved | NA                                                                                                                                                          | R   |
| b25, b24     | MBL      | Only for evaluation. Don't set value other than reset value                                                                                                 | R/W |
| b23 to b21   | Reserved | NA                                                                                                                                                          | R   |
| b20 to b16   | MRL      | Only for evaluation. Don't set value other than reset value                                                                                                 | R/W |
| b15 to b13   | Reserved | NA                                                                                                                                                          | R   |
| b12 to b8    | MWL      | Only for evaluation. Don't set value other than reset value                                                                                                 | R/W |
| b7, b6       | Reserved | NA                                                                                                                                                          | R   |
| b5, b4       | DISOUT   | Output mode setting at DFIDATABYTEDISABLE 2'b00: Floating 2'b01: L Output. (However DDR_DQS_N H output); else: Prohibited                                   | R/W |
| b3           | Reserved | NA                                                                                                                                                          | R   |
| b2           | RESETBOE | Outputting enable setting of DDR_RESET_N 1'b0: Floating 1'b1: Output (default)                                                                              | R/W |
| b1           | CKEODTOE | Outputting enable setting of DDR_CLKEN and DDR_ODT  1'b0: Floating  1'b1: Output (default)                                                                  | R/W |
| b0           | ADCMDOE  | Address and Command output enable setting.  Output controls of address command other than DDR_CLKEN, DDR_ODT, and DDR_RESET_N  1'b0: Floating  1'b1: Output | R/W |

# 6.4.2.9 WLCTRL1 — Write Leveling Control Register 1

Address: 4000 E040h



Table 6.151 WLCTRL1 Register Contents

| Bit Position | Bit Name | Function                                                                                                        | R/W |
|--------------|----------|-----------------------------------------------------------------------------------------------------------------|-----|
|              |          |                                                                                                                 | -   |
| b31          | WLEN     | Write Leveling function use setting.                                                                            | R/W |
|              |          | It is necessary to write "1" in this bit before initialization of the FIFO pointer when Write Leveling is used. |     |
|              |          | 1'b0: Unused (default)                                                                                          |     |
|              |          | 1'b1: Use (FIFO I/F mode limitation)                                                                            |     |
| b30          | WLAUTO   | Setting of Write Leveling execution mode (Reserved mode)                                                        | R/W |
|              |          | 1'b0: Manual setting (default)                                                                                  |     |
|              |          | 1'b1: Automatic setting (Prohibited)                                                                            |     |
| b29          | Reserved | NA                                                                                                              | R   |
| b28          | WLVEND   | Write Leveling End Flag.                                                                                        | R   |
|              |          | 1'b0: Not end                                                                                                   |     |
|              |          | 1'b1: End                                                                                                       |     |
| b27          | Reserved | NA                                                                                                              | R   |
| b26, b25     | WLSTATE  | Write Leveling status setting (Prohibited)                                                                      | R/W |
| b24          | WLSTR    | Write Leveling timing adjustment.                                                                               | W   |
|              |          | The timing is readjusted with the set value by writing "1". "0" is returned when reading it.                    |     |
|              |          | Please write to this register with changing only WLSTR to "1" after waiting for 50                              |     |
|              |          | clocks (DFICLK-converted) after setting each item in the state of "0".                                          |     |
|              |          | Please wait for 50 DFICLK or more after it executes it.                                                         |     |
| b23 to b15   | Reserved | NA                                                                                                              | R   |
| b14 to b8    | WL2OFS   | The second Byte Write Leveling manual operation offset setting.                                                 | R/W |
|              |          | WL2OFS[6] = 1'b1                                                                                                |     |
|              |          | 90-90/32 x WL2OFS[5:0] [degree] (0 to 90 degree: 0 ≤ WL2OFS[5:0] ≤ 32)                                          |     |
|              |          | WL2OFS[6] = 1'b0                                                                                                |     |
|              |          | 90+90/32 × WL2OFS[5:0] [degree] (90 to 135 degree: 0 ≤ WL2OFS[5:0] ≤ 16)                                        |     |
| b7           | Reserved | NA                                                                                                              | R   |
| b6 to b0     | WL1OFS   | The first Byte Write Leveling manual operation offset setting.                                                  | R/W |
|              |          | WL1OFS[6] = 1'b1                                                                                                |     |
|              |          | 90-90/32 x WL1OFS[5:0] [degree] (0 to 90 degree: 0 ≤ WL1OFS[5:0] ≤ 32)                                          |     |
|              |          | WL10FS[6] = 1'b0                                                                                                |     |
|              |          | 90+90/32 x WL1OFS[5:0] [degree] (90 to 135 degree: 0 ≤ WL1OFS[5:0] ≤ 16)                                        |     |

## 6.4.2.10 DQCALOFS1 — DQS Offset Setting

Address: 4000 E0E8h



Table 6.152 DQCALOFS1 Register Contents

| Bit Position | Bit Name  | Function                                         | R/W |
|--------------|-----------|--------------------------------------------------|-----|
| b31          | B2RSSAT   | SDLY Saturation Flag output for 2nd byte Read    | R   |
|              |           | 1'b0: No Saturate State                          |     |
|              |           | 1'b1: Saturate State                             |     |
| b30          | B1RSSAT   | SDLY Saturation Flag output for 1st byte Read    | R   |
|              |           | 1'b0: No Saturate State                          |     |
|              |           | 1'b1: Saturate State                             |     |
| b29 to b15   | Reserved  | NA                                               | R   |
| b14 to b8    | DQCAL2OFS | 2nd byte DQS offset setting                      | R/W |
|              |           | DQCAL2OFS[6] = 1'b1                              |     |
|              |           | 90-90/32 × DQCAL2OFS[5:0] [degree]               |     |
|              |           | (0 to 90 degree: $0 \le DQCAL2OFS[5:0] \le 32$ ) |     |
|              |           | DQCAL2OFS[6] = 1'b0                              |     |
|              |           | 90+90/32 × DQCAL2OFS[5:0] [degree]               |     |
|              |           | (90 to 180 degree: 0 ≤ DQCAL2OFS[5:0] ≤ 32)      |     |
| b7           | Reserved  | NA                                               | R   |
| b6 to b0     | DQCAL1OFS | 1st byte DQS offset setting                      | R/W |
|              |           | DQCAL1OFS[6] = 1'b1                              |     |
|              |           | 90-90/32 × DQCAL10FS[5:0] [degree]               |     |
|              |           | (0 to 90 degree: 0 ≤ DQCAL10FS[5:0] ≤ 32)        |     |
|              |           | DQCAL1OFS[6] = 1'b0                              |     |
|              |           | 90+90/32 x DQCAL1OFS[5:0] [degree]               |     |
|              |           | (90 to 180 degree: 0 ≤ DQCAL1OFS[5:0] ≤ 32)      |     |

# 6.5 Operation

## 6.5.1 Address Mapping

The DDR Controller automatically maps user addresses to the DRAM memory in a contiguous block. Addressing starts at user address 0 and ends at the highest available address according to the size and number of DRAM memories present. This mapping is dependent on how the parameters in the internal DDR Controller registers are programmed.

The mapping of the address space to the internal data storage structure of the DRAM memories is based on the actual size of the DRAM memories available. The size is stored in user-programmable parameters that must be initialized at power up. Certain DRAM memories allow for different mapping options to be chosen, while other DRAM memories depend on the memory burst length chosen.

#### 6.5.1.1 DDR SDRAM Address Mapping Options

The address structure of DDR SDRAM memories contains five fields. Each of these fields can be individually addressed when accessing the DRAM. The address map for this DDR Controller is ordered as follows:

The actual widths of the fields can be changed if the memory address width parameters (COL\_DIFF, BANK\_DIFF and ROW\_DIFF) are programmed differently.

#### CAUTION

The maximum address range of the DDR memory controller is limited to 0x00000000 - 0x7FFFFFFF internally. On RZ/N1, the DDR memory is mapped to 0x80000000 - 0xFFFFFFFF.

## 6.5.1.2 Maximum Address Space

The maximum user address range is determined by the width of the memory datapath, the number of chip select pins, and the address space of the DRAM memory. The maximum amount of memory can be calculated by the following formula:

 $MaxMemBytes = ChipSelects \times 2^{Address} \times NumBanks \times DPWidthBytes$ 

Figure 6.2 Maximum Amount of Memory Formula

Chip Selects = 2 Memory Address = 16 + 11 (Row + Column) Number of Banks Per Chip Select = 8 Memory Datapath Width in Bytes = 2 bytes

#### **CAUTION**

The maximum address range of the DDR memory controller is limited to 0x00000000 - 0x7FFFFFFF internally. On RZ/N1, the DDR memory is mapped to 0x80000000 - 0xFFFFFFFF.

As a result, the maximum accessible memory area is 2 GB.

#### 6.5.1.3 Memory Mapping to Address Space

The maximum allowable address space and mapping into the DRAM memories for the DDR Controller is shown in **Figure 6.3, Maximum Memory Map**.



Figure 6.3 Maximum Memory Map

#### CAUTION

Bit [31] **must** not be used as it is not considered within the DDR controller. The maximum allowed Address is 0x7FFFFFFF.

The "COL\_DIFF" and "ROW\_DIFF" parameters can each range from the maximum available values for the controller to seven bits smaller than the maximum available values. This allows the DDR Controller to function with a wide variety of memory sizes.

The settings for the "COL\_DIFF" and "ROW\_DIFF" parameters control how the address map is used to decode the user address to the DRAM chip selects and row and column addresses. The "BANK\_DIFF" parameter controls the DRAM bank address information. It is assumed that the values in these parameters never exceed the maximum values configured.

For example, if the controller is wired to memories with 13 row pins and 9 column bits, the maximum accessible memory space would be reduced. The accessible memory space for this configuration is 128 MB.

The address map for this configuration is shown in **Figure 6.4, Alternate Memory Map**. Note that address bits 27 through 31 are listed as "don't care" bits. These bits are ignored when the controller generates the address to the DRAM memories, but they are used to verify that the address lies within the usable address range of the controller. Therefore, the user should drive these bits to 0 to avoid the controller interpreting the command as being out-of-range and causing one or both of the out-of-range interrupts (bits 1 or 2) to be set to 1 in the "INT\_STATUS" parameter.



Figure 6.4 Alternate Memory Map

#### **CAUTION**

The Chip Select, Row, Bank, and Column fields are used to address an entire memory word, and the Datapath bits are used to address individual bytes within the word. For example, for a read starting at byte address 0x1, the Datapath bits must be defined as 1'b1 in order to address this byte directly. Reads and writes are memory word-aligned if all the Datapath bits are 0.

#### 6.5.2 AXI Interface Ports

The DDR Controller contains 4 internal AXI ports which communicate on the AXI bus. Each AXI port uses an AXI interface block to connect to the Controller core. An arbitration scheme is responsible for arbitrating requests from the ports and sending requests to the Controller core. Each transaction received at the Arbiter logic has an associated priority, which works with each port's arbitration logic to determine how ports issue requests to the Controller core. This DDR Controller supports the Bandwidth Allocation/Priority Round-Robin arbitration scheme.

The Arbiter logic routes read data from the Controller core to the appropriate port. The requesting port is assumed able to receive the data. Write data from each port is connected directly to its own write data interface in the Controller core, allowing the ports to independently pass write data to the Controller core buffers.

#### 6.5.2.1 Arbitration Scheme

The bandwidth allocation scheme is an extension of simple round-robin arbitration. It is based on the priority of the requests and is influenced by the actual bandwidth consumed by the port inside the Controller core.

Priority round-robin arbitration is a complex arbitration scheme. In order to understand its operation, each concept must be first understood individually. The following Sections describes the various components of priority round-robin arbitration.

#### 6.5.2.2 Understanding Round-Robin Arbitration

Round-robin operation is a simple form of arbitration which offers each port an opportunity to issue a command. This scheme uses a counter that rotates through the port numbers, incrementing every time a port request is granted from any port.

If the port that the counter is referencing has an active request, and the command queue is not full, then this request will be sent to the Controller core. If there is not an active request for that port, then the port will be skipped, and the next port will be checked. The counter will increment by one whenever any request has been processed, regardless of which port's request was arbitrated.

Round-robin operation ensures that each port's requests can be successfully arbitrated into the Controller core every N cycles, where N is the number of ports in the DDR Controller. No port will ever be locked out, and any port can have its requests serviced on every cycle as long as all other ports are quiet and the command queue is not full.

An example of the round-robin scheme is shown in the following **Table 6.153, Round-Robin Operation Example**. Cycles 0, 2 and 6 show the system behavior when the command queue is full. Cycle 8 and 11 show the system behavior when the port addressed by the arbitration counter does not have an active request. In particular, note cycle 11: The port addressed by the arbitration counter (0) is not requesting, so the counter scans through the other ports, in incrementing order, to find an active request. Port 2 is requesting and therefore wins arbitration, but the counter only increments to port 1 which was the next port in the sequence. All other cycles show normal behavior.

Port Addressed by Ports Requesting Value of Arbitration the Arbitration Command Counter at Cycle Counter Port 0 Port 1 Port 2 Port 3 Queue Full? Winner Next Cycle 0 0 Υ Υ Υ Υ Yes None 0 0 Υ Υ P0 1 Υ Υ No 1 2 1 Υ Υ Υ Yes 1 None Υ 3 1 Υ Υ Υ No P1 2 2 Υ 4 Υ No P2 3 5 3 Υ Р3 0 No 0 Υ 6 Υ Yes None 0 7 0 Υ Υ P0 1 No 8 1 P2 2 Υ No 9 2 Υ P2 3 Υ No 10 3 Υ Υ No РЗ 0 11 0 Υ No P2 1

Table 6.153 Round-Robin Operation Example

#### 6.5.2.3 Understanding Port Priority

Priorities are associated with a port and each port has separate priority parameter for reads and writes. These values are stored into the programmable parameters "AXIY\_R\_PRIORITY" and "AXIY\_W\_PRIORITY" at controller initialization (where Y represents the AXI port number [0-3]). Internally, the ports are organized into priority groups based on their priority setting. All ports within a priority group are treated equally for arbitration unless a port has exceeded its allocated bandwidth. The priority value is also used by the placement logic inside the Controller core when filling the command queue.

#### **CAUTION**

A situation may arise where multiple ports are defined with a certain priority, but only a subset of these ports are actively requesting. If this occurs, the ports with active requests may not win arbitration equally. Rather, the behavior is dependent on the port activity and the organization of active ports within the arbitration order. Refer to **Section 6.5.2.8(1), Example with Four Ports, One Priority Level and No Bandwidth Consideration** for more information on this scenario.

A priority value of 0 is highest priority, and a priority value of (decimal) 3 is the lowest priority in the DDR Controller. The user may program at priority level 0; however, it is best to reserve this priority value so that the placement queue can elevate to this level through aging.

#### 6.5.2.4 Understanding Port Bandwidth

Each port has an associated bandwidth limit that sets the maximum percentage of the Controller core bandwidth that the port is allowed to use. Once this level is reached, the Arbiter will no longer accept requests from this port until the bandwidth usage drops below the threshold. This scheme allows for the bandwidth to be shared between the ports. If required, an overflow option allows the port to continue to receive requests after the bandwidth limit has been reached. Refer to **Section 6.5.2.6, Understanding Port Bandwidth Overflow** for more information on this option.

The bandwidth limits are stored in the programmable bandwidth parameters "AXIY\_BDW" for each port Y at DDR Controller initialization. The current bandwidth parameters "AXIY\_CURRENT\_BDW" parameters are used to track the actual bandwidth utilized as computed by the bandwidth calculation module inside the Arbiter.

Port bandwidth is computed by counting the number of cycles that the Controller core is busy actively processing that port's request in each 100 cycles period, referred to as the statistics window. In the DDR Controller, 10 counters are used for this computation. The counters track the number of active cycles in each statistics window, generating a moving average bandwidth value for each port. This is the actual bandwidth utilized value saved in the current bandwidth parameters "AXIY\_CURRENT\_BDW" for each port Y at DDR Controller. The values in the current bandwidth parameters are updated every 10 cycles (the statistics reporting time) with the actual bandwidth used in the last 100 cycles.

Note that if all ports are assigned 100% or greater bandwidth, then bandwidth usage will not factor and arbitration will be purely based on priority.

The Controller core is defined as actively processing for a port if any of the following situations occur:

- The Controller core is ready to transfer write data from the port to memory, but the data has not arrived from the port.
- The Controller core is holding the port's command and is ready to transfer to memory, but is waiting to open a bank, pre-charge a bank, or some other memory-related action.
- The Controller core is actively transferring data from the port to memory.
- The Controller core is ready to transfer read data from memory to the port, but the port is busy and unable to accept the data.

The following **Figure 6.5, System Bandwidth Example** shows bandwidth usage for a 4-port system with a 100-cycle calculation window and 10 counters.





Figure 6.5 System Bandwidth Example

For this system, the bandwidth will be monitored over each 100 cycles. The bandwidth calculation parameters will be updated every 10 cycles with the bandwidth usage of the last 100 cycles as shown graphically in **Figure 6.5**, **System Bandwidth Example**. The bandwidth totals are shown in **Table 6.154**, **System Bandwidth Usage Example**. Note that in the system, these values would be stored in the current bandwidth parameters "AXIY\_CURRENT\_BDW" parameters after each calculation.

| Counter | Cycles   |                | Calculated Usage |                |                |  |  |  |  |
|---------|----------|----------------|------------------|----------------|----------------|--|--|--|--|
| Number  | Counting | Port 0         | Port 1           | Port 2         | Port 3         |  |  |  |  |
| 0       | 0-99     | 31 / 100 = 31% | 20 / 100 = 20%   | 15 / 100 = 15% | 23 / 100 = 23% |  |  |  |  |
| 1       | 10-109   | 29 / 100 = 29% | 19 / 100 = 19%   | 17 / 100 = 17% | 23 / 100 = 23% |  |  |  |  |
| 2       | 20-119   | 26 / 100 = 26% | 18 / 100 = 18%   | 20 / 100 = 20% | 24 / 100 = 24% |  |  |  |  |
| 3       | 30-129   | 19 / 100 = 19% | 18 / 100 = 18%   | 24 / 100 = 24% | 27 / 100 = 27% |  |  |  |  |
| 4       | 40-139   | 21 / 100 = 21% | 16 / 100 = 16%   | 25 / 100 = 25% | 26 / 100 = 26% |  |  |  |  |
| 5       | 50-149   | 20 / 100 = 20% | 19 / 100 = 19%   | 27 / 100 = 27% | 23 / 100 = 23% |  |  |  |  |
| 6       | 60-159   | 15 / 100 = 15% | 18 / 100 = 18%   | 34 / 100 = 34% | 23 / 100 = 23% |  |  |  |  |
| 7       | 70-169   | 16 / 100 = 16% | 16 / 100 = 16%   | 36 / 100 = 36% | 22 / 100 = 22% |  |  |  |  |
| 8       | 80-179   | 14 / 100 = 14% | 17 / 100 = 17%   | 39 / 100 = 39% | 21 / 100 = 21% |  |  |  |  |
| 9       | 90-189   | 17 / 100 = 17% | 14 / 100 = 14%   | 40 / 100 = 40% | 22 / 100 = 22% |  |  |  |  |
| 0       | 100-199  | 18 / 100 = 18% | 14 / 100 = 14%   | 38 / 100 = 38% | 18 / 100 = 18% |  |  |  |  |

Table 6.154 System Bandwidth Usage Example

# 6.5.2.5 Understanding Port Bandwidth Hold-Off

When the bandwidth used by a port exceeds its specified limit, that port is held off from subsequent arbitration decisions for a period of time known as the statistics reporting time. This causes a period of inactivity from that port, allowing the actual bandwidth used for that port to fall below the threshold. Since the bandwidth used is updated every ten cycles, the minimum hold-off period for this system is ten cycles.

After every 10 cycles (the statistics reporting time), the DDR Controller will update the current bandwidth parameters with the bandwidth usage of the last 100 cycles. For any port Y, if the current bandwidth parameter value "AXIY\_CURRENT\_BDW" meets or exceeds the allocated value "AXIY\_BDW", the Arbiter will not accept requests from this port for the next 10 cycles starting at the next statistics reporting time. After 10 cycles, the current bandwidth parameters will be updated and the DDR Controller must evaluate the usage again.

The user must keep the following considerations in mind when using this system:

- The statistics reporting time is 10 cycles. If the port was not being held off at the start of each 10-cycle window, it may issue up to 10 commands during the next 10 cycles until the bandwidth usage is evaluated again. Bandwidth usage is NOT calculated on each cycle.
- The statistics window is 100 clock cycles. Only the last 100 clock cycles are considered for bandwidth usage. Anything older than 100 cycles is not relevant.
- Hysteresis may alter the bandwidth usage. Commands enter the command queue once they have won arbitration, but
  commands sitting in the command queue are not calculated in the port bandwidth usage until they reach the top of the
  command queue and start to execute.

The examples in the previous section, **Figure 6.5, System Bandwidth Example** and **Table 6.154, System Bandwidth Usage Example**, represent a system where all ports are defined with a bandwidth allocation of 100% (or greater) which means that ports are never held off from winning arbitration due to bandwidth usage. The same system will now be evaluated with the following bandwidth limits:

```
axi0_bdw = 20%
axi1_bdw = 10%
axi2_bdw = 30%
axi3_bdw = 50%
```

Port 3 never exceeds the bandwidth allocation based on current traffic. However, Ports 0, 1 and 2 do exceed bandwidth and therefore they will be held off. The cycles marked in asterisks (\*) in **Figure 6.6**, **System Bandwidth Example with Bandwidth Exceeded** are hold-off periods for the port.



Figure 6.6 System Bandwidth Example with Bandwidth Exceeded

# 6.5.2.6 Understanding Port Bandwidth Overflow

The bandwidth hold-off scheme described in **Section 6.5.2.5**, **Understanding Port Bandwidth Hold-Off** is designed to constrain individual ports (especially ports programmed at higher priority) from overtaking all available bandwidth and locking out other ports. However, this can have its drawbacks.

Consider a situation where only one port has been actively requesting and has therefore used all of its available bandwidth. The bandwidth hold-off will prevent additional requests from being accepted, even though no other ports are requesting. The command queue will sit empty for several cycles while the hold-off is cleared. This is obviously wasted DDR Controller bandwidth and is detrimental to overall system performance. A bandwidth hold-off override function has been incorporated for such a situation in the bandwidth overflow parameters "AXIY\_BDW\_OVFLOW".

A port will be allowed to exceed its allocated bandwidth when all of these conditions are true:

- (1) The bandwidth overflow parameter "AXIY\_BDW\_OVFLOW" is set to 1 for port Y.
- (2) No other port, whose bandwidth has not been exceeded, is requesting at the same priority level.
- (3) The command queue has less than the number of entries specified in the "ARB\_CMD\_Q\_THRESHOLD" parameter.

This last condition is a preventative measure to maintain latency requirements for ports programmed at higher priority. When a port is allowed to exceed bandwidth, it may fill the command queue with transactions. If this occurs, and a higher priority port starts requesting, then there will be no room in the command queue for the new requests. This means that the higher priority port will actually be held off for potentially several cycles. In this situation, even though the Controller core bandwidth is being utilized well, the latency requirements of the higher priority port are not being met. The "ARB\_CMD\_Q\_THRESHOLD" parameter is used to limit the bandwidth overflow and prevent this condition. It ensures that a certain number of slots remain available in the command queue for other ports. As a result, bandwidth overflow will be allowed as long as there are less than "ARB\_CMD\_Q\_THRESHOLD" number of entries in the command queue.

# 6.5.2.7 Priority Round-Robin Arbitration Summary

The Controller priority round-robin arbitration system combines the concepts of round-robin operation, priority, port bandwidth, port bandwidth hold-off and port bandwidth overflow. The incoming commands are separated into priority groups based on the priority of the associated port for that type of command. Within each priority group, the Arbiter evaluates the requesting ports, the command queue, the priority of the requests, the bandwidth being used and the overflow option to determine the winner of the arbitration. The order of steps is as follows:

(1) Is the command queue full?

Yes: No further action is taken.

No: Review the ports.

- (2) Within each priority group with at least one active request, select a request for evaluation for that priority group. Each priority group uses a round-robin arbitration counter that will address a port for arbitration.
- (3) Evaluate the highest priority group with a selected command. Has the bandwidth allocation for this port been exceeded?

No: This request wins arbitration. Skip to step 7.

Yes: Continue to step 4 to check the bandwidth overflow status.

(4) Is bandwidth overflow enabled?

No: Skip to step 6.

Yes: Continue to step 5 to check the conditions for overflow.

(5) Are the overflow conditions listed in **Section 6.5.2.6, Understanding Port Bandwidth Overflow** met? No: Continue to step 6.

Yes: This request wins arbitration. Skip to step 7.

- (6) The selected command has failed evaluation. The Arbiter will select another command for evaluation.
  - If there is another command at the same priority group that has not been evaluated, the next active request (in cyclical port order) will be selected for evaluation for that priority group. Return to step 3 with that command.
  - If there are no other commands at that priority group to evaluate, examine the next highest priority group, and return to step 3 with that command.
- (7) Once a request wins arbitration, it is processed into the command queue and the round-robin counter is updated to the next port in the circular queue. If any request is processed for a priority group, the round-robin arbitration counter for that priority group will be incremented by one. The counter will never increment by more than one, regardless of how many commands were evaluated or which port's command was finally accepted.

# 6.5.2.8 Arbitration Examples

## (1) Example with Four Ports, One Priority Level and No Bandwidth Consideration

As a very simple example, consider a system where all ports are programmed to accept all commands at a single priority level. The arbitration counter will address all ports defined at this priority level in cyclical fashion, regardless of the status of their activity. At each cycle, the arbitration counter will address a particular port. If that port is not requesting, the DDR Controller looks for the next port (in circular fashion) making a request and that port wins arbitration. With each successful arbitration, the arbitration counter increments by 1 and on the next cycle, the next port will be given an opportunity to win arbitration.

To demonstrate arbitration behavior, consider the following system:

- Four ports.
- All ports request only at priority 1.
- All ports have bandwidth allocations of 100% and the bandwidth overflow bit is set to 1. (Bandwidth will not affect arbitration.)

An example with these settings is shown in **Table 6.155**, **Priority Round-Robin with One Priority Level**. In cycles 1-4, port 0 and port 1 are always requesting, and port 2 and port 3 are quiet. When the arbitration counter addresses port 0 or 1, these ports win arbitration. When the arbitration counter addresses ports 2, since there is not an active request on that port, the next port in round-robin order that is requesting (port 0) wins arbitration. Similarly, port 0 wins arbitration when port 3 is addressed by the arbitration counter.

Cycles 5 and 6 demonstrate that port 0 or port 1 could win arbitration on any cycle. Even though the arbitration count is addressing port 0 in cycle 5, port 1 wins arbitration, and vice-versa for cycle 6.

In situations where not all ports are requesting, the distribution of arbitration winners across ports is not a standard formula; it is entirely dependent on the organization of requesting ports in the arbitration order. For example, in cycles 1-4, only ports 0 and 1 are requesting. These cycles may seem to suggest that the lowest-numbered port wins arbitration (N-1)/N times, where N represents the number of ports in the priority level. However, this is only a coincidence. Cycles 7-10, where only port 0 and port 3 are requesting, show a scenario in which the higher-numbered port wins arbitration more often. And cycles 11-14, where port 0 and port 2 are requesting, show an equitable distribution of arbitration wins. Therefore, no assumptions should be made on arbitration wins.

If a user wishes to provide each port with an equal opportunity for arbitration, only ports that are requesting at a priority level should be programmed with that priority value.

Table 6.155 Priority Round-Robin with One Priority Level

|       | Port Addressed by          |        | Ports  | Requesting |        |                        |                       | Value of                 |
|-------|----------------------------|--------|--------|------------|--------|------------------------|-----------------------|--------------------------|
| Cycle | the Arbitration<br>Counter | Port 0 | Port 1 | Port 2     | Port 3 | Command<br>Queue Full? | Arbitration<br>Winner | Counter at<br>Next Cycle |
| 0     | 0                          | Υ      | Υ      |            |        | Yes                    | None                  | 0                        |
| 1     | 0                          | Υ      | Υ      |            |        | No                     | P0                    | 1                        |
| 2     | 1                          | Υ      | Υ      |            |        | No                     | P1                    | 2                        |
| 3     | 2                          | Υ      | Υ      |            |        | No                     | P0                    | 3                        |
| 4     | 3                          | Υ      | Υ      |            |        | No                     | P0                    | 0                        |
| 5     | 0                          |        | Υ      |            |        | No                     | P1                    | 1                        |
| 6     | 1                          | Υ      |        |            |        | No                     | P0                    | 2                        |
| 7     | 2                          | Υ      |        |            | Υ      | No                     | P3                    | 3                        |
| 8     | 3                          | Υ      |        |            | Υ      | No                     | P3                    | 0                        |
| 9     | 0                          | Υ      |        |            | Υ      | No                     | P0                    | 1                        |
| 10    | 1                          | Υ      |        |            | Υ      | No                     | P3                    | 2                        |
| 11    | 2                          | Υ      |        | Υ          |        | No                     | P2                    | 3                        |
| 12    | 3                          | Υ      |        | Υ          |        | No                     | P0                    | 0                        |
| 13    | 0                          | Υ      |        | Υ          |        | No                     | P0                    | 1                        |
| 14    | 1                          | Υ      |        | Υ          |        | No                     | P2                    | 2                        |

# (2) Example with Four Ports, Two Priority Levels and No Bandwidth Consideration

To demonstrate arbitration behavior, consider the following system:

- Four ports.
- Ports 0 and 1 request only at priority 1. Ports 2 and 3 request only at priority 2.
- All ports have bandwidth allocations of 100% and the bandwidth overflow bit is set to 1. (Bandwidth will not affect arbitration.)

An example with these settings is shown in Table 6.156, Priority Round-Robin without Bandwidth

**Consideration**. Note that priority 2 requests will only win arbitration when there are no priority 1 requests. Also note that each arbitration counter only increments, and always increments, when a request of that priority is processed. Cycle 5 demonstrates the "always" condition of counter incrementing: even though the arbitration was won by the other port of highest priority instead of the one in the counter, the counter still increments.

Table 6.156 Priority Round-Robin without Bandwidth Consideration

|       |        | ressed by<br>ion Counter |        | Ports Requesting |        |        | Command     | Arbitration | Value of Counter at<br>Next Cycle |        |
|-------|--------|--------------------------|--------|------------------|--------|--------|-------------|-------------|-----------------------------------|--------|
| Cycle | PG 1*1 | PG 2*2                   | Port 0 | Port 1           | Port 2 | Port 3 | Queue Full? | Winner      | PG 1*1                            | PG 2*2 |
| 0     | 0      | 2                        | Υ      | Υ                | Υ      | Υ      | Yes         | None        | 0                                 | 2      |
| 1     | 0      | 2                        | Υ      | Υ                | Υ      | Υ      | No          | P0          | 1                                 | 2      |
| 2     | 1      | 2                        |        | Υ                | Υ      | Υ      | No          | P1          | 0                                 | 2      |
| 3     | 0      | 2                        | Υ      |                  | Υ      | Υ      | No          | P0          | 1                                 | 2      |
| 4     | 1      | 2                        |        |                  | Υ      | Υ      | No          | P2          | 1                                 | 3      |
| 5     | 1      | 3                        | Υ      |                  |        | Υ      | No          | P0          | 0                                 | 3      |
| 6     | 0      | 3                        |        |                  |        | Υ      | No          | P3          | 0                                 | 2      |
| 7     | 0      | 2                        |        |                  |        |        | No          | None        | 0                                 | 2      |
| 8     | 0      | 2                        |        |                  | Υ      | Υ      | Yes         | None        | 0                                 | 2      |
| 9     | 0      | 2                        | Υ      |                  | Υ      | Υ      | No          | P0          | 1                                 | 2      |
| 10    | 1      | 2                        |        |                  | Υ      | Υ      | No          | P2          | 1                                 | 3      |
| 11    | 1      | 3                        |        |                  |        | Υ      | No          | P3          | 1                                 | 2      |

Note 1. PG1 = Priority Group 1 Note 2. PG2 = Priority Group 2

# (3) Example with Four Ports, Two Priority Levels and Bandwidth Consideration

The example shown in **Section 6.5.2.8(2), Example with Four Ports, Two Priority Levels and No Bandwidth Consideration** was a very simplified case without considering bandwidth. However, in most cases, bandwidth will factor into the arbitration. Consider a system in which the allocated bandwidth is less than 100%. This system is shown in **Table 6.157, Priority Round-Robin with Bandwidth Consideration**. The "Bandwidth Held Off" column indicates if the bandwidth was held off for any port in that cycle. (Note cycles 3 and 11.) Even though the priority group 1 arbitration counter is pointing to port 0 in both cases, because the port is held off, port 0 does not win arbitration. A lower priority port, from priority group 2, wins arbitration instead. In this simplified example, every statistics reporting time is represented as 1 cycle, which allows port 0 to win arbitration on the cycle after hold-off (cycles 4 and 12). In the DDR Controller, the statistics reporting time is 10 cycles, so port 0 would actually be held off for 10 cycles.

Table 6.157 Priority Round-Robin with Bandwidth Consideration

|       |        | dressed by tion Counter |        | Ports Requesting |        | Command Queue Bandwidth |       | Arbitration | Value of Counter at Next Cycle |        |        |
|-------|--------|-------------------------|--------|------------------|--------|-------------------------|-------|-------------|--------------------------------|--------|--------|
| Cycle | PG 1*1 | PG 2*2                  | Port 0 | Port 1           | Port 2 | Port 3                  | Full? | Held Off?   | Winner                         | PG 1*1 | PG 2*2 |
| 0     | 0      | 2                       | Υ      | Υ                | Υ      | Υ                       | Yes   | No          | None                           | 0      | 2      |
| 1     | 0      | 2                       | Υ      | Υ                | Υ      | Υ                       | No    | No          | P0                             | 1      | 2      |
| 2     | 1      | 2                       |        | Υ                | Υ      | Υ                       | No    | No          | P1                             | 0      | 2      |
| 3     | 0      | 2                       | Υ      |                  | Υ      | Υ                       | No    | Yes, Port0  | P2                             | 0      | 3      |
| 4     | 0      | 3                       | Υ      |                  |        | Υ                       | No    | No          | P0                             | 1      | 3      |
| 5     | 1      | 3                       | Υ      |                  |        | Υ                       | No    | No          | P0                             | 0      | 3      |
| 6     | 0      | 3                       |        |                  |        | Υ                       | No    | No          | P3                             | 0      | 2      |
| 7     | 0      | 2                       |        |                  |        |                         | No    | No          | None                           | 0      | 2      |
| 8     | 0      | 2                       |        |                  | Υ      | Υ                       | Yes   | No          | None                           | 0      | 2      |
| 9     | 0      | 2                       | Υ      |                  | Υ      | Υ                       | No    | No          | P0                             | 1      | 2      |
| 10    | 1      | 2                       | Υ      |                  | Υ      | Υ                       | No    | No          | P0                             | 0      | 2      |
| 11    | 0      | 2                       | Υ      |                  | Υ      | Υ                       | No    | Yes, Port0  | P2                             | 0      | 3      |
| 12    | 0      | 3                       | Υ      |                  |        | Υ                       | No    | No          | P0                             | 1      | 3      |
| 13    | 1      | 3                       |        |                  |        | Υ                       | No    | No          | P3                             | 1      | 2      |

Note 1. PG1 = Priority Group 1 Note 2. PG2 = Priority Group 2

# 6.5.2.9 Programming for Priority Round-Robin Arbitration

The priority round-robin arbitration scheme requires the use of several programmable parameters: AXIY\_BDW, AXIY\_BDW\_OVFLOW, AXIY\_CURRENT\_BDW, AXIY\_R\_PRIORITY, AXIY\_W\_PRIORITY and ARB CMD Q THRESHOLD. Since these parameters work together, there are trade-offs for the settings.

#### **CAUTION**

All of the arbitration parameters must be programmed prior to setting the start parameter to 1. Any subsequent changes to the arbitration parameters may result in unpredictable system operation.

Command priority, port bandwidth and bandwidth overflow play an important role in arbitration. Priority is the most important factor since commands are first sorted into priority groups based on their priority settings. In a multi-port system, all ports with tight latency requirements should be assigned higher priority values (lower numbers). Note that the priority of the command affects both arbitration and placement into the command queue. As a result, it is more complicated to meet the latency requirements of all ports. For high priority commands or ports with low allocated bandwidths, bandwidth overflow may be useful. To mimic simple round-robin arbitration, program all ports to have the same priority and full bandwidth allocations.

#### **CAUTION**

The bandwidth parameter "AXIY\_BDW" is a 7-bit parameter. Any programmed value greater than 0x64 is interpreted as not having a maximum bandwidth allowance.

# 6.5.3 Port Protection Option

Each AXI port contains an address protection option to set up regions of the memory map that will be protected. If the "PORT\_ADDR\_PROTECTION\_EN" parameter is set to 1, all incoming addresses and access types will be checked against valid address ranges and types in order to protect each port's specified memory space. When the "PORT ADDR PROTECTION EN" parameter is cleared to 0, no addresses will be checked.

When enabled, if the command does not match the region information in address, transaction type or protection level, a port out-of-range error will be logged. The failing transaction will process as a flushed write or a read returning zeroes. In addition, one or both of the out-of-range interrupts (bits 1 or 2) will be set in the "INT\_STATUS" parameter and the error signature will be saved. A bus error will be reported on the AXI interface.

The number of address regions is 16 for each port. Refer to **Table 6.158, AXI Port Address Region Setting** for the number of address regions.

Table 6.158 AXI Port Address Region Setting

| Port Number | Number of Address Regions |
|-------------|---------------------------|
| Port 0      | 16                        |
| Port 1      | 16                        |
| Port 2      | 16                        |
| Port 3      | 16                        |

The system will default to restricting any type of access for the entire memory. For any one port, valid regions must be set up with unique addresses such that the regions do not overlap and with IDs and protection levels that will be supported. Failure to change any of the ID check and protection level parameters prior to enabling protection will result in all commands failing. For ports that will not be using port protection, the user must define at least one region that will accept all read and write cycles, for any address. Therefore, in this case, at least 1 region must be defined with the following characteristics:

AXIY\_START\_ADDR\_Z = All zeros (min address)

AXIY\_END\_ADDR\_Z = All ones (max address)

AXIY\_RANGE\_PROT\_BITS\_Z = 2'b11

AXIY\_RANGE\_RID\_CHECK\_BITS\_Z = 0xFFFF

AXIY\_RANGE\_WID\_CHECK\_BITS\_Z = 0xFFFF

AXIY\_RANGE\_RID\_CHECK\_BITS\_ID\_LOOKUP\_Z = 0xF

AXIY\_RANGE\_WID\_CHECK\_BITS\_ID\_LOOKUP\_Z = 0xF

## CAUTION

ID check is Not supported.

All bits related to ID\_CHECK settings should be set to 1.

For each parameter, Y represents the port number and Z differentiates between the various regions. Note that it is acceptable for address regions for one port to overlap access regions for another port.

The minimum granularity of an address region is 16K. Bit [13] of the incoming system address is used as the lowest bit for comparison. Internally, the Controller compares bit X of the address, where X is the defined as the 14th bit, left shifted by the number of bits used for the datapath. The user may define regions as any multiple of 16K, up to 1/2 of the memory space.

Port protection works by checking incoming requests against the valid address ranges. If enabled by setting the PORT\_ADDR\_PROTECTION\_EN parameter to 1, an incoming command is checked based on the restrictions defined in the port protection parameters. ALL of the following tests must pass for a command to remain valid:



#### • Address Check:

The starting and ending addresses must both fall within a single region Z as defined by the "AXIY\_START\_ADDR\_Z" and "AXIY\_END\_ADDR\_Z" parameters. If both starting and ending addresses do not fall within a single region Z, the command will fail.

#### • Protection Check:

The relevant protection signal "axiY\_ARPROT or axiY\_AWPROT" must match the settings for the associated "AXIY\_RANGE\_PROT\_BITS\_Z" parameter. The "AXIY\_RANGE\_PROT\_BITS\_Z" parameter defines the restrictions for region Z as privileged & secure access, privileged access, secure access or full access. If the protection signal does not match the settings of region Z, the command will fail.

• Set all bits 1 to following parameters

```
"AXIY_RANGE_RID_CHECK_BITS_Z"

"AXIY_RANGE_WID_CHECK_BITS_ID_LOOKUP_Z"

"AXIY_RANGE_WID_CHECK_BITS_ID_LOOKUP_Z"
```

Commands that fail are processed through the controller, but do not corrupt memory and do not return valid data to the user interface. A failing write command will be processed internally as a flushed write command. In this case, the write data is cleared out of the controller FIFOs but the data stored in DRAM memory will NOT change.

A failing read will read the appropriate number of bytes in the memory. However, this data will be ignored. Since the data will be ignored, no ECC detection or correction is attempted. Therefore, a read command error will not trigger an ECC error interrupt or save the erroneous data.

In the event of a failure, the port command error interrupt (bit 7) will be set in the INT\_STATUS parameter, and reported to the Global Interrupt Controller on the DDRC\_Int signal (if the associated bit is not masked in the INT\_MASK parameter). The error signature will be logged in the PORT\_CMD\_ERROR\_ADDR and PORT\_CMD\_ERROR\_TYPE.

# 6.5.4 Command Queue with Placement Logic

The Controller core contains a command queue that accepts commands from the Arbiter. This command queue uses a placement algorithm to determine the order that commands will be placed into the command queue. The placement logic follows many rules to determine where new commands should be inserted into the queue, relative to the contents of the command queue at the time. Placement is determined by considering address collisions, source collisions, data collisions, command types and priorities. In addition, the placement logic attempts to maximize efficiency of the Controller core through command grouping, write-to-read splitting and bank splitting.

Many of the rules used in placement may be individually enabled/disabled. In addition, the command queue may be disabled by clearing the PLACEMENT\_EN parameter, resulting in an in-line queue that services requests in the order they are received. If the PLACEMENT\_EN parameter is cleared to 0 and the IN\_ORDER\_ACCEPT parameter is set to 1, the placement algorithm will be ignored.

# 6.5.4.1 Rules of the Placement Algorithm

The factors affecting command placement all work together to identify where a new command fits into the execution order. They are listed in order of importance.

# (1) Address Collision/Data Coherency Violation

The order in which read and write commands are processed in the controller is critical to proper system behavior. While reads and writes to different addresses are independent and may be re-ordered without affecting system performance, reads and writes that access the same address are significantly related. If the port requests a read after a write to the same address, then repositioning the read before the write would return the original data, not the changed data. Similarly, if the read was requested ahead of the write but accidentally positioned after the write, then the read would return the new data, not the original data prior to being overwritten. These are significant data coherency mistakes.

To avoid address collisions, reads or writes that access the same chip select, bank and row as a command already in the command queue will be inserted into the command queue after the original command, even if the new command is of a higher priority. This rule is ignored when comparing a new read command to an existing read. Even if an address collision occurs between these reads, there is no data integrity issue and the data may be returned in any order.

Address collision checking may be enabled/disabled through the ADDR\_CMP\_EN parameter and should only be disabled if the system can guarantee coherency of reads and writes.

#### (2) Priority

Priorities are used to distinguish important commands from less important commands. Each command is given a priority based on the command type through the programmable parameters "AXIY\_R\_PRIORITY" and "AXIY\_W\_PRIORITY" (where Y represents the port number).

The placement algorithm will attempt to place higher priority commands ahead of lower priority commands, as long as they have no address collisions. Higher priority commands will be placed lower in the command queue if they access the same address, are from the same requestor or use the same buffer as lower priority commands already in the command queue.

Priority checking is enabled through the "PRIORITY\_EN" parameter.

### (3) Bank Splitting

Before accesses can be made to two different rows within the same bank, the first active row must be closed (precharged) and the new row must be opened (activated). Both activities require some timing overhead; therefore, for optimization, the placement logic will attempt to insert the new command into the command queue such that commands



to other banks may execute during this timing overhead. The placement of the new commands will still follow priority and address collision rules.

Bank splitting is enabled through the "BANK\_SPLIT\_EN" parameter.

## (4) Write-to-Read Splitting

When a read command follows a write command to the same chip select, there is some timing overhead to switch command types. For optimization, the placement logic will attempt to insert the new command into the command queue to separate two commands addressing the same chip select of different types where the write is going to execute before the read. The placement of the new commands will still follow priority and address collision rules. Write-to-read splitting is enabled through the "W2R\_SPLIT\_EN" parameter.

# (5) Read/Write Grouping

The memory suffers a small timing overhead when switching from read to write mode. For efficiency, the placement logic will attempt to place a new read command sequentially with other read commands in the command queue, or a new write command sequentially with other write command queue. Grouping will only be possible if no priority or address collision rules are violated.

Read/write grouping is enabled through the "RW\_SAME\_EN" parameter.

# (a) Bank Conflicts and Read/Write Grouping

If the new command addresses the same chip select and same bank, but a different row, as a command currently in the command queue, these commands are considered to have a bank conflict. As described in **Section 6.5.4.1(3)**, **Bank Splitting**, the placement logic will attempt to separate commands with bank conflicts. For this controller, certain placements are prohibited for read/write grouping to support ideal bank splitting.

These checks are controlled through the "DISABLE\_RW\_GROUP\_W\_BNK\_CONFLICT" parameter. If bit [0] of this parameter is set to 1, a new command will be prohibited from placement in the entry directly before or directly after the command with a bank conflict. If bit [1] of this parameter is also set to 1, the new command will also be prohibited from being placed two entries before or two entries after the command with a bank conflict. The following table shows a simplified command queue.

|       | •          | •    |     |  |
|-------|------------|------|-----|--|
| Entry | Read/Write | Bank | Row |  |
| 0     | Rd         | 0    | 0   |  |
| 1     | Rd         | 0    | 0   |  |
| 2     | Rd         | 0    | 0   |  |
| 3     | Rd         | 1    | 0   |  |
| 4     | Rd         | 0    | 0   |  |
| 5     | Rd         | 0    | 0   |  |
|       |            |      |     |  |

Table 6.159 Simple Command Queue Example

For this example, a new entry is received that is a READ to BANK 1, Row 1. Assume that no priority or address collision rules are violated. This new command would have a bank conflict with Entry 3.

• If DISABLE\_RW\_GROUP\_W\_BNK\_CONFLICT[0] = 1, the new command could not be placed immediately before or after the conflicting command. If the command was placed into entry 3, entries 3-5 would be moved to entries 4-6, and the bank conflicts would occur between entries 3 and 4. If the command was placed into entry 4, entries 4-5 would be moved to entries 5-6 and the bank conflict would still occur between entries 3 and 4. Therefore, entries 3 and 4 are prohibited for placement.



- If DISABLE\_RW\_GROUP\_W\_BNK\_CONFLICT[1] = 1, the new command could not be placed two entries before or two entries after the conflicting command. If the command was placed into entry 2, entries 2-5 would move to entries 3-6, and the bank conflict would occur between entries 2 and 4. If the command was placed into entry 5, the bank conflict would occur with between entries 3 and 5. Therefore, entries 2 and 5 are also prohibited for placement.
- Therefore, if the "DISABLE\_RW\_GROUP\_W\_BNK\_CONFLICT" parameter was set to 2'b11, the new entry could only be placed at entry 0, 1 or 6, allowing at least 2 commands in between the conflicting commands.

#### **CAUTION**

It is not meaningful to set bit [1] of the "DISABLE\_RW\_GROUP\_W\_BNK\_CONFLICT" parameter without bit [0].

## (b) Chip Select Grouping with Read/Write Grouping

When attempting to group read and write commands, the placement logic will also consider the chip select for the commands. If possible, read commands will be grouped with read commands to the same chip select, and write commands with write commands to the same chip select. If chip select grouping is not possible, commands will still be grouped by command type if the "RW\_SAME\_EN" parameter is set to 1. If read/write grouping is disabled ("RW\_SAME\_EN" is cleared to 0), chip select grouping will have no effect.

Chip select grouping is enabled through the "CS\_SAME\_EN" parameter.

# (c) Page Grouping with Read/Write Grouping

When attempting to group read and write commands, the placement logic will also consider the page for the commands. If possible, read commands will be grouped with read commands to the same page, and write commands with write commands to the same page. If page grouping is not possible, commands will still be grouped by command type if the "RW\_SAME\_EN" parameter is set to 1. If read/write grouping is disabled (RW\_SAME\_EN is cleared to 0), page grouping will have no effect.

Page grouping is enabled through the "RW\_SAME\_PAGE\_EN" parameter.

#### 6.5.4.2 Command Execution Order After Placement

Once a command has been placed in the command queue, selection logic will be used to determine how to pull commands from the queue for execution. This logic may be disabled by setting the "IN\_ORDER\_ACCEPT" parameter to 1, resulting in the command queue executing the commands in the order that they are placed relatively in the command queue. If the "IN\_ORDER\_ACCEPT" parameter is cleared to 0, the selection logic will be utilized. Regardless of the setting of this parameter, high-priority command swapping and command aging are provided which may affect commands after they have been placed into the command queue.

## (1) Command Selection Logic

On each clock cycle, the selection logic will scan the top 4 entries of the command queue to determine which command to execute. This value is defined at configuration. Commands are considered for execution based on bank readiness, availability of at least 1 burst of data (writes), availability of storage for at least 1 burst of data (reads), bus turnaround timing (JEDEC-specified and programmable) and conflicts. Similar to the placement rules, a command will not be executed before a command that was placed ahead of it in the command queue if there are any address or bank conflicts.

All placement rules mentioned in this chapter are followed by the selection logic other than priority. It is possible that lower priority commands may be executed ahead of higher priority commands if the higher priority commands are not ready to execute, provided that there are no conflicts with commands ahead in the command queue. The controller will also not execute a read/modify/write sequence before another read/modify/write sequence ahead of it in the command queue due to limited storage in the Controller core.

The selection feature is disabled through the "IN\_ORDER\_ACCEPT" parameter. If this parameter is set to 1, only the top entry of the command queue will be considered for execution. **Figure 6.7, Selection Logic** shows the command selection logic relative to the rest of the placement logic.



Figure 6.7 Selection Logic

## (2) High-Priority Command Swapping

Commands are assigned priority values to ensure that critical commands are executed more quickly in the controller than less important commands. Therefore, it is desirable that high-priority commands pass into the Controller core as soon as possible. The placement algorithm takes priority into account when determining the order of commands, but still allows a scenario in which a high-priority command sits waiting in the command queue while another command, perhaps of a lower priority, is in process.

The high-priority command swapping feature allows this new high-priority command to be executed more quickly. If the user has enabled the swapping function through the "SWAP\_EN" parameter, then the behavior of the swapping logic will be dependent on the value of the "IN\_ORDER\_ACCEPT" parameter. If the command queue must be executed in order (IN\_ORDER\_ACCEPT = 1), the entry at the top of the command queue will be compared with the current command in progress. If the selection logic is being used (IN\_ORDER\_ACCEPT = 0), the top 4 entries of the command queue will be compared with the current command in progress to determine which command may need to be executed first. If the selected command queue entry is of a higher priority (not the same priority) and it does not have an address conflict with the current command being executed, then the original command will be interrupted.

If the command is to be interrupted, it will be halted after completing the current burst, stored and placed at the top of the command queue, and the new command will begin executing. As long as the command queue is not full, new commands may continue to be inserted into the command queue based on the placement rules, even at the top of the queue ahead of the interrupted command. The selection logic will determine the command to execute next. Whenever the interrupted command is resumed, it will start from the point at which it was interrupted.

Note that priority 0 commands will never be interrupted, so the user should set any commands that should not be interrupted to priority 0.

#### (3) Command Aging

Since commands can be inserted ahead of existing commands in the command queue, the situation could occur where a low priority command remains at the bottom of the queue indefinitely. To avoid such a lockout condition, aging counters have been included in the placement logic that measure the number of cycles that each command has been waiting. If an aging counter hits its maximum, the priority of the associated command will be decremented by one (lower priority commands are executed first). This increases the likelihood that this command will be picked by the selection logic and execute. Note that this command does not move relative positions in the command queue when it ages; the new priority will be considered when placing new commands into the command queue.

Aging is controlled through a master aging counter and command aging counters associated with each command in the command queue. The AGE\_COUNT and "COMMAND\_AGE\_COUNT" parameters hold the initial values for each of these counters, respectively. When the master counter counts down the "AGE\_COUNT" parameter value, a signal is sent to the command aging counters to decrement. When the command aging counters have expired, the priority of the associated command is decremented and the counter is reset. Therefore, a command does not age by a priority level until the total elapsed cycles has reached the product of (AGE\_COUNT + 1) and (COMMAND\_AGE\_COUNT + 1). The maximum number of cycles that any command can wait in the command queue until reaching the top priority level is the product of (AGE\_COUNT + 1), (COMMAND\_AGE\_COUNT + 1), and the number of priority levels in the system.

If command swapping is enabled, it is possible that a command in progress could be interrupted by a higher priority command in the command queue. This situation could arise if a new higher-priority command arrives and is placed while the current command is in progress, or by a command in the queue aging to a lower priority while the current command is in progress. An interrupted command will be placed at the top of the command queue. Command aging will always be enabled.



# 6.5.4.3 ACT Request Control

The DDR Controller provides a means to limit which commands of the command queue may issue ACT requests. This can be used to prevent situations in which an ACT is issued for a command in the queue, and before that command can be executed, a new command is placed ahead of it which accesses the same bank but a different row. This would require a PRE-ACT sequence that may have been avoided if the first ACT was never issued.

This functionality is controlled through the "NUM\_Q\_ENTRIES\_ACT\_DISABLE" parameter, which specifies the number of entries of the command queue in which ACT requests are not allowed. For this 8-deep command queue, the entries are numbered 0-7, where entry 0 is the command next to execute.

Table 6.160 Programming of NUM\_Q\_ENTRIES\_ACT\_DISABLE Parameter

| Effect                                 |
|----------------------------------------|
| ACT request can occur from entries 0-7 |
| ACT request can occur from entries 0-6 |
| ACT request can occur from entries 0-5 |
| ACT request can occur from entries 0-4 |
| ACT request can occur from entries 0-3 |
| ACT request can occur from entries 0-2 |
| ACT request can occur from entries 0-1 |
| ACT request can occur from entries 0   |
|                                        |

# 6.5.5 DRAM Command Processing

The DRAM command processing logic is used to process the commands in the command queue. The logic organizes the commands to the memories in such a way that data throughput is maximized. Bank opening and closing cycles are used for data transfers.

The logic uses a variety of factors to determine when to issue bank open and close commands. The logic reviews the entire command queue for look-ahead of which banks are to be accessed in the future. The timing is then set to meet the "TRC" and "TRAS\_MIN" timing parameters of the memories, values which were programmed into the controller on initialization. This flexibility allows the controller to be tuned to extract the maximum performance out of memories. The parameters that relate to DRAM memory protocol are listed in the **Section 6.4.1, DDR Controller Register Description**.

# 6.5.6 ECC Function

The DDR Controller provide an optional error reporting and correcting circuitry that can be used to verify data in memory and correct memory errors if they occur. The logic will check for errors in both the data and the check code on all read transactions. ECC, or error checking and correcting, is the process of detecting bit errors in the memory data and if possible, correcting them. This function can confirm the accuracy of data and remove or at least identify bit errors. ECC works by storing unique "check codes" in memory. A check code is a mathematical description of the information in an aligned segment of memory known as an "ECC data word". The check code is always related to the entire ECC data word, and is used inside the DDR Controller on all memory reads to control data accuracy. Check codes are not input from, or output to, the user interface.

An ECC data word cannot start and end at any random address; these words are memory aligned to their size. The starting addresses of ECC data words are defined as ECC word boundaries and the alignment of user transactions to these boundaries determines how transactions are processed inside the DDR Controller. If the user does not wish to use the ECC option, the ECC module may be disabled by setting the control parameter "ECC\_EN" to 0. This DDR Controller supports a 32-bit ECC data word size. A 7-bit check code is maintained for each 32-bit memory area. ECC word boundaries fall on each 4-byte address (0xN0, 0xN4, 0xN8,0xNC).

# 6.5.6.1 ECC Error Types

An ECC error is defined in the DDR Controller as "correctable" or "un-correctable". A correctable error is a single bit error in the check code or the data. The controller uses the syndrome to determine which bit is erroneous and is able to correct the error. An un-correctable error is a double bit error in the check code and/or the data. The controller is able to identify that 2 bits in the check code and/or the data are incorrect, but cannot determine exactly which 2 bits are erroneous, and therefore cannot correct the error.

#### CAUTION

The DDR Controller can detect single bit and double bit errors. Errors in more than 2 bits of the check code and/or the data will cause the controller to behave unpredictably.



# 6.5.6.2 Features of the ECC Logic

The Controller ECC implementation provides the following features:

• Internal controls to disable individual I/O pads or to disable the ECC module

The DDR Controller provides disable signals to ignore certain or all bits of the memory datapath. This is useful with the Controller reduced datapath feature, with specific ECC memories, or when there is no ECC memory available. The user may disable the ECC module completely by programming the "ECC\_EN" parameter to 0. In this mode, the controller will not compute and compare check codes, nor attempt to store the check codes to memory.

• Register storage of the ECC signature on ECC errors

Two sets of parameters (one set for correctable errors, one set for un-correctable errors) store the address, data, and syndrome associated with the ECC error on a read command.

• Interrupt generation

Four interrupt bits in the register array communicate ECC status to the user for read commands.

• Automatic correction of single-bit errors

If single bit error occurs, the erroneous bit will be flipped automatically and accurate data/check codes will be written to memory (write transactions) or returned to the user interface (read transactions). Note that corrections made on read data will not be reflected to memory.

• Memory integrity preservation through ECC scrubbing

ECC scrubbing will ensure that the entire combined ECC data word will be written to memory to preserve memory integrity. ECC scrubbing does not automatically correct memory errors on read operations, but does allow a simple way for the user to correct errors in memory. If a correctable error is detected on a read, and ECC reporting and correction is enabled, the controller will fix the data prior to returning it to the user interface and flag the existence of the error in memory. However, the error still exists in the memory.

With ECC scrubbing, the user may respond to a correctable error by issuing a write to this memory location with all bytes masked. This will trigger a read/modify/write operation where the controller will read in the data from memory, discover and correct the error and then write the data and the check code to memory. Since all bytes of the data are written to memory, the error is overwritten - or scrubbed - from memory. ECC scrubbing requires that ECC correction and reporting are both enabled.

• Automatic corruption of ECC codes for read data errors

The read data is verified for ECC prior to combining the read data with the new write data and calculating a new ECC. If an un-correctable error is detected on the read data, it is likely that this address space contains bad memory. As a result, the Controller will automatically corrupt the check code for this ECC data word so that all future accesses to this area will result in an error. This feature may be disabled. If disabled, the error will be ignored and new data and a new check code will be written to memory. A future access to this address may or may not result in an uncorrectable error.

• ECC error forcing

The user can force a specific check code to be written into memory for diagnostic purposes or for flagging a particular memory address as erroneous for future accesses. When a write check is initiated, the programmed value will be XOR'ed with the generated ECC bits and written to memory. When this ECC data word is read back, the ECC error event will be detected.



#### 6.5.6.3 ECC Control

ECC functionality is controlled through a parameter named "ECC\_EN". This parameter enables ECC and sets the reporting and correcting behavior. To enable the ECC function, set "REDUC" to 1 to enable the half datapath feature. The rest of the datapath is used for the ECC check code, so the data area is halved.

# (1) Error Signature Parameters

Register storage is provided for the failing address, data, and syndrome for ECC single bit and double bit errors for read operations. There is one set of parameters for each type of error.

Note that the controller is only able to report errors within a half 64-bit-defined-word range. Therefore, if an error occurs, the address reported in the "ECC\_C\_ADDR" or "ECC\_U\_ADDR" parameter will be the previous 32-bit boundary of the erring location.

The signature information will be stored until the user reads these register locations. Subsequent errors that occur before the error reporting parameters are read will trigger an interrupt, but their error signature will be lost.

# (2) Interrupt Status Bits

The "INT\_STATUS" parameter indicates the status of all interrupts in the DDR Controller. The parameter is cleared on reset of the controller. There are 4 bits in the "INT\_STATUS" parameter relating to ECC.

Bits [4] and [6] will only be set if a subsequent ECC error occurs before the initial ECC error has been acknowledged by setting the associated bit in the "INT\_ACK" parameter to 1. When any of these errors occur, the associated bit will be set in the "INT\_STATUS" parameter. If the associated interrupt is not masked, the DDRC\_Int signal will also be triggered to the Global Interrupt Controller. An interrupt is masked if the associated bit is set to 1 in the "INT\_MASK" parameter.

# 6.5.6.4 Syndromes

On read commands, the controller will retrieve ECC data words from memory and their associated check codes. The Controller will generate a check code based on the data that it has read from memory. The checking function will XOR this value with the check code read from memory. The result of the XOR operation between a generated check code and a stored check code is known as a syndrome. If the syndrome is anything other than 0x00, an ECC error event has occurred. Incorrect bits could be located in the data or in the saved check code. In either case, the data and the check code do not match. The syndrome identifies which bit (on a single bit error) of the ECC data or check code is incorrect. If a syndrome does not deterministically identify which particular data bit which must be flipped, the error is a double bit or multi-bit error and cannot be corrected.

The following **Table 6.161, 32-Bit ECC Syndromes** displays the syndromes that correspond to single bit errors. If the syndrome is 0x00, then there was no ECC error. Any values other than the ones shown relate to double bit or multibit errors.

Table 6.161 32-Bit ECC Syndromes

| Syndrome | Incorrect Bit | Syndrome | Incorrect Bit | Syndrome | Incorrect Bit |
|----------|---------------|----------|---------------|----------|---------------|
| 0x00     | No Error      | 0x20     | Check [5]     | 0x57     | Data [11]     |
| 0x01     | Check [0]     | 0x23     | Data [23]     | 0x58     | Data [10]     |
| 0x02     | Check [1]     | 0x25     | Data [22]     | 0x5B     | Data [9]      |
| 0x04     | Check [2]     | 0x26     | Data [21]     | 0x5E     | Data [8]      |
| 0x08     | Check [3]     | 0x29     | Data [20]     | 0x62     | Data [7]      |
| 0x0B     | Data [31]     | 0x2A     | Data [19]     | 0x64     | Data [6]      |
| 0x0E     | Data [30]     | 0x2C     | Data [18]     | 0x67     | Data [5]      |
| 0x10     | Check [4]     | 0x31     | Data [17]     | 0x68     | Data [4]      |
| 0x13     | Data [29]     | 0x34     | Data [16]     | 0x6B     | Data [3]      |
| 0x15     | Data [28]     | 0x40     | Check [6]     | 0x6D     | Data [2]      |
| 0x16     | Data [27]     | 0x4A     | Data [15]     | 0x70     | Data [1]      |
| 0x19     | Data [26]     | 0x4F     | Data [14]     | 0x75     | Data [0]      |
| 0x1A     | Data [25]     | 0x52     | Data [13]     |          |               |
| 0x1C     | Data [24]     | 0x54     | Data [12]     |          |               |

#### **CAUTION**

Any other syndrome than the above table relate to double bit or multi-bit errors.

# 6.5.6.5 Command Processing when ECC is Enabled

A read command to the DDR Controller will always result in reading complete ECC data words of information, and their associated check codes, from the DRAM memory. The information will first be read into the Controller core where a check code will be generated for each read ECC data word. This generated code will be compared with the check code read from memory. If the two check codes do not match, then an error has occurred. Entire ECC data words containing the starting and ending addresses will be returned to the requestor; the requestor must ignore bytes that are not relevant.

A write command to the DDR Controller will trigger an internal read command before the write occurs. A read will be required because this allows the controller knowledge of the entire ECC data word for accurate check code generation. Once the data has been read into the controller core, a check code will be computed on the read data. Errors will be reported or corrected if possible. Then the read data will be combined with the new write data to create a new ECC data word.

A check code will be generated on the new ECC data word, whether all the data is new or only some of it. This code will be stored in the memories along with the new ECC data word and will be available to the controller when that data is required by the user interface.

The behavior of the ECC logic on each of the commands is shown in the following **Table 6.162**, **ECC Functionality** on **Various Transaction Types**.

Table 6.162 ECC Functionality on Various Transaction Types (1/2)

| Type of | Starting  | Ending    |                                                                                                |                 | Check Code |        |
|---------|-----------|-----------|------------------------------------------------------------------------------------------------|-----------------|------------|--------|
| Command | Address   | Address   | Internal Command                                                                               | Generated?      | Compared?  | Saved? |
| Read    | Any       | Any       | Reads of Complete ECC Data Words                                                               | Yes             | Yes        | No     |
| Write   | Aligned   | Aligned   | Writes of Complete ECC Data Words                                                              | Yes             | No         | Yes    |
| Write   | Aligned   | Unaligned | 1 Read prior to the Writes. All writes of cor                                                  | mplete ECC data | words.     |        |
|         |           |           | Read of the ECC data word containing the ending address.                                       | Yes             | Yes        | No     |
|         |           |           | Writes of complete ECC data words of new write data.                                           | Yes             | No         | Yes    |
|         |           |           | Final ECC data word written is a combination of read data and new write data (RMW).            | Yes             | No         | Yes    |
| Write   | Unaligned | Aligned   | 1 Read prior to the Writes. All writes of cor                                                  | nplete ECC data | words.     | •      |
|         |           |           | Read of the ECC data word containing the starting address.                                     | Yes             | Yes        | No     |
|         |           |           | First ECC data word written is a combination of read data and new write data (RMW).            | Yes             | No         | Yes    |
|         |           |           | Writes of complete ECC data words of new write data.                                           | Yes             | No         | Yes    |
| Write   | Unaligned | Unaligned | 2 Reads prior to the Writes. All writes of co                                                  | mplete ECC dat  | a words.   | •      |
|         |           |           | Read of the ECC data word containing the starting address.                                     | Yes             | Yes        | No     |
|         |           |           | First ECC data word written is a combination of first word read data and new write data (RMW). | Yes             | No         | Yes    |
|         |           |           | Writes of complete ECC data words of new write data.                                           | Yes             | No         | Yes    |
|         |           |           | Read of the ECC data word containing the ending address.                                       | Yes             | Yes        | No     |
|         |           |           | Final ECC data word written is a combination of last word read data and new write data (RMW).  | Yes             | No         | Yes    |

| Type of      | Starting | Ending  |                                                                                                               | Check Code |           |        |  |  |
|--------------|----------|---------|---------------------------------------------------------------------------------------------------------------|------------|-----------|--------|--|--|
| Command      | Address  | Address | Internal Command                                                                                              | Generated? | Compared? | Saved? |  |  |
| Masked Write | Any      | Any     | Masked Writes are limited to 1 64-bit-define RMW operations. All writes of complete EC                        | 9          |           |        |  |  |
|              |          |         | Read of the ECC data word containing the starting address.                                                    | Yes        | Yes       | No     |  |  |
|              |          |         | First ECC data word written is a combination of first word read data and new write data (RMW).                | Yes        | No        | Yes    |  |  |
|              |          |         | Read of the ECC data word containing the ending address - if applicable.                                      | Yes        | Yes       | No     |  |  |
|              |          |         | Final ECC data word written is a combination of last word read data and new write data (RMW) - if applicable. | Yes        | No        | Yes    |  |  |

# 6.5.6.6 ECC and Read Operations

If ECC is disabled (the "ECC\_EN" parameter is cleared to 0), read requests will pull data from memory and return the data to the user interface. No ECC checking will occur and no error information will be saved or reported. If ECC is enabled (the "ECC\_EN" parameter is set to 1), ECC behavior will follow the information shown in **Table 6.162, ECC Functionality on Various Transaction Types**. On all reads, even read requests that do not span an entire ECC data word, the entire ECC data word that contains the starting address will be read to the DDR Controller core and returned to the user. If the request did not encompass the entire ECC data word, the user will need to ignore the extra bytes. The stored check code will also be read to the controller core. The entire ECC data word and the stored check code are required for ECC verification. The internal logic will generate a check code for this data and XOR the generated code with the value read from memory. The result of the XOR operation between a generated check code and a stored check code is known as a syndrome. The action of the Controller is dependent on the syndrome:

# • The syndrome is 0x00

The computed check code and the stored check code match and therefore the data is accurate. The Controller will send the data to the user interface. No errors occurred, so the ECC error parameters will not be updated, no interrupts will occur and the user-interface signals will not be asserted.

## • The syndrome indicates a single-bit error

The error is in the data or the check code, but the Controller is aware of exactly which bit is erroneous by the value of the syndrome. Even though the bit can and will be corrected, the error will still be flagged as a "correctable" error. The Controller will store the address, data, and syndrome in the ECC correctable error parameters, and either the first correctable ECC error interrupt (bit [3]) or the second correctable ECC error interrupt (bit [4]) will be set in the "INT\_STATUS" parameter. The Controller will use the syndrome information to correct the erroneous bit and then the correct data will be sent to the user interface. The erroneous data or check code bit in memory will not be changed.

#### • The syndrome indicates a multi-bit error

The error is in the data or the check code, but the Controller cannot identify which bits are erroneous. The Controller will store the address, data, and syndrome in the ECC un-correctable error parameters, and either the first uncorrectable ECC error interrupt (bit [5]) or the second un-correctable ECC error interrupt (bit [6]) will be set in the "INT\_STATUS" parameter. The incorrect data will be sent to the user interface. In addition, an error response will be sent on the "axiY\_RRESP" signal. For default transfers, the error will be sent with the beats that caused the error. If the error was associated with a narrow transfer, then the error will be sent with each beat of the erroneous data word.

# 6.5.6.7 ECC and Write Operations

If ECC is disabled (the "ECC\_EN" parameter is cleared to 0), write requests will write the data from memory. If a read/modify/write operation is required, data will be pulled from memory, combined with the new data and then written to memory. ECC check codes will not be read from memory, no ECC checking will occur and no error information will be saved or reported. If ECC is enabled (the "ECC\_EN" parameter is set to 1), all ECC writes are completed as read/modify/write operations. Since the value of the check code depends on the entire ECC word, and it is possible that only some of the bytes of the ECC word are new data, the controller cannot compute a check code on this data. As a result, these types of operations are performed as read/modify/write operations. A read/modify/write operation consists of these steps:

#### • Reading the ECC Data Word

The ECC data word containing the write data address, and the corresponding check code, will be read to the DDR Controller core.

#### • Validating the Data

The controller will generate a check code from the read data and XOR this value with the check code read from memory to determine the syndrome. The action of the Controller is dependent on the syndrome:

- The syndrome is 0x00. The computed check code and the stored check code match and therefore the data is accurate.
- The syndrome indicates a single-bit error. The error is in the data or the check code, but the Controller is aware of exactly which bit is erroneous by the value of the syndrome. Even though the bit can and will be corrected, the error will still be flagged as a "correctable" error. The Controller will store the address, data, and syndrome in the ECC correctable error parameters, and either the first correctable ECC error interrupt (bit [3]) or the second correctable ECC error interrupt (bit [4]) will be set in the "INT\_STATUS" parameter. The Controller will use the syndrome information to correct the erroneous bit.
- The syndrome indicates a multi-bit error. The error is in the data or the check code, but the Controller cannot identify which bits are erroneous. The Controller will store the address, data, and syndrome in the ECC uncorrectable error parameters, and either the first un-correctable ECC error interrupt (bit [5]) or the second uncorrectable ECC error interrupt (bit [6]) will be set in the "INT\_STATUS" parameter. The Controller will automatically corrupt the check code for this ECC data word if ECC corruption is enabled (the "ECC\_DISABLE\_W\_UC\_ERR" parameter is cleared to 0). This ensures that a future access to this location will reveal an ECC error. If the "ECC\_DISABLE\_W\_UC\_ERR" parameter is set to 1, the check code will not be corrupted and the un-correctable error will be lost.

#### • Combining the Data

The corrected or un-corrected 64-bit-defined-word will be combined with the new write data. If the check code was intentionally corrupted during the read phase, the new check code will also be corrupted. Otherwise, the controller will calculate a new check code based on the combined data.

#### • Writing the Information

The new check code [accurate or corrupted] and the entire 64-bit-defined-word will be written to memory.



# 6.5.6.8 Automatic ECC Corruption

For ECC accuracy, data is verified for ECC during the read phase of a write prior to modifying and writing. If an uncorrectable error is detected on the read data, it is likely that this address space contains bad memory. As a result, the Controller will automatically corrupt the check code for this ECC data word so that all future accesses to this area will result in an error. The corruption occurs during both the read and the write phases of the write transaction. If desired, this feature may be disabled by setting the "ECC\_DISABLE\_W\_UC\_ERR" parameter. If disabled, the un-correctable error will be ignored. The read data and write data will be combined, and a check code will be calculated to match the new ECC data word. New data and the new check code will be written to memory. A future access to this address may or may not result in an un-correctable error.

# 6.5.6.9 Forcing an ECC Error Event

There are situations where the user may wish to force an ECC error. This could be used for testing purposes or to tag a particular memory location as erroneous. The latter could be used when an un-correctable error occurs on a write operation and the "ECC\_DISABLE\_W\_UC\_ERR" parameter was accidentally set to 1 at the time. By having corruption disabled, the ECC error was lost. By forcibly corrupting the check code in memory, an ECC error will occur on subsequent reads of this location. The procedure for forcing an ECC event is as follows:

- (1) Set the "ECC\_EN" parameter to 1. This will enable ECC checking.
- (2) Ensure that no writes to the controller are pending.
- (3) Write a value to the "XOR\_CHECK\_BITS" parameter that will trigger an ECC event once that word is read. Use the syndromes listed in **Section 6.5.6.4**, **Syndromes** to program the "XOR\_CHECK\_BITS" parameter. Each byte of the "XOR\_CHECK\_BITS" parameter controls the ECC event forcing for a separate 64-bit-defined-word space. **Table 6.163**, **Parameter XOR\_CHECK\_BITS Mapping** shows how each byte of the "XOR\_CHECK\_BITS" parameter maps to 64-bit-defined-word bits. For example, to force a single bit correctable error on bit 0 of the 64-bit-defined-word space shown, write 0x75 into that byte of the "XOR\_CHECK\_BITS" parameter. To force a double bit un-correctable error for the 64-bit-defined-word space, write 0x03 into that byte of the "XOR\_CHECK\_BITS" parameter.
- (4) Assert the FWC (force write check) parameter using the register interface.
- (5) Execute a write command to the controller for an aligned 64-bit-defined-word.
- (6) The next read command to the same address will force the ECC error. This action also automatically clears the "FWC" parameter bit to 0.
- (7) Depending on the programming of the "XOR\_CHECK\_BITS" parameter, a single bit, double bit or multi-bit ECC error will occur. For single bit and double bit errors, the appropriate bit in the "INT\_STATUS" parameter will be set to 1 and the ECC error signature parameters will be filled with the relevant information. Refer to **Table**6.163, Parameter XOR\_CHECK\_BITS Mapping for details on how to force a bad ECC syndrome.

Table 6.163 Parameter XOR\_CHECK\_BITS Mapping

| Mapping                                                                                                                    | Description                                                                                                                                                                                                                                                             |
|----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| XOR_CHECK_BITS [13:7] maps to<br>64-bit-defined-word [63:32]<br>XOR_CHECK_BITS [6:0] maps to<br>64-bit-defined-word [31:0] | This value will be XOR'ed with the generated ECC bits and then written to memory when the FWC bit is also set to 1. When this 64-bit-defined-word is read back, an ECC event will be detected. For codes to force a particular event, refer to the ECC syndromes table. |

# 6.5.6.10 Clearing a Reported ECC Event

To clear a reported ECC event, the user should follow these steps:

- Read the ECC data, address and syndrome parameters to determine where the event occurred.
- Set the associated bit in the "INT\_ACK" parameter to 1. This clears the ECC interrupt as well as the ECC event parameters, and allows future events to be captured.

# 6.5.7 Low Power Control Management

In many applications, it is desirable to minimize the power consumption of the DDR Controller and the memories. The DDR Controller provides various user-configurable low power options to address power savings. The low power logic is located in the Low Power Control (LPC) module.

#### 6.5.7.1 Low Power States

#### CAUTION

- Transitions will only be made into deeper low power states. If the user requires to switch to a higher power state, the current state must be exited and then the new state entered.
- Low power state transitions that may be completed without a low power exit will be performed when possible. The system will include low power exits if necessary when switching from one low power state to another.

### (1) Active Power-Down

The controller sets the memories into power-down while any row is active in the bank. This state reduces the overall power consumption of the system, but has the least effect of all the low power states. In this state, the controller and memory clocks are fully operational, but the CKE input bit to the memories is de-asserted. If entry into the "Active Power-Down" state was requested, the memory will enter either active or pre-charge power-down mode depending on the state of the rows. If there are no open rows, pre-charge power-down mode will be entered.

The controller will continue to monitor memory refresh needs and will automatically bring the memory out of power-down to perform these refreshes. When a refresh is required, the CKE input bit to the memories will be re-enabled. This action brings the memories out of power-down. Memory that has been transitioned into active power-down mode will automatically transition to pre-charge power-down mode after the controller performs a refresh since the refresh process includes a pre-charge all command.

For DDR2, active power-down mode supports both fast and slow exit modes depending on how the memory mode registers are programmed. If the active power-down bit (MR [A12]) is cleared to 0 (fast exit), the timing parameter TXARD will define the exit time from this low power state to a read command. If the active power-down bit is set to 1 (slow exit), the timing parameter TXARDS will be used.

# (2) Active Power-Down with Memory Clock Gating

# **CAUTION**

This low power state is NOT supported for standard DDR2 or DDR3 memories. When set into this state, the controller will attempt to place the memories in power-down and gate off the memory clock. The memory will function unpredictably and may hang.

#### (3) Pre-Charge Power-Down

The controller sets the memories into power-down once all banks are idle. If any rows are active, prior to issuing the power-down mode command, the controller will issue a pre-charge all command. If any NVM memories are present in the system, the pre-charge command is not relevant and will not be sent to the NVM memories.

The controller will continue to monitor memory refresh needs and will automatically bring the memory out of power-down to perform these refreshes. When a refresh is required, the CKE input bit to the memories will be re-enabled. This action brings the memories out of power-down. Once the refresh has been completed, the memories will be returned to pre-charge power-down mode following the de-assertion the CKE input bit.



For DDR3, pre-charge power-down mode supports both fast and slow exit modes depending on how the memory mode registers are programmed. If the pre-charge power-down bit (MR0 [A12]) is cleared to 0 (slow exit), the timing parameter "TXPDLL" will define the exit time from this low power state to a read command. If the pre-charge power-down bit is set to 1 (fast exit), the timing parameter "TPDEX" will be used.

# (4) Pre-Charge Power-Down with Memory Clock Gating

#### CAUTION

This low power state is NOT supported for standard DDR2 or DDR3 memories. When set into this state, the controller will attempt to place the memories in power-down and gate off the memory clock. The memory will function unpredictably and may hang.

#### (5) Self-Refresh

The controller sets the memories into self-refresh mode. In this low power mode, the controller and memory clocks are fully operational and the CKE input bit to the memories is de-asserted. Since the memory automatically refreshes its contents, the controller does not need to send explicit refreshes to the memory.

# (6) Self-Refresh with Memory Clock Gating

The controller sets the memories into self-refresh and gates off the clock to the memories. Before the memories are removed from self-refresh, the clock will be gated on again.

### (7) Self-Refresh with Memory and Controller Clock Gating

This is the deepest low power state of the controller. The controller sets the memories into self-refresh and gates off the clock to the memories. In addition, the clock to the controller will be gated off (except the AHB Register interface).

Before the memories are removed from self-refresh, the controller and memory clocks will be gated on. If automatic exit from this state is enabled, a new transaction that addresses a memory device in this state will wake up the memory to process the transaction.

#### CAUTION

- This state should not be entered when a read or write command is being processed. When using the software
  programmable interface, the user should ensure that the controller is idle before requesting entry into this state by
  checking the "CONTROLLER\_BUSY" parameter. When using the automatic interface, the DDR Controller will
  complete this check.
- When the controller clock is gated through the low power control module, writes to any of the programmable command parameters - parameters that result in command execution within the controller - will be ignored and not result in execution of the associated commands. Any commands issued while the controller clock is gated may or may not be executed once the controller clock is un-gated. In general, command registers should not be programmed during controller clock gating as the commands will have undefined results.



# 6.5.7.2 Management of the Low Power Control Module

## (1) Interfaces

There are two means to manage the LPC module:

• Software Programmable Interface

This interface uses programmable parameters in the DDR Controller registers and status reporting to manage low power command activity.

• Automatic Interface

This interface supports automatic entry and exit for all low power states with separate enables and counters for each low power state.

Table 6.164 Low Power State Management

|                                                      | Int                   | Interfaces |  |  |  |  |
|------------------------------------------------------|-----------------------|------------|--|--|--|--|
| Low Power State                                      | Software Programmable | Automatic  |  |  |  |  |
| Normal Mode                                          | _                     | _          |  |  |  |  |
| Active Power-Down                                    | Yes                   | Yes        |  |  |  |  |
| Pre-Charge Power-Down                                | Yes                   | Yes        |  |  |  |  |
| Self-Refresh                                         | Yes                   | Yes        |  |  |  |  |
| Self-Refresh with Memory Clock Gating                | Yes                   | Yes        |  |  |  |  |
| Self-Refresh with Memory and Controller Clock Gating | Yes                   | Yes        |  |  |  |  |
| Shutdown                                             | No                    | No         |  |  |  |  |

### **CAUTION**

Memory clock gating with power-down is NOT supported for DDR2 and DDR3 memories.

# (2) Low Power Arbiter

Since the LPC module may be managed by multiple masters, an arbitration scheme has been implemented that only allows one interface (software programmable, automatic) to execute low power commands at a time. Each interface may maintain ownership of the LPC module as long as it maintains its request.

The software programmable interface and automatic interfaces generate request signals with a command to win arbitration of the LPC module. They lose arbitration after their request has completed. The software programmable interface does include a lock option to hold arbitration for another command. This lock is not failsafe.

Commands will only be executed once the low power arbiter grants control to the interface associated with the operation and only when the LPC module is not executing a command. The interfaces have the following priorities:

- (1) Software programmable interface
- (2) Automatic interface



# 6.5.7.3 Software Programmable Interface

The software programmable interface provides a single programmable parameter "LP\_CMD" which is used to request entry into or exit from any of the supported low power states. When the user programs the "LP\_CMD" parameter with a supported value, if the module is idle "LP\_ARB\_STATE = 4'b0000", the software programmable interface will win arbitration of the LPC module. This will be reflected in the "LP\_ARB\_STATE" parameter being set to 4'b0001 (or 4'b1001 if the "LOCK" bit (bit 7) was set when the command was requested). If the arbitration status is already defined for the software programmable interface "LP\_ARB\_STATE = 4'b0001 or 4'b1001", the command will continue without any change to this parameter. If any other interface has won arbitration, the software command will remain pending until it can execute. There is no way to abort the command once it has been issued.

When the interface wins arbitration, the command defined in the "LP\_CMD" parameter will be passed to the LPC module. The "LP\_CMD" parameter is encoded to initiate an entry or exit, and to specify the low power state requested. Once the command is accepted, the "VALID" bit (bit 5) of the "LP\_STATE" parameter will be cleared to 0 and the command processed.

The action taken by the LPC module depends on the low power state request and the state of the LPC module at the time that the request is received. If the memory is currently in a low power state and the exit bit is set in the command request, the LPC module will trigger an exit of the current low power state. If the entry bit is set, the LPC module will review the specified low power state. If the memory is not in a low power state, or the request is for a deeper low power state than the current state, the LPC module will trigger an entry into the new low power state. If the request is for the same or a lesser low power state than the current state, no action will be taken by the LPC module.

Once the command has completed (or if no action is taken), the "VALID" bit (bit 5) of the "LP\_STATE" parameter will be set to 1, the new state will be reflected in the low power state bits (bits [4:0] of the "LP\_STATE" parameter), and the low power command complete interrupt (bit 9) will be set to 1 in the INT\_STATUS parameter. If the command was issued without the "LOCK" bit set "LP\_CMD[7]", the arbitration parameter will be reset to idle "LP\_ARB\_STATE = 4'b0000". If the command was issued with the "LOCK" bit set "LP\_CMD[7]", the low power arbiter will hold the arbitration in software programmable interface control with the lock indicator set "LP\_ARB\_STATE = 4'b1001". If a high-priority request breaks the software programmable interface's lock, the system may require a system reset.

While the "VALID" bit (bit 5) of the "LP\_STATE" parameter is cleared to 0, no additional commands will be accepted into the LPC module. Any writes to the "LP\_CMD" parameter will result in unpredictable behavior.

# (1) Lock Option

The software programmable interface provides the option to lock the arbitration. Since the LPC module may be modifying the low power state of the memory at any moment, reading the "LP\_STATE" parameter even immediately prior to issuing a low power command through the software programmable interface does not guarantee that the low power state of the system has not changed since the parameter was read. One way to be sure that the state does not change from a read of the "LP\_STATE" parameter to the execution of an "LP\_CMD" is to lock the LPC module from access by any other interfaces. This can be done by issuing a lock without an entry into any low power state "LP\_CMD = 8'b100\_000\_00". This will gain control of the LPC module, define a specific state and set the low power command complete interrupt (bit 9) in the INT\_STATUS parameter to 1. The only difference between this command and any other low power command issued from the software programmable interface is that at the end of the command, the "LP\_ARB\_STATE" parameter is not reset to idle (4'b0000) but instead remains at 4'b1001 for software programmable interface control with a lock. Based on the current state, the software programmable interface can then enter any other low power state or exit the low power state.

The lock option may also be issued along with any low power entry or exit command "LP\_CMD = 8'b100\_xxx\_10 or 8'b100\_000\_01". This command is also processed in the same way as any other low power command, with the only difference that the "LP\_ARB\_STATE" is not reset to idle at the end of the command. However, note that the only way to remove the lock is to issue another low power entry or exit command with the lock bit cleared.



# (2) Software Programmable Interface Commands

The "LP\_CMD" parameter is used to issue low power commands to the LPC module through the software programmable interface. There is no strobe associated with the software programmable interface and writes to this parameter will be sent to the LPC module for arbitration and execution. For detailed description refer please to the detailed **Section 6.4.1.27, DDR\_CTL\_26** — **DDR-Controller Status & Control 26**.

Three low power modes are supported for the software programmable interface with the following bit (LP\_CMD[4:2]) settings:

• 3'b000 = Active Power-Down

### CAUTION

If entry into either of the "Active Power-Down" was requested, the memory will enter either active or pre-charge power-down mode depending on the state of the rows. If not all rows are closed at the time, the memories will enter active power-down mode. If there are no open rows, the memories will enter pre-charge power-down mode. To ensure that all rows are closed, the user should specify a "Pre-Charge Power-Down".

- 3'b001 = Pre-Charge Power-Down
- 3'b010 = Self-Refresh

Table 6.165 Supported Software Programmable Interface Commands

| Parameter "LP_CMD" | Description                                                                                                                                                                                                                           |  |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 8'b000_000_01      | Exit any low power state                                                                                                                                                                                                              |  |
| 8'b000_000_10      | "Active Power-Down" Entry                                                                                                                                                                                                             |  |
| 8'b000_001_10      | "Pre-Charge Power-Down" Entry                                                                                                                                                                                                         |  |
| 8'b000_010_10      | "Self-Refresh Entry"                                                                                                                                                                                                                  |  |
| 8'b001_010_10      | "Self-Refresh with Memory Clock Gating" Entry                                                                                                                                                                                         |  |
| 8'b011_010_10      | "Self-Refresh with Memory and Controller Clock Gating" Entry                                                                                                                                                                          |  |
|                    | <b>Note</b> ) This state should not be entered when a read or write command is being processed. The user should ensure that the controller is idle before requesting entry into this state by checking the CONTROLLER_BUSY parameter. |  |
| 8'b100_000_00      | Set the lock (no low power command)                                                                                                                                                                                                   |  |
| 8'b100_000_01      | Exit any low power state, with lock                                                                                                                                                                                                   |  |
| 8'b100_000_10      | "Active Power-Down" Entry, with lock                                                                                                                                                                                                  |  |
| 8'b100_001_10      | "Pre-Charge Power-Down Entry", with lock                                                                                                                                                                                              |  |
| 8'b100_010_10      | "Self-Refresh Entry", with lock                                                                                                                                                                                                       |  |
| 8'b101_010_10      | "Self-Refresh with Memory Clock Gating" Entry, with lock                                                                                                                                                                              |  |
| 8'b111_010_10      | "Self-Refresh with Memory and Controller Clock Gating" Entry, with lock                                                                                                                                                               |  |
|                    | <b>Note)</b> This state should not be entered when a read or write command is being processed. The user should ensure that the controller is idle before requesting entry into this state by checking the CONTROLLER_BUSY parameter.  |  |

#### 6.5.7.4 Automatic Interface

The LPC module supports automatic entry into each of the low power states based on programmable enables and idle state monitors. Each low power mode (not state) has a separate enable bit and counter as shown in **Table 6.166, Low Power State Management**. As with the software programmable interface, the automatic interface must win arbitration of the LPC module to issue requests. The automatic interface has the lowest priority for arbitration.

When the controller is idle, each of the timing counters that are enabled begin counting down the cycles of inactivity. Idle time requires that no read or write commands are executing or pending in the command queue or any of the ports. For the power-down states, idle time begins when no commands are waiting to be sent to memory and the counter decrements for each cycle of controller inactivity. For the self-refresh states, idle time begins only after all the read data for outstanding read commands has been retrieved; this restriction ensures that all read data is received even if the automatic request includes gating off the controller clock. The self-refresh counters decrement for each long count of inactivity.

# (1) Automatic Entry

If any of the counters expire, the automatic interface will request arbitration. The timing counters are initially loaded with the values in the associated parameters, and will only decrement if the associated "LP\_AUTO\_ENTRY\_EN" parameter bit is set to 1 and the counters are loaded with a non-zero value. If no other interface has control of the LPC module "LP\_ARB\_STATE = 4'b0000 or 4'b0011", the automatic interface will win arbitration and the specified low power state will be compared to the current state of the memories. If the memory is already in a low power state, and the expired counter is associated with a deeper low power state than the current state, the LPC module will trigger an entry into the new low power state. If the expired counter is associated with a higher power usage state, the counter expiration will be ignored.

If a counter expires while the LPC module is being controlled by the software programmable interface, the automatic request will remain pending until the arbiter returns to idle "LP\_ARB\_STATE = 4'b0000" and the automatic interface is granted control of the LPC module. A pending request will be cancelled if a read or write command enters the command queue, resetting the automatic counters to the programmed values.

If the power-down counter expires, the DDR Controller will evaluate the state of the memory and the setting of the "LP\_AUTO\_MEM\_GATE\_EN" parameter to determine which low power state to enter. If not all rows are closed at the time, the memories will enter active power-down mode. If there are no open rows, the memories will enter pre-charge power-down mode. The memory clock will be gated off in either mode if bit [0] is set to 1 in the "LP\_AUTO\_MEM\_GATE\_EN" parameter. Memory that has been transitioned into active power-down mode will automatically transition to pre-charge power-down mode when the controller performs a refresh since the refresh process includes a pre-charge all command.

Multiple automatic low power idle counters may expire at the same time. When this happens, the counter associated with the deepest low power state will be entered. No state change will occur if current low power state is deeper than the states associated with any of the expired counters.

Since the controller only supports entering deeper low power states, it is meaningful to program progressively larger idle times for the deeper low power states. The parameters are shown in **Table 6.166**, **Low Power State Management** from least power savings to most power savings. The associated counters will only count idle cycles if the "LP\_AUTO\_ENTRY\_EN" parameter bit is set to 1, and if the associated parameter is a non-zero value.

Table 6.166 Low Power State Management

| Low Power State                                            | Enabling Parameter                                            | Counter Parameter       |
|------------------------------------------------------------|---------------------------------------------------------------|-------------------------|
| Active Power-Down                                          | LP_AUTO_ENTRY_EN [0] = 1'b1<br>LP_AUTO_MEM_GATE_EN [0] = 1'b0 | LP_AUTO_PD_IDLE         |
| Pre-Charge Power-Down                                      | LP_AUTO_ENTRY_EN [0] = 1'b1<br>LP_AUTO_MEM_GATE_EN [0] = 1'b0 | LP_AUTO_PD_IDLE         |
| Self-Refresh                                               | LP_AUTO_ENTRY_EN [1] = 1'b1<br>LP_AUTO_MEM_GATE_EN [1] = 1'b0 | LP_AUTO_SR_IDLE         |
| Self-Refresh with<br>Memory Clock Gating                   | LP_AUTO_ENTRY_EN [1] = 1'b1<br>LP_AUTO_MEM_GATE_EN [1] = 1'b1 | LP_AUTO_SR_IDLE         |
| Self-Refresh with<br>Memory and<br>Controller Clock Gating | LP_AUTO_ENTRY_EN [2] = 1'b1                                   | LP_AUTO_SR_MC_GATE_IDLE |

#### **CAUTION**

When the DDR Controller issues a power-down mode entry, the DRAMs will enter one of the power-down states depending on the state of the rows and the setting of the "LP\_AUTO\_MEM\_GATE\_EN[0]" parameter bit at that time.

### (2) Automatic Exit

The automatic interface also supports automatic exit from a low power state if the system requires, with separate enable bits for each low power state. During an automatic exit, all of the idle counters are reset to their programmed values and the memories are returned to normal operation. When a new read or write command enters the command queue, if the current low power state's associated "LP\_AUTO\_EXIT\_EN" parameter bit is set to 1, the automatic interface will request arbitration. If no other interface has control of the LPC module "LP\_ARB\_STATE = 4'b0000 or 4'b0011", the automatic interface will win arbitration and an exit low power command be triggered. If the current state is not enabled for automatic exit in the "LP\_AUTO\_EXIT\_EN" parameter, the LPC module will not exit low power.

If the LPC module is being controlled by the software programmable interface when the new read or write command appears, the automatic request will remain pending until the arbiter returns to idle "LP\_ARB\_STATE = 4'b0000" and the automatic interface is granted control of the LPC module.

Only new read or write commands will cause the counters to be reloaded to their programmed values and trigger an exit. Other commands, including MRR, MRW, low power entry and exit commands, register accesses, refresh, ZQ, etc., do not reset the counters and do not trigger an exit from low power. When the controller is idle and the memories have automatically entered a low power state, these commands may be prevented from executing.

It is generally expected that any state that is defined for automatic entry "LP\_AUTO\_ENTRY\_EN" should also be enabled for automatic exit "LP\_AUTO\_EXIT\_EN". Automatic exit may also be used for low power states that are not defined for automatic entry, but are expected to be entered manually through the software programmable interface "LP\_CMD". If it is desirable to use both manual and automatic entry/exit into the same low power state, then the user may need to re-program the "LP\_AUTO\_EXIT\_EN" parameter prior to issuing a request through the software programmable interface.

# (3) Automatic Interface Management

The LPC module may be manipulated through programmable parameters in the DDR Controller registers.

# 6.6 Usage Notes

# 6.6.1 Simplified DDR Initialization



Figure 6.8 Simplified Init Flow

# 6.6.2 DDR Initialization Example

#### (1) Clock Enable

```
Enable AXI Interconnection (NoC) Clock-A (DDR_XCLK) and DDR (Ctrl/PHY) Clock-B (DDR_DFICLK):  \{write\} \ PWRCTRL\_DDRC.CLKEN\_B = 1 \\ \{write\} \ PWRCTRL\_DDRC.CLKEN\_A = 1
```

# (2) Reset

```
Request idle state for AXI interconnection and wait for acknowledge
{write} PWRCTRL_DDRC.MIREQ_A = 1
{wait} PWRSTAT_DDRC.MISTAT_A = 1

Assert Reset to AXI Interconnection (NoC) Reset-A and DDR (Ctrl/PHY) Reset-B
{write} PWRCTRL_DDRC.RSTN_A = 0
{write} PWRCTRL_DDRC.RSTN_B = 0

Assert Soft-Reset of DDR (PHY) and pre-define Voltage setting and Hi-Z mask
{write} FUNCCTRL = 0x00180100 (DDR3)
{write} FUNCCTRL = 0x002000000 (DDR2)

De-Assert Reset to AXI Interconnection (NoC) Reset-A and DDR (Ctrl/PHY) Reset-B
{write} PWRCTRL_DDRC.RSTN_B = 1
```

{write} PWRCTRL DDRC.RSTN A = 1

```
Request active state for AXI interconnection and wait for acknowledge
    {write} PWRCTRL DDRC.MIREQ A = 0
    \{wait\} PWRSTAT_DDRC.MISTAT_A = 0
 Assert Soft-Reset of DLL (PHY) and pre-define frequency band setting
    \{write\}\ DLLCTRL = 0x000000005\ (DDR3)
    \{\text{write}\}\ DLLCTRL = 0x0000000D\ (DDR2)
(3) DDRPHY Configuration
 ZQCALCTRL register setting
    {write} ZQCALCTRL = 0x00000186 (Use termination)
    {write} ZQCALCTRL = 0x00000182 (No termination)
 ZQODTCTRL register setting
    {write} ZQODTCTRL = 0xAB330031 (DDR3)
    {write} ZQODTCTRL = 0xAB330070 (DDR2)
 RDCTRL register setting
    \{write\}\ RDCTRL = 0xB545B544\ (DDR3)
    \{write\}\ RDCTRL = 0x94449443\ (DDR2)
 RDTMG register setting
    \{write\}\ RDTMG = 0x000000B0\ (DDR3)
    \{write\}\ RDTMG = 0x000000A0\ (DDR2)
 Enable output for DDR CLKEN, DDR ODT and DDR RESET N
    {write} OUTCTRL = 0x020A0806
 Write Leveling Settings
    \{write\}\ WLCTRL1 = 0x80005556\ (DDR3)
    \{\text{write}\}\ \text{WLCTRL1} = 0\text{x}80005\text{C5D}\ (\text{DDR2})
 DQCALOFS1 register setting
    {write} DQCALOFS1 = 0x00004545
 De-Assert Soft-Reset of DLL (PHY) and define frequency band setting
    \{write\}\ DLLCTRL = 0x00000004\ (DDR3)
    \{write\}\ DLLCTRL = 0x0000000C\ (DDR2)
 De-Assert Soft-Reset of DDR (PHY) and define Voltage setting and Hi-Z mask
    \{write\}\ FUNCCTRL = 0x00180101\ (DDR3)
    \{\text{write}\}\ \text{FUNCCTRL} = 0\text{x}00200001\ (\text{DDR2})
 Initialize DDR (PHY) FIFO-pointer
    {write} FIFOINIT = 0x00000101
 Configuration for ZQ calibration
    \{\text{write}\}\ ZQCALCTRL = 0x00000187\ (\text{Use termination})
    {write} ZQCALCTRL = 0x00000183 (No termination)
 Wait more than 200 us, or wait until MDLL locked and ZQ calibration completed
    {wait} DLLCTRL.ASDLLOCK = 1
    {wait} ZQCALCTRL.ZQCALEND = 1
 Enable output also for Address and Command
    {write} OUTCTRL = 0x020A0807
```

Wait 200 us or more

(4) DDR (Ctrl) initialization

```
DDR Controller configuration
{write} DDR_CTL_00
{write} :
{write} DDR_CTL_87

AXI port setting
{write} DDR_CTL_87
{write} :
{write} DDR_CTL_349
{write} DDR_CTL_349
{write} DDR_CTL_374

PHY setting
{write} DDR_CTL_350
{write} :
{write} DDR_CTL_372

Start Initialization
{write} DDR_CTL_00.START = 1
```

#### Wait initialization complete

```
{wait} DDR_CTL_56.INT_STATUS[20] = 1 
{wait} DDR_CTL_56.INT_STATUS[8] = 1
```

Wait tXPR (DDR3) or 400 ns (DDR2)

Initialize DDR memory

Write Leveling Settings

 $\{write\}\ WLCTRL1 = 0x81005556\ (DDR3)$ 

{write} WLCTRL1 = 0x81005C5D (DDR2)

#### Section 7 NAND Flash Controller

Portions © Copyright Cadence Design System Inc 2012 to 2016. All right reserved worldwide. Used with permission.

#### 7.1 Overview

The NAND Flash Controller supports the functionality of the devices described in the ONFI 2.2 specifications, as well as older devices compatible with the ONFI 1.x specifications. The integrated BCH Error Correction Code (ECC) algorithm allows up to 32-bit error correction.

The correction ability and subpage size of the BCH component are programmable. The number of banks and the number of devices per bank that can be handled by the controller are one and four respectively.

- NAND interface with 8-bit bus width
- Compatible with ONFI 1.x and 2.x standards (RZ/N1 NAND Boot mode supports ONFI compliant memories only)
- Support for asynchronous mode
- 4 chip selects
- Support for 4 NAND Flash device per bank (4 Chip Selects)
- Write protection
- Programmable address cycle (0/1/2/3/4/5)
- Protected area size
- Integrated DMA
- Support for 256 B, 512 B, 2 KB, 1 KB, 4 KB, 8 KB, 16 KB pages
- BCH ECC algorithm for multiple errors (Error detection and data correction)
  - ECC data block size: 256 B, 512 B, 1024 B
  - ECC correction capability: 2, 4, 8, 16, 24, 32 bits errors
- Bad Block Management (BBM)



Figure 7.1 NAND Flash Controller Interfaces and Connections

# 7.2 Signal Interfaces

|                    | Input  |                                        |
|--------------------|--------|----------------------------------------|
| Signal Name        | Output | Description                            |
| Clock              |        |                                        |
| NAND_HCLK          | Input  | Internal bus clock (AHB)               |
| NAND_ECLK          | Input  | External Interface clock               |
| Interrupt          |        |                                        |
| NAND_Int           | Output | Level sensitive interrupt, Active High |
| External signal    |        |                                        |
| FNAND_CE_N[3:0]    | Output | Chip Enable, Active Low                |
| FNAND_IO[7:0]      | I/O    | Data                                   |
| FNAND_CLE          | Output | Command Latch Enable                   |
| FNAND_ALE          | Output | Address Latch Enable                   |
| FNAND_RE_N         | Output | Read Enable, Active Low                |
| FNAND_WE_N         | Output | Write Enable, Active Low               |
| FNAND_WP_N[3:0]    | Output | Write Protect/Reset                    |
| FNAND_RY/BY_N[3:0] | Input  | Ready/Busy (RnB), Ready=High, Busy=Low |

# 7.3 Register Map

Table 7.1 NAND Flash Controller Register Map

|                     | Tiden Controller Register Map |                                        |
|---------------------|-------------------------------|----------------------------------------|
| Address             | Register Symbol               | Register Name                          |
| 4010 2000h          | COMMAND                       | Command Register                       |
| 4010 2004h          | CONTROL                       | CONTROL Register                       |
| 4010 2008h          | STATUS                        | STATUS Register                        |
| 4010 200Ch          | STATUS_MASK                   | STATUS_MASK Register                   |
| 4010 2010h          | INT_MASK                      | INT_MASK Register                      |
| 4010 2014h          | INT_STATUS                    | INT_STATUS Register                    |
| 4010 2018h          | ECC_CTRL                      | ECC Control Register                   |
| 4010 201Ch          | ECC_OFFSET                    | ECC Offset Register                    |
| 4010 2020h          | ECC_STAT                      | ECC Status Register                    |
| 4010 2024h          | ADDR0_COL                     | Column Address 0 Register              |
| 4010 2028h          | ADDR0_ROW                     | Row Address 0 Register                 |
| 4010 202Ch          | ADDR1_COL                     | Column Address 1 Register              |
| 4010 2030h          | ADDR1_ROW                     | Row Address 1 Register                 |
| 4010 2034h          | PROTECT                       | Protect Register                       |
| 4010 2038h          | FIFO_DATA                     | FIFO Data Register                     |
| 4010 203Ch          | DATA_REG                      | Data Register                          |
| 4010 2040h          | DATA_REG_SIZE                 | DATA_REG_SIZE Register                 |
| 4010 2044h + 4h × n | $DEV[n]_PTR (n = 03)$         | Device [n] Remap Pointer Register      |
| 4010 2064h          | DMA_ADDR                      | DMA Address Register                   |
| 4010 206Ch          | DMA_CNT                       | DMA Counter Register                   |
| 4010 2070h          | DMA_CTRL                      | DMA Control Register                   |
| 4010 2074h          | BBM_CTRL                      | BBM Control Register                   |
| 4010 2080h          | MEM_CTRL                      | Memory Devices Control Register        |
| 4010 2084h          | DATA_SIZE                     | Data Size Register                     |
| 4010 2088h          | TIMINGS_ASYN                  | Asynchronous Mode Timings Register     |
| 4010 2090h          | TIME_SEQ_0                    | Command Sequence Timing Register 0     |
| 4010 2094h          | TIME_SEQ_1                    | Command Sequence Timing Register 1     |
| 4010 2098h          | TIME_GEN_SEQ_0                | Generic Command Sequence Register 0    |
| 4010 209Ch          | TIME_GEN_SEQ_1                | Generic Command Sequence Register 1    |
| 4010 20A0h          | TIME_GEN_SEQ_2                | Generic Command Sequence Register 2    |
| 4010 20B0h          | FIFO_INIT                     | FIFO Init Register                     |
| 4010 20B4h          | FIFO_STATE                    | FIFO Status Register                   |
| 4010 20B8h          | GEN_SEQ_CTRL                  | Generic Sequence Register              |
| 4010 20BCh          | MLUN                          | LUN Configuration Register             |
| 4010 20C0h + 4h x n | DEV[n]_SIZE (n = 03)          | Device [n] BBM Record Counter Register |
| 4010 2114h          | DMA_TLVL                      | DMA Trigger Level Register             |
| 4010 2124h          | CMD_MARK                      | CMD ID Initial Value                   |
| 4010 2128h          | LUN_STATUS_0                  | LUN Status Register                    |
| 4010 2134h          | TIME_GEN_SEQ_3                | Generic Command Sequence Register 3    |
| 4010 2148h          | INT_STAT                      | Internal Status Register               |
| 4010 214Ch          | ECC_CNT                       | ECC Error Counter                      |
| 4010 2150h          | PARAM_REG                     | PARAMETER Register                     |
|                     |                               | - <del>y</del> - · ·                   |

# 7.4 Register Description

Address:

# 7.4.1 COMMAND — Command Register

4010 2000h

The write of the command sequence code to this register triggers the programmed command sequence execution as soon as it is possible. If the execution cannot be started immediately, then the transfer to this register is prolonged by the series of the WAIT responses best suited for the selected system bus. Each command sequence can trigger the interrupt when it is completed.

b27 b31 b29 b28 b26 b25 b24 b23 b22 b21 b20 b19 b18 b17 b16 Bit b30 cmd\_2 cmd\_1\_cmd\_3 Value after reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 b10 b7 b6 Bit b15 b14 b13 b12 b11 b9 b8 b5 b4 b3 b2 b1 b0 data input cmd\_0 cmd\_seq \_sel \_sel 0 0 0 0 0 0 0 0 0 Value after reset 0

Table 7.2 COMMAND Register Contents

| Bit Position | Bit Name    | Function                                                                                           | R/W |
|--------------|-------------|----------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | cmd_2       | Code of the third command in a sequence                                                            | R/W |
| b23 to b16   | cmd_1_cmd_3 | Code of the second command in a sequence                                                           | R/W |
| b15 to b8    | cmd_0       | Code of the first command in a sequence                                                            | R/W |
| b7           | data_sel    | Data or FIFO selection flag 0: The FIFO module selected 1: The DATA register selected              | R/W |
| b6           | input_sel   | Input module selection flag  0: Select the AHBS module as input  1: Select the DMA module as input | R/W |
| b5 to b0     | cmd_seq     | Command code                                                                                       | R/W |

# 7.4.2 CONTROL — CONTROL Register

Address: 4010 2004h

| Bit               | b31 | b30     | b29    | b28      | b27 | b26 | b25 | b24 | b23                       | b22         | b21                | b20    | b19 | b18     | b17 | b16                 |
|-------------------|-----|---------|--------|----------|-----|-----|-----|-----|---------------------------|-------------|--------------------|--------|-----|---------|-----|---------------------|
|                   | _   | _       |        | ı        | _   | ı   |     |     | auto_re<br>ad_stat<br>_en | mlun_e<br>n | small_bl<br>ock_en | -      | I   |         |     | addr0_a<br>uto_incr |
| Value after reset | Х   | Х       | Х      | Х        | Х   | Х   | Х   | Х   | 0                         | 0           | 0                  | Х      | Х   | Х       | 0   | 0                   |
| Bit               | b15 | b14     | b13    | b12      | b11 | b10 | b9  | b8  | b7                        | b6          | b5                 | b4     | b3  | b2      | b1  | b0                  |
|                   | _   | prot_en | bbm_en | io_width | _   | _   | _   | _   | block                     | _size       | ecc_en             | int_en | -   | ecc_ble |     | read_st<br>atus_en  |
| Value after reset | Х   | 0       | 0      | 0        | Х   | Х   | Х   | Х   | 0                         | 0           | 0                  | 0      | Х   | 0       | 0   | 0                   |

Table 7.3 CONTROL Register Contents (1/2)

| Bit Position | Bit Name          | Function                                                                                                                                                                                                                | R/W |  |  |  |
|--------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|
| b31 to b24   | Reserved          |                                                                                                                                                                                                                         | R   |  |  |  |
| b23          | auto_read_stat_en | Auto Read Status mode enable                                                                                                                                                                                            |     |  |  |  |
|              |                   | If active, the controller reads the status after the PROGRAM PAGE and BLOCK ERASE commands. It can trigger interrupt. The ERROR_MASK field in the STATUS_MASK register must be configured when this feature is enabled. |     |  |  |  |
|              |                   | 0: Auto Read Status mode disabled                                                                                                                                                                                       |     |  |  |  |
|              |                   | 1: Auto Read Status mode enabled                                                                                                                                                                                        |     |  |  |  |
| b22          | mlun_en           | Multi LUN mode enable                                                                                                                                                                                                   | R/W |  |  |  |
|              |                   | 0: Multi LUN mode disabled                                                                                                                                                                                              |     |  |  |  |
|              |                   | 1: Multi LUN mode enabled                                                                                                                                                                                               |     |  |  |  |
| b21          | small_block_en    | Enable small block mode                                                                                                                                                                                                 | R/W |  |  |  |
|              |                   | In this mode, the controller sends only a single byte as the column address instead of two bytes, as done in the big block NAND Flash devices.                                                                          |     |  |  |  |
|              |                   | 0: Big block mode enabled                                                                                                                                                                                               |     |  |  |  |
|              |                   | 1: Small block mode enabled                                                                                                                                                                                             |     |  |  |  |
|              |                   | Caution) Only devices that allow to disable CE signal when device is in the busy<br>state are supported.                                                                                                                |     |  |  |  |
| b20 to b18   | Reserved          |                                                                                                                                                                                                                         | R   |  |  |  |
| b17          | addr1_auto_incr   | Address auto increment for row address register 1                                                                                                                                                                       |     |  |  |  |
|              |                   | 0: Auto increment disabled                                                                                                                                                                                              |     |  |  |  |
|              |                   | 1: Auto increment enabled                                                                                                                                                                                               |     |  |  |  |
|              |                   | When this bit is set, sending any command sequence using address register 1 causes the increment of address register 1                                                                                                  |     |  |  |  |
| b16          | addr0_auto_incr   | Address auto increment for row address register 0                                                                                                                                                                       | R/W |  |  |  |
|              |                   | 0: Auto increment disabled                                                                                                                                                                                              |     |  |  |  |
|              |                   | 1: Auto increment enabled                                                                                                                                                                                               |     |  |  |  |
|              |                   | When this bit is set, sending any command sequence using address register 0 causes the increment of address register 0                                                                                                  |     |  |  |  |
| b15          | Reserved          |                                                                                                                                                                                                                         | R   |  |  |  |
| b14          | prot_en           | Protect mechanism enable                                                                                                                                                                                                | R/W |  |  |  |
|              |                   | 0: Protect disabled                                                                                                                                                                                                     |     |  |  |  |
|              |                   | 1: Protect enabled                                                                                                                                                                                                      |     |  |  |  |
| b13          | bbm_en            | Bad Block Management enable                                                                                                                                                                                             | R/W |  |  |  |
|              |                   | For more details, see Section 7.5.6, Remapping Mechanism                                                                                                                                                                |     |  |  |  |
| b12          | io_width          | NAND Flash I/O width select                                                                                                                                                                                             | R/W |  |  |  |
|              | _                 | 0: 8 bits                                                                                                                                                                                                               |     |  |  |  |
|              |                   | 1: Reserved                                                                                                                                                                                                             |     |  |  |  |

| Table 7.3  | CONTROL  | Register Contents (2/2)  |  |
|------------|----------|--------------------------|--|
| I avic 1.0 | CONTINUE | Neulalei Cultellia (2/2) |  |

| Table 1.5    | CONTINUE Registe | Si Contento (2/2)                                                                                                              |     |  |  |
|--------------|------------------|--------------------------------------------------------------------------------------------------------------------------------|-----|--|--|
| Bit Position | Bit Name         | Function                                                                                                                       | R/W |  |  |
| b11 to b8    | Reserved         |                                                                                                                                | R   |  |  |
| b7, b6       | block_size       | Block size select                                                                                                              |     |  |  |
|              |                  | 2'b00: 32 pages per block                                                                                                      |     |  |  |
|              |                  | 2'b01: 64 pages per block                                                                                                      |     |  |  |
|              |                  | 2'b10: 128 pages per block                                                                                                     |     |  |  |
|              |                  | 2'b11: 256 pages per block                                                                                                     |     |  |  |
| b5           | ecc_en           | Hardware ECC support enable                                                                                                    | R/W |  |  |
|              |                  | 0: ECC disabled                                                                                                                |     |  |  |
|              |                  | 1: ECC enabled                                                                                                                 |     |  |  |
|              |                  | Hardware ECC can be used only when m x (ECC_BLOCK_SIZE) $\leq$ DATA_SIZE $\leq$ m x (ECC_BLOCK_SIZE + 32), where m is 1, 2, 3, |     |  |  |
| b4           | int_en           | Interrupt enables                                                                                                              | R/W |  |  |
|              |                  | 0: Interrupts disabled                                                                                                         |     |  |  |
|              |                  | 1: Interrupts enabled                                                                                                          |     |  |  |
| b3           | Reserved         |                                                                                                                                | R   |  |  |
| b2, b1       | ecc_block_size   | The ECC block size                                                                                                             | R/W |  |  |
|              |                  | 2'b00: 256 bytes                                                                                                               |     |  |  |
|              |                  | 2'b01: 512 bytes                                                                                                               |     |  |  |
|              |                  | 2'b10: 1024 bytes                                                                                                              |     |  |  |
|              |                  | 2'b11: Not available                                                                                                           |     |  |  |
|              |                  | The ECC block size can be changed only when all memory devices are ready.                                                      |     |  |  |
| b0           | read_status_en   | Automatically check RnB lines status                                                                                           | R/V |  |  |
|              |                  | The STATE_MASK field in the STATUS_MASK register must be configured when this feature is enabled.                              |     |  |  |
|              |                  | 0: The controller checks RnB lines                                                                                             |     |  |  |
|              |                  | 1: The Controller sends READ STATUS commands                                                                                   |     |  |  |
|              |                  | Caution) Automatically sent READ STATUS command is only available in devices<br>compatible with ONFI 1.0                       |     |  |  |

#### 7.4.3 STATUS — STATUS Register

This register stores the NAND Flash Controller and connected device status flags. These flags can be used by the system to obtain the current controller internal state.

The CTRL\_STAT flag is set after the controller starts to execute the requested command for the selected NAND Flash device, and it is active while the command execution is not completed. Command execution can be divided into two phases. In the first phase, the command sequence is executed at the moment when the NAND Flash device goes into the busy state. After that, the controller stores information about the pending operation on the selected device, but is also able to execute a new command on any other device. In the second phase, the controller automatically finishes the pending command execution based on the previously stored data. As long as this flag is set, the controller does not accept any new commands.

The MEM[n]\_ST flags correspond to the NAND Flash device with the same index value. The flags give information about the NAND Flash devices' state.



Table 7.4 STATUS Register Contents (1/2)

| Bit Position | Bit Name          | Function                                                                                | R/W |
|--------------|-------------------|-----------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved          |                                                                                         | R   |
| b23 to b16   | cmd_id            | Command id field                                                                        | R   |
| b15 to b11   | Reserved          |                                                                                         | R   |
| b10          | data_reg_st       | Data Reg status flag                                                                    | R   |
|              |                   | Resetting of this flag is possible only by reading the data from the DATA_REG register. |     |
|              |                   | 1: Data in DATA_REG is available                                                        |     |
|              |                   | 0: Data in DATA_REG is not available                                                    |     |
| b9           | datasize_error_st | The data size value error                                                               | R   |
|              |                   | When the ECC is enabled, this bit indicates incorrect value in the DATA_SIZE register   |     |
|              |                   | 0: Correct value                                                                        |     |
|              |                   | 1: Incorrect value                                                                      |     |
| b8           | ctrl_stat         | The main controller status bit                                                          | R   |
|              |                   | 0: Controller ready                                                                     |     |
|              |                   | 1: Controller busy                                                                      |     |
| b7 to b4     | Reserved          |                                                                                         | R   |
| b3           | mem3_st           | Device 3 status flag                                                                    | R   |
|              |                   | 1: Device ready                                                                         |     |
|              |                   | 0: Device busy                                                                          |     |
| b2           | mem2_st           | Device 2 status flag                                                                    | R   |
|              |                   | 1: Device ready                                                                         |     |
|              |                   | 0: Device busy                                                                          |     |

Table 7.4 STATUS Register Contents (2/2)

| Bit Position | Bit Name | Function             | R/W |
|--------------|----------|----------------------|-----|
| b1           | mem1_st  | Device 1 status flag | R   |
|              |          | 1: Device ready      |     |
|              |          | 0: Device busy       |     |
| b0           | mem0_st  | Device 0 status flag | R   |
|              |          | 1: Device ready      |     |
|              |          | 0: Device busy       |     |

#### 7.4.4 STATUS\_MASK — STATUS\_MASK Register

The state\_mask field is used to mark the ready/busy bits in the NAND Flash device status byte. This field is used during the internal read status operation. In the case of ONFI, the user must mask all fields except RDY or ARDY (depending on the application).

The error\_mask field is used to mask unused fields when the controller automatically reads the status of the NAND Flash memory device. In the case of ONFI, the user must mask all fields except FAIL or FAILC (depending on the application).



Table 7.5 STATUS\_MASK Register Contents

| Bit Position | Bit Name   | Function                                                                                      | R/W |
|--------------|------------|-----------------------------------------------------------------------------------------------|-----|
| b31 to b16   | Reserved   |                                                                                               | R   |
| b15 to b8    | error_mask | Error mask                                                                                    |     |
|              |            | Used to mask the error bits if automatic read status feature is enabled.                      |     |
|              |            | 0: Masked                                                                                     |     |
|              |            | 1: Unmasked                                                                                   |     |
| b7 to b0     | state_mask | State mask                                                                                    | R/W |
|              |            | Used to mask status bits when the read status command is used to obtain the NAND Flash status |     |
|              |            | 0: Masked                                                                                     |     |
|              |            | 1: Unmasked                                                                                   |     |

### 7.4.5 INT\_MASK — INT\_MASK Register

4010 2010h

This register allows masking of the selected interrupts source in the NAND Flash Controller. The masked interrupts still set the appropriate bits in the status register, but those changes do not trigger the interrupt.

Bit b29 b28 b26 b25 b20 b31 b30 b27 b24 b23 b22 b21 b19 b18 b17 b16 stat\_err stat\_err stat\_err stat\_err ecc\_int3ecc\_int2ecc\_int1 ecc\_int0 \_int2\_e \_en \_en \_en \_en n Χ Χ Χ Χ Χ Χ Χ 0 Value after reset Bit b15 b14 b13 b12 b11 b10 b9 b8 b7 b6 b5 b3 b2 b1 b0 b4 mem3\_rmem2\_rmem1\_rmem0\_r pg\_sz\_ data\_re cmd\_en dma\_int prot int dy\_int\_ err\_int\_ g\_int\_e d\_int\_e dy\_int\_ dy\_int\_ dy\_int\_ \_en Value after reset Χ Χ 0 Χ Χ Χ 0 0 Χ Χ 0 0

Table 7.6 INT\_MASK Register Contents (1/2)

| Bit Position | Bit Name         | Function                                                                                                                                                                                                                         | R/W |
|--------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b28   | Reserved         |                                                                                                                                                                                                                                  | R   |
| b27          | ecc_int3_en      | Enable the interrupt from the ECC module status for device 3 0: Interrupt disabled 1: Interrupt enabled                                                                                                                          | R/W |
| b26          | ecc_int2_en      | Enable the interrupt from the ECC module status for device 2 0: Interrupt disabled 1: Interrupt enabled                                                                                                                          | R/W |
| b25          | ecc_int1_en      | Enable the interrupt from the ECC module status for device 1 0: Interrupt disabled 1: Interrupt enabled                                                                                                                          |     |
| b24          | ecc_int0_en      | Enable the interrupt from the ECC module status for device 0  0: Interrupt disabled  1: Interrupt enabled                                                                                                                        |     |
| b23 to b20   | Reserved         |                                                                                                                                                                                                                                  | R   |
| b19          | stat_err_int3_en | Enable flag if most recently finished operation on the Memory device 3 failed applied to PROGRAM PAGE and BLOCK ERASE operations. It is not valid following a READ-series operation  0: Interrupt disabled  1: Interrupt enabled | R/W |
| b18          | stat_err_int2_en | Enable flag if most recently finished operation on the Memory device 2 failed applied to PROGRAM PAGE and BLOCK ERASE operations. It is not valid following a READ-series operation  0: Interrupt disabled  1: Interrupt enabled | R/W |
| b17          | stat_err_int1_en | Enable flag if most recently finished operation on the Memory device 1 failed applied to PROGRAM PAGE and BLOCK ERASE operations. It is not valid following a READ-series operation  0: Interrupt disabled 1: Interrupt enabled  | R/W |
| b16          | stat_err_int0_en | Enable flag if most recently finished operation on the Memory device 0 failed applied to PROGRAM PAGE and BLOCK ERASE operations. It is not valid following a READ-series operation  0: Interrupt disabled  1: Interrupt enabled | R/W |
| b15 to b12   | Reserved         |                                                                                                                                                                                                                                  | R   |

| Table 7.6 | INIT | NANCI | Dogiotor | Contents | (2)(2) |
|-----------|------|-------|----------|----------|--------|
| Table / b | 1171 | MASK  | Redister | Comenis  | (///)  |
|           |      |       |          |          |        |

| Bit Position | Bit Name         | Function                                         | R/W |
|--------------|------------------|--------------------------------------------------|-----|
| b11          | mem3_rdy_int_en  | The memory device 3 is ready for the new command | R/W |
|              |                  | 0: Interrupt disabled                            |     |
|              |                  | 1: Interrupt enabled                             |     |
| b10          | mem2_rdy_int_en  | The memory device 2 is ready for the new command | R/W |
|              |                  | 0: Interrupt disabled                            |     |
|              |                  | 1: Interrupt enabled                             |     |
| b9           | mem1_rdy_int_en  | The memory device 1 is ready for the new command | R/W |
|              |                  | 0: Interrupt disabled                            |     |
|              |                  | 1: Interrupt enabled                             |     |
| b8           | mem0_rdy_int_en  | The memory device 0 is ready for the new command | R/W |
|              |                  | 0: interrupt disabled                            |     |
|              |                  | 1: interrupt enabled                             |     |
| b7           | Reserved         |                                                  | R   |
| b6           | pg_sz_err_int_en | Data size error occur                            | R/W |
|              |                  | 0: Interrupt disabled                            |     |
|              |                  | 1: Interrupt enabled                             |     |
| b5, b4       | Reserved         |                                                  | R   |
| b3           | dma_int_en       | DMA transfer ended                               | R/W |
|              |                  | 0: Interrupt disabled                            |     |
|              |                  | 1: Interrupt enabled                             |     |
| b2           | data_reg_int_en  | data in data_reg is available                    | R/W |
|              |                  | 0: Interrupt disabled                            |     |
|              |                  | 1: Interrupt enabled                             |     |
| b1           | cmd_end_int_en   | Command sequence ended                           | R/W |
|              |                  | 0: Interrupt disabled                            |     |
|              |                  | 1: Interrupt enabled                             |     |
| b0           | prot_int_en      | Erase or Write protected area interrupt enable   | R/W |
|              |                  | 0: Interrupt disabled                            |     |
|              |                  | 1: Interrupt enabled                             |     |

#### 7.4.6 INT\_STATUS — INT\_STATUS Register

4010 2014h

This register stores the NAND Flash Controller interrupt flags. If the given bit has the logical '0' value, then the corresponding interrupt condition is not met. If the given bit has the logical '1' value, then the corresponding interrupt condition is met.

b24 Bit b31 b30 b29 b28 b27 b26 b25 b23 b22 b21 b20 b19 b18 b17 b16 ecc\_int0 ecc\_int3 ecc\_int2ecc\_int1 stat\_err stat\_err stat\_err stat\_err \_fl \_int3\_fl \_int2\_fl \_int1\_fl \_int0\_fl \_fl \_fl Value after reset Х Χ Χ 0 0 0 Χ Χ Χ 0 0 Bit b15 b12 b10 b7 b6 b14 b13 b11 b9 b8 b5 b4 b3 b2 b1 b0 pg\_sz\_ mem3\_rmem2\_rmem1\_rmem0\_r dma\_int data\_re cmd\_en prot\_int err\_int\_t g\_int\_fl d\_int\_fl dy\_int\_fldy\_int\_fldy\_int\_fldy\_int\_f Χ Χ Χ 0 Χ 0 0 Value after reset

Table 7.7 INT\_STATUS Register Contents

| Bit Position | Bit Name         | Function                                                                                                                                                                         | R/W |
|--------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b28   | Reserved         |                                                                                                                                                                                  | R   |
| b27          | ecc_int3_fl      | Interrupt flag in the ECC module is set for device 3                                                                                                                             | R/W |
| b26          | ecc_int2_fl      | Interrupt flag in the ECC module is set for device 2                                                                                                                             | R/W |
| b25          | ecc_int1_fl      | Interrupt flag in the ECC module is set for device 1                                                                                                                             | R/W |
| b24          | ecc_int0_fl      | Interrupt flag in the ECC module is set for device 0                                                                                                                             | R/W |
| b23 to b20   | Reserved         |                                                                                                                                                                                  | R   |
| b19          | stat_err_int3_fl | Interrupt flag for most recently finished operation on the device 3 failed applies to PROGRAM PAGE and BLOCK ERASE operations. It is not valid following a READ-series operation | R/W |
| b18          | stat_err_int2_fl | Interrupt flag for most recently finished operation on the device 2 failed applies to PROGRAM PAGE and BLOCK ERASE operations. It is not valid following a READ-series operation | R/W |
| b17          | stat_err_int1_fl | Interrupt flag for most recently finished operation on the device 1 failed applies to PROGRAM PAGE and BLOCK ERASE operations. It is not valid following a READ-series operation | R/W |
| b16          | stat_err_int0_fl | Interrupt flag for most recently finished operation on the device 0 failed applies to PROGRAM PAGE and BLOCK ERASE operations. It is not valid following a READ-series operation | R/W |
| b15 to b12   | Reserved         |                                                                                                                                                                                  | R   |
| b11          | mem3_rdy_int_fl  | The memory device 3 is ready for the new command interrupt flag                                                                                                                  | R/W |
| b10          | mem2_rdy_int_fl  | The memory device 2 is ready for the new command interrupt flag                                                                                                                  | R/W |
| b9           | mem1_rdy_int_fl  | The memory device 1 is ready for the new command interrupt flag                                                                                                                  | R/W |
| b8           | mem0_rdy_int_fl  | The memory device 0 is ready for the new command interrupt flag                                                                                                                  | R/W |
| b7           | Reserved         |                                                                                                                                                                                  | R   |
| b6           | pg_sz_err_int_fl | Data size error occur interrupt flag                                                                                                                                             | R/W |
| b5, b4       | Reserved         |                                                                                                                                                                                  | R   |
| b3           | dma_int_fl       | DMA transfer ended interrupt flag                                                                                                                                                | R/W |
| b2           | data_reg_int_fl  | data in data_reg is available interrupt flag                                                                                                                                     | R/W |
| b1           | cmd_end_int_fl   | Command sequence ended interrupt flag                                                                                                                                            | R/W |
| b0           | prot_int_fl      | Erase or Write protected area interrupt flag                                                                                                                                     | R/W |

0

#### ECC\_CTRL — ECC Control Register 7.4.7

4010 2018h

This register stores all configuration parameters required by the ECC. The ECC\_CAP field is only available if the BCH ECC module with software configurable correction factor is selected.

Bit b31 b29 b28 b26 b25 b23 b21 b20 b19 b17 b16 b30 b27 b24 b22 b18 ecc\_sel Value after reset Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ 0 Bit b15 b14 b13 b12 b11 b10 b9 b8 b7 b6 b5 b4 b3 b2 b1 b0 err\_threshold ecc\_cap Value after reset Χ Χ 0 0 Χ Χ Χ Χ Χ 0

0

0

Table 7.8 ECC\_CTRL Register Contents

| Bit Position | Bit Name      | Function                                                                                                                           | R/W |
|--------------|---------------|------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b18   | Reserved      |                                                                                                                                    | R   |
| b17, b16     | ecc_sel       | The ECC interrupt source select                                                                                                    | R/W |
|              |               | This signal selects the ECC module flag that will be used as a source for the interrupt signal:                                    |     |
|              |               | 2'b00: Select ECC_ERROR (correctable error) flag as interrupt source.                                                              |     |
|              |               | 2'b01: Select ECC_UNC (uncorrectable error) flag as interrupt source.                                                              |     |
|              |               | 2'b1x: Select ECC_OVER (acceptable errors level overflow) flag as interrupt                                                        |     |
|              |               | source.                                                                                                                            |     |
| b15, b14     | Reserved      |                                                                                                                                    | R   |
| b13 to b8    | err_threshold | The acceptable errors level                                                                                                        | R/W |
|              |               | The value of this field contains the number of errors that is acceptable for software. This field must be initialized by software. |     |
| b7 to b3     | Reserved      |                                                                                                                                    | R   |
| b2 to b0     | ecc_cap       | Correction ability.                                                                                                                | R/W |
|              |               | The correction ability can be changed only when all memory devices are ready.                                                      |     |
|              |               | 3'b000: 2                                                                                                                          |     |
|              |               | 3'b001: 4                                                                                                                          |     |
|              |               | 3'b010: 8                                                                                                                          |     |
|              |               | 3'b011: 16                                                                                                                         |     |
|              |               | 3'b100: 24                                                                                                                         |     |
|              |               | 3'b101: 32                                                                                                                         |     |
|              |               | Values other than those above select the 32 correction ability.                                                                    |     |

### 7.4.8 ECC\_OFFSET — ECC Offset Register

This register stores the offset value from the beginning of the page to the place where correction words will be stored.

The value of this register must be bigger than the value in the DATA\_SIZE register.

In small block mode, the value in the ECC\_OFFSET is ignored, and the correction words are located in the NAND Flash memory device just behind the data.

4010 201Ch Address: Bit b31 b30 b29 b28 b27 b26 b25 b24 b23 b22 b21 b20 b19 b18 b17 b16 Value after reset Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Bit b15 b14 b13 b12 b11 b10 b9 b8 b7 b6 b5 b4 b3 b1 b0 ecc\_offset 0 0 0 0 0 0 0 0 Value after reset 0 0 0 0 0 0 0

Table 7.9 ECC\_OFFSET Register Contents

| Bit Position | Bit Name   | Function                      | R/W |
|--------------|------------|-------------------------------|-----|
| b31 to b16   | Reserved   |                               | R   |
| b15 to b0    | ecc_offset | Correction words block offset | R/W |

# 7.4.9 ECC\_STAT — ECC Status Register

This register stores all the ECC module status information.

Address: 4010 2020h



Table 7.10 ECC\_STAT Register Contents

| Bit Position | Bit Name    | Function                                                                                                                                                 | R/W |
|--------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b20   | Reserved    |                                                                                                                                                          | R   |
| b19          | ecc_over_3  | The Memory device 3 acceptable errors level overflow  The bit is set when the number of errors is bigger than the value of declared  ERR_THRESHOLD bits. | R/W |
| b18          | ecc_over_2  | The Memory device 2 acceptable errors level overflow  The bit is set when the number of errors is bigger than the value of declared ERR_THRESHOLD bits.  | R/W |
| b17          | ecc_over_1  | The Memory device 1 acceptable errors level overflow  The bit is set when the number of errors is bigger than the value of declared ERR_THRESHOLD bits.  | R/W |
| b16          | ecc_over_0  | The Memory device 0 acceptable errors level overflow  The bit is set when the number of errors is bigger than the value of declared ERR_THRESHOLD bits.  | R/W |
| b15 to b12   | Reserved    |                                                                                                                                                          | R   |
| b11          | ecc_unc_3   | The Memory device 3 uncorrectable error flag  The bit is set when the uncorrectable errors occur during the read operation.                              | R/W |
| b10          | ecc_unc_2   | The Memory device 2 uncorrectable error flag  The bit is set when the uncorrectable errors occur during the read operation.                              | R/W |
| b9           | ecc_unc_1   | The Memory device 1 uncorrectable error flag  The bit is set when the uncorrectable errors occur during the read operation.                              | R/W |
| b8           | ecc_unc_0   | The Memory device 0 uncorrectable error flag  The bit is set when the uncorrectable errors occur during the read operation.                              | R/W |
| b7 to b4     | Reserved    |                                                                                                                                                          | R   |
| b3           | ecc_error_3 | The Memory device 3 correctable error flag  The bit is set when the correctable errors occur during the read operation.                                  | R/W |
| b2           | ecc_error_2 | The Memory device 2 correctable error flag  The bit is set when the correctable errors occur during the read operation.                                  | R/W |
| b1           | ecc_error_1 | The Memory device 1 correctable error flag  The bit is set when the correctable errors occur during the read operation.                                  | R/W |
| b0           | ecc_error_0 | The Memory device 0 correctable error flag  The bit is set when the correctable errors occur during the read operation.                                  | R/W |

# 7.4.10 ADDR0\_COL — Column Address 0 Register

Address: 4010 2024h



Table 7.11 ADDR0\_COL Register Contents

| Bit Position | Bit Name  | Function                                                                                        | R/W |
|--------------|-----------|-------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | Reserved  |                                                                                                 | R   |
| b15 to b0    | addr0_col | Column address                                                                                  | R/W |
|              |           | For detailed description refer to <b>Section 7.8.1, ADDR[n]_COL and ADDR[n]_ROW Registers</b> . |     |

# 7.4.11 ADDR0\_ROW — Row Address 0 Register

**Address:** 4010 2028h



Table 7.12 ADDR0\_ROW Register Contents

| Bit Position | Bit Name  | Function                                                                                                            | R/W |
|--------------|-----------|---------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved  |                                                                                                                     | R   |
| b23 to b0    | addr0_row | Row address For detailed description refer to <b>Section 7.8.1</b> , <b>ADDR[n]_COL and ADDR[n]_ROW Registers</b> . | R/W |

# 7.4.12 ADDR1\_COL — Column Address 1 Register

Address: 4010 202Ch



Table 7.13 ADDR1\_COL Register Contents

| Bit Position | Bit Name  | Function                                                                                               | R/W |
|--------------|-----------|--------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | Reserved  |                                                                                                        | R   |
| b15 to b0    | addr1_col | Column address For detailed description refer to Section 7.8.1, ADDR[n]_COL and ADDR[n]_ROW Registers. | R/W |

# 7.4.13 ADDR1\_ROW — Row Address 1 Register

Address: 4010 2030h



Table 7.14 ADDR1\_ROW Register Contents

| Bit Position | Bit Name  | Function                                                                                                            | R/W |
|--------------|-----------|---------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved  |                                                                                                                     | R   |
| b23 to b0    | addr1_row | Row address For detailed description refer to <b>Section 7.8.1</b> , <b>ADDR[n]_COL and ADDR[n]_ROW Registers</b> . | R/W |

#### 7.4.14 PROTECT — Protect Register

The NAND Flash Controller allows the defining of the area that will be protected against any modifications.

The protected area is a space which cannot be erased or overwritten. Any attempt to erase/overwrite this space always ends with an error. Since write and erase processes have constraints (only Page can be written and only Block can be erased), the protected area can be defined with Block-size precision. This register's lower bits [15:0] define the beginning address of the protected area and are related to the NAND Flash memory block address bits of ADDR0\_ROW and ADDR1\_ROW registers. This register higher bits [31:16] define the ending address of the protected area and are related to the NAND Flash memory block address bits of ADDR0\_ROW and ADDR1\_ROW registers. Please refer to **Section 7.8.2, Protect Register (PROTECT)** how this register fields are used to define the protected area.



Table 7.15 PROTECT Register Contents

| Bit Position | Bit Name  | Function                 | R/W |
|--------------|-----------|--------------------------|-----|
| b31 to b16   | prot_up   | Protect area upper limit | R/W |
| b15 to b0    | prot_down | Protect area lower limit | R/W |

#### 7.4.15 FIFO\_DATA — FIFO Data Register

This register is used as an entry point to the FIFO module for the AHBS module. The CPU can access the FIFO module by reading or writing to this register in the same way as it accesses any other registers. The FIFO module works on 32-bit words, thus when this register is accessed from the narrower bus, then:

- For the read operation, the access to the lowest byte triggers the word read from the FIFO module. If the requested data is narrower than the FIFO word size, then the read word is stored for further access. If the read request does not strobe the lowest byte, then the previously stored data is used instead, triggering new access to the FIFO.
- For the write operation, the situation is almost the same. Only the request that strobes the lowest byte triggers the write access to the FIFO module. Any other requests cause only write to the temporary register used for further access to the FIFO module.



Table 7.16 FIFO\_DATA Register Contents

| Bit Position | Bit Name  | Function                         | R/W |
|--------------|-----------|----------------------------------|-----|
| b31 to b0    | fifo_data | The data FIFO interface register | R/W |

### 7.4.16 DATA\_REG — Data Register

This register is used for storage of the data that is read in the registered mode. The registered mode is allowed in the read direction only.



Table 7.17 DATA\_REG Register Contents

| Bit Position | Bit Name | Function          | R/W |
|--------------|----------|-------------------|-----|
| b31 to b0    | data_reg | The data register | R   |

#### 7.4.17 DATA\_REG\_SIZE — DATA\_REG\_SIZE Register

4010 2040h

This register allows the selection of data size in the registered work mode. The data size in the registered mode is limited to four bytes.

Bit b29 b28 b26 b25 b24 b23 b21 b20 b19 b17 b16 b31 b30 b27 b22 b18 Χ Χ Χ Value after reset Χ Χ Χ Χ Χ Χ Χ Χ Χ Х Χ Χ Bit b15 b13 b12 b10 b7 b6 b3 b0 b14 b11 b9 b8 b5 b4 b2 b1 data\_reg\_size Value after reset Χ Χ Χ Χ Χ Χ Χ Χ Χ Х Χ Χ Χ Х 0 0

Table 7.18 DATA\_REG\_SIZE Register Contents

| Bit Position | Bit Name      | Function                                                     | R/W |
|--------------|---------------|--------------------------------------------------------------|-----|
| b31 to b2    | Reserved      |                                                              | R   |
| b1, b0       | data_reg_size | selection of the number of valid bytes in the DATA register: | R/W |
|              |               | 2'b00: Single byte valid                                     |     |
|              |               | 2'b01: Two lower bytes valid                                 |     |
|              |               | 2'b10: Three lower bytes valid                               |     |
|              |               | 2'b11: All four bytes valid                                  |     |

### 7.4.18 DEV[n]\_PTR — Device [n] Remap Pointer Register (n = 0..3)

The bad block management mechanism implemented in the controller uses the tables in the system memory to store the remapping records. Each device in the bank requires a separate table. This register stores the table of the remapping records address for the device [n].

b25 Bit b31 b30 h29 b28 b27 b26 b24 b23 b22 b21 b20 b19 b18 b17 b16 ptr\_addr 0 Value after reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 Bit b15 b14 b13 b12 b11 b10 b9 b8 b7 b6 b5 b4 b3 b2 b1 b0 ptr\_addr Value after reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Table 7.19 DEV[n]\_PTR Register Contents

Address:

4010 2044h + 4h × n

| Bit Position | Bit Name | Function                                                               | R/W |
|--------------|----------|------------------------------------------------------------------------|-----|
| b31 to b0    | ptr_addr | The remap table pointer                                                | R/W |
|              |          | The field contains an address of the remap table in the system memory. |     |

0

0

#### 7.4.19 DMA\_ADDR — DMA Address Register

4010 2064h

This register defines the DMA base address. The two least significant bits are ignored.

0

0

Bit b31 b30 b29 b27 b26 b25 b24 b23 b22 b21 b20 b19 b18 b17 b16 dma\_addr\_l 0 0 0 0 0 0 0 0 0 0 Value after reset 0 0 0 0 b15 b13 b12 b11 b10 b7 b6 b5 b3 b0 dma\_addr\_l

Table 7.20 DMA\_ADDR Register Contents

0

Value after reset

| Bit Position | Bit Name   | Function        | R/W |
|--------------|------------|-----------------|-----|
| b31 to b0    | dma_addr_l | The DMA address | R/W |

0

0

0

0

0

0

0

0

### 7.4.20 DMA\_CNT — DMA Counter Register

0

This register defines the number of bytes that will be transferred by the DMA module. The register remains unchanged during the transfer process.

**Address:** 4010 206Ch



Table 7.21 DMA\_CNT Register Contents

| Bit Position | Bit Name | Function                                                                | R/W |
|--------------|----------|-------------------------------------------------------------------------|-----|
| b31 to b0    | cnt_init | Bytes counter initial value                                             | R/W |
|              |          | The field contains data page length in bytes (0000_0004h - FFFF_FFFCh). |     |
|              |          | The number of the bytes has to be divided by 4.                         |     |

# 7.4.21 DMA\_CTRL — DMA Control Register

Address: 4010 2070h



Table 7.22 DMA\_CTRL Register Contents

| Bit Position | Bit Name  | Function                                                                                    | R/W |
|--------------|-----------|---------------------------------------------------------------------------------------------|-----|
| b31 to b8    | Reserved  |                                                                                             | R   |
| b7           | dma_start | The DMA start                                                                               | R/W |
|              |           | Set bit DMA_START to start DMA when the command sequence is sent to the NAND Flash memory.  |     |
| b6           | Reserved  |                                                                                             | R   |
| b5           | dma_mode  | The DMA work mode                                                                           | R/W |
|              |           | 0: The register-s managed mode                                                              |     |
|              |           | 1: The Scatter-Gather mode                                                                  |     |
| b4 to b2     | dma_burst | The DMA burst type                                                                          | R/W |
|              |           | These bits define the main transfer type used by the DMA to precede the requested transfer. |     |
|              |           | 3'b000: Incrementing burst of four transfers (address increment, fixed length)              |     |
|              |           | 3'b001: Address constant burst of sixteen transfers (fixed length)                          |     |
|              |           | 3'b010: Single transfer (address increment)                                                 |     |
|              |           | 3'b011: Burst of unspecified length (address increment)                                     |     |
|              |           | 3'b100: Incrementing burst of eight transfers (address increment, fixed length)             |     |
|              |           | 3'b101: Incrementing burst of sixteen transfers (address increment, fixed length)           |     |
| b1           | err_flag  | The DMA error flag                                                                          | R   |
|              |           | The flag is set when a transmission error occurs during the DMA transfer.                   |     |
| b0           | dma_ready | The DMA ready flag                                                                          | R   |
|              |           | The flag is set when transfer is completed.                                                 |     |

# 7.4.22 BBM\_CTRL — BBM Control Register

Address: 4010 2074h



Table 7.23 BBM\_CTRL Register Contents

| Bit Position | Bit Name | Function                                                                                              | R/W |
|--------------|----------|-------------------------------------------------------------------------------------------------------|-----|
| b31 to b1    | Reserved |                                                                                                       | R   |
| b0           | rmp_init | Remap initial flag                                                                                    | R/W |
|              |          | If set this flag force the BBM module to reread the remapping table after it was updated by software. |     |
|              |          | This flag is set by software and cleared by hardware.                                                 |     |

# 7.4.23 MEM\_CTRL — Memory Devices Control Register

This register stores the set of configuration parameters that are used to select the destination NAND Flash device for the current transfer and the write protect signal for each device.



Table 7.24 MEM\_CTRL Register Contents

| Bit Position | Bit Name | Function                                      | R/W |
|--------------|----------|-----------------------------------------------|-----|
| b31 to b12   | Reserved |                                               | R   |
| b11          | mem3_wp  | The memory device 3 WP line                   | R/W |
|              |          | The setting value is output to FNAND_WP_N[3]. |     |
| b10          | mem2_wp  | The memory device 2 WP line                   | R/W |
|              |          | The setting value is output to FNAND_WP_N[2]. |     |
| b9           | mem1_wp  | The memory device 1 WP line                   | R/W |
|              |          | The setting value is output to FNAND_WP_N[1]. |     |
| b8           | mem0_wp  | The memory device 0 WP line                   | R/W |
|              |          | The setting value is output to FNAND_WP_N[0]. |     |
| b7 to b2     | Reserved |                                               | R   |
| b1, b0       | mem_ce   | The memory device select field                | R/W |
|              |          | 2'b00: Memory device 0                        |     |
|              |          | 2'b01: Memory device 1                        |     |
|              |          | 2'b10: Memory device 2                        |     |
|              |          | 2'b11: Memory device 3                        |     |

#### 7.4.24 DATA\_SIZE — Data Size Register

This register stores the value of the data block size. The data size value is remembered as the number of bytes per transferred block, but its size must be declared as the multiple of the chosen NAND Flash word size. The unused bits for the given word size configuration are ignored and replaced with zeros.



Table 7.25 DATA\_SIZE Register Contents

| Bit Position | Bit Name  | Function  | R/W |
|--------------|-----------|-----------|-----|
| b31 to b15   | Reserved  |           | R   |
| b14 to b0    | data_size | Data size | R/W |

Caution) Write the proper value when ECC is enabled: (ECC\_BLOCK\_SIZE) x m ≤ data\_size ≤ (ECC\_BLOCK\_SIZE +32) x m, where m is 1,2,3...

#### 7.4.25 TIMINGS\_ASYN — Asynchronous Mode Timings Register

The NAND Flash Controller is intended for use with a wide range of host clock rates. To maximize flexibility, some timing parameters are configurable. Two waveform configuration parameters are defined in this register. The value generated by the controller equals the minimum value written into the register, increased by 1. All the timings are generated using the NAND\_ECLK clock signal.

Please refer to **Section 7.8.3, Asynchronous Mode Timings Register (TIMINGS\_ASYN)** how timing parameters are mapped to the NAND Flash interface.



Table 7.26 TIMINGS\_ASYN Register Contents

| Bit Position | Bit Name | Function                    | R/W |
|--------------|----------|-----------------------------|-----|
| b31 to b8    | Reserved |                             | R   |
| b7 to b4     | trwh     | RE_N or WE_N high hold time | R/W |
| b3 to b0     | trwp     | RE_N or WE_N pulse width    | R/W |

4010 2090h

### 7.4.26 TIME\_SEQ\_0 — Command Sequence Timing Register 0

The NAND Flash Controller is intended for use with a wide range of host clock rates. To maximize flexibility, some timing parameters are configurable. Some waveform configuration parameters are defined in this register. The value generated by the controller equals the minimum value written into the register, increased by 1. All the timings are generated using the NAND\_ECLK clock signal.

b31 b29 b27 b26 b25 b23 b22 b21 b20 b19 b17 b16 Bit b30 b28 b24 b18 twhr trhw Value after reset Χ 0 0 0 0 0 Χ Χ 0 0 0 0 0 0 b13 b12 b10 b7 Bit b15 b14 b11 b9 b8 b6 b5 b4 b3 b2 b1 b0 tadl tccs Value after reset Χ 0 Χ Χ 0

Table 7.27 TIME\_SEQ\_0 Register Contents

| Bit Position | Bit Name | Function                   | R/W |
|--------------|----------|----------------------------|-----|
| b31, b30     | Reserved |                            | R   |
| b29 to b24   | twhr     | WE_N high to RE_N low time | R/W |
| b23, b22     | Reserved |                            | R   |
| b21 to b16   | trhw     | RE_N high to WE_N low time | R/W |
| b15, b14     | Reserved |                            | R   |
| b13 to b8    | tadl     | ALE to data start time     | R/W |
| b7, b6       | Reserved |                            | R   |
| b5 to b0     | tccs     | Change column setup        | R/W |

#### 7.4.27 TIME\_SEQ\_1 — Command Sequence Timing Register 1

The NAND Flash Controller is intended for use with a wide range of host clock rates. To maximize flexibility, some timing parameters are configurable. Some waveform configuration parameters are defined in this register. The value generated by the controller equals the minimum value written into the register, increased by 1. All the timings are generated using the NAND\_ECLK clock signal.

Please refer to **Section 7.8.4, Command Sequence Timing Register 1 (TIME\_SEQ\_1)** how the tWW timing parameter is mapped to the NAND Flash interface.

b31 b27 b26 b25 b23 b22 b21 b20 b19 Bit b30 b29 b28 b24 b18 b17 b16 tww Value after reset Χ Χ Х Χ Х Χ Χ Χ Χ Χ 0 0 0 0 0 0 Bit b15 b13 b12 b11 b10 b9 b8 b7 b6 b5 b4 b3 b0 b14 b2 b1 trr twb Value after reset Χ 0 0 0 0 0 0 Χ Χ 0 0 0 0 0 0

Table 7.28 TIME\_SEQ\_1 Register Contents

Address:

4010 2094h

| Bit Position | Bit Name | Function                                                                                                                       | R/W |
|--------------|----------|--------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b22   | Reserved |                                                                                                                                | R   |
| b21 to b16   | tww      | Delay time between WP_N change and command drive                                                                               | R/W |
|              |          | This field is used to parameterize the tWW delay.                                                                              |     |
| b15, b14     | Reserved |                                                                                                                                | R   |
| b13 to b8    | trr      | RnB high to RE_N low                                                                                                           | R/W |
|              |          | TRR time period from rising edge on RnB input line to the moment when the read enable signal can be asserted.                  |     |
| b7, b6       | Reserved |                                                                                                                                | R   |
| b5 to b0     | twb      | tWB delay                                                                                                                      | R/W |
|              |          | Time period measured from rising edge of the WE_N signal to a falling edge on the RnB line or the NAND Flash device SR[6] low. |     |

#### 7.4.28 TIME\_GEN\_SEQ\_0 — Generic Command Sequence Register 0

The NAND Flash Controller is intended for use with a wide range of host clock rates. To maximize flexibility, some timing parameters are configurable. Some waveform configuration parameters for the Generic Sequence are defined in this register. The value generated by the controller equals the minimum value written into the register, increased by 1. All the timings are generated using the NAND\_ECLK clock signal. For more detail, refer to Section 7.5.3, Generic **Command Sequence.** 

Address: Bit b31 b28 b27 b26 b25 b23 b22 b20 b19 b17 b16 b30 b29 b24 b21 b18 t0\_d3 t0\_d2 Χ 0 0 0 0 0 Χ Χ 0 0 0 Value after reset 0 0 Bit b15 b13 b12 b11 b10 h7 b6 b5 b3 b2 b0 b14 h9 b8 b4 t0\_d1 t0\_d0 Value after reset Х 0 0 0 0 0

Table 7.29 TIME\_GEN\_SEQ\_0 Register Contents

4010 2098h

| Bit Position | Bit Name | Function                                                                                                 | R/W |
|--------------|----------|----------------------------------------------------------------------------------------------------------|-----|
| b31, b30     | Reserved |                                                                                                          | R   |
| b29 to b24   | t0_d3    | Command to data time                                                                                     | R/W |
|              |          | The time between sending a command and data transferring                                                 |     |
| b23, b22     | Reserved |                                                                                                          | R   |
| b21 to b16   | t0_d2    | Command to delay time                                                                                    | R/W |
|              |          | The time between sending a command to the NAND Flash memory device and waiting until the memory is ready | I   |
| b15, b14     | Reserved |                                                                                                          | R   |
| b13 to b8    | t0_d1    | Command to command time                                                                                  | R/W |
|              |          | The time between two subsequent commands sent to the NAND Flash memory device.                           |     |
| b7, b6       | Reserved |                                                                                                          | R   |
| b5 to b0     | t0_d0    | Command to address time                                                                                  | R/W |
|              |          | The time between sending a command and sending the address to the NAND Flash memory device.              |     |

#### 7.4.29 TIME\_GEN\_SEQ\_1 — Generic Command Sequence Register 1

The NAND Flash Controller is intended for use with a wide range of host clock rates. To maximize flexibility, some timing parameters are configurable. Some waveform configuration parameters for the Generic Sequence are defined in this register. The value generated by the controller equals the minimum value written into the register, increased by 1. All the timings are generated using the NAND\_ECLK clock signal. For more detail, refer to Section 7.5.3, Generic **Command Sequence.** 

Address: b28 Bit b31 b27 b26 b25 b23 b22 b20 b19 b17 b16 b30 b29 b24 b21 b18 t0\_d7 t0\_d6 Χ 0 0 0 0 0 Χ Χ 0 0 0 Value after reset 0 0 Bit b15 b13 b12 b11 b10 h7 b6 b5 b3 b2 b0 b14 h9 b8 b4 t0\_d5 t0\_d4 Value after reset 0 0 0 0 0 0 0

**Table 7.30** TIME\_GEN\_SEQ\_1 Register Contents

4010 209Ch

| Bit Position | Bit Name | Function                                                                                                   | R/W |
|--------------|----------|------------------------------------------------------------------------------------------------------------|-----|
| b31, b30     | Reserved |                                                                                                            | R   |
| b29 to b24   | t0_d7    | Address to data time                                                                                       | R/W |
|              |          | The time between sending the address and data transferring                                                 |     |
| b23, b22     | Reserved |                                                                                                            | R   |
| b21 to b16   | t0_d6    | Address to delay time                                                                                      | R/W |
|              |          | The time between sending the address to the NAND Flash memory device and waiting until the memory is ready | 1   |
| b15, b14     | Reserved |                                                                                                            | R   |
| b13 to b8    | t0_d5    | Address to address time                                                                                    | R/W |
|              |          | The time between two subsequent addresses sent to the NAND Flash memory device                             | -   |
| b7, b6       | Reserved |                                                                                                            | R   |
| b5 to b0     | t0_d4    | Address to command time                                                                                    | R/W |
|              |          | The time between sending the address and the command to the NAND Flash memory device                       |     |

4010 20A0h

### 7.4.30 TIME\_GEN\_SEQ\_2 — Generic Command Sequence Register 2

The NAND Flash Controller is intended for use with a wide range of host clock rates. To maximize flexibility, some timing parameters are configurable. Some waveform configuration parameters for the Generic Sequence are defined in this register. The value generated by the controller equals the minimum value written into the register, increased by 1. All the timings are generated using the NAND\_ECLK clock signal. For more detail, refer to **Section 7.5.3, Generic Command Sequence**.

Bit b31 b28 b27 b26 b25 b23 b22 b20 b19 b17 b16 b30 b29 b24 b21 b18 t0\_d11 t0\_d10 Χ 0 0 0 0 Χ Χ 0 0 0 Value after reset 0 0 0 Bit b15 b13 b12 b11 b10 h7 b6 b5 b3 b2 b0 b14 h9 b8 b4 t0\_d9 t0\_d8 Value after reset Х 0 0 Χ 0 0 0 0

Table 7.31 TIME\_GEN\_SEQ\_2 Register Contents

| Bit Position | Bit Name | Function                                                                                                  | R/W |
|--------------|----------|-----------------------------------------------------------------------------------------------------------|-----|
| b31, b30     | Reserved |                                                                                                           | R   |
| b29 to b24   | t0_d11   | Data to delay time                                                                                        | R/W |
|              |          | The time between data transferring and waiting until the memory is ready.                                 |     |
| b23, b22     | Reserved |                                                                                                           | R   |
| b21 to b16   | t0_d10   | Data to command time                                                                                      | R/W |
|              |          | The time between data transferring and sending a command to the NAND Flash memory device.                 |     |
| b15, b14     | Reserved |                                                                                                           | R   |
| b13 to b8    | t0_d9    | Delay to command time                                                                                     | R/W |
|              |          | The time between waiting until the memory is ready and sending a command to the NAND Flash memory device. |     |
| b7, b6       | Reserved |                                                                                                           | R   |
| b5 to b0     | t0_d8    | Delay to data time                                                                                        | R/W |
|              |          | The time between waiting until the memory is ready and data transferring.                                 |     |

### 7.4.31 FIFO\_INIT — FIFO Init Register

The setting of this bit causes the flushing of FIFO. It is not necessary to set this bit before sending each command to the NAND Flash memory device. This feature is reserved only for a situation where previous FIFO content must be purged before a new operation.



Table 7.32 FIFO\_INIT Register Contents

| Bit Position | Bit Name  | Function              | R/W |
|--------------|-----------|-----------------------|-----|
| b31 to b1    | Reserved  |                       | R   |
| b0           | fifo_init | The FIFO init request | W   |

# 7.4.32 FIFO\_STATE — FIFO Status Register

Address: 4010 20B4h



Table 7.33 FIFO\_STATE Register Contents

| Bit Position | Bit Name    | Function                                                                                                                                                                                  | R/W |
|--------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b8    | Reserved    |                                                                                                                                                                                           | R   |
| b7           | df_w_empty  | The FIFO empty state bit If this flag is set, there is no data in the FIFO available. This flag is valid for the write direction.                                                         | R   |
| b6           | df_r_full   | The FIFO full state bit  If this flag is set, there is no free space for the data in FIFO available. This flag is valid for the read direction.                                           | R   |
| b5           | cf_accept_w | The Command FIFO accept flag - write direction  If this flag is set then next write access will finish with any additional delay.                                                         | R   |
| b4           | cf_accept_r | The Command FIFO accept flag - read direction  This is informational flag. If it is set then read transfer on the CMD FIFO internal interface will be accepted with any additional delay. | R   |
| b3           | cf_full     | The Command FIFO full flag  If this flag is set, there is no free space for the data in the actual command FIFO. It can't be used to check if next transfer will be accepted.             | R   |
| b2           | cf_empty    | The Command FIFO empty flag  If this flag is set, there is no data in the actual command FIFO. It can't be used to check if next transfer will be accepted.                               | R   |
| b1           | df_w_full   | The FIFO full state bit  If this flag is set, there is no free space for the data in FIFO available. This flag is valid for the write direction.                                          |     |
| b0           | df_r_empty  | The FIFO empty state bit If this flag is set, there is no data in the FIFO available. This flag is valid for the read direction.                                                          | R   |

# 7.4.33 GEN\_SEQ\_CTRL — Generic Sequence Register

This register is used to parameterize the generic command sequences. For more detail, refer to **Section 7.5.3, Generic Command Sequence**.

**Address:** 4010 20B8h



Table 7.34 GEN\_SEQ\_CTRL Register Contents (1/2)

| Bit Position | Bit Name | Function                                                                                                  | R/W |
|--------------|----------|-----------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved |                                                                                                           | R   |
| b23 to b16   | cmd3     | Command 3 code value                                                                                      | R/W |
| b15          | imd_seq  | Enable immediate command execution                                                                        | R/W |
|              |          | This bit allows the command sequence to be executed without checking the selected target state.           |     |
|              |          | 0: Feature disabled                                                                                       |     |
|              |          | 1: Feature enabled                                                                                        |     |
| b14, b13     | delay_en | Enable the busy 0 or 1 phase                                                                              | R/W |
|              |          | This bit allows enabling or disabling the presence of the "busy" phase in the universal command sequence. |     |
|              |          | 2'b00: disable both delays                                                                                |     |
|              |          | 2'b01: Enable DELAY0                                                                                      |     |
|              |          | 2'b10: Enable DELAY1                                                                                      |     |
|              |          | 2'b11: Disable both delays                                                                                |     |
| b12          | data_en  | Enable data part sequence                                                                                 | R/W |
|              |          | This bit allows enabling or disabling the data phase of the universal command sequence.                   |     |
|              |          | 0: Disable data phase                                                                                     |     |
|              |          | 1: Enable data phase                                                                                      |     |
| b11, b10     | row_a1   | Row address cycles                                                                                        | R/W |
|              |          | Number of the row address bytes sent to NAND Flash device.                                                |     |
|              |          | 2'b00: 0 address cycles                                                                                   |     |
|              |          | 2'b01: 1 address cycles                                                                                   |     |
|              |          | 2'b10: 2 address cycles                                                                                   |     |
|              |          | 2'b11: 3 address cycles                                                                                   |     |
| b9, b8       | row_a0   | Row address cycles                                                                                        | R/W |
|              |          | Number of the row address bytes sent to NAND Flash device.                                                |     |
|              |          | 2'b00: 0 address cycles                                                                                   |     |
|              |          | 2'b01: 1 address cycles                                                                                   |     |
|              |          | 2'b10: 2 address cycles                                                                                   |     |
|              |          | 2'b11: 3 address cycles                                                                                   |     |

Table 7.34 GEN\_SEQ\_CTRL Register Contents (2/2)

| Bit Position | Bit Name | Function                                                                                                       | R/W |
|--------------|----------|----------------------------------------------------------------------------------------------------------------|-----|
| b7, b6       | col_a1   | Column address cycles                                                                                          | R/W |
|              |          | Number of the column address bytes sent to NAND Flash device.                                                  |     |
|              |          | 2'b00: 0 address cycles                                                                                        |     |
|              |          | 2'b01: 1 address cycles                                                                                        |     |
|              |          | 2'b10: 2 address cycles                                                                                        |     |
|              |          | 2'b11: Not available                                                                                           |     |
| b5, b4       | col_a0   | Column address cycles                                                                                          | R/W |
|              |          | Number of the column address bytes sent to NAND Flash device.                                                  |     |
|              |          | 2'b00: 0 address cycles                                                                                        |     |
|              |          | 2'b01: 1 address cycles                                                                                        |     |
|              |          | 2'b10: 2 address cycles                                                                                        |     |
|              |          | 2'b11: Not available                                                                                           |     |
| b3           | cmd3_en  | Enable command 3 phase                                                                                         | R/W |
|              |          | This bit allows enabling or disabling the presence of the "command 3" phase in the                             |     |
|              |          | universal command sequence.                                                                                    |     |
|              |          | 1: Enable                                                                                                      |     |
|              |          | 0: Disable                                                                                                     |     |
| b2           | cmd2_en  | Enable command 2 phase                                                                                         | R/W |
|              |          | This bit allows enabling or disabling the presence of the "command 2" phase in the                             |     |
|              |          | universal command sequence.                                                                                    |     |
|              |          | 1: Enable                                                                                                      |     |
|              |          | 0: Disable                                                                                                     |     |
| b1           | cmd1_en  | Enable command 1 phase                                                                                         | R/W |
|              |          | This bit allows enabling or disabling the presence of the "command 1" phase in the                             |     |
|              |          | universal command sequence.                                                                                    |     |
|              |          | 1: Enable                                                                                                      |     |
|              |          | 0: Disable                                                                                                     |     |
| b0           | cmd0_en  | Enable command 0 phase                                                                                         | R/W |
|              |          | This bit allows enabling or disabling the presence of the "command 0" phase in the universal command sequence. |     |
|              |          | 1: Enable                                                                                                      |     |
|              |          | 0: Disable                                                                                                     |     |

0

# 7.4.34 MLUN — LUN Configuration Register

This register contains the LUN address offset bits and number of available LUNs.

Address: 4010 20BCh b29 b28 b27 b26 b25 b23 b22 b21 b20 b19 b17 b16 Bit b31 b30 b24 b18 Χ Χ Χ Χ Χ Χ Χ Χ Χ Value after reset Bit b15 b13 b12 b10 b9 b7 b6 b3 b0 b14 b11 b8 b5 b4 b2 b1 mlun\_sel mlun\_idx

Table 7.35 MLUN Register Contents

Value after reset

| Bit Position | Bit Name | Function                                                                                                                                                                          | R/W |
|--------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b10   | Reserved |                                                                                                                                                                                   | R   |
| b9, b8       | mlun_sel | LUN number                                                                                                                                                                        | R/W |
|              |          | 2'b00: Two LUN-s.                                                                                                                                                                 |     |
|              |          | 2'b01: Four LUN-s.                                                                                                                                                                |     |
| b7 to b3     | Reserved |                                                                                                                                                                                   | R   |
| b2 to b0     | mlun_idx | The LUN address offset                                                                                                                                                            | R/W |
|              |          | The content of this field is used as the bit offset value from the bit zero of the last address byte. This fields point to the bit index in the address that identify active LUN. |     |

# 7.4.35 DEV[n]\_SIZE — Device [n] BBM Record Counter Register (n = 0..3)

Χ

The bad block management mechanism implemented in the controller uses the tables in the system memory to store the remapping records. Each table can store a variable number of records depending on the number of bad blocks in the given NAND Flash device. This stores the number of records in the table for device [n].

**Address:** 4010 20C0h + 4h × n



Table 7.36 DEV[n]\_SIZE Register Contents

| Bit Position | Bit Name | Function                        | R/W |
|--------------|----------|---------------------------------|-----|
| b31 to b12   | Reserved |                                 | R   |
| b11 to b0    | dev_size | Number of record for device [n] | R/W |

# 7.4.36 DMA\_TLVL — DMA Trigger Level Register

This register allows the setting of the data FIFO occupancy level that will trigger the DMA module.

Address: 4010 2114h



Table 7.37 DMA\_TLVL Register Contents

| Bit Position | Bit Name | Function                                                       | R/W |
|--------------|----------|----------------------------------------------------------------|-----|
| b31 to b8    | Reserved |                                                                | R   |
| b7 to b0     | dma_tlvl | The DMA trigger level                                          | R/W |
|              |          | The trigger level is counted using the 32-bit words as entity. |     |

## 7.4.37 CMD\_MARK — CMD ID Initial Value

Address: 4010 2124h



Table 7.38 CMD\_MARK Register Contents

| Bit Position | Bit Name | Function             | R/W |
|--------------|----------|----------------------|-----|
| b31 to b8    | Reserved |                      | R   |
| b7 to b0     | cmd_id   | CMD ID initial value | W   |

#### LUN\_STATUS\_0 — LUN Status Register 7.4.38

4010 2128h

The LUN\_STATUS\_0 register allow to access the LUN status information for devices 0-3. Each bit of the LUN status field contain the status of single LUN of device. The busy status is marked as logical '0', the ready state is marked as logical '1'.

Address: b27 Bit b31 b30 b29 b28 b26 b25 b24 b23 b22 b21 b20 b19 b18 b17 b16 mem3\_lun mem2\_lun Value after reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 b15 b7 b13 b12 b10 b9 b6 b5 Bit b14 b11 b8 b4 b3 b2 b1 b0 mem1\_lun mem0\_lun Value after reset 0 0 0 0 0 0 0 0 0 0

**Table 7.39** LUN\_STATUS\_0 Register Contents

| Bit Position | Bit Name | Function                        | R/W |
|--------------|----------|---------------------------------|-----|
| b31 to b24   | mem3_lun | The memory 3 LUN-s status field | R   |
| b23 to b16   | mem2_lun | The memory 2 LUN-s status field | R   |
| b15 to b8    | mem1_lun | The memory 1 LUN-s status field | R   |
| b7 to b0     | mem0_lun | The memory 0 LUN-s status field | R   |

## 7.4.39 TIME\_GEN\_SEQ\_3 — Generic Command Sequence Register 3

The NAND Flash Controller is intended for use with a wide range of host clock rates. To maximize flexibility, some timing parameters are configurable. Some waveform configuration parameters for the Generic Sequence are defined in this register. The value generated by the controller equals the minimum value written into the register, increased by 1. All the timings are generated using the NAND\_ECLK clock signal. For more detail, refer to **Section 7.5.3**, **Generic Command Sequence**.



Table 7.40 TIME\_GEN\_SEQ\_3 Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                           | R/W |
|--------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b6    | Reserved |                                                                                                                                                                    | R   |
| b5 to b0     | t0_d12   | Data to sequence end time                                                                                                                                          | R/W |
|              |          | The time between the data transferring phase and sequence end. The sequence is ended when any other sequence phases after the data transfer phase are not enabled. |     |

Address:

# 7.4.40 INT\_STAT — Internal Status Register

4010 2148h

The internal operations status register stores the status values read for the internal status sequences send to the NAND Flash device. The higher two bits identify the sequence that was used to get value for the lower field (bits 7 to 0).

Bit b31 b29 b28 b26 b25 b23 b20 b19 b17 b16 b30 b27 b24 b22 b21 b18 Value after reset Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Bit b15 b14 b13 b12 b11 b10 b9 b8 b7 b6 b5 b4 b3 b2 b1 b0 seq\_id stat\_value Value after reset Χ Χ Χ Χ Χ 0 0 0 0 0 0 0 0 0

Table 7.41 INT\_STAT Register Contents

| Bit Position | Bit Name   | Function                                                                                                     | R/W |
|--------------|------------|--------------------------------------------------------------------------------------------------------------|-----|
| b31 to b10   | Reserved   |                                                                                                              | R   |
| b9, b8       | seq_id     | The status operation identification field                                                                    | R/W |
|              |            | 2'b00: No pending status value                                                                               |     |
|              |            | 2'b01: The read status operation after the program/erase sequence. It is enabled in<br>the control register. | ı   |
| b7 to b0     | stat_value | The status operation value                                                                                   | R/W |

# 7.4.41 ECC\_CNT — ECC Error Counter

This register stores number of value detected during last page read operation. This register content isn't automatically cleared it must be done by software. The new page read operation doesn't overwrite previous register value. Register contain value of the largest error level detected in processed ECC blocks.



Table 7.42 ECC\_CNT Register Contents

| Bit Position | Bit Name | Function                        | R/W |
|--------------|----------|---------------------------------|-----|
| b31, b30     | Reserved |                                 | R   |
| b29 to b24   | err_lvl3 | The Memory device 3 error level | R/W |
| b23, b22     | Reserved |                                 | R   |
| b21 to b16   | err_lvl2 | The Memory device 2 error level | R/W |
| b15, b14     | Reserved |                                 | R   |
| b13 to b8    | err_lvl1 | The Memory device 1 error level | R/W |
| b7, b6       | Reserved |                                 | R   |
| b5 to b0     | err_lvl0 | The Memory device 0 error level | R/W |

# 7.4.42 PARAM\_REG — PARAMETER Register

This register contains fields that describes the configuration of the NAND Flash Controller core. It is read only register.

Address: 4010 2150h



Table 7.43 PARAM\_REG Register Contents (1/2)

| Table 7.43   | PARAM_REG Register Contents (1/2) |                                                                                                                                                                                                                           |     |  |  |  |  |
|--------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|
| Bit Position | Bit Name                          | Function                                                                                                                                                                                                                  | R/W |  |  |  |  |
| b31, b30     | Reserved                          |                                                                                                                                                                                                                           | R   |  |  |  |  |
| b29          | asyn_reset_implemen<br>t          | Flag of the asynchronous reset feature presence This field describes the type of reset implemented in the controller 0: Synchronous reset is implemented 1: Asynchronous reset is implemented                             | R   |  |  |  |  |
| b28 to b25   | Reserved                          |                                                                                                                                                                                                                           | R   |  |  |  |  |
| b24          | dma_implement                     | Flag of the DMA master feature presence This field indicates if the DMA master module is implemented in the controller 0: DMA master is not implemented 1: DMA master is implemented                                      | R   |  |  |  |  |
| b23          | small_block_impleme<br>nt         | Flag of the small block devices support feature presence This field specifies if the small block support is implemented in the controller 0: Small block support is not implemented 1: Small block support is implemented | R   |  |  |  |  |
| b22          | gen_seq_implement                 | Flag of the generic sequence feature presence This field specifies if the generic sequence feature is implemented in the controller 0: Generic sequence is not implemented 1: Generic sequence is implemented             | R   |  |  |  |  |
| b21          | Reserved                          |                                                                                                                                                                                                                           | R   |  |  |  |  |
| b20          | ss_implement                      | Flag of the super sequence feature presence This field specifies if the super sequence feature is implemented in the controller 0: Super Sequence is not implemented 1: Super Sequence is implemented                     | R   |  |  |  |  |
| b19          | noecc_implement                   | Flag of the ECC feature lack This field indicates if the controller does not contain the correction module 0: Correction module is implemented 1: Correction module is not implemented                                    | R   |  |  |  |  |
| b18 to b13   | Reserved                          |                                                                                                                                                                                                                           | R   |  |  |  |  |
| b12          | bch32_conf_impleme<br>nt          | Flag of the BCH32_CONF feature presence This field indicates if the BCH32 conf correction module is implemented in the controller  0: BCH32 conf is not implemented  1: BCH32 conf is implemented                         | R   |  |  |  |  |

Table 7.43 PARAM\_REG Register Contents (2/2)

| Bit Position | Bit Name                  | Function                                                                                                                                                                                                                                 | R/W |  |  |  |  |
|--------------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|
| b11          | big_endian_implemen<br>t  | Flag that mark selected endianness type This field indicates endianness of the controller 0: Little endian is implemented 1: Big endian is implemented                                                                                   |     |  |  |  |  |
| b10          | clearnand_implement       | Flag of the ClearNAND™ support presence  This field indicates if the ClearNAND support is implemented in the controller  0: ClearNAND support is not implemented  1: ClearNAND support is implemented                                    | R   |  |  |  |  |
| b9           | toggle_mode_implem<br>ent | Flag of the toggle mode feature presence This field indicates if the Toggle Mode support is implemented in the controller 0: Toggle Mode support is not implemented 1: Toggle Mode support is implemented                                | R   |  |  |  |  |
| b8           | syn_mode_implement        | Flag of the synchronous work mode feature presence This field indicates if the synchronous work mode support is implemented in the controller  0: Synchronous mode support is not implemented 1: Synchronous mode support is implemented | R   |  |  |  |  |
| b7           | protect_implement         | Flag of the protect feature presence This field specify if the write protection feature is implemented in the controller 0: Write protection is not implemented 1: Write protection is implemented                                       | R   |  |  |  |  |
| b6           | bbm_int_implement         | Memory location of the bad block management feature  This field indicates the memory location for the BBM mechanism  0: External memory access by the master interface  1: Internal memory build in the controller                       | R   |  |  |  |  |
| b5           | bbm_implement             | Flag of the bad block management feature presence This field specify if the BBM feature is implemented in the controller 0: BBM is not implemented 1: BBM is implemented                                                                 | R   |  |  |  |  |
| b4           | boot_implement            | Flag of the boot feature presence This field specify if the boot feature is implemented in the controller 0: BOOT is not implemented 1: BOOT is implemented                                                                              | R   |  |  |  |  |
| b3, b2       | device_per_bank           | Number of devices per bank This field indicates the number of devices per bank that can be handled by the controller 2'b00: 1 device per bank 2'b01: 2 devices per bank 2'b10: 4 devices per bank 2'b11: 8 devices per bank              | R   |  |  |  |  |
| b1, b0       | bank_num                  | Number of banks This field indicates the number of banks that can be handled by the controller 2'b00: 1 bank 2'b01: 2 banks 2'b10: 4 banks 2'b11: 8 banks                                                                                | R   |  |  |  |  |

# 7.5 Operation

## 7.5.1 Programming the NAND Flash Controller

To be able to support future NAND Flash devices, the NAND Flash Controller provides the configurable instruction set that can be extended as new commands in new devices appear.

### 7.5.2 Command Generation

The NAND Flash devices are constantly extended and evaluated to the larger capacities and higher data throughput. Frequently during this process, new commands appear in the next generation of devices. To allow use of the NAND Flash Controller with future generations of devices, the parameterizable command sequences have been added.

The parameterization allows for a defining set of parameters for each supported command sequence.

# 7.5.2.1 Instruction Encoding

The controller instruction field is constant and has 32 bits. The instruction field contains the command sequence code and optional parameters. Those parameters are:

- The command codes present in the instruction sequence.
- The flag used to select data destination; possible options are DATA register and FIFO module.
- The flag used to select data source/sink for the command sequence. The possible choices are the AHBS module or the DMA module.
- The command sequence code.

If the given command sequence does not use all parameter fields those unused are ignored. The instruction encoding scheme is presented in the table below:

Table 7.44 Instruction Encoding

| Field Name    | Bits    | Description                                                                                    |
|---------------|---------|------------------------------------------------------------------------------------------------|
| CMD_2         | [31:24] | Code of the third command in a sequence.                                                       |
| CMD_1/CMD_3*1 | [23:16] | Code of the second or fourth command in a sequence.                                            |
| CMD_0         | [15:8]  | Code of the first command in a sequence                                                        |
| DATA_SEL      | [7]     | Data or FIFO selection flag: 0: The FIFO module selected 1: The DATA register selected         |
| INPUT_SEL     | [6]     | Input module select flag: 0: Select the AHBS module as input 1: Select the DMA module as input |
| CMD_SEQ       | [5:0]   | Command code.                                                                                  |

Note 1. Depending on the selected command sequence, this field will store the CMD1 or CMD3 code. Both commands are never used in a single sequence.

### 7.5.2.2 Command Sequence Encoding

The NAND Flash devices use the same set of signals independently of the memory capacity. This allows upgrading of obsolete devices with newer ones without PCB redesign. The disadvantage of this is a more complicated access protocol for the device.

The NAND Flash devices use common IO bus to transfer commands, addresses and data. The predefined set of command sequences is used for the read and write operations on those devices. The set of supported command sequences is not constant for all the NAND Flash device producers and evolves as the devices are more capable.

The NAND Flash Controller must be able to support the new NAND Flash device features as they appear with a minimum effort from the designer side. This objective can be achieved in many cases because most of the new instructions use the previously defined sequence of commands and addresses, along with new command codes, data page size, data spare area size, etc.

The NAND Flash Controller defines the set of commands, addresses and data sequences that allows implementation of all present and many future instructions. The following description of those sequences is adequate to define most of the future NAND Flash device instructions.

The table below contains the command sequence encoding details. Each sequence is encoded according to the fields defined in the GEN\_SEQ\_CTRL register.

Table 7.45 Command Sequence Encoding

| Sequence symbol | Sequence encoding | CMD0     | CMD1 | CMD2 | CMD3 | COL<br>_A0*2 | COL<br>_A1 | ROW<br>_A0 | ROW<br>_A1 | DATA<br>_EN | DELAY<br>_EN | IMD_SEQ*3 |
|-----------------|-------------------|----------|------|------|------|--------------|------------|------------|------------|-------------|--------------|-----------|
| SEQ_0           | 000000            | ✓        | _    | _    | _    | _            | _          | _          | _          | _           | DELAY1       | _         |
| SEQ_1           | 100001            | ✓        | _    | _    | _    | 1            | _          | _          | _          | ✓           | _            | _         |
| SEQ_2           | 100010            | ✓        |      | -    |      | 1            | _          | _          | _          | ✓           | DELAY0       | _         |
| SEQ_3           | 000011            | ✓        | _    | _    | _    | 1            | _          | _          | _          | ✓           | DELAY1       | _         |
| SEQ_4           | 100100            | ✓        | _    | _    | _    | _            | _          | _          | _          | ✓           | _            | ✓         |
| SEQ_5           | 100101            | ✓        | _    | _    | _    | _            | _          | 3          | _          | ✓           | _            | ✓         |
| SEQ_6           | 100110            | ✓        | _    | ✓    | _    | 2(1)         | _          | _          | _          | ✓           | _            | _         |
| SEQ_7           | 100111            | ✓        | _    | ✓    | _    | 2(1)         | _          | 3          | _          | ✓           | DELAY0       | _         |
| SEQ_8           | 001000            | ✓        | _    | _    | _    | 2(1)         | _          | _          | _          | ✓           | _            | _         |
| SEQ_9           | 101001            | ✓        | ✓    | _    | _    | 2(1)         | _          | 3          | _          | _           | DELAY1       | _         |
| SEQ_10          | 101010            | ✓        | _    | ✓    | _    | 2(1)         | _          | 3          | _          | ✓           | DELAY0       | _         |
| SEQ_11          | 101011            | ✓        |      | -    |      |              | _          | _          | _          | ✓           | DELAY0       | _         |
| SEQ_12          | 001100            | ✓        | ✓    | _    | _    | 2(1)         | _          | 3          | _          | ✓           | DELAY1       | _         |
| SEQ_13          | 001101            | ✓        | _    | _    | _    | 2(1)         | _          | 3          | _          | ✓           | DELAY1       | _         |
| SEQ_14          | 001110            | ✓        | ✓    | ı    |      | 1            | _          | 3          | _          | _           | DELAY1       | _         |
| SEQ_15          | 101111            | ✓        | _    | ✓    | ✓    | 2            | 2          | 3          | 3          | ✓           | DELAY0       | _         |
| SEQ_17          | 110001            | ✓        | _    | _    | _    | 2(1)         | _          | 3          | _          | ✓           | DELAY1       | _         |
| SEQ_18          | 110010            | *1       | *1   | *1   | *1   | *1           | *1         | *1         | *1         | *1          | *1           | *1        |
| SEQ_19          | 010011            | *1       | *1   | *1   | *1   | *1           | *1         | *1         | *1         | *1          | *1           | *1        |
| SEQ_20          | 010100            | ✓        | _    | _    | _    | _            | _          | 3          | _          | _           | DELAY1       | _         |
| SEQ_21          | 010101            | <b>✓</b> | I    | ı    | I    | 1            | _          | _          | _          | _           | 1            | _         |
| SEQ_22          | 110110            | <b>✓</b> |      | ✓    |      | 2(1)         | 2          | _          | 3          | ✓           | DELAY0       | _         |
| SEQ_23          | 010111            | ✓        | ✓    | _    | _    | _            | _          | 3          | _          | ✓           | DELAY1       | _         |
| SEQ_24          | 011000            | ✓        | _    | ✓    | ✓    | _            |            | 3          | 3          |             | DELAY0       | _         |
| SEQ_25          | 111001            | ✓        | _    | ✓    | ✓    | 2(1)         | 2          | 3          | _          | ✓           | _            | _         |

**Note:** Gray rows – read from NAND Flash memory; White rows – write to NAND Flash memory; Blue rows – Non-directional commands

- Note 1. SEQ\_18 and SEQ\_19 are the parameterized Generic Sequences. The GEN\_SEQ\_CTRL register defines which parts of sequences are executed.
- Note 2. The value given in the brackets relates to the small block mode. In this mode, the controller sends only a single byte as the column address.
- Note 3. IMD\_SEQ The command will be sent immediately.

## 7.5.2.3 Sequence SEQ\_0

This non-directional sequence is composed from only one command.

After the command is written to the NAND Flash device, the controller waits until the device goes into the busy state and drives the RnB line low, or sends the READ STATUS command. When delay time (tWB) passes or the device is ready, the sequence ends.



Figure 7.2 SEQ-0 Sequence

## 7.5.2.4 Sequence SEQ\_1

This is a read-sequence that is composed from a single command cycle, single address cycle and the single data cycle with a programmable number of read sequences.

After the address sequence is finished, the controller measures the standard delay of first data read after the last write (tWHR). Next, the read data words are written to the FIFO module. The input module is selected by the INPUT\_SEL field of the COMMAND register, the source for the address is placed in the ADDR0\_COL register, and the commend code is stored in the CMD\_0 field.



Figure 7.3 SEQ-1 Sequence

### 7.5.2.5 Sequence SEQ\_2

This is a read-sequence and it is similar to the SEQ\_1 sequence except that after the address cycle the controller expects that device goes to the busy state.

The controller sequentially checks state of the RnB line or send READ STATUS command to obtain the NAND Flash device status.



Figure 7.4 SEQ-2 Sequence

### 7.5.2.6 Sequence SEQ\_3

This is a write-sequence that is composed from a single command cycle, single address cycle and single data cycle with a programmable number of write sequences.

After the address sequence is finished, the controller measures the standard delay of first data write after the last address cycle (tADL). The written words are read from the FIFO module. The controller sequentially checks the state of the RnB line or sends the READ STATUS command to obtain the NAND Flash device status. The input module is selected by the INPUT\_SEL field of the COMMAND register; the source for the address is placed in the ADDR0\_COL register, and the commend code is stored in the CMD\_0 field.



Figure 7.5 SEQ-3 Sequence

## 7.5.2.7 Sequence SEQ\_4

This is a special read-sequence that is used to implement the read status command sequences.

The command is sent immediately. The sequence is composed of a single command cycle and a single data cycle. Between those cycles, the delay is counted (tWHR). The command code is read from the CMD\_0 field.

When the DATA register is selected in the COMMAND register, the data is stored in the DATA register. The user defines the number of data in the DATA\_REG\_SIZE register. The registered mode is allowed only for the read direction.

When the FIFO register is selected in the COMMAND register, the data is stored in the FIFO. Because user has to change DATA\_SIZE register, the command will be sent when all memories are ready and the Controller is in the idle state.



Figure 7.6 SEQ-4 Sequence

## 7.5.2.8 Sequence SEQ\_5

This is a read-sequence and it is similar to the SEQ\_4 sequence.

The command is sent immediately. The only difference is that after the command cycle, an additional address cycle is performed. The ADDR0\_ROW register is used in this sequence.



Figure 7.7 SEQ-5 Sequence

## 7.5.2.9 Sequence SEQ\_6

This is a read-sequence.

The sequence of command cycle, address cycle, command cycle is executed. After that, the delay from the change column to the next operation (tCCS) is measured. Finally, the read data cycle is executed. The first command code is encoded in the CMD\_0 instruction field; the second command code is encoded in the CMD\_1 instruction field; the ADDR0\_COL register is used in this sequence; the input module is selected by the INPUT\_SEL field.



Figure 7.8 SEQ-6 Sequence

## **7.5.2.10** Sequence SEQ\_7

This read-sequence is similar to the SEQ\_6 sequence, differing only because the address cycle in this sequence is composed of five bytes (ADDR0\_COL and ADDR0\_ROW) instead of three bytes.

All else is the same as in the SEQ\_6 sequence.



Figure 7.9 SEQ-7 Sequence

## 7.5.2.11 Sequence SEQ\_8

This is a write-sequence.

First, the sequence of command cycle and two bytes address cycle is executed. Next, the delay after the column address changes (tCCS) is measured. Finally, the single data cycle with programmable number of write sequences is executed.

The first command code is encoded in the CMD\_0 instruction field; the ADDR0\_COL register is used in this sequence; the input module is selected by the INPUT\_SEL field.



Figure 7.10 SEQ-8 Sequence

## 7.5.2.12 **Sequence SEQ\_9**

This is a non-directional sequence.

The first step is to execute the five bytes address command cycle. The controller sequentially checks the state of the RnB line or sends the READ STATUS command to obtain the NAND Flash device status.

The first command code is encoded in the CMD\_0 instruction field; the second command code is encoded in the CMD\_1 instruction field; the ADDR0\_COL and ADDR0\_ROW registers are used in this sequence.



Figure 7.11 SEQ-9 Sequence

## 7.5.2.13 Sequence SEQ\_10

This is a read-sequence.

The SEQ\_10 sequence is similar to the SEQ\_9, except this sequence is extended by the data read cycle. All else is the same.

The input module is selected by the INPUT\_SEL field.



Figure 7.12 SEQ-10 Sequence

### 7.5.2.14 Sequence SEQ\_11

This is the read-sequence.

The first step is to execute the command cycle. Next, the device goes to the busy state. The controller sequentially checks the state of the RnB line or sends the READ STATUS command to obtain the NAND Flash device status. As soon as the device reaches the ready state, the write data cycle with configurable read sequences is executed.

The command code is encoded in the CMD\_0 instruction field; the input module is selected by the INPUT\_SEL field. The number of transferred bytes are configured using the DATA\_SIZE register.



Figure 7.13 SEQ-11 Sequence

## 7.5.2.15 Sequence SEQ\_12

This is a write-sequence.

The SEQ\_12 sequence is a series of command cycle, address cycle, and data cycle with a configurable number of write operations and another command cycle. Between the last address cycle and first data cycle, a delay is measured (tADL) and, after the second command cycle, another delay is measured (tWB).

The first command code is encoded in the CMD\_0 instruction field; the second command code is encoded in the CMD\_1 instruction field; the ADDR0\_COL and ADDR0\_ROW registers are used in this sequence; the input module is selected by the INPUT\_SEL field.



Figure 7.14 SEQ-12 Sequence

## 7.5.2.16 Sequence SEQ\_13

This is a write-sequence.

The SEQ\_13 sequence is a series of command cycle and address cycles, data cycle with a configurable number of write operations. Between the last address cycle and first data cycle, a delay is measured (tADL).

The command code is encoded in the CMD\_0 instruction field; the ADDR0\_COL and ADDR0\_ROW registers are used in this sequence; the input module is selected by the INPUT\_SEL field.



Figure 7.15 SEQ-13 Sequence

### 7.5.2.17 Sequence SEQ\_14

This is a non-directional sequence.

First, the series of command cycle, address cycle, command cycle is executed. The controller sequentially checks the state of the RnB line or sends the READ STATUS command to obtain the NAND Flash device status.

The first command code is encoded in the CMD\_0 instruction field; the second command code is encoded in the CMD\_1 instruction field; the ADDR0\_ROW and ADDR0\_COL registers are used in this sequence.



Figure 7.16 SEQ-14 Sequence

### 7.5.2.18 Sequence SEQ\_15

This is a read-sequence.

First, the series of command cycle, address cycle, second command cycle, second address cycle, third command cycle is executed. The controller sequentially checks the state of the RnB line or sends the READ STATUS command to obtain the NAND Flash device status. After the NAND Flash device returns to the ready state, the data sequence, with a configurable number of read operations, is executed.

The first command code is encoded in the CMD\_0 instruction field; the second command code is encoded in the CMD\_2 instruction field; the third command code is encoded in the CMD\_3 instruction field.

In this sequence, all address registers are used. The ADDR0\_ROW and ADDR0\_COL register content is sent after the first command in the sequence, the ADDR1\_ROW and ADDR1\_COL register content is sent after the second command in the sequence.



Figure 7.17 SEQ-15 Sequence

## 7.5.2.19 Sequence SEQ\_17

This is a read-sequence.

This sequence is similar to the SEQ\_10 sequence, except that the second command cycle is omitted.

This sequence is implemented to use small block memories. The controller sends only four bytes of the address when the small block mode is enabled.



Figure 7.18 SEQ-17 Sequence

## 7.5.2.20 Sequence SEQ\_18

This generic read sequence is described in detail in the following **Section 7.5.3, Generic Command Sequence**.

# 7.5.2.21 Sequence SEQ\_19

This generic write sequence is described in detail in the following **Section 7.5.3, Generic Command Sequence**.

# 7.5.2.22 Sequence SEQ\_20

This non-directional sequence is composed from one command and three addresses bytes.

After the command and addresses are written to the NAND Flash device, the controller waits until the device goes into the busy state and drives the RnB line low, or sends the READ STATUS command. When delay time (tWB) passes or the device is ready, the sequence ends.



Figure 7.19 SEQ-20 Sequence

## 7.5.2.23 Sequence SEQ\_21

This non-directional sequence is composed from one command and one addresses byte.

After the command and address are written to the NAND Flash device, the sequence ends.



Figure 7.20 SEQ-21 Sequence

## 7.5.2.24 Sequence SEQ\_22

This is a read-sequence.

The first step is to execute the address command cycle. The controller sequentially checks the state of the RnB line or sends the READ STATUS command to obtain the NAND Flash device status.

The first command code is encoded in the CMD\_0 instruction field; the second command code is encoded in the CMD\_2 instruction field; the ADDR0\_COL, ADDR1\_COL and ADDR1\_ROW registers are used in this sequence.



Figure 7.21 SEQ-22 Sequence

### 7.5.2.25 Sequence SEQ\_23

This is a write-sequence.

The SEQ\_23 sequence is a series of command cycle, address cycle, and data cycle with a configurable number of write operations and another command cycle. Between the last address cycle and first data cycle, a delay is measured (tADL) and, after the second command cycle, another delay is measured (tWB).

The first command code is encoded in the CMD\_0 instruction field; the second command code is encoded in the CMD\_1 instruction field; the ADDR0\_ROW registers is used in this sequence; the input module is selected by the INPUT\_SEL field.



Figure 7.22 SEQ-23 Sequence

## 7.5.2.26 Sequence SEQ\_24

This is a write-sequence.

It is composed from the three commands cycles and two addresses cycles. Both addresses cycle contain the row address part. After the last command cycle the tWB delay is measured.



Figure 7.23 SEQ-24 Sequence

## 7.5.2.27 Sequence SEQ\_25

This is a read-sequence.

It is composed from the three commands cycles and two addresses cycles. The first addresses cycle contain the column and row address part. The second address cycle contain only the column address part. After the last command cycle the tWHR delay is measured.



Figure 7.24 SEQ-25 Sequence

## 7.5.3 Generic Command Sequence

There will be cases where the set of predefined sequences above will not be sufficient to handle a new command sequence. If that occurs, the generic command sequence feature of the NAND Flash Controller can be used.

This sequence is designed to mimic almost every available command supported by the NAND Flash devices; however, additional effort required to trigger such commands.

Generic command sequence is executed in the following steps:

#### CMD0

The first command in the sequence. The value of this command is stored in the CMD\_0 field of the COMMAND register.

#### • ADDR0

The first address sequence. This is enabled if the COL\_A0 and ROW\_A0 fields in the GEN\_SEQ\_CTRL register have values other than zero. In this phase, the address is sent to the NAND Flash device and is read from the ADDR0\_COL and ADDR0\_ROW registers. The number of the bytes in the address cycle is configured by the COL\_A0 and ROW\_A0 fields of the GEN\_SEQ\_CTRL register.

#### • CMD1

The fourth command in the sequence. The value of this command is stored in the CMD\_1 field of the COMMAND register. This is enabled by the CMD1\_EN field in the GEN\_SEQ\_CTRL register.

#### • ADDR1

The second address in the sequence. This is enabled if the COL\_A1 and ROW\_A1 fields of the GEN\_SEQ\_CTRL register have a value other than zero. In this phase, the address is sent to the NAND Flash device from the ADDR1\_COL and ADDR1\_ROW registers. The number of bytes in the address cycle is configured by the COL\_A1 and ROW\_A1 fields of the GEN\_SEQ\_CTRL register.

#### • CMD2

The third command in the sequence. The value of this command is stored in the CMD\_2 field of the COMMAND register. This is enabled by the CMD2\_EN field in the GEN\_SEQ\_CTRL register.

### • DELAY0

Waiting for the device to return to the ready state and continue the sequence. This is enabled by the DELAY\_EN field in the GEN\_SEQ\_CTRL register. Only one delay phase can be present in the generic sequence.

### • DATA

The data phase of the sequence. This is enabled by the DATA\_EN field in the GEN\_SEQ\_CTRL register. Additionally, the transfer direction must be selected by the sequence number. Sequence number 18 reads data from the NAND Flash memory, sequence number 19 writes data to the NAND Flash memory. The size of the transferred data block is configured by the DATA\_SIZE register value.

#### • CMD3

The second command in the sequence. This is enabled by the CMD3\_EN field in the GEN\_SEQ\_CTRL register. The value of this command is stored in the CMD\_3 field of the GEN\_SEQ\_CTRL register.

### • DELAY1

Waiting for the device to return to the ready state and finish the sequence. This is enabled by the DELAY\_EN field in the GEN\_SEQ\_CTRL register. The controller waits for the device to return to the ready state and finish the sequence. Only one delay phase can be present in generic sequence.



Figure 7.25 Generic Sequence

There are few constraints on the generic sequence usage:

- The DELAY0 and DELAY1 delay phases cannot both be enabled in a single command sequence.
- The TIMINGS\_ASYN registers must be set even when the generic sequence is used.

It is possible to force an immediate command sequence execution by enabling the IMD\_SEQ bit in the GEN\_SEQ\_CTRL register.

In this case, the triggered command will be executed even if the previously sent command for a selected device is not completed. If both the IMD\_SEQ and DATA\_EN flags are enabled in a single sequence, then the register must be selected as data source/sink. The IMD\_SEQ is valid only for the read direction. This feature is intended to implement all state read operations.

After each step of the generic sequence, the programmable delay time is measured. These delays are configured using the TIME\_GEN\_SEQ[0-2] registers. Refer to the TIME\_GEN\_SEQ[0-2] registers description for further information and see figures below.



Figure 7.26 Generic Sequence Timing Parameters 1



Figure 7.27 Generic Sequence Timing Parameters 2

### 7.5.4 Instructions

The implementation of the instruction set presented at this point is an example of how to use the instruction encoding scheme presented in **Section 7.5.2.1**, **Instruction Encoding**. The command sequences presented previously given sufficient information to implement new commands and command sequences for future NAND Flash devices.

### 7.5.4.1 Instruction Set

The table below contains the basic instruction defined to implement the all command sequences accessible in the ONFI 1.x and 2.2 standards.

Table 7.46 Instruction Set (1/2)

|                        |       |               |       |         | Send wher memory is |
|------------------------|-------|---------------|-------|---------|---------------------|
| Instruction            | CMD_0 | CMD_1 / CMD_3 | CMD_2 | CMD_SEQ | busy                |
| RESET                  | 0xFF  | _             | _     | SEQ_0   | No                  |
| READ ID                | 0x90  | _             | _     | SEQ_1   | No                  |
| READ PARAMETER PAGE    | 0xEC  | _             | _     | SEQ_2   | No                  |
| READ UNIQUE ID         | 0xED  | _             | _     | SEQ_2   | No                  |
| GET FEATURES           | 0xEE  | _             | _     | SEQ_2   | No                  |
| SET FEATURES           | 0xEF  | _             | _     | SEQ_3   | No                  |
| READ STATUS            | 0x70  | _             | _     | SEQ_4   | Yes                 |
| SELECT LUN WITH STATUS | 0x78  | _             | _     | SEQ_5   | Yes                 |
| LUN STATUS             | 0x71  | _             | _     | SEQ_5   | Yes                 |
| DEVICE STATUS          | 0x72  | _             | _     | SEQ_4   | Yes                 |
| VOLUME SELECT          | 0xE1  | _             | _     | SEQ_21  | Yes                 |
| CHANGE READ COLUMN     | 0x05  | _             | 0xE0  | SEQ_6   | No                  |
| SELECT CACHE REGISTER  | 0x06  | _             | 0xE0  | SEQ_7   | No                  |
| CHANGE WRITE COLUMN    | 0x85  | _             | _     | SEQ_8   | No                  |
| CHANGE ROW ADDRESS     | 0x85  | 0x11          | _     | SEQ_12  | No                  |
| READ PAGE              | 0x00  | _             | 0x30  | SEQ_10  | No                  |
| READ PAGE CACHE        | 0x31  | _             | _     | SEQ_11  | No                  |
| READ PAGE CACHE LAST   | 0x3F  | _             | _     | SEQ_11  | No                  |
| READ MULTIPLANE        | 0x00  | 0x32          | _     | SEQ_9   | No                  |
| TWO PLANE PAGE READ    | 0x00  | 0x30          | 0x00  | SEQ_15  | No                  |
| QUEUE PAGE READ        | 0x07  | _             | 0x37  | SEQ_22  | No                  |
| PROGRAM PAGE           | 0x80  | 0x10          | _     | SEQ_12  | No                  |
| PROGRAM PAGE IMMEDIATE | 0x80  | 0x10          | _     | SEQ_23  | No                  |
| PROGRAM PAGE DELAYED   | 0x80  | 0x13          | _     | SEQ_23  | No                  |
| PROGRAM PAGE 1         | 0x80  | _             | _     | SEQ_13  | No                  |
| PROGRAM PAGE CACHE     | 0x80  | 0x15          | _     | SEQ_12  | No                  |
| PROGRAM MULTIPLANE     | 0x80  | 0x11          | _     | SEQ_12  | No                  |
| WRITE PAGE             | 0x10  | _             | _     | SEQ_0   | No                  |
| WRITE PAGE CACHE       | 0x15  | _             | _     | SEQ_0   | No                  |
| WRITE MULTIPLANE       | 0x11  | _             | _     | SEQ_0   | No                  |
| ERASE BLOCK            | 0x60  | 0xD0          | _     | SEQ_14  | No                  |
| ERASE MULTIPLANE       | 0x60  | 0xD1          | _     | SEQ_14  | No                  |
| COPYBACK READ          | 0x00  | _             | 0x35  | SEQ_10  | No                  |
| COPYBACK PROGRAM       | 0x85  | 0x10          | _     | SEQ_9   | No                  |
| COPYBACK PROGRAM 1     | 0x85  | _             | _     | SEQ_13  | No                  |

Table 7.46 Instruction Set (2/2)

| Instruction         | CMD_0 | CMD_1 / CMD_3 | CMD_2 | CMD_SEQ | Send when<br>memory is<br>busy |
|---------------------|-------|---------------|-------|---------|--------------------------------|
| COPYBACK MULTIPLANE | 0x85  | 0x11          | _     | SEQ_12  | No                             |
| PROGRAM OTP         | 0xA0  | 0x10          | _     | SEQ_12  | No                             |
| DATA PROTECT OTP    | 0xA5  | 0x10          | _     | SEQ_9   | No                             |
| READ PAGE OTP       | 0xAF  | _             | 0x30  | SEQ_10  | No                             |

#### 7.5.4.2 Instruction Execution

The execution of each instruction has well-defined phases. The current controller configuration decides if a given phase is executed or not. The command execution cycle functions as follows:

The instruction code is written to the COMMAND register. This triggers the instruction execution.

The DCU unit decodes the instruction and configures the controller for its execution. At this point, the input module for the data FIFO is selected. The NCU module receives the sequence number to execute and the auxiliary parameter that parameterizes this operation.

The command sequence encoded in the instruction is executed in the NCU module. The details of this process depend on the controller configuration.

If the interrupts are enabled after command execution, the interrupt will occur.

The DATA\_SEL and INPUT\_SEL fields of the instruction code are configurable for every instruction used. When the instruction does not use the register or FIFO address, those fields are ignored. The ignored field has the logical zero value.

## 7.5.4.3 RESET Command

## a. Command Description

The RESET command is used to put a target into a known condition and to abort command sequences in progress.

#### b. Command Encoding

The RESET instruction uses the SEQ\_0 commands sequence. The command is encoded, as shown in the following table:

Table 7.47 RESET Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|-------|---------------|-------|----------|-----------|----------|
| _     | _             | 0xFF  | _        | _         | SEQ_0_ID |

### 7.5.4.4 READ ID Command

### a. Command Description

The READ ID command is used to read identifier codes programmed into the target. This command is accepted by the target only when all LUNs on the target are in the IDLE state.

When the command is followed by an address cycle of 0x00, the target returns a 5-byte identifier code that includes the manufacturer ID, device configuration, and part-specific information.

When the READ ID command is followed by an address cycle of 0x20, the target returns the 4-byte ONFI identifier code.

### b. Command Encoding

The READ ID instruction uses the SEQ\_1 commands sequence. The command is encoded, as shown in the table below:

Table 7.48 READ ID Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|-------|---------------|-------|----------|-----------|----------|
| _     | _             | 0x90  | 0/1      | 0/1       | SEQ_1_ID |

### 7.5.4.5 READ PARAMETER PAGE Command

### a. Command Description

The READ PARAMETER PAGE command is used to read the ONFI parameter page programmed into the target. This command is accepted by the target only when all LUNs on the target are idle.

When the command is followed by an address cycle of 00h, the target goes into busy state. After the read process is completed, the controller enables the data output mode to read the parameter page.

### b. Command Encoding

The READ PARAMETER PAGE instruction uses the SEQ\_2 commands sequence. The command is encoded, as shown in the following table:

Table 7.49 READ PARAMETER PAGE Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|-------|---------------|-------|----------|-----------|----------|
| _     | _             | 0xEC  | 0/1      | 0/1       | SEQ_2_ID |

### 7.5.4.6 READ UNIQUE ID Command

### a. Command Description

The READ UNIQUE ID instruction is used to read a unique identifier programmed into the target. This command is accepted by the target only when all LUNs on the target are idle.

When the address cycle of 00h is written to the target, then the target goes into busy state. After the read process is complete, the controller enables the data output mode to read the unique ID. Sixteen copies of the unique ID data are stored in the device. Each copy is 32 bytes. The first 16 bytes are unique data and the second 16 bytes are the complement of the first 16 bytes. The host will XOR the first 16 bytes with the second 16 bytes. If the result is 16 bytes of 0xFF, then that copy of the unique ID data is correct. In the event that there is a non-0xFF result, the host repeats the XOR operation on a subsequent copy of the unique ID data.

### b. Command Encoding

The READ UNIQUE ID instruction uses the SEQ\_2 commands sequence. The command is encoded, as shown in the following table:

Table 7.50 READ UNIQUE ID Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|-------|---------------|-------|----------|-----------|----------|
| _     | _             | 0xED  | 0/1      | 0/1       | SEQ_2_ID |

### 7.5.4.7 GET FEATURES Command

### a. Command Description

The GET FEATURES instruction reads the sub-feature parameters (P1-P4) from the specified feature address. This command is accepted by the target only when all LUNs on the target are idle.

When the 0xEE command is followed by a feature address, the target goes into busy state. After the target internal read operation completes, the controller enables the data output mode to read the sub-feature parameters.

### b. Command Encoding

The GET FEATURES instruction uses the SEQ\_2 commands sequence. The command is encoded, as shown in the following table:

Table 7.51 GET FEATURES Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|-------|---------------|-------|----------|-----------|----------|
| _     | _             | 0xEE  | 0/1      | 0/1       | SEQ_2_ID |

#### 7.5.4.8 SET FEATURES Command

### a. Command Description

The SET FEATURES instruction writes the sub-feature parameters (P1-P4) to the specified feature address to enable or disable target-specific features. This command is accepted by the target only when all LUNs on the target are idle.

The 0xEF command is followed by a valid feature address. The possible address value depends on the features set implemented in the target device. The address cycle is followed by the configurable number of data cycles. Values of the address and data encoding scheme allowed are found in the device vendor documentation.

### b. Command Encoding

The SET FEATURES instruction uses the SEQ\_3 commands sequence. The command is encoded, as shown in the following table:

Table 7.52 SET FEATURES Instruction Encoding

| CMD_2    | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|----------|---------------|-------|----------|-----------|----------|
| <u> </u> | _             | 0xEF  | _        | 0/1       | SEQ_3_ID |

#### 7.5.4.9 READ STATUS Command

### a. Command Description

Each LUN provides its status independently of other LUNs on the same target through its 8-bit status register. Once the READ STATUS instruction is issued, status register output is enabled. The contents of the status register are returned on DQ[7:0] for each data output request.

The READ STATUS command returns the status of the most recently selected LUN.

#### b. Command Encoding

The READ STATUS instruction uses the SEQ\_4 commands sequence. The command is encoded, as shown in the following table:

Table 7.53 READ STATUS Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|-------|---------------|-------|----------|-----------|----------|
| _     | _             | 0x70  | 0/1      | _         | SEQ_4_ID |

### **CAUTION**

This instruction has special meaning because it can be executed when the target is in the BUSY state. The FIFO cannot be used to access the read data because it can be occupied by the operation under execution. For the sequence, the data field of command must select the DATA\_REG register as data destination. The DATA\_REG\_SIZE must be select single byte.



#### 7.5.4.10 DEVICE STATUS Command

### a. Command Description

Each LUN provides its status independently of other LUNs on the same target through its 8-bit status register. Once the DEVICE STATUS instruction is issued, status register output is enabled. The contents of the status register are returned on DQ[7:0] for each data output request.

The DEVICE STATUS command returns the status of the most recently selected LUN.

### b. Command Encoding

The DEVICE STATUS instruction uses the SEQ\_4 commands sequence. The command is encoded, as shown in the following table:

Table 7.54 DEVICE STATUS Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|-------|---------------|-------|----------|-----------|----------|
| _     | _             | 0x72  | 0/1      | _         | SEQ_4_ID |

### CAUTION

This instruction has special meaning because it can be executed when the target is in the BUSY state. The FIFO cannot be used to access the read data because it can be occupied by the operation under execution. For the sequence, the data field of command must select the DATA\_REG register as data destination. The DATA\_REG\_SIZE must be select single byte.

### 7.5.4.11 VOLUME SELECT Command

### a. Command Description

The VOLUME SELECT command is used to select a particular volume based on the address specified.

This command is accepted by all initialized devices that share a CE pin. The command may be executed with any volume on the target in any state. When the VOLUME SELECT command is issued, all volumes with unselected volume addresses will be deselected to save power.

If the Volume address entered is invalid or does not match any appointed volume address, all volume addresses will be deselected.

If the VOLUME SELECT command is not issued after CE high time then all volumes revert to their previous state.

### b. Command Encoding

The VOLUME SELECT instruction uses the SEQ\_21 commands sequence. The command is encoded, as shown in the following table:

Table 7.55 VOLUME SELECT Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| _     | _             | 0xE1  | 0/1      | _         | SEQ_21_ID |

#### 7.5.4.12 SELECT LUN WITH STATUS Command

### a. Command Description

Each LUN provides its status independently of other LUNs on the same target through its 8-bit status register. Once the SELECT LUN WITH STATUS instruction is issued, status register output is enabled. The contents of the status register are returned on DQ[7:0] for each data output request.

The SELECT LUN WITH STATUS command returns the status of the selected LUN.

### b. Command Encoding

The SELECT LUN WITH STATUS instruction uses the SEQ\_5 commands sequence. The command is encoded, as shown in the following table:

Table 7.56 SELECT LUN WITH STATUS Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|-------|---------------|-------|----------|-----------|----------|
| _     | _             | 0x78  | 0/1      | _         | SEQ_5_ID |

#### CAUTION

This instruction has special meaning because it can be executed when the target is in the BUSY state. The FIFO cannot be used to access the read data because it can be occupied by the operation under execution. For the sequence, the data field of command must select the DATA\_REG register as data destination. The DATA\_REG\_SIZE must be select single byte.

### 7.5.4.13 LUN STATUS Command

### a. Command Description

Each LUN provides its status independently of other LUNs on the same target through its 8-bit status register. Once the LUN STATUS instruction is issued, status register output is enabled. The contents of the status register are returned on DQ[7:0] for each data output request. The LUN STATUS command returns the status of the selected LUN.

### b. Command Encoding

The LUN STATUS instruction uses the SEQ\_5 commands sequence. The command is encoded, as shown in the following table:

Table 7.57 LUN STATUS Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|-------|---------------|-------|----------|-----------|----------|
| _     | _             | 0x71  | 0/1      | _         | SEQ_5_ID |

#### CAUTION

This instruction has special meaning because it can be executed when the target is in the BUSY state. The FIFO cannot be used to access the read data because it can be occupied by the operation under execution. For the sequence, the data field of command must select the DATA\_REG register as data destination. The DATA\_REG\_SIZE must be select single byte.



#### 7.5.4.14 CHANGE READ COLUMN Command

### a. Command Description

The CHANGE READ COLUMN command changes the column address of the selected cache register and enables data output of the last selected LUN. This command is accepted by the selected LUN when it is ready.

Writing 0x05 to the target command register, followed by two column address cycles containing the column address, followed by the 0xE0 command puts the selected LUN into data output mode. The selected LUN stays in data output mode until another valid command is issued.

### b. Command Encoding

The CHANGE READ COLUMN instruction uses the SEQ\_6 commands sequence. The command is encoded, as shown in the following table:

Table 7.58 CHANGE READ COLUMN Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|-------|---------------|-------|----------|-----------|----------|
| 0xE0  | _             | 0x05  | 0/1      | _         | SEQ_6_ID |

#### 7.5.4.15 SELECT CACHE REGISTER Command

### a. Command Description

The SELECT CACHE REGISTER command enables data output on the addressed LUN and cache register at the specified column address. This command is accepted by a LUN when it is ready.

Writing the 0x06 to the target internal command register, followed by two column address cycles and three row address cycles, followed by 0xE0 enables data output mode on the address LUN and cache register at the specified column address.

### b. Command Encoding

The SELECT CACHE REGISTER instruction uses the SEQ\_7 commands sequence. The command is encoded, as shown in the following table:

Table 7.59 SELECT CACHE REGISTER Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|-------|---------------|-------|----------|-----------|----------|
| 0xE0  | _             | 0x06  | 0/1      | _         | SEQ_7_ID |

## 7.5.4.16 CHANGE WRITE COLUMN Command

### a. Command Description

The CHANGE WRITE COLUMN command changes the column address of the selected cache register and enables data input on the last selected LUN. Writing the 0x85 to the target internal command register, followed by two column address cycles containing the column address puts the selected LUN into data input mode.

### b. Command Encoding

The CHANGE WRITE COLUMN instruction uses the SEQ\_8 commands sequence. The command is encoded, as shown in the following table:

Table 7.60 CHANGE WRITE COLUMN Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|-------|---------------|-------|----------|-----------|----------|
| _     | _             | 0x85  | _        | _         | SEQ_8_ID |

### 7.5.4.17 CHANGE ROW ADDRESS Command

### a. Command Description

The CHANGE ROW ADDRESS command changes the row address (block and page) where the cache register contents are to be programmed in the NAND array. It also changes the column address of the selected cache register and enables data input on the specified LUN.

### b. Command Encoding

The CHANGE ROW ADDRESS instruction uses the SEQ\_12 commands sequence. The command is encoded, as shown in the following table:

Table 7.61 CHANGE ROW ADDRESS Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| _     | 0x11          | 0x85  | 0        | _         | SEQ_12_ID |

## 7.5.4.18 READ PAGE Command

### a. Command Description

The READ PAGE command copies a page from the NAND Flash array to its respective cache register and enables data output. This command is accepted by the LUN when it is ready.

To read a page from the NAND Flash array, the controller writes the 0x00 command to the target internal command register, then writes 5 address cycles to the address registers, and concludes with the 0x30 command.

The selected LUN will go into busy state as the data is transferred. When the LUN is ready, data output is enabled for the cache register linked to the plane addressed in the READ PAGE command.

The controller reads the programmed number of bytes to the FIFO.

### b. Command Encoding

The READ PAGE instruction uses the SEQ\_10 commands sequence. The command is encoded, as shown in the following table:

Table 7.62 READ PAGE Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| 0x30  | _             | 0x00  | 0/1      | 0/1       | SEQ_10_ID |

#### 7.5.4.19 READ PAGE CACHE Command

### a. Command Description

The READ PAGE CACHE command reads the next sequential page within a block into the DATA register, while the previous page is output from the cache register. To issue this command, the controller writes 0x31 to the target internal command register. After this command is issued, the RnB goes LOW and the LUN goes into busy state. Afterwards, the RnB goes HIGH and the LUN is busy with a cache operation, indicating that the cache register is available and that the specified page is copying from the NAND Flash array to the DATA register. At this point, data is read from the cache register.

### b. Command Encoding

The READ PAGE CACHE instruction uses the SEQ\_11 commands sequence. The command is encoded, as shown in the following table:

Table 7.63 READ PAGE CACHE Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| _     | _             | 0x31  | 0/1      | 0/1       | SEQ_11_ID |

### 7.5.4.20 READ PAGE CACHE LAST Command

### a. Command Description

The READ PAGE CACHE LAST command ends the READ PAGE CACHE sequence and copies a page from the DATA register to the cache register. This command is accepted by the LUN when it is ready.

To issue the READ PAGE CACHE LAST command, the controller writes 0x3F to the target internal command register. After this command is issued, RnB goes LOW and the LUN goes into busy state. Afterwards, the RnB goes HIGH and the LUN is ready. At this point, data from the targets cache register is read into the FIFO.

### b. Command Encoding

The READ PAGE CACHE LAST instruction uses the SEQ\_11 commands sequence. The command is encoded, as shown in the following table:

Table 7.64 READ PAGE CACHE LAST Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| _     | _             | 0x3F  | 0/1      | 0/1       | SEQ_11_ID |

### 7.5.4.21 READ MULTIPLANE Command

### a. Command Description

The READ MULTIPLANE command queues a plane to transfer data from the NAND array to its cache register. This command can be issued one or more times. Each time a new plane address is specified, that plane is also queued for data transfer. To select the final plane and to begin the read operation for all previously queued planes, issue the READ PAGE command. All queued planes will transfer data from the NAND array to their cache registers.

### b. Command Encoding

The READ MULTIPLANE instruction uses the SEQ\_9 commands sequence. The command is encoded, as shown in the following table:

Table 7.65 READ MULTIPLANE Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|-------|---------------|-------|----------|-----------|----------|
| _     | 0x32          | 0x00  | _        | _         | SEQ_9_ID |

### 7.5.4.22 QUEUE PAGE READ Command

### a. Command Description

The QUEUE PAGE READ operation allows for partial-page reads by using a 7-address cycle. The first two bytes of the address cycle indicate the length of the page to read - those bytes are stored in ADDR0 register, followed by the column and row addresses - those bytes are stored in the ADDR1 register. This can help overall performance should only a portion of the page data be needed because only the codeword containing the requested data will have ECC decoded.

### b. Command Encoding

The QUEUE PAGE READ instruction uses the SEQ\_22 commands sequence. The command is encoded, as shown in the following table:

Table 7.66 QUEUE PAGE READ Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| 0x37  | _             | 0x07  | _        | _         | SEQ_22_ID |

### 7.5.4.23 TWO PLANE PAGE READ Command

### a. Command Description

This command was implemented to preserve the compatibility with the ONFI 1.x and some older devices.

The TWO PLANE PAGE READ (00h-00h-30h) operation is similar to the PAGE READ (00h-30h) operation. It transfers two pages of data from the NAND Flash array to the DATA registers. Each page must be from a different plane on the same die. The software is responsible for generating correct addresses for the requested pages. Both the ADDR0 and ADDR1 address registers are used in this case.

### b. Command Encoding

The TWO PLANE PAGE READ instruction uses the SEQ\_15 commands sequence. The command is encoded, as shown in the table below. In this case, both the address registers are used.

Table 7.67 TWO PLANE PAGE READ Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| 0x00  | 0x30          | 0x00  | 0/1      | 0/1       | SEQ_15_ID |



#### 7.5.4.24 PROGRAM PAGE Command

#### a. Command Description

The PROGRAM PAGE command allows the host to input data to a cache register and moves the data from the cache register to the specified block and page address in the array of the selected LUN. This command is accepted by the LUN when it is ready.

To input a page to the cache register and move it to the NAND array at the block and page address specified, the controller writes 0x80 to the target internal command register. Then five address cycles containing the column address and row address are written. Data input cycles follow. Serial data is input, beginning at the column address specified.

When data input is complete, the controller writes 0x10 to the target internal command register. The selected LUN goes into the busy state.

## b. Command Encoding

The PROGRAM PAGE instruction uses the SEQ\_12 commands sequence. The command is encoded, as shown in the following table:

Table 7.68 PROGRAM PAGE Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| _     | 0x10          | 0x80  | 0        | 0/1       | SEQ_12_ID |

### 7.5.4.25 PROGRAM PAGE IMMEDIATE Command

## a. Command Description

The PROGRAM PAGE IMMEDIATE command allows the host to input data to a cache register and moves the data from the cache register to the specified block and page address in the array of the selected LUN. This command is accepted by the LUN when it is ready.

To input a page to the cache register and move it to the NAND array at the block and page address specified, the controller writes 0x80 to the target internal command register. Then three address cycles containing the row address are written. Data input cycles follow. Serial data is input, beginning at the column address specified.

When data input is complete, the controller writes 0x10 to the target internal command register. The selected LUN goes into the busy state. This command writes only the row address to the NAND Flash device.

#### b. Command Encoding

The PROGRAM PAGE IMMEDIATE instruction uses the SEQ\_23 commands sequence. The command is encoded, as shown in the following table:

Table 7.69 PROGRAM PAGE IMMEDIATE Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| _     | 0x10          | 0x80  | 0        | 0/1       | SEQ_23_ID |

#### 7.5.4.26 PROGRAM PAGE DELAYED Command

#### a. Command Description

The device internal controller can automatically manage multi-plane programming. It does this with PROGRAM PAGE DELAYED command.

When this command issued, the controller will delay issuing the program operation to the array until the address for the subsequent program operation is examined. If that operation allows the previous operation to complete as part of multiplane operation, the controller will issue a multi-plane program to the array.

Multi-plane operations are only completed if an LUN address from plane 0 is issued prior to a LUN address from plane 1. If the subsequent program operation does not allow the multi-plane operation, the controller will immediately start the previous program. It is presumed that the host may use this command to initiate all the program operations. In this way the host does not have to maintain information regarding multi-plane operation usage.

# b. Command Encoding

The PROGRAM PAGE DELAYED instruction uses the SEQ\_23 commands sequence. The command is encoded, as shown in the following table:

Table 7.70 PROGRAM PAGE DELAYED Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| _     | 0x13          | 0x80  | 0        | 0/1       | SEQ_23_ID |

#### 7.5.4.27 PROGRAM PAGE 1 Command

## a. Command Description

The PROGRAM PAGE 1 command allows the host to input data to a cache register and moves the data from the cache register to the specified block and page address in the array of the selected LUN. This command is accepted by the LUN when it is ready.

To input a page to the cache register and move it to the NAND array at the block and page address specified, the controller writes 0x80 to the target internal command register. Then five address cycles containing the column address and row address are written. Data input cycles follow. Serial data is input, beginning at the column address specified.

When data input is complete, the commands sequence ends

#### b. Command Encoding

The PROGRAM PAGE 1 instruction uses the SEQ\_13 commands sequence. The command is encoded, as shown in the following table:

Table 7.71 PROGRAM PAGE 1 Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| _     | _             | 0x80  | 0        | 0/1       | SEQ_13_ID |

#### 7.5.4.28 PROGRAM PAGE CACHE Command

#### a. Command Description

The PROGRAM PAGE CACHE command allows the controller to input data to a cache register, copies the data from the cache register to the DATA register, and then moves the DATA register contents to the specified block and page address in the array of the selected LUN.

After the data is copied to the DATA register, the cache register is available for additional PROGRAM PAGE CACHE or PROGRAM PAGE commands. The PROGRAM PAGE CACHE command is accepted by the LUN when it is ready.

To input a page to the cache register to move it to the NAND array at the block and page address specified, the controller writes 0x80 to the target internal command register. Then five address cycles containing the column address and row address are written. Data input cycles follow. Serial data is input, beginning at the column address specified.

When data input is complete, 0x15 is written to the command register. The selected LUN goes into busy state to allow the DATA register to become available from a previous program cache operation, to copy data from the cache register to the DATA register, and then to begin moving the DATA register contents to the specified page and block address.

# b. Command Encoding

The PROGRAM PAGE CACHE instruction uses the SEQ\_12 commands sequence. Command is encoded as shown in the following table:

Table 7.72 PROGRAM PAGE CACHE Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| _     | 0x15          | 0x80  | 0        | 0/1       | SEQ_12_ID |

# 7.5.4.29 PROGRAM MULTIPLANE Command

#### a. Command Description

The PROGRAM MULTIPLANE command allows the controller to input data to the addressed plane cache register and queue the cache register to ultimately be moved to the NAND array. This command can be issued one or more times. Each time a new plane address is specified that plane is also queued for data transfer. This command is accepted by the LUN when it is ready.

The controller writes 0x80 to the target internal command register. Then five address cycles containing the column address and row address are written. Data input cycles follow. Serial data is input beginning at the column address specified.

When data input is complete, the controller writes 0x11 to the target internal command register.

### b. Command Encoding

The PROGRAM MULTIPLANE instruction uses the SEQ\_12 commands sequence. The command is encoded, as shown in the following table:

Table 7.73 PROGRAM MULTIPLANE Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| _     | 0x11          | 0x80  | 0        | 0/1       | SEQ_12_ID |

#### 7.5.4.30 WRITE PAGE Command

#### a. Command Description

The WRITE PAGE command allows the controller to move data from the targets cache register to the NAND array. This command is accepted by the LUN when it is ready.

The controller writes 0x10 to the target internal command register.

# b. Command Encoding

The WRITE PAGE instruction uses the SEQ\_0 commands sequence. The command is encoded, as shown in the following table:

Table 7.74 WRITE PAGE Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|-------|---------------|-------|----------|-----------|----------|
| _     | _             | 0x10  | _        | _         | SEQ_0_ID |

#### 7.5.4.31 WRITE PAGE CACHE Command

## a. Command Description

The WRITE PAGE CACHE command allows the controller to move data from the targets cache register to the targets DATA register. This command is accepted by the LUN when it is ready.

The controller writes 0x15 to the target internal command register.

## b. Command Encoding

The WRITE PAGE CACHE instruction uses the SEQ\_0 commands sequence. The command is encoded, as shown in the following table:

Table 7.75 WRITE PAGE CACHE Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|-------|---------------|-------|----------|-----------|----------|
| _     | _             | 0x15  | _        | _         | SEQ_0_ID |

## 7.5.4.32 WRITE MULTIPLANE Command

## a. Command Description

The WRITE MULTIPLANE command allows the controller to queue data from the targets cache register to the NAND array. This command is accepted by the LUN when it is ready.

The controller writes 0x11 to the target internal command register.

#### b. Command Encoding

The WRITE MULTIPLANE instruction uses the SEQ\_0 commands sequence. The command is encoded, as shown in the following table:

Table 7.76 WRITE MULTIPLANE Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|-------|---------------|-------|----------|-----------|----------|
| _     | _             | 0x11  | _        | _         | SEQ_0_ID |



#### 7.5.4.33 ERASE BLOCK Command

#### a. Command Description

The ERASE BLOCK command erases the specified block in the NAND array. This command is accepted by the LUN when it is ready.

To erase a block, the controller writes 0x60 to the target internal command register. Then three address cycles containing the row address are written; the column address is ignored. Finally, 0xD0 is written to the target internal command register.

### b. Command Encoding

The ERASE BLOCK instruction uses the SEQ\_14 commands sequence. The command is encoded, as shown in the following table:

Table 7.77 ERASE BLOCK Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| _     | 0xD0          | 0x60  | _        | _         | SEQ_14_ID |

#### 7.5.4.34 ERASE MULTIPLANE Command

## a. Command Description

The ERASE MULTIPLANE command queues a block in the specified plane to be erased from the NAND array. This command can be issued one or more times. Each time a new plane address is specified, that plane is also queued for a block to be erased. This command is accepted by the LUN when it is ready.

To queue a block to be erased, the controller writes0x60 to the command register. Then three address cycles containing the row address are written; the column address is ignored. Finally, 0xD1 is written to the command register.

# b. Command Encoding

The ERASE MULTIPLANE instruction uses the SEQ\_14 commands sequence. The command is encoded, as shown in the following table:

Table 7.78 ERASE MULTIPLANE Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| _     | 0xD1          | 0x60  | _        | _         | SEQ_14_ID |

# 7.5.4.35 COPYBACK READ Command

### a. Command Description

The COPYBACK READ command is functionally identical to the READ PAGE command, except that 0x35 is written to the target internal command register instead of 0x30.

For more detail, see the READ PAGE command description.

#### b. Command Encoding

The COPYBACK READ instruction uses the SEQ\_10 commands sequence. The command is encoded, as shown in the following table:

Table 7.79 COPYBACK READ Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| 0x35  | _             | 0x00  | 0/1      | 0/1       | SEQ_10_ID |



#### 7.5.4.36 COPYBACK PROGRAM Command

#### a. Command Description

The Copyback function reads a page of data from one location and then moves that data to a second location. The COPYBACK PROGRAM command is functionally identical to the PROGRAM PAGE command, except that when 0x85 is written to the target internal command register, the cache register contents are not cleared.

The SEQ\_9 command sequence does not have the data phase, so the data from the cache register are written into the second location without modification. If data must be written with modification to the second location, the SEQ\_12 command sequence, which includes the data phase, is used.

## b. Command Encoding

The COPYBACK PROGRAM instruction uses the SEQ\_9 commands sequence. The command is encoded, as shown in the following table:

Table 7.80 COPYBACK PROGRAM Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|-------|---------------|-------|----------|-----------|----------|
| _     | 0x10          | 0x85  | _        | _         | SEQ_9_ID |

### 7.5.4.37 COPYBACK PROGRAM 1 Command

### a. Command Description

The COPYBACK PROGRAM 1 command is functionally identical to the PROGRAM PAGE 1 command, except that when 0x85 is written to the target internal command register, the cache register contents are not cleared.

See Section 7.5.4.27, PROGRAM PAGE 1 Command for further details.

#### b. Command Encoding

The COPYBACK PROGRAM 1 instruction uses the SEQ\_13 commands sequence. The command is encoded as shown in the following table:

Table 7.81 COPYBACK PROGRAM 1 Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| _     | _             | 0x85  | 0        | _         | SEQ_13_ID |

#### 7.5.4.38 COPYBACK MULTIPLANE Command

# a. Command Description

The COPYBACK MULTIPLANE command is functionally identical to the PROGRAM MULTIPLANE command, except that when 0x85 is written to the target internal command register, cache register contents are not cleared.

See Section 7.5.4.29, PROGRAM MULTIPLANE Command for further details.

#### b. Command Encoding

The COPYBACK MULTIPLANE instruction uses the SEQ\_12 commands sequence. The command is encoded, as shown in the following table:

Table 7.82 COPYBACK MULTIPLANE Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| _     | 0x11          | 0x85  | 0        | 0/1       | SEQ_12_ID |



#### 7.5.4.39 PROGRAM OTP Command

#### a. Command Description

The PROGRAM OTP command is used to write data to the pages within the OTP area. An entire page can be programmed at one time, or a page can be partially programmed up to four times. There is no ERASE operation for the OTP pages.

To use the PROGRAM OTP command, the controller issues the 0xA0 command. Next, 5 address cycles are issued. The address write is followed by a programmable number of data cycles.

After data input is complete, the controller issues the 0x10 command. The internal control logic automatically executes the proper programming algorithm and controls the necessary timing for programming and verification.

# b. Command Encoding

The PROGRAM OTP instruction uses the SEQ\_12 commands sequence. The command is encoded as shown in the following table:

Table 7.83 PROGRAM OTP Instruction Encoding

| CMD_2    | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|----------|---------------|-------|----------|-----------|-----------|
| <u> </u> | 0x10          | 0xA0  | 0        | 0/1       | SEQ_12_ID |

## 7.5.4.40 DATA PROTECT OTP Command

### a. Command Description

The DATA PROTECT OTP command is used to protect all the data in the OTP area. After the data is protected, it cannot be further programmed. When the OTP area is protected, the pages within the area are no longer programmable and cannot be unprotected.

To use the DATA PROTECT OTP command, the controller issues the 0xA5 command. Next, the controller issues the following 5 addresses cycles. Finally, the 0x10 command is issued.

# b. Command Encoding

The DATA PROTECT OTP instruction uses the SEQ\_9 commands sequence. The command is encoded, as shown in the following table:

Table 7.84 DATA\_PROTECT OTP Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ  |
|-------|---------------|-------|----------|-----------|----------|
| _     | 0x10          | 0xA5  | _        | _         | SEQ_9_ID |

## 7.5.4.41 PAGE READ OTP Command

# a. Command Description

The PAGE READ OTP command is used to read data from a page within the OTP area. An OTP page within the OTP area is available for reading data whether or not the area is protected.

To use the PAGE READ OTP command, the controller issues the 0xAF command. Next, 5 address cycles are issued. Finally, the 0x30 command is issued. After internal read from the NAND matrix is ended, the data is copied to the FIFO.

# b. Command Encoding

The PAGE READ OTP instruction uses the SEQ\_10 commands sequence. The command is encoded, as shown in the following table:

Table 7.85 PAGE READ OTP Instruction Encoding

| CMD_2 | CMD_1 / CMD_3 | CMD_0 | DATA_SEL | INPUT_SEL | CMD_SEQ   |
|-------|---------------|-------|----------|-----------|-----------|
| 0x30  | _             | 0xAF  | 0/1      | 0/1       | SEQ_10_ID |

## 7.5.5 Multi LUN Work Mode

The multi LUN work mode is enabled by setting the MLUN\_EN bit in the CONTROL register. In this mode, each LUN is handled as separate target. The active LUN number is decoded directly from the address value.

This multi LUN mode is parameterized by the following parameters:

- The MLUN\_IDX field in the MLUN register. This parameter provides the bits index for the last address byte where the LUN select bits is present. This parameter must be set according to the NAND Flash device datasheet in use.
- The MLUN\_SEL bits in MLUN register is used to configure the number of LUN-s per device.
- The LUN STATUS 0 holds the LUN-s statuses, each bit corresponds to the single LUN status.
- The STATE\_MASK field in the STATUS\_MASK register. This parameter is used to mask the part of the LUN status byte that will be ignored during the LUN ready/busy check.

# 7.5.6 Remapping Mechanism

The remapping mechanism implemented in the core is designed to support the bad blocks management solution in the core application. The hardware remapping mechanism relieves software from the time-consuming operations of finding the physical address for the given linear address in the requested operation. The software initializes only the remapping tables for uses in the application of the NAND Flash device. It sorts those tables in ascending order, and then the whole operation of searching tables and substituting addresses is accomplished automatically.

The remapping solution uses two groups of the control registers:

- The pointer registers DEV0\_PTR DEV3\_PTR. These registers store the address in the system memory where record tables used by the BBM mechanism are placed. Each device in the bank uses a separate table. All tables are sorted in ascending order.
- The size registers DEV0\_SIZE DEV3\_SIZE. These registers store the number of records in a table. Each device in the bank uses a separate register to store the table size.

The remapping module uses the special CAM memory implementation built around the 32-bit registers. This solution requires use of the record of the eight 32-bit width words as the smallest entity of data in the BBM solution. Each row in the record has two 16-bit width columns. The column that uses the lower part of the word stores the source address that will be replaced by the destination address in the remapping process. The column that uses the higher part of the word stores the destination address which replaces the source address in the remapping process. The unused rows in the record are filled with all ones values.

The following figure shows the record structure:



Figure 7.28 Example of BBM Records

The remapping process begins with the search. The source address fields are compared in parallel with the current request block address. If there is a source address equal to the request address, then the remapping module returns the destination address from the same row in the record. If there is no match, then the remapping module returns the request address itself.

# 7.5.7 Interrupts Mechanism

The NAND Flash Controller interrupt system uses two control registers:

- The interrupt mask register (INT\_MASK) each bit of this register masks a single interrupt. The register is described in more detail in **Section 7.4**, **Register Description**.
- The interrupt flag register (INT\_STATUS) each bit of this register is an active flag from the single interrupt source. The register is described in more detail in **Section 7.4**, **Register Description**.

Both registers are aligned in the same way. Corresponding bits of these registers are related to the same interrupt source. On the core, only the top level single interrupt line is present. This line is set when any of the bit pairs in the interrupts flag and mask registers are set.

The available interrupt sources are:

- Write/Erase protects mechanism interrupt.
   This interrupt occurs when the write/erase operation to the protected area is triggered. This interrupt is valid only if the hardware write/erase feature is implemented in the core and is enabled in the CONTROL register.
- Command sequence finished interrupt.
   This interrupt occurs when the previously triggered command sequence is finished and the new one can be started.
   The command sequence is marked as finished when the full sequence is executed or when the NAND Flash device goes into the busy state.
- The ECC module detects the uncorrectable error in the transmitted data.
- The ECC module detects when the configured errors threshold level is exceeded.
- The memory device is ready.
  This interrupt occurs when the NAND Flash device finishes executing the programmed command sequence and is ready for the new one. Each NAND Flash device has a single interrupt flag. The difference between "command sequence finished" interrupt and "memory device is ready" interrupt is presented in the following figure.
- The error on the slave interface during access to the controller FIFO.

  This interrupt occurs if the access to the FIFO memory has the opposite direction to the current FIFO configuration: the FIFO is read when it is configured for write, or the FIFO is write when it is configured for read.



Figure 7.29 Command Sequence End and Memory-Ready Interrupts

# 7.6 Setup and Configuration

The CONTROL register is the main control register in the NAND Flash Controller.

The following bits configure basic settings of the controller:

- INT EN Bit which enables Interrupt.
- ECC\_EN Bit which enables Hardware ECC.
- BLOCK\_SIZE Bits which configure block size.
- IO\_WIDTH Bit which configures width of the I/O bus connected to the NAND Flash memory device.
- BBM\_EN Bit which enables remapping process.
- PROT EN Bit which enables Protect mechanism.
- ADDR[n]\_AUTO\_INCR Addresses auto increment for row address register 0 or 1.
- SMALL\_BLOCK\_EN Bit which enables Small Block Mode.
- MLUN\_EN Bit which enables Multi LUN mode.
- AUTO\_READ\_STAT\_EN Bit which activates automatic read status after the PROGRAM PAGE and BLOCK ERASE commands.
- READ\_STATUS\_EN Bit which chooses whether the controller checks RnB lines or sends READ\_STATUS commands.
- ECC\_BLOCK\_SIZE Bits which define ECC Block Size.

The registers described below are configured according to the settings of other bits in the CONTROL register:

- (1) Basic setting is done with the CONTROL register.
- (2) If INT\_EN bit is set, the software must write the mask into the INT\_MASK register, which masks the selected interrupts source in the NAND Flash Controller.
- (3) If ECC\_EN bit is set, the software must correctly configure the ECC module by writing the appropriate configuration into the ECC\_CTRL. Additionally, the software configures the offset in the ECC\_OFFSET register. In small block mode, the value in the ECC\_OFFSET is ignored and the correction words are located in the NAND Flash memory device, right behind the data.
- (4) The write number of the data which will be transferred by the controller (DATA\_SIZE register). When ECC is enabled, there are some restrictions to the DATA\_SIZE value.
- (5) If the BBM\_EN bit is set, the software must initialize the remapping tables (DEV[n]\_PTR and DEV[n]\_SIZE registers).
- (6) If the PROT\_EN bit is set, the software can protect the area space which cannot be erased or overwritten. The PROTECT register defines the area that will be protected against any modifications.
- (7) Additionally, the software must configure time parameters which can be found in the TIMINGS\_ASYN register for asynchronous mode. Additionally, the software must configure the TIME\_SEQ\_0 and TIME\_SEQ\_1 registers.

When the NAND Flash Controller uses DMA to transfer data, the software must configure the DMA\_ADDR, DMA\_CTRL and DMA\_CNT registers. The software can modify these registers before any transfer or during the initialization procedure.



Figure 7.30 Configuration

## 7.6.1 Send Data to NAND Flash via Slave Interface

- (1) The NAND Flash Controller must be correctly configured before sending data to the NAND Flash memory device. The setup process is described in detail in the previous **Section 7.6**, **Setup and Configuration** and in the **Section 7.4**, **Register Description**.
- (2) Write the address of the data in NAND Flash memory into the address register 0 (ADDR0\_COL and ADDR0\_ROW registers). Write the number of data which you want to read (DATA\_SIZE register). Choose the active memory device in the MEM\_CTRL register (MEM\_CE bits). Additionally, the software must check that the MEM[n]\_WP bit which corresponds to the memory device (write protect must be disabled).
- (3) To use the simplest program command, write 0x0010800C to the COMMAND register (PROGRAM PAGE command, FIFO module selected, AHBS module as input).
- (4) Write data to the FIFO using the FIFO\_DATA register. Data is sent to the NAND Flash memory device.

When the memory is ready for further work, the appropriate bit MEM[n]\_ST is set. When the software needs to send the command to another memory, it is not necessary to wait for the MEM[n]\_ST bit to be set.



Figure 7.31 Write Data to NAND Flash Memory via Slave Interface

## 7.6.2 Read Data from NAND Flash via Slave Interface

- (1) The NAND Flash Controller must be correctly configured before sending data to the NAND Flash memory device. The setup process is described in detail in the previous **Section 7.6**, **Setup and Configuration** and in the **Section 7.4**, **Register Description**.
- (2) Write the address of the data in NAND Flash memory into the address register 0 (ADDR0\_COL and ADDR0\_ROW registers). Write the number of data which you want to read (DATA\_SIZE register). Choose the active memory device in the MEM\_CTRL register (MEM\_CE bits).
- (3) To use the simplest read command, write 0x3000002A to the COMMAND register (READ PAGE command, FIFO module selected, AHBS module as input).
- (4) It is recommended to read FIFO\_STATE register and wait when CF\_EMPTY bit is set. After that wait for the DF\_R\_EMPTY bit in the FIFO\_STATE register to be clear.
- (5) Read data from the FIFO using the FIFO\_DATA register.

When the memory is ready for further work, the appropriate bit MEM[n]\_ST is set. When the software needs to send the command to another memory, it is not necessary to wait for the MEM[n]\_ST bit to be set.



Figure 7.32 Read Data from NAND Flash Memory via Slave Interface

# 7.6.3 Send Data to NAND Flash via Master Interface (Using DMA)

- (1) The NAND Flash Controller must be correctly configured before sending data to the NAND Flash memory device. The setup process is described in detail in the previous Section 7.6, Setup and Configuration and in the Section 7.4, Register Description.
- (2) Set the INT\_EN bit in the CONTROL register to enable interrupt.
- (3) Select active interrupt in the INT\_MASK register and write 0x00000000 into the INT\_STATUS register to clear all interrupts.
- (4) Select the DMA work mode to configure the DMA module correctly: In register's-managed mode, the address of the data is written in the system memory (DMA\_ADDR register). Write the number of the transferred data into the DMA\_CNT register. Set bit DMA\_START to start DMA when the command sequence is sent to the NAND Flash memory. Bits ERR\_FLAG and DMA\_READY are read-only. The first indicates the error on the internal system bus while DMA is transferring data; the second indicates when DMA is ready (transfer is completed).
- (5) Write the address of the data in the NAND Flash memory device into the address register 0. Choose the active memory device in the MEM\_CTRL register (MEM\_CE bits). Additionally, the software must confirm that the MEM[n]\_WP bit which corresponds to the memory device (Write protect must be disabled).
- (6) To use the simplest program command, write 0x0010804C to the COMMAND register (PROGRAM PAGE command, FIFO module selected, DMA module as input).
- (7) When the memory is ready for further work, the appropriate bit MEM[n]\_ST is set and interrupt is active.



Figure 7.33 Send Data to NAND Flash Using DMA Interrupt Enable

# 7.6.4 Fast Writing and Reading of Several Pages from the Memory Using DMA

- (1) The NAND Flash Controller must be correctly configured before sending data to the NAND Flash memory device. The setup process is described in detail in the previous Section 7.6, Setup and Configuration and in the Section 7.4, Register Description.
- (2) Set INT\_EN bit in CONTROL register to enable interrupt.
- (3) Select the active interrupt (CMD\_END\_INT\_EN) in the INT\_MASK register and write 0x00000000 into the INT\_STATUS register to clear all interrupts.
- (4) In Scatter-Gather mode, it is necessary to write the descriptors into the system memory. Select the DMA work mode to correctly configure the DMA module. In Scatter-Gather mode, it is not necessary to configure the DMA\_CNT register.
- (5) Set DMA\_START bit to start the DMA when the command sequence is sent to the NAND Flash memory. Bits ERR\_FLAG and DMA\_READY are read-only. The former indicates the error on the system bus while DMA is transferring data, the latter indicates when the DMA is ready (transfer is completed).
- (6) Choose the active memory device in the MEM\_CTRL register (MEM\_CE bits). Additionally, the software must confirm if the MEM[n]\_WP bit which corresponds to the memory device (Write protection must be disable). Set the ADDR0\_AUTO\_INCR bit to auto increment row address 0 register after each command. Write address of the data in the NAND Flash memory device into the address register 0.
- (7) Write 0x00000000 into the INT\_STATUS register to clear all interrupts.
- (8) Write address of the first descriptor into the DMA\_ADDR register.
- (9) Write PROGRAM PAGE CACHE command to the NAND Flash memory device by writing 0x0015804C into the COMMAND register (DMA module as input, FIFO module selected). When the controller is ready for further work, the appropriate CMD\_END\_INT\_FL bit is set and the interrupt is activated.
- (10) When the number of the pages to transfer does not equal one, go to section 7.
- (11) The last command in the sequence of sending data is the PROGRAM PAGE (write 0x0010804C) into the COMMAND register (DMA module as input, FIFO module selected).
- (12) Write the address of the read data to the NAND Flash memory device into address register 0.
- (13) Write the new descriptors to the system memory.
- (14) If DMA should work in the same work mode and burst type do not modify DMA\_BURST and DMA\_MODE bits. Set DMA\_START bit to start DMA when the command sequence is sent to the NAND Flash memory.
- (15) Write the READ PAGE command into the NAND Flash memory device by writing 0x30000069 into the COMMAND register (FIFO module selected, DMA module as input).
- (16) Write the address of the first descriptor to the DMA\_ADDR register.
- (17) Write 0x00000000 into the INT\_STATUS register to clear all interrupts.
- (18) Write READ PAGE CACHE command to the NAND Flash memory device by writing 0x0000316B into the COMMAND register (FIFO module selected, DMA module as input).
- (19) When the controller is ready for further work, the appropriate CMD\_END\_INT\_FL bit is set and the interrupt is activated. When the number of the pages to transfer does not equal zero, go to section 16.
- (20) The last command in the sequence of reading data is READ PAGE CACHE LAST (write 0x00003F6B into the COMMAND register).



Figure 7.34 Fast Writing and Reading of Several Pages from the Memory Using DMA

# 7.6.5 Writing of Data into Two NAND Flash Memory Devices

Here is an example of how to write data into two NAND Flash memory devices:



Figure 7.35 Writing Data into Two NAND Flash Memory Devices 1



Figure 7.36 Writing Data into Two NAND Flash Memory Devices 2

# 7.6.6 Reading Data from Two NAND Flash Memory Devices

Here is an example of how to read data from two NAND Flash memory devices:



Figure 7.37 Reading Data from Two NAND Flash Memory Devices

# 7.6.7 Writing Data into Four NAND Flash Memory Devices

Here is an example of how to write data into four NAND Flash memory devices:



Figure 7.38 Writing Data into Four NAND Flash Memory Devices 1



Figure 7.39 Writing Data into Four NAND Flash Memory Devices 2

# 7.6.8 Reading Data from Four NAND Flash Memory Devices

Here is an example of how to read data from four NAND Flash memory devices:



Figure 7.40 Reading Data from Four NAND Flash Memory Devices 1



Figure 7.41 Reading Data from Four NAND Flash Memory Devices 2

# 7.6.9 Writing Partial Pages

The following procedure need to be used to write partial pages with ECC engine enabled:

- (1) The NAND Flash Controller must be correctly configured before sending data to the NAND Flash memory device. The setup process is described in detail in the previous **Section 7.6**, **Setup and Configuration** and in the **Section 7.4**, **Register Description**.
- (2) Write the address of the data in NAND Flash memory into the address register 0 (ADDR0\_COL and ADDR0\_ROW registers). You need to write partial page offset into the ADDR0\_COL register. Write the number of data which you want to read (DATA\_SIZE register) in this case you need to set partial sector size. Choose the active memory device in the MEM\_CTRL register (MEM\_CE bits). Write the offset value of the ECC data into the ECC\_OFFSET register. Additionally, the software must check that the MEM[n]\_WP bit which corresponds to the memory device (write protect must be disabled).
- (3) To use the simplest program command, write 0x0010800C to the COMMAND register (PROGRAM PAGE command, FIFO module selected, AHBS module as input).
- (4) Write data to the FIFO using the FIFO\_DATA register. Data is sent to the NAND Flash memory device.



Figure 7.42 Writing Partial Pages

# 7.6.10 Reading Partial Pages

- (1) The NAND Flash Controller must be correctly configured before sending data to the NAND Flash memory device. The setup process is described in detail in the previous **Section 7.6**, **Setup and Configuration** and in the **Section 7.4**, **Register Description**.
- (2) Write the address of the data in NAND Flash memory into the address register 0 (ADDR0\_COL and ADDR0\_ROW registers). You need to write partial page offset into the ADDR0\_COL register. Write the number of data which you want to read (DATA\_SIZE register) in this case you need to set partial page size. Choose the active memory device in the MEM\_CTRL register (MEM\_CE bits).
- (3) To use the simplest read command, write 0x3000002A to the COMMAND register (READ PAGE command, FIFO module selected, AHBS module as input).
- (4) It is recommended to read FIFO\_STATE register and wait when CF\_EMPTY bit is set. After that wait for the DF\_R\_EMPTY bit in the FIFO\_STATE register to be clear.
- (5) Read data from the FIFO using the FIFO\_DATA register.



Figure 7.43 Reading Partial Pages

# 7.7 ECC Module

The ECC module is based on one of the BCH algorithms and allows correction of multiple bit errors. The ECC engine integrated into the NAND Flash Controller has the following properties:

- The encoder and decoder works on the 256, 512, 1024 bytes data blocks.
- Programmable correction capability: 2, 4, 8, 16, 24 or 32 errors.
- The corrected data words are aligned to the 32 bits.
- The correction words are aligned to the 32 bits.
- Correction words are placed after the data.
- The NAND Flash control unit writes to the target NAND Flash device only the valid correction word bytes.

# 7.7.1 ECC and Data Location within the Page

There is one method of organizing information within the page. Generally, the physical data organization within the page is transparent to the software. ECC and extended information is stored at the top of the page, above all subpages of user data – see figure below.



Figure 7.44 Data in Data Area, ECC Stored in the Spare Area

# 7.7.2 BCH Algorithm Implementation

- Data block length: 256 (small block memory), 512 bytes or 1024 bytes.
- Programmable memory page length, multiple of the block length by any power of 2.
- Programmable correction capability: 2, 4, 8, 16, 24 or 32 errors.
- Separate encoder and decoder modules.
- Calculation of correction data performed during write to memory.
- Error detection performed during read data from memory.
- Internal pipeline allows the correction of errors in one data block simultaneously with detection of errors in the following data block.

Table 7.86 Size of Correction Bytes

| Correction<br>Capability | ECC Block Size     | Size of Correction Bytes per one ECC Block (IO_WIDTH = 8) |
|--------------------------|--------------------|-----------------------------------------------------------|
| 2                        | 256 / 512 / 1024 B | 4                                                         |
| 4                        | 256 / 512 / 1024 B | 7                                                         |
| 8                        | 256 / 512 / 1024 B | 14                                                        |
| 16                       | 256 / 512 / 1024 B | 28                                                        |
| 24                       | 256 / 512 / 1024 B | 42                                                        |
| 32                       | 256 / 512 / 1024 B | 56                                                        |

# 7.8 Usage Notes

# 7.8.1 ADDR[n]\_COL and ADDR[n]\_ROW Registers

The address registers store the packaged version of the address that will be used by the next command sequence during access to the NAND Flash device.

| Address    | Register Symbol | Register Name             |
|------------|-----------------|---------------------------|
| 4010 2024h | ADDR0_COL       | Column Address 0 Register |
| 4010 2028h | ADDR0_ROW       | Row Address 0 Register    |
| 4010 202Ch | ADDR1_COL       | Column Address 1 Register |
| 4010 2030h | ADDR1_ROW       | Row Address 1 Register    |

ADDR[n]\_COL - [15:0] - Column address. A15-A0 address bits.

ADDR[n]\_ROW – [23:0] – Row address. A39-A16 address bits (Page address, Block address and LUN address in the ONFI case).

#### CAUTION

There is no register that defines the total memory size of the NAND Flash memory chip, thus the controller is not able to determine which address bits in ADDR[n]\_COL and ADDR[n]\_ROW registers are important and which must be zero. For this reason, the software must take special care with the values written to these registers. Incorrect values of unused address bits (none '0' values) can cause errors in memory access.

A relation between address register's and memory device address width is configured by the command sequence field of the COMMAND register. This field determines which command sequence has to be used and how many number of address bytes are used when addressing a NAND Flash memory device. (Example: In order to erase blocks, the three address cycles containing the row address are written into the NAND Flash memory device. The NAND Flash Controller automatically writes bits A39-A16 to the NAND Flash device). Refer to **Section 7.5.2.2, Command Sequence Encoding** in order to see how many address cycles are written into the NAND Flash memory device by each Command Sequence.

The address written to the address register must be aligned according to the NAND Flash device. Unused bits must be padded with zeros.

#### **CAUTION**

When the auto increment for the row address register is enabled, the proper value of this register can be read only when the bit CTRL\_STAT in STATUS register is clear.

Table 7.87 Address Cycles

| Address Cycle | FNAND_IO<br>[0] | FNAND_IO<br>[1] | FNAND_IO<br>[2] | FNAND_IO [3] | FNAND_IO<br>[4] | FNAND_IO<br>[5] | FNAND_IO<br>[6] | FNAND_IO<br>[7] |
|---------------|-----------------|-----------------|-----------------|--------------|-----------------|-----------------|-----------------|-----------------|
| 1st cycle     | A0              | A1              | A2              | A3           | A4              | A5              | A6              | A7              |
| 2nd cycle     | A8              | A9              | A10             | A11          | A12             | A13             | A14             | A15             |
| 3rd cycle     | A16             | A17             | A18             | A19          | A20             | A21             | A22             | A23             |
| 4th cycle     | A24             | A25             | A26             | A27          | A28             | A29             | A30             | A31             |
| 5th cycle     | A32             | A33             | A34             | A35          | A36             | A37             | A38             | A39             |

# 7.8.2 Protect Register (PROTECT)

The NAND Flash Controller allows the defining of the area that will be protected against any modifications.

| Address    | Register Symbol | Register Name    |
|------------|-----------------|------------------|
| 4010 2034h | PROTECT         | Protect Register |

The protected area is a space which cannot be erased or overwritten. Any attempt to erase/overwrite this space always ends with an error. Since write and erase processes have constraints (only Page can be written and only Block can be erased), the protected area can be defined with Block-size precision.

The PROTECT register lower bits [15:0] define the beginning address of the protected area and are related to the NAND Flash memory block address bits of ADDR0\_ROW and ADDR1\_ROW register's.

The PROTECT register higher bits [31:16] define the ending address of the protected area and are related to the NAND Flash memory block address bits of ADDR0\_ROW and ADDR1\_ROW register's.

Figure below shows how the PROTECT register fields are used to define the protected area.



Figure 7.45 Protected Area

# 7.8.3 Asynchronous Mode Timings Register (TIMINGS\_ASYN)

The NAND Flash Controller is intended for use with a wide range of host clock rates. To maximize flexibility, some timing parameters are configurable. Two waveform configuration parameters are defined in the TIMINGS\_ASYN register.

| Address    | Register Symbol | Register Name                      |
|------------|-----------------|------------------------------------|
| 4010 2088h | TIMINGS_ASYN    | Asynchronous Mode Timings Register |

The value generated by the controller equals the minimum value written into the register, increased by 1. All the timings are generated using the NAND\_ECLK clock signal.

The figure below shows how timings parameters are mapped to the NAND Flash interface. The upper part of figure shows read transfer, lower part shows write transfer.



Figure 7.46 Timing Parameters (ASYNC)

# 7.8.4 Command Sequence Timing Register 1 (TIME\_SEQ\_1)

The NAND Flash Controller is intended for use with a wide range of host clock rates. To maximize flexibility, some timing parameters are configurable. Some waveform configuration parameters are defined in the TIME\_SEQ\_1 register.

| Address    | Register Symbol | Register Name                      |
|------------|-----------------|------------------------------------|
| 4010 2094h | TIME_SEQ_1      | Command sequence timing register 1 |

The value generated by the controller equals the minimum value written into the register, increased by 1. All the timings are generated using the NAND\_ECLK clock signal.

The figure below shows how the t<sub>ww</sub> timing parameter is mapped to the NAND flash interface.



Figure 7.47 Timing Parameters (tww)

# Section 8 Quad IO SPI

Portions © Copyright Cadence Design System Inc 2012 to 2016. All right reserved worldwide. Used with permission.

# 8.1 Overview

- Up to 2 units
- Single, dual or quad I/O instructions supported
- Memory mapped 'direct' access to FLASH data supported
- Supported read performance enhanced mode (NoCMD mode) for most QSPI flash devices
- Remap address direct access
- Programmable device sizes
- Up to 4 chip selects
- Support for 1/2/3/4 byte addressing
- Support for programmable page size default 256 bytes
- Support for programmable number of bytes per device block
- Programmable write protected regions
- Transmit and receive FIFOs are 16 bytes
- Legacy mode allowing software direct access to low level transmit and receive FIFOs
- Set of control registers to perform any FLASH command
- Support for write burst in direct access
- Not support for Burst Read with wrap



Figure 8.1 Quad SPI Controller Interfaces and Connections

# 8.2 Signal interfaces

|                   | Input        |                                        |  |  |
|-------------------|--------------|----------------------------------------|--|--|
| Signal Name       | Output       | Description                            |  |  |
| Clock             |              |                                        |  |  |
| QSPI[m]_HCLK      | Input        | Internal bus clock (AHB)               |  |  |
| QSPI[m]_PCLK      | Input        | Internal bus clock (APB)               |  |  |
| QSPI[m]_REFCLK    | Input        | Reference clock for external signal    |  |  |
| Interrupt         |              |                                        |  |  |
| QSPI[m]_Int       | Output       | Level sensitive interrupt, Active High |  |  |
| External Signal   |              |                                        |  |  |
| QUAD[m]_CLK       | Output       | Master clock output                    |  |  |
| QUAD[m]_IO[3:0]   | Input/Output | Data input/output                      |  |  |
| QUAD[m]_CS_N[3:0] | Output       | Chip select                            |  |  |

**Note:** m = 1 or 2

Index removed style is used in this chapter. Ex) QUAD\_CLK

## **CAUTION**

QUAD[m]\_IO[3]: Not support for HOLD signal to the flash device when not in quad I/O mode

# 8.3 Register Map

Table 8.1 Register Map of QSPI1

| Address    | Register Symbol           | Register Name                                   |  |  |
|------------|---------------------------|-------------------------------------------------|--|--|
| 4000 5000h | config_reg                | QSPI Configuration Register                     |  |  |
| 4000 5004h | dev_instr_rd_config_reg   | Device Read Instruction Configuration Register  |  |  |
| 4000 5008h | dev_instr_wr_config_reg   | Device Write Instruction Configuration Register |  |  |
| 4000 500Ch | dev_delay_reg             | QSPI Device Delay Register                      |  |  |
| 4000 5010h | rd_data_capture_reg       | Read Data Capture Register                      |  |  |
| 4000 5014h | dev_size_config_reg       | Device Size Configuration Register              |  |  |
| 4000 5024h | remap_addr_reg            | Remap Address Register                          |  |  |
| 4000 5028h | mode_bit_config_reg       | Mode Bit Configuration Register                 |  |  |
| 4000 5030h | tx_thresh_reg             | TX Threshold Register                           |  |  |
| 4000 5034h | rx_thresh_reg             | RX Threshold Register                           |  |  |
| 4000 5038h | write_completion_ctrl_reg | Write Completion Control Register               |  |  |
| 4000 503Ch | no_of_polls_bef_exp_reg   | Polling Expiration Register                     |  |  |
| 4000 5040h | irq_status_reg            | Interrupt Status Register                       |  |  |
| 4000 5044h | irq_mask_reg              | Interrupt Mask Register                         |  |  |
| 4000 5050h | lower_wr_prot_reg         | Lower Write Protection Register                 |  |  |
| 4000 5054h | upper_wr_prot_reg         | Upper Write Protection Register                 |  |  |
| 4000 5058h | wr_prot_ctrl_reg          | Write Protection Control Register               |  |  |
| 4000 5090h | flash_cmd_ctrl_reg        | Flash Command Control Register                  |  |  |
| 4000 5094h | flash_cmd_addr_reg        | Flash Command Address Register                  |  |  |
| 4000 50A0h | flash_rd_data_lower_reg   | Flash Command Read Data Register (Lower)        |  |  |
| 4000 50A4h | flash_rd_data_upper_reg   | Flash Command Read Data Register (Upper)        |  |  |
| 4000 50A8h | flash_wr_data_lower_reg   | Flash Command Write Data Register (Lower)       |  |  |
| 4000 50ACh | flash_wr_data_upper_reg   | Flash Command Write Data Register (Upper)       |  |  |
| 4000 50B0h | polling_flash_status_reg  | Polling Flash Status Register                   |  |  |
| 4000 50FCh | module_id_reg             | Module ID Register                              |  |  |

Table 8.2 Register Map of QSPI2 (RZ/N1S only)

| 1 4510 0.2 | register map or der 12 (112/11/10 only) |                                                 |
|------------|-----------------------------------------|-------------------------------------------------|
| Address    | Register Symbol                         | Register Name                                   |
| 4000 E000h | config_reg                              | QSPI Configuration Register                     |
| 4000 E004h | dev_instr_rd_config_reg                 | Device Read Instruction Configuration Register  |
| 4000 E008h | dev_instr_wr_config_reg                 | Device Write Instruction Configuration Register |
| 4000 E00Ch | dev_delay_reg                           | QSPI Device Delay Register                      |
| 4000 E010h | rd_data_capture_reg                     | Read Data Capture Register                      |
| 4000 E014h | dev_size_config_reg                     | Device Size Configuration Register              |
| 4000 E024h | remap_addr_reg                          | Remap Address Register                          |
| 4000 E028h | mode_bit_config_reg                     | Mode Bit Configuration Register                 |
| 4000 E030h | tx_thresh_reg                           | TX Threshold Register                           |
| 4000 E034h | rx_thresh_reg                           | RX Threshold Register                           |
| 4000 E038h | write_completion_ctrl_reg               | Write Completion Control Register               |
| 4000 E03Ch | no_of_polls_bef_exp_reg                 | Polling Expiration Register                     |
| 4000 E040h | irq_status_reg                          | Interrupt Status Register                       |
| 4000 E044h | irq_mask_reg                            | Interrupt Mask Register                         |
| 4000 E050h | lower_wr_prot_reg                       | Lower Write Protection Register                 |
| 4000 E054h | upper_wr_prot_reg                       | Upper Write Protection Register                 |
| 4000 E058h | wr_prot_ctrl_reg                        | Write Protection Control Register               |
| 4000 E090h | flash_cmd_ctrl_reg                      | Flash Command Control Register                  |
| 4000 E094h | flash_cmd_addr_reg                      | Flash Command Address Register                  |
| 4000 E0A0h | flash_rd_data_lower_reg                 | Flash Command Read Data Register (Lower)        |
| 4000 E0A4h | flash_rd_data_upper_reg                 | Flash Command Read Data Register (Upper)        |
| 4000 E0A8h | flash_wr_data_lower_reg                 | Flash Command Write Data Register (Lower)       |
| 4000 E0ACh | flash_wr_data_upper_reg                 | Flash Command Write Data Register (Upper)       |
| 4000 E0B0h | polling_flash_status_reg                | Polling Flash Status Register                   |
| 4000 E0FCh | module_id_reg                           | Module ID Register                              |
| •          |                                         |                                                 |

# 8.4 Register Description

# 8.4.1 config\_reg — QSPI Configuration Register

**Address:** 4000 5000h (QSPI1) 4000 E000h (QSPI2)

| Bit               | b31               | b30                       | b29 | b28      | b27        | b26 | b25 | b24 | b23                            | b22 | b21       | b20      | b19 | b18                            | b17                 | b16                            |
|-------------------|-------------------|---------------------------|-----|----------|------------|-----|-----|-----|--------------------------------|-----|-----------|----------|-----|--------------------------------|---------------------|--------------------------------|
|                   | qspi_idl<br>e_fld | -                         | _   | _        | _          | _   | _   | ı   | enable_a<br>hb_decod<br>er_fld |     | mstr_baud | _div_fld |     | enter_xip_<br>mode_im<br>m_fld |                     | enb_ahb_<br>addr_rem<br>ap_fld |
| Value after reset | 1                 | 0                         | 0   | 0        | 0          | 0   | 0   | 0   | 0                              | 1   | 1         | 1        | 1   | 0                              | 0                   | 0                              |
| Bit               | b15               | b14                       | b13 | b12      | b11        | b10 | b9  | b8  | b7                             | b6  | b5        | b4       | b3  | b2                             | b1                  | b0                             |
|                   | ı                 | wr_prot<br>_flash<br>_fld | ŗ   | eriph_cs | _lines_flo | d   |     |     | enb_dir<br>_acc_ctl<br>r_fld   | _   | _         | _        | _   | sel_clk_<br>phase<br>_fld      | sel_clk_<br>pol_fld | enb_qsp<br>i_fld               |
| Value after reset | 0                 | 0                         | 0   | 0        | 0          | 0   | 0   | 0   | 1                              | 0   | 0         | 0        | 0   | 0                              | 0                   | 1                              |

Table 8.3 config\_reg Register Contents (1/3)

| Bit Position | Bit Name           | Function                                                                                                                                                                                                                                                                                                                          |                                                               | R/W |  |  |  |  |  |  |  |
|--------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|-----|--|--|--|--|--|--|--|
| b31          | qspi_idle_fld      | Serial interface and QSPI pipeline are IDLE  This is a STATUS read-only bit.  Note this is a retired signal, so there will be some inherent delay on the generation of                                                                                                                                                            |                                                               |     |  |  |  |  |  |  |  |
|              |                    | Note this is a retimed sigr this status signal.                                                                                                                                                                                                                                                                                   | al, so there will be some inherent delay on the generation of |     |  |  |  |  |  |  |  |
|              |                    | 0: Non-Idle mode                                                                                                                                                                                                                                                                                                                  |                                                               |     |  |  |  |  |  |  |  |
|              |                    | 1: Idle mode                                                                                                                                                                                                                                                                                                                      |                                                               |     |  |  |  |  |  |  |  |
| b30 to b24   | Reserved           |                                                                                                                                                                                                                                                                                                                                   |                                                               | R   |  |  |  |  |  |  |  |
| b23          | enable_ahb_decoder | Enable Address Decoder (Direct Access Mode Only)                                                                                                                                                                                                                                                                                  |                                                               |     |  |  |  |  |  |  |  |
|              | _fld               | Not support for the address decoder.                                                                                                                                                                                                                                                                                              |                                                               |     |  |  |  |  |  |  |  |
|              |                    | Keep the initial value.                                                                                                                                                                                                                                                                                                           |                                                               |     |  |  |  |  |  |  |  |
| b22 to b19   | mstr_baud_div_fld  | Baud Rate Divisor (4 to 32                                                                                                                                                                                                                                                                                                        | 2)                                                            | R/W |  |  |  |  |  |  |  |
|              |                    | SPI baud rate = (QSPI_R                                                                                                                                                                                                                                                                                                           | EFCLK) / ((mstr_baud_div_fld+1) × 2)                          |     |  |  |  |  |  |  |  |
|              |                    | mstr_baud_div_fld                                                                                                                                                                                                                                                                                                                 | Actual Divisor                                                |     |  |  |  |  |  |  |  |
|              |                    | 0000b                                                                                                                                                                                                                                                                                                                             | Prohibit                                                      |     |  |  |  |  |  |  |  |
|              |                    | 0001b                                                                                                                                                                                                                                                                                                                             | 4                                                             |     |  |  |  |  |  |  |  |
|              |                    |                                                                                                                                                                                                                                                                                                                                   |                                                               |     |  |  |  |  |  |  |  |
|              |                    | 1110b                                                                                                                                                                                                                                                                                                                             | 30                                                            |     |  |  |  |  |  |  |  |
|              |                    | 1111b 32                                                                                                                                                                                                                                                                                                                          |                                                               |     |  |  |  |  |  |  |  |
|              |                    | Set these bits up before enabling the Quad SPI Controller.                                                                                                                                                                                                                                                                        |                                                               |     |  |  |  |  |  |  |  |
| b18          | enter_xip_mode_imm | Enter NoCMD Mode imme                                                                                                                                                                                                                                                                                                             | ediately                                                      | R/W |  |  |  |  |  |  |  |
|              | _fld               | For detailed description refer to <b>Section 8.6.5</b> , <b>Entering and Exiting NoCMD mode</b> .  0: If NoCMD mode is enabled, then setting to 0 will cause the controller to exit NoCMD mode after the next READ instruction has completed.  1: Access to the device in NoCMD mode immediately                                  |                                                               |     |  |  |  |  |  |  |  |
|              |                    | Use this register when the external device is in NoCMD mode. The controller will assume the next READ instruction will be passed to the device as an NoCMD mode instruction, and therefore will not require the READ opcode to be transferred.                                                                                    |                                                               |     |  |  |  |  |  |  |  |
|              |                    | Note) To exit NoCMD mode on Quad SPI Controller, this bit should be set to 0. This will take effect in the attached device only after the next READ operation is executed. Software therefore should ensure that at least one READ operation is requested after resetting this bit in order to be sure that NoCMD mode is exited. |                                                               |     |  |  |  |  |  |  |  |
|              |                    | This bit is synchronized in hardware and can be set/unset while the controller is operational. Don't write 1 to enter_xip_mode_fld at the same time.                                                                                                                                                                              |                                                               |     |  |  |  |  |  |  |  |

R/W

| Table 8.3    | config_reg Register Contents (2/3) |                                                                                                                                              |     |  |  |  |  |  |  |  |  |
|--------------|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|--|--|--|
| Bit Position | Bit Name                           | Function                                                                                                                                     | R/W |  |  |  |  |  |  |  |  |
| b17          | enter_xip_mode_fld                 | Enter NoCMD Mode on next READ  For detailed description refer to Section 8.6.5, Entering and Exiting NoCMD mode.                             | R/W |  |  |  |  |  |  |  |  |
|              |                                    | If NoCMD mode is enabled, then setting to 0 will cause the controller to exit      NoCMD mode after the next READ instruction has completed. |     |  |  |  |  |  |  |  |  |

1: If NoCMD mode is disabled, then setting to "1" will inform the controller that the device is ready to enter NoCMD mode on the next READ instruction. The

controller will therefore send the appropriate command sequence, including mode bits to cause the device to enter NoCMD mode.

Use this register after the controller has ensured the FLASH device has been configured to be ready to enter NoCMD mode.

Note) To exit NoCMD mode on Quad SPI Controller, this bit should be set to 0. This will take effect in the attached device only after the next READ operation is executed. Software therefore should ensure that at least one READ operation is requested after resetting this bit in order to be sure that NoCMD mode is

This bit is synchronized in hardware and can be set/unset while the controller is operational. Don't write 1 to enter\_xip\_mode\_imm\_fld at the same time.

b16 enb\_ahb\_addr\_remap Enable AHB Address Re-mapping (Direct Access Mode Only) \_fld When set to 1, the incoming Memory Map address will be adapted and sent to the FLASH device as (address + N), where N is the value stored in the Remap Address

> This bit is synchronized in hardware and can be set/unset while the controller is operational.

| b15 | Reserved          |                                                                                                                                                                                                      | R   |
|-----|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b14 | wr_prot_flash_fld | Set to drive the Write Protect pin of the FLASH device.                                                                                                                                              | R/W |
|     |                   | Note that the WP pin is only valid in SINGLE or DUAL transfer modes. During QUAD transfers, the WP pin is used for transferring data and therefore any setting of this register bit will be ignored. |     |
|     |                   | This hit is synchronized in hardware and can be set/unset while the controller is                                                                                                                    |     |

operational.

0: Disable write protect 1: Enable write protect

Peripheral Chip Select Lines b13 to b10 periph\_cs\_lines\_fld R/W If periph sel dec fld = 0,

xxx0b: QUAD\_CS\_N[3:0] = 1110b xx01b: QUAD CS N[3:0] = 1101b x011b: QUAD CS N[3:0] = 1011b 0111b: QUAD\_CS\_N[3:0] = 0111b

1111b: QUAD\_CS\_N[3:0] = 1111b (no peripheral selected)

If periph\_sel\_dec\_fld = 1,

QUAD CS N[3:0] = periph cs lines fld

|    |                    | QUAD_C3_N[3.0] - peripri_cs_lines_lid                                                                                                                              |     |  |  |  |  |  |  |
|----|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|--|
| b9 | periph_sel_dec_fld | Peripheral select decode                                                                                                                                           |     |  |  |  |  |  |  |
|    |                    | 0: Only 1 of 4 selects QUAD_CS_N[3:0] is active                                                                                                                    |     |  |  |  |  |  |  |
|    |                    | 1: QUAD_CS_N[3:0] = periph_cs_lines_fld                                                                                                                            |     |  |  |  |  |  |  |
| b8 | enb_legacy_ip_mode | Legacy IP Mode Enable                                                                                                                                              | R/W |  |  |  |  |  |  |
|    | _fld               | 0: Use Direct Access Controller or STIG interface for data transfers                                                                                               |     |  |  |  |  |  |  |
|    |                    | 1: Legacy Mode is enabled. The controller via the AHB interface accesses the FLASH device in legacy mode (For detailed description refer to <b>Section 8.6.4</b> , |     |  |  |  |  |  |  |

Using SPI Legacy Mode). This bit is synchronized in hardware and can be set/unset while the controller is operational.

|              | <u> </u>             |                                                                                                                  |     |  |  |  |  |  |  |
|--------------|----------------------|------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|--|
| Bit Position | Bit Name             | Function                                                                                                         | R/W |  |  |  |  |  |  |
| b7           | enb_dir_acc_ctlr_fld | Enable Direct Access Controller                                                                                  | R/W |  |  |  |  |  |  |
|              |                      | <ol> <li>Disable the Direct Access Controller once current transfer of the data word is<br/>complete.</li> </ol> |     |  |  |  |  |  |  |
|              |                      | 1: Enable the Direct Access Controller                                                                           |     |  |  |  |  |  |  |
|              |                      | When the Direct Access Controller is disabled, all AHB requested are completed with an error response.           |     |  |  |  |  |  |  |
|              |                      | This bit is synchronized in hardware and can be set/unset while the controller is operational.                   |     |  |  |  |  |  |  |
| b6 to b3     | Reserved             |                                                                                                                  | R   |  |  |  |  |  |  |
| b2           | sel_clk_phase_fld    | СРНА                                                                                                             |     |  |  |  |  |  |  |
|              |                      | 0: Data is sampled on the leading edge of the clock                                                              |     |  |  |  |  |  |  |
|              |                      | 1: Data is sampled on the trailing edge of the clock                                                             |     |  |  |  |  |  |  |
| b1           | sel_clk_pol_fld      | CPOL                                                                                                             | R/W |  |  |  |  |  |  |
|              |                      | 0: The leading edge of the clock is rising and the trailing edge is falling                                      |     |  |  |  |  |  |  |
|              |                      | 1: The leading edge of the clock is falling and the trailing edge is rising                                      |     |  |  |  |  |  |  |
| b0           | enb_qspi_fld         | QSPI Enable                                                                                                      | R/W |  |  |  |  |  |  |
|              |                      | 0: Disable the QSPI once current transfer of the data word is complete.                                          |     |  |  |  |  |  |  |
|              |                      | 1: Enable the QSPI                                                                                               |     |  |  |  |  |  |  |
|              |                      | When QSPI Enable = 0, all output enables are inactive and all pins are set to input mode.                        |     |  |  |  |  |  |  |

## 8.4.2 dev\_instr\_rd\_config\_reg — Device Read Instruction Configuration Register

**Address:** 4000 5004h (QSPI1) 4000 E004h (QSPI2)



Table 8.4 dev\_instr\_rd\_config\_reg Register Contents

| l able 8.4   | dev_instr_rd_config  | _reg Register Contents                                                                                                                   |     |  |  |  |  |  |  |  |
|--------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|--|--|
| Bit Position | Bit Name             | Function                                                                                                                                 | R/W |  |  |  |  |  |  |  |
| b31 to b29   | Reserved             |                                                                                                                                          | R   |  |  |  |  |  |  |  |
| b28 to b24   | dummy_rd_clk_cycles  | Dummy Read Clock Cycles                                                                                                                  | R/W |  |  |  |  |  |  |  |
|              | _fld                 | Number of dummy clock cycles required by device for read instruction.                                                                    |     |  |  |  |  |  |  |  |
| b23 to b21   | Reserved             |                                                                                                                                          | R   |  |  |  |  |  |  |  |
| b20          | mode bit enable fld  | Mode Bit Enable                                                                                                                          | R/W |  |  |  |  |  |  |  |
|              |                      | Set this field to 1 to ensure that the mode bits as defined in the Mode Bit Configuration Register are sent following the address bytes. |     |  |  |  |  |  |  |  |
| b19, b18     | Reserved             |                                                                                                                                          | R   |  |  |  |  |  |  |  |
| b17, b16     | data xfer type ext m | Data Transfer Type, when instr_type_fld is 0.                                                                                            | R/W |  |  |  |  |  |  |  |
|              | ode_fld              | SIO mode - data is shifted to the device on QUAD_IO0 only and from the device on QUAD_IO1 only                                           |     |  |  |  |  |  |  |  |
|              |                      | <ol> <li>Used for Dual Input/Output instructions. For data transfers, QUAD_IO[1:0] are<br/>used as both inputs and outputs.</li> </ol>   |     |  |  |  |  |  |  |  |
|              |                      | <ol><li>Used for Quad Input/Output instructions. For data transfers, QUAD_IO[3:0] are<br/>used as both inputs and outputs.</li></ol>     |     |  |  |  |  |  |  |  |
|              |                      | 3: Reserved (not used)                                                                                                                   |     |  |  |  |  |  |  |  |
|              |                      | When instr_type_fld is not 0, this bit is ignored.                                                                                       |     |  |  |  |  |  |  |  |
| b15, b14     | Reserved             |                                                                                                                                          | R   |  |  |  |  |  |  |  |
| b13, b12     | addr_xfer_type_std_  | Address Transfer Type, when instr_type_fld is 0                                                                                          |     |  |  |  |  |  |  |  |
|              | mode_fld             | 0: Addresses transferred on QUAD_IO0 only                                                                                                |     |  |  |  |  |  |  |  |
|              |                      | 1: Addresses transferred on QUAD_IO[1:0] only                                                                                            |     |  |  |  |  |  |  |  |
|              |                      | 2: Addresses transferred on QUAD IO[3:0]                                                                                                 |     |  |  |  |  |  |  |  |
|              |                      | 3: Reserved (not used)                                                                                                                   |     |  |  |  |  |  |  |  |
|              |                      | When instr_type_fld is not 0, this bit is ignored.                                                                                       |     |  |  |  |  |  |  |  |
| b11, b10     | Reserved             |                                                                                                                                          | R   |  |  |  |  |  |  |  |
| b9, b8       | instr type fld       | Instruction Type                                                                                                                         | R/W |  |  |  |  |  |  |  |
| , .          | _71 _                | 0: Use Standard SPI mode (Instruction always sent on QUAD IO0 only)                                                                      |     |  |  |  |  |  |  |  |
|              |                      | 1: Use DIO-SPI mode (Instructions, Address and Data always sent on                                                                       |     |  |  |  |  |  |  |  |
|              |                      | QUAD_IO[1:0])                                                                                                                            |     |  |  |  |  |  |  |  |
|              |                      | 2: Use QIO-SPI mode (Instructions, Address and Data always sent on                                                                       |     |  |  |  |  |  |  |  |
|              |                      | QUAD_IO[3:0])                                                                                                                            |     |  |  |  |  |  |  |  |
|              |                      | 3: Reserved (not used)                                                                                                                   |     |  |  |  |  |  |  |  |
|              |                      | <b>Note)</b> These bits are relevant not just to READ transfers. They are global settings and will affect READ's, WRITES.                |     |  |  |  |  |  |  |  |
| b7 to b0     | rd opcode non xip fl | Read Opcode in non-NoCMD mode                                                                                                            | R/W |  |  |  |  |  |  |  |
|              | d - ' '-             | Read Opcode to use when not in NoCMD mode                                                                                                |     |  |  |  |  |  |  |  |

# 8.4.3 dev\_instr\_wr\_config\_reg — Device Write Instruction Configuration Register

Address: 4000 5008h (QSPI1)

4000 E008h (QSPI2)



Table 8.5 dev\_instr\_wr\_config\_reg Register Contents

| Table 0.5    | a                    | g_reg register contents                                                                                                                |     |  |  |  |  |  |  |  |
|--------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|--|--|
| Bit Position | Bit Name             | Function                                                                                                                               | R/W |  |  |  |  |  |  |  |
| b31 to b29   | Reserved             |                                                                                                                                        | R   |  |  |  |  |  |  |  |
| b28 to b24   | dummy_wr_clk_cycle   | Dummy Write Clock Cycles                                                                                                               | R/W |  |  |  |  |  |  |  |
|              | s_fld                | Number of dummy clock cycles required by device for write instruction.                                                                 |     |  |  |  |  |  |  |  |
| b23 to b18   | Reserved             |                                                                                                                                        | R   |  |  |  |  |  |  |  |
| b17, b16     | data_xfer_type_ext_m | Data Transfer Type, when instr_type_fld is 0.                                                                                          | R/W |  |  |  |  |  |  |  |
|              | ode_fld              | <ol><li>SIO mode data is shifted to the device on QUAD_IO0 only and from the device<br/>on QUAD_IO1 only</li></ol>                     |     |  |  |  |  |  |  |  |
|              |                      | <ol> <li>Used for Dual Input/Output instructions. For data transfers, QUAD_IO[1:0] are<br/>used as both inputs and outputs.</li> </ol> |     |  |  |  |  |  |  |  |
|              |                      | 2: Used for Quad Input/Output instructions. For data transfers, QUAD_IO[3:0] are used as both inputs and outputs.                      |     |  |  |  |  |  |  |  |
|              |                      | 3: Reserved (not used)                                                                                                                 |     |  |  |  |  |  |  |  |
|              |                      | When instr_type_fld is not 0, this bit is ignored.                                                                                     |     |  |  |  |  |  |  |  |
| b15, b14     | Reserved             |                                                                                                                                        | R   |  |  |  |  |  |  |  |
| b13, b12     | addr_xfer_type_std_  | Address Transfer Type, when instr_type_fld is 0.                                                                                       | R/W |  |  |  |  |  |  |  |
|              | mode_fld             | 0: Addresses transferred on QUAD_IO0 only                                                                                              |     |  |  |  |  |  |  |  |
|              |                      | 1: Addresses transferred on QUAD_IO[1:0] only                                                                                          |     |  |  |  |  |  |  |  |
|              |                      | 2: Addresses transferred on QUAD_IO[3:0]                                                                                               |     |  |  |  |  |  |  |  |
|              |                      | 3: Reserved (not used)                                                                                                                 |     |  |  |  |  |  |  |  |
|              |                      | When instr_type_fld is not 0, this bit is ignored.                                                                                     |     |  |  |  |  |  |  |  |
| b11 to b9    | Reserved             |                                                                                                                                        | R   |  |  |  |  |  |  |  |
| b8           | wel_dis_fld          | WEL Disable                                                                                                                            | R/W |  |  |  |  |  |  |  |
|              |                      | This is to turn off automatic issuing of WriteEnableLatch Command before write operation for Direct Access Controller                  |     |  |  |  |  |  |  |  |
|              |                      | 0: Enable automatic issuing of WEL                                                                                                     |     |  |  |  |  |  |  |  |
|              |                      | 1: Disable automatic issuing of WEL                                                                                                    |     |  |  |  |  |  |  |  |
| b7 to b0     | wr opcode fld        | Write Opcode                                                                                                                           | R/W |  |  |  |  |  |  |  |

## 8.4.4 dev\_delay\_reg — QSPI Device Delay Register

This register is used to introduce relative delays into the generation of the master output signals. All timings are defined in cycles of the QSPI\_REFCLK.

**Address:** 4000 500Ch (QSPI1)

4000 E00Ch (QSPI2)

| Bit               | b31         | b30 | b29 | b28  | b27   | b26 | b25 | b24 | b23        | b22        | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-------------|-----|-----|------|-------|-----|-----|-----|------------|------------|-----|-----|-----|-----|-----|-----|
|                   |             |     |     | d_ns | s_fld |     |     |     | d_btwn_fld |            |     |     |     |     |     |     |
| Value after reset | 0           | 0   | 0   | 0    | 0     | 0   | 0   | 0   | 0          | 0          | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15         | b14 | b13 | b12  | b11   | b10 | b9  | b8  | b7         | b6         | b5  | b4  | b3  | b2  | b1  | b0  |
|                   | d_after_fld |     |     |      |       |     |     |     |            | d_init_fld |     |     |     |     |     |     |
| Value after reset | 0           | 0   | 0   | 0    | 0     | 0   | 0   | 0   | 0          | 0          | 0   | 0   | 0   | 0   | 0   | 0   |

Table 8.6 dev\_delay\_reg Register Contents

| Bit Position | Bit Name    | Function                                                                                                                                                                            | R/W |
|--------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | d_nss_fld   | Chip Select De-Assert                                                                                                                                                               | R/W |
|              |             | Added delay in QSPI_REFCLK for the length that the chip select outputs are deasserted between transactions.                                                                         |     |
|              |             | The minimum delay for chip select to be de-asserted (0x0) is;                                                                                                                       |     |
|              |             | 1 QUAD_CLK + 1 QSPI_REFCLK                                                                                                                                                          |     |
|              |             | If value=X, then the chip select de-assert time will be;                                                                                                                            |     |
|              |             | 1 QUAD_CLK + 1 QSPI_REFCLK + X QSPI_REFCLKs.                                                                                                                                        |     |
| b23 to b16   | d_btwn_fld  | Chip Select De-Assert Different Slaves                                                                                                                                              | R/W |
|              |             | Delay in QSPI_REFCLK between one chip select being de-activated and the activation of another. This is used to ensure a quiet period between the selection of two different slaves. |     |
|              |             | The minimum delay (0x0) is;                                                                                                                                                         |     |
|              |             | 1 QUAD_CLK + 3 QSPI_REFCLKs.                                                                                                                                                        |     |
|              |             | If the value=X, then the delay will be;                                                                                                                                             |     |
|              |             | 1 QUAD_CLK + 3 QSPI_REFCLKs + X QSPI_REFCLKs                                                                                                                                        |     |
| b15 to b8    | d_after_fld | Chip Select End of Transfer                                                                                                                                                         | R/W |
|              |             | Delay in QSPI_REFCLK between last bit of current transaction and de-asserting the device chip select.                                                                               |     |
|              |             | By default, the chip select will be de-asserted on the cycle following the completion of the current transaction.                                                                   |     |
|              |             | If the value=X, then the chip select will be de-asserted X QSPI_REFCLKs after the last falling edge of QUAD_CLK.                                                                    |     |
| b7 to b0     | d_init_fld  | Chip Select Start of Transfer                                                                                                                                                       | R/W |
|              |             | Delay in QSPI_REFCLK between setting chip select low and first bit transfer.                                                                                                        |     |
|              |             | By default (value=0), chip select will be asserted half a QUAD_CLK period before the first rising edge of QUAD_CLK.                                                                 |     |
|              |             | If the value=X, the chip select will be asserted half a QUAD_CLK period before the first rising edge of QUAD_CLK + X QSPI_REFCLKs.                                                  |     |

## 8.4.5 rd\_data\_capture\_reg — Read Data Capture Register

**Address:** 4000 5010h (QSPI1) 4000 E010h (QSPI2)



Table 8.7 rd\_data\_capture\_reg Register Contents

| Bit Position | Bit Name            | Function                                                                                              | R/W |
|--------------|---------------------|-------------------------------------------------------------------------------------------------------|-----|
| b31 to b6    | Reserved            |                                                                                                       | R   |
| b5           | sample_edge_sel_fld | Sample edge selection                                                                                 | R/W |
|              |                     | Choose edge on which data from flash memory will be sampled                                           |     |
|              |                     | <ol> <li>Data outputs from flash memory are sampled on falling edge of the<br/>QSPI_REFCLK</li> </ol> |     |
|              |                     | <ol> <li>Data outputs from flash memory are sampled on rising edge of the<br/>QSPI_REFCLK</li> </ol>  |     |
| b4 to b1     | delay_fld           | Read Delay                                                                                            | R/W |
|              |                     | Delay the read data capturing logic by the programmed number of QSPI_REFCLK cycles                    |     |
| b0           | Reserved            | Keep the reset value                                                                                  | R/W |

# 8.4.6 dev\_size\_config\_reg — Device Size Configuration Register

**Address:** 4000 5014h (QSPI1) 4000 E014h (QSPI2)

| Bit               | b31                       | b30       | b29   | b28     | b27 | b26 | b25             | b24 | b23             | b22 | b21             | b20 | b19     | b18      | b17       | b16 |
|-------------------|---------------------------|-----------|-------|---------|-----|-----|-----------------|-----|-----------------|-----|-----------------|-----|---------|----------|-----------|-----|
|                   | dev_                      | _size_res | v_fld | mem_siz |     |     | ze_on_c<br>_fld |     | ze_on_c<br>_fld |     | ze_on_c<br>_fld |     | bytes_p | er_subse | ector_fld |     |
| Value after reset | 0                         | 0         | 0     | 0       | 0   | 0   | 0               | 0   | 0               | 0   | 0               | 1   | 0       | 0        | 0         | 0   |
| Bit               | b15                       | b14       | b13   | b12     | b11 | b10 | b9              | b8  | b7              | b6  | b5              | b4  | b3      | b2       | b1        | b0  |
|                   | bytes_per_device_page_fld |           |       |         |     |     |                 |     |                 |     |                 |     |         | um_addr  | _bytes_fl | d   |
| Value after reset | 0                         | 0         | 0     | 1       | 0   | 0   | 0               | 0   | 0               | 0   | 0               | 0   | 0       | 0        | 1         | 0   |

Table 8.8 dev\_size\_config\_reg Register Contents

| Table 0.0    | dev_size_comig_register contents |                                                                                                                                                                                                                              |     |  |  |  |
|--------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|
| Bit Position | Bit Name                         | Function                                                                                                                                                                                                                     | R/W |  |  |  |
| b31 to b29   | dev_size_resv_fld                |                                                                                                                                                                                                                              | R   |  |  |  |
| b28, b27     | mem_size_on_cs3_fl<br>d          | Size of Flash Device connected to QUAD_CS_N[3] pin  This field is only valid when Address Decoder is enabled (enable_ahb_decoder_fld = 1).  00b: Size of 512 Mb.  01b: Size of 1 Gb.  10b: Size of 2 Gb.  11b: Size of 4 Gb. | R/W |  |  |  |
| LOO LOE      |                                  | Caution) This bit is ignored because decoding the Address Decoder is not supported.                                                                                                                                          |     |  |  |  |
| b26, b25     | mem_size_on_cs2_fl<br>d          | Size of Flash Device connected to QUAD_CS_N[2] pin Same as mem_size_on_cs3_fld                                                                                                                                               | R/W |  |  |  |
| b24, b23     | mem_size_on_cs1_fl<br>d          | Size of Flash Device connected to QUAD_CS_N[1] pin Same as mem_size_on_cs3_fld                                                                                                                                               | R/W |  |  |  |
| b22, b21     | mem_size_on_cs0_fl<br>d          | Size of Flash Device connected to QUAD_CS_N[0] pin Same as mem_size_on_cs3_fld                                                                                                                                               | R/W |  |  |  |
| b20 to b16   | bytes_per_subsector_<br>fld      | Number of bytes per Block This is required by the controller for performing the write protection logic. The number of bytes per block must be a power of 2 number.  0 = 1 byte 1 = 2 bytes 16 = 65536 bytes                  | R/W |  |  |  |
| b15 to b4    | bytes_per_device_pa<br>ge_fld    | Number of bytes per device page  This is required by the controller for performing FLASH writes up to and across page boundaries.                                                                                            | R/W |  |  |  |
| b3 to b0     | num_addr_bytes_fld               | Number of address bytes (= num_addr_bytes_fld + 1) This field should be set the address byte number of the device. A value of 0 = 1 byte.                                                                                    | R/W |  |  |  |

#### remap\_addr\_reg — Remap Address Register 8.4.7

Address: 4000 5024h (QSPI1)

4000 E024h (QSPI2)

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24  | b23   | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|------|-------|-----|-----|-----|-----|-----|-----|-----|
|                   |     |     |     |     |     |     |     | valu | e_fld |     |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8   | b7    | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                   |     |     |     |     |     |     |     | valu | e_fld |     |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 8.9 remap\_addr\_reg Register Contents

| Bit Position | Bit Name  | Function                                                                                                          | R/W |
|--------------|-----------|-------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b0    | value_fld | This register is used to remap an incoming direct access address to a different address used by the FLASH device. | R/W |

#### mode\_bit\_config\_reg — Mode Bit Configuration Register 8.4.8

Address: 4000 5028h (QSPI1) 4000 E028h (QSPI2)



Table 8.10 mode\_bit\_config\_reg Register Contents

| Bit Position | Bit Name | Function                                                                           | R/W |
|--------------|----------|------------------------------------------------------------------------------------|-----|
| b31 to b8    | Reserved |                                                                                    | R   |
| b7 to b0     | mode_fld | Mode bits                                                                          | R/W |
|              |          | These are the 8 mode bits that are sent to the device following the address bytes. |     |

## 8.4.9 tx\_thresh\_reg — TX Threshold Register

**Address:** 4000 5030h (QSPI1) 4000 E030h (QSPI2)



Table 8.11 tx\_thresh\_reg Register Contents

| Bit Position | Bit Name           | Function                                                               | R/W |
|--------------|--------------------|------------------------------------------------------------------------|-----|
| b31 to b4    | tx_thresh_resv_fld | Reserved                                                               | R   |
| b3 to b0     | level_fld          | Defines the level at which the TX FIFO not full interrupt is generated | R/W |
|              |                    | (Legacy mode only)                                                     |     |

## 8.4.10 rx\_thresh\_reg — RX Threshold Register

**Address:** 4000 5034h (QSPI1) 4000 E034h (QSPI2)



Table 8.12 rx\_thresh\_reg Register Contents

| Bit Position | Bit Name  | Function                                                                                   | R/W |
|--------------|-----------|--------------------------------------------------------------------------------------------|-----|
| b31 to b4    | Reserved  |                                                                                            | R   |
| b3 to b0     | level_fld | Defines the level at which the RX FIFO not empty interrupt is generated (Legacy mode only) | R/W |

## 8.4.11 write\_completion\_ctrl\_reg — Write Completion Control Register

This register defines how the controller will poll the device following a write transfer.

**Address:** 4000 5038h (QSPI1) 4000 E038h (QSPI2)



Table 8.13 write\_completion\_ctrl\_reg Register Contents

| Bit Position | Bit Name              | Function                                                                                                                                                                                 | R/W |
|--------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | poll_rep_delay_fld    | Polling repetition delay                                                                                                                                                                 | R/W |
|              |                       | The polling interval is extended by setting this bit.                                                                                                                                    |     |
| b23 to b16   | poll_count_fld        | Poll count                                                                                                                                                                               | R/W |
|              |                       | Defines the number of times the controller should expect to see a true result from the polling in successive reads of the device register.                                               |     |
| b15          | Reserved              |                                                                                                                                                                                          | R   |
| b14          | disable_polling_fld   | Disable polling                                                                                                                                                                          | R/W |
|              |                       | This switches off the automatic polling function.                                                                                                                                        |     |
|              |                       | 0: Enable automatic polling                                                                                                                                                              |     |
|              |                       | 1: Disable automatic polling                                                                                                                                                             |     |
| b13          | polling_polarity_fld  | Polling polarity                                                                                                                                                                         | R/W |
|              |                       | Defines the polling polarity.                                                                                                                                                            |     |
|              |                       | 1: The write transfer to the device will be completed if the polled bit is equal to "1".                                                                                                 |     |
|              |                       | 0: The write transfer to the device will be completed if the polled bit is equal to "0".                                                                                                 |     |
| b12, b11     | Reserved              |                                                                                                                                                                                          | R   |
| b10 to b8    | polling_bit_index_fld | Polling bit index                                                                                                                                                                        | R/W |
|              |                       | Defines the bit index that should be polled.                                                                                                                                             |     |
|              |                       | A value of 010b means that bit 2 of the returned data will be polled for.                                                                                                                |     |
|              |                       | A value of 111b means that bit 7 of the returned data will be polled for.                                                                                                                |     |
| b7 to b0     | opcode_fld            | Opcode                                                                                                                                                                                   | R/W |
|              |                       | Defines the opcode that should be issued by the controller when it is automatically polling for device program completion. This command is issued following all device write operations. |     |
|              |                       | By default, this will poll the standard device STATUS register using opcode 0x05                                                                                                         |     |

## 8.4.12 no\_of\_polls\_bef\_exp\_reg — Polling Expiration Register

**Address:** 4000 503Ch (QSPI1) 4000 E03Ch (QSPI2)



Table 8.14 no\_of\_polls\_bef\_exp\_reg Register Contents

| Bit Position | Bit Name                    | Function                                                                                                                                                      | R/W |
|--------------|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b0    | no_of_polls_bef_exp_<br>fld | Defines the maximum number of polls that will stop polling and generate an interrupt if the write is not completed.  This field should be greater than 32769. | R/W |

## 8.4.13 irq\_status\_reg — Interrupt Status Register

The status fields in this register are set when the described event occurs and the interrupt is enabled in the Interrupt Mask Register. When any of these bit fields are set, the interrupt output is asserted high. The fields are cleared by reading this register. Note that bit fields 7 through 11 are only valid when legacy SPI mode is active.

**Address:** 4000 5040h (QSPI1) 4000 E040h (QSPI2)



Table 8.15 irq\_status\_reg Register Contents (1/2)

| Bit Position | Bit Name              | Function                                                                                                                                                                                                                                            | R/W |
|--------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b14   | Reserved              |                                                                                                                                                                                                                                                     | R   |
| b13          | poll_exp_int_fld      | The maximum number of programmed polling cycles is expired                                                                                                                                                                                          | R   |
| b12          | Reserved              |                                                                                                                                                                                                                                                     | R   |
| b11          | rx_fifo_full_fld      | RX FIFO full (Current FIFO status)                                                                                                                                                                                                                  | R   |
|              |                       | This can be ignored in non-SPI legacy mode.                                                                                                                                                                                                         |     |
|              |                       | 0: FIFO is not full                                                                                                                                                                                                                                 |     |
|              |                       | 1: FIFO is full                                                                                                                                                                                                                                     |     |
| b10          | rx_fifo_not_empty_fld | RX FIFO not empty (Current FIFO status)                                                                                                                                                                                                             | R   |
|              |                       | This can be ignored in non-SPI legacy mode.                                                                                                                                                                                                         |     |
|              |                       | 0: FIFO has < RX THRESHOLD entries                                                                                                                                                                                                                  |     |
|              |                       | 1: FIFO has ≥ RX THRESHOLD entries                                                                                                                                                                                                                  |     |
| b9           | tx_fifo_full_fld      | TX FIFO full (Current FIFO status)                                                                                                                                                                                                                  | R   |
|              |                       | This can be ignored in non-SPI legacy mode.                                                                                                                                                                                                         |     |
|              |                       | 0: FIFO is not full                                                                                                                                                                                                                                 |     |
|              |                       | 1: FIFO is full                                                                                                                                                                                                                                     |     |
| b8           | tx_fifo_not_full_fld  | TX FIFO not full (Current FIFO status)                                                                                                                                                                                                              | R   |
|              |                       | This can be ignored in non-SPI legacy mode.                                                                                                                                                                                                         |     |
|              |                       | 0: FIFO has > TX THRESHOLD entries                                                                                                                                                                                                                  |     |
|              |                       | 1: FIFO has ≤ TX THRESHOLD entries                                                                                                                                                                                                                  |     |
| b7           | recv_overflow_fld     | Receive Overflow                                                                                                                                                                                                                                    | R   |
|              |                       | This should only occur in Legacy SPI mode.                                                                                                                                                                                                          |     |
|              |                       | Set if an attempt is made to push the RX FIFO when it is full. This bit is reset only by a module reset and cleared only when this register is read. If a new push to the RX FIFO occurs coincident with a register read this flag will remain set. |     |
|              |                       | 0: No overflow has been detected.                                                                                                                                                                                                                   |     |
|              |                       | 1: An overflow has occurred.                                                                                                                                                                                                                        |     |
| b6           | Reserved              |                                                                                                                                                                                                                                                     | R   |

Table 8.15 irq\_status\_reg Register Contents (2/2)

| Bit Position | Bit Name               | Function                                                                                                                                                                                               | R/W |  |  |  |  |  |
|--------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|
| b5           | illegal_access_det_fld | Illegal AHB access has been detected.                                                                                                                                                                  | R   |  |  |  |  |  |
|              |                        | This interrupt is also triggered, if AHB access is performed when the DirectAccessController is disabled.                                                                                              |     |  |  |  |  |  |
|              |                        | 0: Illegal AHB access is not detected                                                                                                                                                                  |     |  |  |  |  |  |
|              |                        | 1: Illegal AHB access is detected                                                                                                                                                                      |     |  |  |  |  |  |
| b4           | prot_wr_attempt_fld    | Write to protected area was attempted and rejected.                                                                                                                                                    | R   |  |  |  |  |  |
|              |                        | 0: Write to protected area was not attempted                                                                                                                                                           |     |  |  |  |  |  |
|              |                        | 1: Write to protected area was attempted                                                                                                                                                               |     |  |  |  |  |  |
| b3, b2       | Reserved               |                                                                                                                                                                                                        | R   |  |  |  |  |  |
| b1           | underflow_det_fld      | Underflow Detected                                                                                                                                                                                     | R   |  |  |  |  |  |
|              |                        | 0: No underflow has been detected                                                                                                                                                                      |     |  |  |  |  |  |
|              |                        | Underflow is detected and an attempt to transfer data is made when the TX FIFO is empty. This may occur when AHB write data is being supplied too slowly to keep up with the requested write operation |     |  |  |  |  |  |
|              |                        | This bit is reset only by a module reset and cleared only when this register is read.                                                                                                                  |     |  |  |  |  |  |
| b0           | Reserved               |                                                                                                                                                                                                        | R   |  |  |  |  |  |

## 8.4.14 irq\_mask\_reg — Interrupt Mask Register

0: The interrupt for the corresponding Interrupt Status Register bit is disabled.

1: The interrupt for the corresponding Interrupt Status Register bit is enabled.

**Address:** 4000 5044h (QSPI1) 4000 E044h (QSPI2)



Table 8.16 irq\_mask\_reg Register Contents

| Bit Position | Bit Name                        | Function                          | R/W |
|--------------|---------------------------------|-----------------------------------|-----|
| b31 to b14   | Reserved                        |                                   | R   |
| b13          | poll_exp_int_mask_fld           | Polling expiration detected mask  | R/W |
| b12          | Reserved                        | Keep the reset value              | R/W |
| b11          | rx_fifo_full_mask_fld           | RX FIFO full mask                 | R/W |
| b10          | rx_fifo_not_empty_ma<br>sk_fld  | RX FIFO not empty mask            | R/W |
| b9           | tx_fifo_full_mask_fld           | TX FIFO full mask                 | R/W |
| b8           | tx_fifo_not_full_mask<br>_fld   | TX FIFO not full mask             | R/W |
| b7           | recv_overflow_mask_<br>fld      | Receive Overflow mask             | R/W |
| b6           | Reserved                        | Keep the reset value              | R/W |
| b5           | illegal_access_det_m<br>ask_fld | Illegal Access Detected mask      | R/W |
| b4           | prot_wr_attempt_mas<br>k_fld    | Protected Area Write Attempt mask | R/W |
| b3, b2       | Reserved                        | Keep the reset value              | R/W |
| b1           | underflow_det_mask_<br>fld      | Underflow Detected mask           | R/W |
| b0           | Reserved                        | Keep the reset value              | R/W |

## 8.4.15 lower\_wr\_prot\_reg — Lower Write Protection Register

**Address:** 4000 5050h (QSPI1) 4000 E050h (QSPI2)



Table 8.17 lower\_wr\_prot\_reg Register Contents

| Bit Position | Bit Name      | Function                                                                                                          | R/W |
|--------------|---------------|-------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b0    | subsector_fld | The block number that defines the lower block in the range of blocks that is to be locked from writing.           | R/W |
|              |               | The definition of a block in terms of number of bytes is programmable via the Device Size Configuration Register. |     |
|              |               | Modify this bit only when write protection feature is low.                                                        |     |

## 8.4.16 upper\_wr\_prot\_reg — Upper Write Protection Register

**Address:** 4000 5054h (QSPI1)

4000 E054h (QSPI2)



Table 8.18 upper\_wr\_prot\_reg Register Contents

| Bit Position | Bit Name      | Function                                                                                                          | R/W |
|--------------|---------------|-------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b0    | subsector_fld | The block number that defines the upper block in the range of blocks that is to be locked from writing.           | R/W |
|              |               | The definition of a block in terms of number of bytes is programmable via the Device Size Configuration Register. |     |
|              |               | Modify this bit only when write protection feature is off.                                                        |     |

## 8.4.17 wr\_prot\_ctrl\_reg — Write Protection Control Register

**Address:** 4000 5058h (QSPI1) 4000 E058h (QSPI2)



Table 8.19 wr\_prot\_ctrl\_reg Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                                                                                | R/W |
|--------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b2    | Reserved |                                                                                                                                                                                                                         | R   |
| b1           | enb_fld  | Write Protection Enable Bit                                                                                                                                                                                             | R/W |
|              |          | 1: Any AHB write access with an address within the protection region defined in the<br>Lower and Upper Write Protection Registers is rejected. An AHB error response<br>is generated and an interrupt source triggered. |     |
|              |          | 0: The protection region is disabled.                                                                                                                                                                                   |     |
| b0           | inv_fld  | Write Protection Inversion Bit                                                                                                                                                                                          | R/W |
|              |          | 1: The protection region defined in the Lower and Upper Write Protection Registers is inverted meaning it is the region that the system is permitted to write to.                                                       |     |
|              |          | 0: The protection region defined in the Lower and Upper Write Protection Registers is the region that the system is not permitted to write to.                                                                          |     |
|              |          | Modify this bit only when write protection feature is low.                                                                                                                                                              |     |

## 8.4.18 flash\_cmd\_ctrl\_reg — Flash Command Control Register

This register is used for STIG. Refer to Section 8.5.3, Software Triggered Instruction Generator (STIG).

**Address:** 4000 5090h (QSPI1) 4000 E090h (QSPI2)



Table 8.20 flash\_cmd\_ctrl\_reg Register Contents (1/2)

| Bit Position | Bit Name                                       | ame Function                                                                                                                                                                                                    |     |  |  |  |  |  |
|--------------|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|
| b31 to b24   | cmd_opcode_fld                                 | Command Opcode  The command opcode field should be setup before triggering the command.  For example, 0x20 maps to SubSector Erase. Writing to the execute field (bit 0) of this register launches the command. | R/W |  |  |  |  |  |
|              |                                                | <b>Note)</b> Using this approach to issue commands to the device will make use of the instruction type of the Device Read Instruction Configuration Register.                                                   |     |  |  |  |  |  |
|              |                                                | 00b: The command opcode data will be transferred in a serial fashion.                                                                                                                                           |     |  |  |  |  |  |
|              |                                                | 01b: The command opcode, command address, command dummy bytes and<br>command data will all be transferred in parallel using QUAD_IO[1:0] pins.                                                                  |     |  |  |  |  |  |
|              |                                                | 10b: The command opcode, command address, command dummy bytes and command data will all be transferred in parallel using QUAD_IO[3:0] pins.                                                                     |     |  |  |  |  |  |
| b23          | enb_read_data_fld                              | Read Data Enable                                                                                                                                                                                                | R/W |  |  |  |  |  |
|              |                                                | Set to 1 if the command specified in the command opcode field (bits[31:24]) requires read data bytes to be received from the device.                                                                            |     |  |  |  |  |  |
| b22 to b20   | num_rd_data_bytes_fl Number of Read Data Bytes |                                                                                                                                                                                                                 |     |  |  |  |  |  |
|              | d                                              | Up to 8 data bytes may be read using this command. Set to 0 for 1 byte and 7 for 8 bytes.                                                                                                                       |     |  |  |  |  |  |
| b19          | enb_comd_addr_fld                              | Command Address Enable                                                                                                                                                                                          | R/W |  |  |  |  |  |
|              |                                                | Set to 1 if the command specified in bits[31:24] requires an address. This should be setup before triggering the command via writing a 1 to the execute field.                                                  |     |  |  |  |  |  |
| b18          | enb_mode_bit_fld                               | Mode Bit Enable                                                                                                                                                                                                 | R/W |  |  |  |  |  |
|              |                                                | Set to 1 to ensure the mode bits as defined in the Mode Bit Configuration Register are sent following the address bytes.                                                                                        |     |  |  |  |  |  |
| b17, b16     | num_addr_bytes_fld                             | Number of Address Bytes                                                                                                                                                                                         | R/W |  |  |  |  |  |
|              |                                                | Set to the number of address bytes required (the address itself is programmed in the Flash Command Address Register). This should be setup before triggering the command via bit 0 of this register.            |     |  |  |  |  |  |
|              |                                                | 00b: 1 address byte                                                                                                                                                                                             |     |  |  |  |  |  |
|              |                                                | 01b: 2 address bytes                                                                                                                                                                                            |     |  |  |  |  |  |
|              |                                                | 10b: 3 address bytes                                                                                                                                                                                            |     |  |  |  |  |  |
|              |                                                | 11b: 4 address bytes                                                                                                                                                                                            |     |  |  |  |  |  |
| b15          | enb_write_data_fld                             | Write Data Enable                                                                                                                                                                                               | R/W |  |  |  |  |  |
|              |                                                | Set to 1 if the command specified in the command opcode field requires write data bytes to be sent to the device.                                                                                               |     |  |  |  |  |  |
| b14 to b12   | num_wr_data_bytes_f                            | Number of Write Data Bytes                                                                                                                                                                                      | R/W |  |  |  |  |  |
|              | ld                                             | Up to 8 Data bytes may be written using this command Set to 0 for 1 byte, 7 for 8 bytes.                                                                                                                        |     |  |  |  |  |  |

| Table 8.20   | flash_cmd_ctrl_reg      | flash_cmd_ctrl_reg Register Contents (2/2)                                                                                                                                                                                     |     |  |  |  |  |  |  |
|--------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|--|
| Bit Position | Bit Name                | Function                                                                                                                                                                                                                       | R/W |  |  |  |  |  |  |
| b11 to b7    | num_dummy_bytes_fl<br>d | Number of Dummy Bytes Set to the number of dummy bytes required This should be setup before triggering the command via the execute field of this register.                                                                     | R/W |  |  |  |  |  |  |
|              |                         | <b>Note</b> ) This field must not be greater than 5'h03. Setting more dummy bytes can cause TX FIFO full condition to be triggered or overlooking some data for read commands and the behavior of the module is unpredictable. |     |  |  |  |  |  |  |

| b6 to b2 | Reserved            |                                                    | R |
|----------|---------------------|----------------------------------------------------|---|
| b1       | cmd_exec_status_fld | Command execution status                           | R |
|          |                     | When the command is in progress, this bit is set.  |   |
| b0       | cmd_exec_fld        | Execute the command                                | W |
|          |                     | The command is executed by writing 1b to this bit. |   |

## 8.4.19 flash\_cmd\_addr\_reg — Flash Command Address Register

**Address:** 4000 5094h (QSPI1) 4000 E094h (QSPI2)



Table 8.21 flash\_cmd\_addr\_reg Register Contents

| Bit Position | Bit Name | Function                                                                                                                   | R/W |  |  |
|--------------|----------|----------------------------------------------------------------------------------------------------------------------------|-----|--|--|
| b31 to b0    | addr_fld | Command Address                                                                                                            | R/W |  |  |
|              |          | This field should be setup before triggering the command in bit 0 of the Flash Command Control Register.                   |     |  |  |
|              |          | It is the address used by the command specified in the cmd_opcode_fld (bits[31:24]) of the Flash Command Control Register. |     |  |  |

## 8.4.20 flash\_rd\_data\_lower\_reg — Flash Command Read Data Register (Lower)

**Address:** 4000 50A0h (QSPI1) 4000 E0A0h (QSPI2)



Table 8.22 flash\_rd\_data\_lower\_reg Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                                                                                                                           | R/W |
|--------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b0    | data_fld | Command Read Data (Lower byte)                                                                                                                                                                                                                                     | R   |
|              |          | This is the data that is returned by the flash device for any status or configuration read operation carried out by triggering the event in the Flash Command Control Register.  The register will be valid when bit 1 in the Flash Command Control Register is 0. |     |

## 8.4.21 flash\_rd\_data\_upper\_reg — Flash Command Read Data Register (Upper)

**Address:** 4000 50A4h (QSPI1) 4000 E0A4h (QSPI2)

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24  | b23   | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|------|-------|-----|-----|-----|-----|-----|-----|-----|
|                   |     |     |     |     |     |     |     | data | a_fld |     |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8   | b7    | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                   |     |     |     |     |     |     |     | data | a_fld |     |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 8.23 flash\_rd\_data\_upper\_reg Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                                        | R/W |
|--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b0    | data_fld | Command Read Data (Upper byte)                                                                                                                                                  | R   |
|              |          | This is the data that is returned by the FLASH device for any status or configuration read operation carried out by triggering the event in the Flash Command Control Register. |     |
|              |          | The register will be valid when the polling bit in the Flash Command Control Register is low.                                                                                   |     |

## 8.4.22 flash\_wr\_data\_lower\_reg — Flash Command Write Data Register (Lower)

**Address:** 4000 50A8h (QSPI1)

4000 E0A8h (QSPI2)



Table 8.24 flash\_wr\_data\_lower\_reg Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                                     | R/W |
|--------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b0    | data_fld | Command Write Data Lower Byte                                                                                                                                                | R/W |
|              |          | This is the command write data lower byte. This should be setup before triggering the command in bit 0 of the Flash Command Control Register.                                |     |
|              |          | It is the data that is to be written to the flash for any status or configuration write operation carried out by triggering the event in the Flash Command Control Register. |     |

## 8.4.23 flash\_wr\_data\_upper\_reg — Flash Command Write Data Register (Upper)

**Address:** 4000 50ACh (QSPI1) 4000 E0ACh (QSPI2)



Table 8.25 flash\_wr\_data\_upper\_reg Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                                     | R/W |
|--------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b0    | data_fld | Command Write Data Upper Byte                                                                                                                                                | R/W |
|              |          | This is the command write data upper byte. This should be setup before triggering the command in bit 0 of the Flash Command Control Register.                                |     |
|              |          | It is the data that is to be written to the flash for any status or configuration write operation carried out by triggering the event in the Flash Command Control Register. |     |

## 8.4.24 polling\_flash\_status\_reg — Polling Flash Status Register

**Address:** 4000 50B0h (QSPI1) 4000 E0B0h (QSPI2)



Table 8.26 polling\_flash\_status\_reg Register Contents

| Bit Position | Bit Name                    | Function                                                                          | R/W |
|--------------|-----------------------------|-----------------------------------------------------------------------------------|-----|
| b31 to b9    | Reserved                    |                                                                                   | R   |
| b8           | device_status_valid_fl<br>d | Polling Status Valid This bit is set when the value in bits from 7 to 0 is valid. | R   |
| b7 to b0     | device_status_fld           | Flash Status Actual status register of the device                                 | R   |

## 8.4.25 module\_id\_reg — Module ID Register

**Address:** 4000 50FCh (QSPI1) 4000 E0FCh (QSPI2)



Table 8.27 module\_id\_reg Register Contents

| Bit Position | Bit Name  | Function                  | R/W |
|--------------|-----------|---------------------------|-----|
| b31 to b24   | Reserved  |                           | R   |
| b23 to b0    | value_fld | Module/Revision ID number | R   |

## 8.5 Operation

#### 8.5.1 AHB Control Interface

The AHB slave controller performs the following operation.

- Validates incoming AHB accesses
- Responds to invalid requests
- Performs any required byte and half-word reordering
- Blocks write that violate the programmed write protection rules
- Forwards the transfer request to the direct access controller

#### 8.5.1.1 Remapping the Memory Map address

The Quad SPI Controller does not implement any specific address decoding to error incoming addresses that may lie outside the connected FLASH memory space. The incoming direct access address, by default, maps directly to the address sent serially to the FLASH device.

If the FLASH device has a 24-bit address, then the 24 LSBs of the Memory Map address will be forwarded. A remap feature is available to remap all incoming Memory Map addresses to ADDRESS+ N, where N is the value store in the Remap Address Register. It is enabled via the enb\_ahb\_addr\_remap\_fld bit of QSPI Configuration Register. Disable the Quad SPI Controller before configuring the remap setting. This feature could be used when software needs to move boot code to another FLASH region.

#### 8.5.1.2 Write Protection

In order to protect the FLASH device, a write protection feature is implemented in hardware and controlled from software. Any write detected, pointing to protected FLASH area, will generate a bus error.

A programmable region of the FLASH device, defined as a number of FLASH "blocks" starting from a particular block number can be protected. Three programmable protection registers (Lower Write Protection Register/Upper Write Protection Register/Write Protection Control Register) are provided.

The first register defines the FLASH block that is located at the bottom of the region to be protected.

The second register defines the FLASH block that is located at the top of the region to be protected.

The third register is a control register consisting of 2 bits. Bit 0 allows software to invert the region that is being protected, causing the programmed region to become the only areas of FLASH memory that is not protected from writes. Bit 1 is the write protection enable bit. When low, the FLASH device is unprotected.

A block can be between 1 and 64 Kbytes, programmed via the Device Size Configuration Register.



#### 8.5.2 Direct Access Controller (DAC)

Direct access refers to the operation where the Memory Map address access directly trigger a read or write to FLASH memory. It can be used to both access and directly execute code from external FLASH memory.

FLASH erase operations, which may be required before a page write, are triggered by software using the documented programming interface.

Once a page program cycle has been started, the Quad SPI Controller will automatically poll for the write cycle to complete before the next access. This is achieved by holding any subsequent direct accesses in the wait state. The wait time depends to the device.

## 8.5.3 Software Triggered Instruction Generator (STIG)

The direct access controller is used to transfer data. In order to access the volatile and non-volatile configuration registers, the SPI Status register, other status/protection registers as well as to perform ERASE functions, a separate software controller is required.

The software triggered instruction generator, or STIG, is controlled using the Flash Command Control Register by setting up the command to issue to the FLASH device. This is a generic controller and can be used to perform any instruction that the FLASH device supports from the extended SPI protocol.

Bit 0 is used to trigger the command, bit 1 used by software to poll the status of the command execution.

For reads, when the command has been serviced (bit 1 toggles from "1" to "0"), up to 8 bytes of read data will be placed in the Flash Command Read Data Register.

For writes, the write data should be placed in the Flash Command Write Data Register.

#### 8.5.4 Servicing a STIG request

A STIG request will cause the Quad SPI Controller to interrogate the Flash Command Control Register to determine what and how many bytes it should send to the FLASH device.

If there is an address to send, then the address (the size of which is also programmed in the same register) is sent next. The address itself is stored in the Flash Command Address Register.

If there are any dummy bytes to send (the size of which is also programmed in the same register) then those are sent next.

If there is data to write or read (the size of which is also programmed in the same register) then for the case of writes, up to 8 bytes can be sent (as stored in the Flash Command Write Data Registers) next.

In the read case, when the read data has been collected from the FLASH device, the Quad SPI Controller stores that in the Flash Command Read Data Registers.

When the Quad SPI Controller starts to service a STIG request, it sets bit 1 of the Flash Command Control Register to indicate a command execution is in progress.



#### 8.5.5 Arbitration between Direct Access Controller and STIG

When multiple controllers are active simultaneously, a simple fixed-priority arbitration scheme is used to arbitrate between each interface and access the external FLASH. The fixed priority is defined as follows, highest priority first.

- (1) The Direct Access Write
- (2) The STIG
- (3) The Direct Access Read

Each controller is back pressured while waiting to be serviced.

#### 8.5.6 SPI Command Translation

Requests issued by the direct access controller or the STIG will be translated into a sequence of byte transfers to send downstream (before serialization to the FLASH device). These sequences depend on the requested transfer but an example of a typical 1-byte non sequential READ is shown below:

INSTRUCTION OPCODE → ADDRESS → Mode Byte → Dummy Bytes → 1 byte of don't care

For sequential accesses, an extra byte of data per read is pushed to the FLASH device on the back of the above sequence assuming it can be done so with no gap between each transferred byte.

The actual sequence sent to the FLASH device depends on the requested transfers, whether the transfer is non-sequential or sequential, whether the device has been configured in NoCMD mode and the state of the Device Read/Write Instruction Configuration Registers.

For writes, the write enable latch (WEL) within the FLASH device itself must be high before a write sequence can be issued. The Quad SPI Controller will automatically issue the write enable latch command before triggering a write command via the direct access controller - i.e. the user does not need to perform this operation. The op-code for this operation is typically 06h and is common between devices.

When write requests from the direct access controller are no longer being received and all outstanding requests have been sent, the FLASH device will automatically start the page program write cycle. Any incoming request at this time will be held in wait states until the cycle has completed. The Quad SPI Controller will automatically poll the FLASH device SPI status register to identify when the write cycle has completed. This is achieved by sending the command to read status register to the FLASH device and waiting until the device itself has indicated the write cycle has completed (until the Write in Progress bit [0] has cleared to zero and the write enable latch bit has also cleared to zero).

The write enable latch command and the command to read status register are the ones that are sent by the controller automatically. For any other specific instruction that the user determines should be sent to the device (for example if the device needs to be unprotected before a write command is issued), these should be handled separately by issuing FLASH commands via the STIG.

## 8.5.7 Selecting the Flash Instruction Type

In order to send the correct READ and WRITE opcodes, software should initialize the Device READ Instruction Configuration Register and the Device WRITE Instruction Configuration Register. These registers include fields to setup the required instruction op-codes that is intended to be used to access the FLASH (default is basic READ and basic page program) as well as the instruction type and whether the instruction uses single, dual or quad pins for address and data transfer.

Despite being applicable for both READs and WRITEs, the Instruction Type field (instr\_type\_fld) in the Device READ Instruction Configuration Register only appears once - it is not included in the Device WRITE Instruction Configuration Register.

If software sets the Instruction Type field to anything other than "0", then the address xfer type and the data xfer type bits of both the registers become don't care. It is made available to allow software to support the less common FLASH instructions where the opcode, address and data are sent on 2 or 4 lanes (the opcode from most instructions are sent serially to the FLASH device, even for dual/quad instructions).

Also note that for devices that support instructions that can send the OPCODE over 2 or 4 lanes, the name for these instructions are not consistently named in the FLASH datasheets. One of the devices that support these instructions is the Numonyx (Micron) N25Q128. The extra READ instructions are called DCFR and QCFR. The WRITE instructions are DCPP and QCPP. For reference, below is a table illustrating how software should configure the Quad SPI Controller for each specific READ and WRITE instruction supported by the N25Q128 device.

Table 8.28 Number of Lanes for READ Instructions Supported by the N25Q128 Device

|                                  |                            |                                  |                               | Device Read Instruction Config Re |            | nfig Register                       |
|----------------------------------|----------------------------|----------------------------------|-------------------------------|-----------------------------------|------------|-------------------------------------|
| Instruction                      | Lanes<br>Used by<br>OPCODE | Lanes<br>Used to Send<br>Address | Lanes<br>Used to Send<br>Data | instr_type_fld                    |            | data_xfer_typ<br>e_ext_mode_f<br>ld |
| READ                             | 1                          | 1                                | 1                             | 0                                 | 0          | 0                                   |
| FAST_READ                        | 1                          | 1                                | 1                             | 0                                 | 0          | 0                                   |
| DOFR<br>(Dual Output Fast Read)  | 1                          | 1                                | 2                             | 0                                 | 0          | 1                                   |
| DIOFR<br>(Dual I/O Fast Read)    | 1                          | 2                                | 2                             | 0                                 | 1          | 1                                   |
| QOFR<br>(Quad Output Fast Read)  | 1                          | 1                                | 4                             | 0                                 | 0          | 2                                   |
| QIOFR<br>(Quad I/O Fast Read)    | 1                          | 4                                | 4                             | 0                                 | 2          | 2                                   |
| DCFR<br>(Dual Command Fast Read) | 2                          | 2                                | 2                             | 1                                 | Don't care | Don't care                          |
| QCFR<br>(Quad Command Fast Read) | 4                          | 4                                | 4                             | 2                                 | Don't care | Don't care                          |

Table 8.29 Number of Lanes for WRITE Instructions Supported by the N25Q128 Device

|                                             |                            |                                  |                               | Device Write Instruction Config Register |                                     |                                     |
|---------------------------------------------|----------------------------|----------------------------------|-------------------------------|------------------------------------------|-------------------------------------|-------------------------------------|
| Instruction                                 | Lanes<br>Used by<br>OPCODE | Lanes<br>Used to Send<br>Address | Lanes<br>Used to Send<br>Data | instr_type_fld *1                        | addr_xfer_typ<br>e_std_mode_<br>fld | data_xfer_typ<br>e_ext_mode_f<br>Id |
| PP<br>(Page Program)                        | 1                          | 1                                | 1                             | 0                                        | 0                                   | 0                                   |
| DIFP<br>(Dual Input Fast Program)           | 1                          | 1                                | 2                             | 0                                        | 0                                   | 1                                   |
| DIEFP<br>(Dual Input Extended Fast Program) | 1                          | 2                                | 2                             | 0                                        | 1                                   | 1                                   |
| QIFP<br>(Quad Input Fast Program)           | 1                          | 1                                | 4                             | 0                                        | 0                                   | 2                                   |
| QIEFP<br>(Quad Input Extended Fast Program) | 1                          | 4                                | 4                             | 0                                        | 2                                   | 2                                   |
| DCPP<br>(Dual Command Page Program)         | 2                          | 2                                | 2                             | 1                                        | Don't care                          | Don't care                          |
| QCPP<br>(Quad Command Page Program)         | 4                          | 4                                | 4                             | 2                                        | Don't care                          | Don't care                          |

Note 1. Device Read Instruction Configuration Register

## 8.5.8 APB Interface and Register Module

The APB interface is used to configure the controller and perform software controlled FLASH accesses using the Flash Command Control Register (refer to Section 8.5.3, Software Triggered Instruction Generator (STIG) and Section 8.6.3, Using the Flash Command Control Register (STIG Operation) for detailed description).

#### 8.5.9 Read Data Capturing

There are programmable features allowing software to tune the logic that captures the read data from the device.

After reset, the QSPI\_REFCLK delay is in a disabled state. This should be valid for most applications, and can be used for device enumeration, where the device clock will be configured variously. The Read Data Capture Register provides the control for these features.

Bit[4:1] controls the additional number of read data capture cycles (this is the fast QSPI\_REFCLK, running at least x4 of the device clock) that should be applied to the internal read data capture circuit. The large clock-to-out delay of the flash memory together with trace delays as well as other device delays may impose a maximum flash clock frequency which is less than the flash memory device itself can operate at. To compensate, software should set this register to a value that guarantees robust data captures.

#### 8.5.9.1 Example of an 8 byte Read Transfer

To help understand the high level behavior of the Quad SPI interface, the following diagram shows the primary stages in a read transfer. Note this is just one type of read instruction so there are many variations on this.



Figure 8.2 Example of an 8 Byte Read Transfer

- (1) Start of transaction, chip select (QUAD CS N) activates slave 1 (transitions from 4'hF to 4'hD).
- (2) Start of instruction phase. The first of 8 bits are output only on QUAD\_IO0. Other QUAD\_IO pins are unused at this stage.
- (3) End of instruction phase. The last of the 8 instruction bits is out.
- (4) Start of address phase. The example uses a 3 byte address output across all 4 QUAD\_IO pins. One address nibble is output per clock cycle so 3 bytes takes 6 cycles.
- (5) End of address phase. The last address nibble is output using all 4 QUAD\_IO pins.
- (6) The example read transaction requires 3 bytes of dummy write data. The edge is where the first of the 6 nibbles are output across all 4 QUAD\_IO pins.
- (7) Last nibble of dummy write data. This is the last write phase of the read transfer therefore QUAD\_IO pins change "Data Input Cycle".
- (8) First cycle of read data on QUAD\_IO pins. Example is reading 8 bytes which will take 16 cycles using all QUAD\_IO pins.

- (9) Last cycle of read data input. QUAD\_IO pins switch back to being floating. Chip enable is de-asserted for slave 1. Transaction complete.
- (10) QUAD\_IO pins change "DATA Output Cycle" for next transaction.

## 8.6 Programming Quad SPI Controller

Software is responsible for configuring the Quad SPI Controller before it can communicate with the FLASH device.

It is assumed that the controller's static configuration bits are setup before the Quad SPI Controller is "enabled" via bit[0] of the "QSPI Configuration Register". This is necessary in order to avoid any clock boundary issues. If the user wishes to change the controller's configuration, the QSPI Enable bit should be set to "disabled" before reconfiguring.

## 8.6.1 Configuring the Quad SPI Controller for use after reset

The Quad SPI Controller has been designed to wake up in a state that is suitable for performing basic reads and writes using the direct access controller. The BASIC read (opcode 03h) and BASIC write (opcode 02h) instructions are operations supported by all target devices.

The Controller also wakes up with a baud rate divider setting of divide-by-32. Assuming the QSPI\_REFCLK is operating at 166.67 MHz after reset, then this means the effective QUAD\_CLK is just 5.2 MHz. This should be slow enough to meet all timing requirements of all target devices without any further device programming.

If the target device does not use 3 address bytes, the Device Size Configuration Register must be modified to the appropriate size.

If software plans to write to the device, and the number of bytes per device page is NOT equal to 256, then the Device Size Configuration Register must also be modified.

While not a requirement, it is prudent for software to enable the write protect feature prior to enabling the Quad SPI Controller. This will block any direct writes from taking effect. To do so, the protection registers (Offset 50h, 54h and 58h) should be setup and the number of bytes per device block in the Device Size Configuration Register should also be setup.

#### 8.6.2 Configuring the Quad SPI Controller for optimal use

To access the flash optimally, software must configure the controller accurately.

- (1) Wait until any pending STIG operation has completed.
- (2) Disable the DAC (Direct Access Controller) bit 7 of the QSPI Configuration Register. It is permitted, but not necessary to also disable the Quad SPI Controller completely here via bit 0 of the same register.
- (3) Update the Device Write/Read Instruction Configuration Register for the instruction type you wish to use for direct writes and reads.
- (4) Update Mode Bit Configuration Register, if mode bits have been enabled in the Device Read Instruction Configuration Register.
- (5) Update the Device Size Configuration Register as needed. The number of address bytes is a key configuration setting required for performing reads and writes. The number of bytes per page is required for performing any write. The number of bytes per device block is only required if the write protect feature is used.
- (6) Update QSPI Device Delay Register. This register allows the user to tweak how the chip select is driven after each FLASH access. This is required as each device may have different timing requirements. As the serial clock frequency is increased, these timing requirements become more important. Note the numbers programmed in this register are based on the period of QSPI\_REFCLK. Example: A device needs 50 ns minimum time before CS can be reasserted after it has been de-asserted. By default, the controller will only provide a minimum of 1 QUAD\_CLK period. When the device is operating at 62.5 MHz, the QUAD\_CLK period is only 16 ns, so 34 ns extra is required. Since the register defines the number of QSPI\_REFCLK cycles to add, and QSPI\_REFCLK is



- running at 250 MHz (4 ns period), then the user should program a value of at least 9 to the d\_nss\_fld of this register.
- (7) Update Remap Address Register, if required.
- (8) Setup and enable Write Protection Registers, if they are required and if they have not already been setup from post initialization.
- (9) Enable required interrupts via the Interrupt Mask Register.
- (10) Setup the baud rate divisor in the QSPI Configuration Register to define the required clock frequency of the target device.
- (11) Update Read Data Capture Register. This register will delay when the read data is captured and can help when the read data path from the device to the controller is long and the device clock frequency is high. An update to this register may not be necessary.
- (12) Enable the Quad SPI Controller and the DAC via the QSPI Configuration Register.

#### 8.6.3 Using the Flash Command Control Register (STIG Operation)

The Flash Command Control Register provides software a means to access the FLASH device is a flexible and programmable manner. This is a STIG operation (Software Triggered Instruction Generator).

The instruction opcode, number of address bytes (if any), the address itself, number of dummy bytes (if any), number of write data bytes(if any), the write data itself and the number of read data bytes(if any) can be programmed. Once these have been programmed, software can trigger the command via bit 0 and wait for its completion by polling bit 1.

This method of accessing the FLASH is the typical mechanism that software would use to access the FLASH device's registers, as well as for performing ERASE operations. It can also be used to access the FLASH array itself, although it only has the ability to drive a single I/O pin, so dual and quad instructions would not be possible. In addition, a maximum of 8 data bytes may be read or written at any one time, defined in the Flash Command Write/Read Data Registers (Offset A0h, A4h, A8h and ACh).

Commands issued using this interface have a higher priority than all other direct READ accesses, and will therefore interrupt any READ commands being requested by the direct access controller. It will, however, not interrupt a write sequence that may have been issued via the direct access controller. In these cases, software may find it takes a long time for bit 1 to indicate the operation has completed.

#### 8.6.4 Using SPI Legacy Mode

SPI legacy mode allows software to access the internal TX-FIFO and RX-FIFO directly, thus bypassing the direct and STIG controllers. These controllers should therefore be disabled before legacy mode is entered.

Legacy mode allows the user to issue any FLASH instruction to the device, but does place a heavy software overhead in order to manage the fill levels of the FIFO's effectively. This is because the legacy SPI core is bi-directional in nature, with data continuously being transferred while the chip select is enabled.

Even if the driver only wishes to read data from the FLASH device, dummy data must be written out to ensure the chip select stays active, and vice versa for write transactions. This means that to perform a basic READ of 4 bytes to a device that has 3 address bytes, software would have to write a total of 8 bytes to the TX FIFO. The first byte would be the instruction opcode, the next 3 bytes are the address, and the final 4 bytes would be dummy data to ensure the chip select stays active while the read data is returned.

Similarly, since 8 bytes were written to the TX-FIFO, software should expect 8 bytes to be returned in the RX-FIFO. The first 4 bytes of this would be the unnecessary READ data, leaving the final 4 bytes holding the required READ data. Since the TX-FIFO and RX-FIFO are of limited depth (8 bytes) in legacy mode, software has a responsibility to maintain the FIFO levels to ensure the TX-FIFO does not become exhausted during the instruction execution and the RX-FIFO doesn't overflow. This can place a lot of overhead on software.

Interrupts are provided to indicate when the fill levels pass programmable watermarks, which are TX/RX Threshold Registers. Software accesses the TX-FIFO by writing any value to any address via the QSPI[m] ROM area to the Quad SPI Controller while legacy mode is enabled. Software accesses the RX-FIFO by reading any address via the QSPI[m] ROM area to the Quad SPI Controller while legacy mode is enabled. (m = 1 or 2)



#### 8.6.5 Entering and Exiting NoCMD mode

The read instruction can be reduced by NoCMD mode, and the performance can be improved especially in the case of Execute in Place (XIP). The name of this mode is vary depending on the FLASH device and manufacturer.

To enter or exit the NoCMD mode, set the mode bit according to the device. For each Mode Bit setting, refer to the device datasheet.

The below procedures are common entering and exiting procedures for most flash devices, Refer to the data sheet of each device for details.

#### 8.6.5.1 Entering NoCMD mode

To enter NoCMD mode, perform the following steps:

- (1) Disable the Direct Access Controller to ensure no new read or write accesses will be sent to the FLASH device.
- (2) Configure the mode bits to the values of the device, depending on the FLASH device and manufacturer. Set Mode Bit Enable to 1.
- (3) When the device is not in NoCMD mode:
  - Set bit 17 (enter xip mode fld) of the QSPI Configuration Register to 1.

When the device is in NoCMD mode:

Set bit 18 (enter xip mode imm fld) of the QSPI Configuration Register to 1.

## 8.6.5.2 Exiting NoCMD mode

To exit NoCMD mode, perform the following steps:

- (1) Disable the Direct Access Controller to ensure no new read or write accesses will be sent to the FLASH device.
- (2) Restore the setting related to mode bits to the values before entering NoCMD mode, depending on the FLASH device and manufacturer.
- (3) Set bit 17 (enter\_xip\_mode\_fld) and bit 18 (enter\_xip\_mode\_imm\_fld) of the QSPI Configuration Register to 0.

A READ operation with disabling NoCMD mode is required to exit the mode in the FLASH device, so NoCMD mode will internally stay active in the device until the next READ operation. The method for disabling NoCMD mode in the flash device depends on the device.

#### 8.6.6 Using the Write Protection Registers

After reset, the AHB protection mechanism wakes in a disabled state. Software can use the protection registers to block QSPI Memory Map area writes.

Refer to **Section 8.5.1.2, Write Protection** for details. It is recommended that the Quad SPI Controller is disabled before configuring the protection registers.

## 8.7 Usage Notes

#### 8.7.1 4-byte Address Output

The incoming direct access address maps directly to the address sent serially to the FLASH device. When the 4-byte address is output (dev\_size\_config\_reg. num\_addr\_bytes\_fld = 3), the access to address 0x10000000 in the QSPI1 ROM area will sent the same address to the FLASH device.

The address remapping function makes it possible to make the address appropriate for the FLASH device. Set the offset value to Remap Address Register (remap\_addr\_reg) and set enb\_ahb\_addr\_remap\_fld bit of QSPI Configuration Register (config reg) to 1 to enable the address remapping function.

Ex.)

To send 4-byte address 0x00000000 to the FLASH device by accessing to address 0x10000000 in the QSPI1 ROM area, set remap addr reg = 0xF0000000 and enable the address remapping function.

#### 8.7.2 Write Protection Area

Any writing to the protected area set in Write Protection Register will generate a bus error. The block sets in Write Protection Register is based on the Memory Map address.

The address remapping function makes it possible to make the starting block appropriate for the FLASH device. Set the offset value to Remap Address Register (remap\_addr\_reg) and set enb\_ahb\_addr\_remap\_fld bit of QSPI Configuration Register (config reg) to 1 to enable the address remapping function.

Ex.)

To set 0x10000000 in QSPI1 ROM area as 0 block base, set remap\_addr\_reg = 0xF0000000 and enable the address remapping function.

## 8.7.3 Automatically Polling for Write Complete

In direct access, the controller will automatically poll for the write cycle complete before the next access. The next access may be delayed for this reason. The wait time depends to the page program period of the FLASH device.

The automatic polling function is controlled by disable\_polling\_fld bit of Write Completion Control Register (write\_completion\_ctrl\_reg). If disabling automatically polling, the user must confirm that the FLASH device write cycle is complete.

#### 8.7.4 Chip Select Output

Because the function of enable\_ahb\_decoder\_fld bit of QSPI Configuration Register (config\_reg) cannot be used, the chip select cannot be automatically selected by the address decoder. Use periph\_sel\_dec\_fld and periph\_cs\_lines\_fld bits of QSPI Configuration Register (config\_reg) by software setting.



## Section 9 SDIO/SD/eMMC Controller

#### 9.1 Overview

There are two instances of SDIO/SD/eMMC Controllers, each instance supports SD, SDIO, and eMMC. This controller supports connection to a single slot and performs multi-block writes and erases that lower access overhead.

- SD/SDIO Card interface
  - Transfers data in 1 bit or 4 bits mode
  - Speeds:

Default Speed Mode: 3.3 V signaling, Frequency up to 25 MHz, up to 12.5 MB/sec High Speed Mode: 3.3 V signaling, Frequency up to 50 MHz, up to 25 MB/sec

#### • eMMC interface

- Transfers data in 1 bit, 4 bits or 8 bits mode
- Speeds:

Backwards Compatibility Mode: 3.3 V signaling, Frequency up to 25 MHz, up to 25 MB/sec High Speed SDR Mode: 3.3 V signaling, Frequency up to 50 MHz, up to 50 MB/sec

#### • Miscellaneous

- Card Detection (Insertion/Removal)
- Support for SPI mode
- Support for PIO/SDMA/ADMA2 transfer
- Support for Read wait Control, Suspend/Resume operation
- Support for FIFO Overrun and Underrun condition by stopping SD clock
- Support for Multi Media Card Interrupt mode
- Wakeup capability



Figure 9.1 SDIO/SD/eMMC1 & 2 Controller Interfaces and Connections

# 9.2 Signal Interfaces

|                  | Input  |                                                      |
|------------------|--------|------------------------------------------------------|
| Signal Name      | Output | Description                                          |
| Clock            |        |                                                      |
| SDIO[m]_HCLK     | Input  | Internal bus clock (AHB)                             |
| SDIO[m]_ECLK     | Input  | External Interface clock                             |
| Interrupt        |        |                                                      |
| SDIF[m]_Int      | Output | SD/SDIO/eMMC interrupt, level sensitive, Active High |
| SDIF[m]_wkup_Int | Output | Wakeup interrupt, level sensitive, Active High       |
| External Signal  |        |                                                      |
| SDIO[m]_CLK      | Output | Clock                                                |
| SDIO[m]_CMD      | I/O    | Command/Response                                     |
| SDIO[m]_IO[7:0]  | I/O    | DAT line                                             |
| SDIO[m]_CD_N     | Input  | Card Detection, Active Low                           |
| SDIO[m]_WP       | Input  | Write Protect, Active High                           |
| SDIO[m]_LEDCTRL  | Output | Card access status                                   |

Note: m=1 or 2

Index removed style is used in this chapter.

Ex) SDIO\_CLK

# 9.3 Register Map

# 9.3.1 Register Map (SDIO1)

Table 9.1 SDIO Controller 1 Register Map

| Table 9.1 ODIO (    | Softtoller i Register Map           |                                                 |
|---------------------|-------------------------------------|-------------------------------------------------|
| Address             | Register Symbol                     | Register Name                                   |
| 4010 0000h          | reg_sdmasysaddrlo                   | SDMA System Address Register Low                |
| 4010 0002h          | reg_sdmasysaddrhi                   | SDMA System Address Register High               |
| 4010 0004h          | reg_blocksize                       | Block Size Register                             |
| 4010 0006h          | reg_blockcount                      | Block Count Register                            |
| 4010 0008h          | reg_argument1lo                     | Argument1 Register Low                          |
| 4010 000Ah          | reg_argument1hi                     | Argument1 Register High                         |
| 4010 000Ch          | reg_transfermode                    | Transfer Mode Register                          |
| 4010 000Eh          | reg_command                         | Command Register                                |
| 4010 0010h + 2h × n | reg_response[n] (n = 07)            | Response Register [n]                           |
| 4010 0020h          | reg_dataport                        | Buffer Data Port Register                       |
| 4010 0024h          | reg_presentstate                    | Present State Register                          |
| 4010 0028h          | reg_hostcontrol1                    | Host Control 1 Register                         |
| 4010 0029h          | reg_powercontrol                    | Power Control Register                          |
| 4010 002Ah          | reg_blockgapcontrol                 | Block Gap Control Register                      |
| 4010 002Bh          | reg_wakeupcontrol                   | Wake-up Control Register                        |
| 4010 002Ch          | reg_clockcontrol                    | Clock Control Register                          |
| 4010 002Eh          | reg_timeoutcontrol                  | Timeout Control Register                        |
| 4010 002Fh          | reg_softwarereset                   | Software Reset Register                         |
| 4010 0030h          | reg_normalintrsts                   | Normal Interrupt Status Register                |
| 4010 0032h          | reg_errorintrsts                    | Error Interrupt Status Register                 |
| 4010 0034h          | reg_normalintrstsena                | Normal Interrupt Status Enable Register         |
| 4010 0036h          | reg_errorintrstsena                 | Error Interrupt Status Enable Register          |
| 4010 0038h          | reg_normalintrsigena                | Normal Interrupt Signal Enable Register         |
| 4010 003Ah          | reg_errorintrsigena                 | Error Interrupt Signal Enable Register          |
| 4010 003Ch          | reg_autocmderrsts                   | Auto CMD Error Status Register                  |
| 4010 003Eh          | reg_hostcontrol2                    | Host Control 2 Register                         |
| 4010 0040h          | reg_capabilities                    | Capabilities Register                           |
| 4010 0044h          | reg_capabilities_cont               | Capabilities Register (Continue)                |
| 4010 0048h          | reg_maxcurrentcap                   | Maximum Current Capabilities Register           |
| 4010 0050h          | reg_ForceEventforAUTOCMDErrorStatus | Force Event for Auto CMD Error Status Register  |
| 4010 0052h          | reg_forceeventforerrintsts          | Force Event for Error Interrupt Status Register |
| 4010 0054h          | reg_admaerrsts                      | ADMA Error Status Register                      |
| 4010 0058h          | reg_admasysaddr0                    | ADMA System Address Register Low                |
| 4010 005Ah          | reg_admasysaddr1                    | ADMA System Address Register High               |
| 4010 0060h          | reg_presetvalue0                    | Preset Value Register for Initialization        |
| 4010 0062h          | reg_presetvalue1                    | Preset Value Register for Default Speed         |
| 4010 0064h          | reg_presetvalue2                    | Preset Value Register for High Speed            |
| 4010 00FCh          | reg_slotintrsts                     | Slot Interrupt Status Register                  |
| 4010 00FEh          | reg_hostcontrollerver               | Host Controller Version Register                |
|                     |                                     |                                                 |

## 9.3.2 Register Map (SDIO2)

Table 9.2 SDIO Controller 2 Register Map

| Table 3.2 ODIO      | Softioner 2 Register Map            |                                                 |
|---------------------|-------------------------------------|-------------------------------------------------|
| Address             | Register Symbol                     | Register Name                                   |
| 4010 1000h          | reg_sdmasysaddrlo                   | SDMA System Address Register Low                |
| 4010 1002h          | reg_sdmasysaddrhi                   | SDMA System Address Register High               |
| 4010 1004h          | reg_blocksize                       | Block Size Register                             |
| 4010 1006h          | reg_blockcount                      | Block Count Register                            |
| 4010 1008h          | reg_argument1lo                     | Argument1 Register Low                          |
| 4010 100Ah          | reg_argument1hi                     | Argument1 Register High                         |
| 4010 100Ch          | reg_transfermode                    | Transfer Mode Register                          |
| 4010 100Eh          | reg_command                         | Command Register                                |
| 4010 1010h + 2h × n | reg_response[n] (n = 07)            | Response Register [n]                           |
| 4010 1020h          | reg_dataport                        | Buffer Data Port Register                       |
| 4010 1024h          | reg_presentstate                    | Present State Register                          |
| 4010 1028h          | reg_hostcontrol1                    | Host Control 1 Register                         |
| 4010 1029h          | reg_powercontrol                    | Power Control Register                          |
| 4010 102Ah          | reg_blockgapcontrol                 | Block Gap Control Register                      |
| 4010 102Bh          | reg_wakeupcontrol                   | Wake-up Control Register                        |
| 4010 102Ch          | reg_clockcontrol                    | Clock Control Register                          |
| 4010 102Eh          | reg_timeoutcontrol                  | Timeout Control Register                        |
| 4010 102Fh          | reg_softwarereset                   | Software Reset Register                         |
| 4010 1030h          | reg_normalintrsts                   | Normal Interrupt Status Register                |
| 4010 1032h          | reg_errorintrsts                    | Error Interrupt Status Register                 |
| 4010 1034h          | reg_normalintrstsena                | Normal Interrupt Status Enable Register         |
| 4010 1036h          | reg_errorintrstsena                 | Error Interrupt Status Enable Register          |
| 4010 1038h          | reg_normalintrsigena                | Normal Interrupt Signal Enable Register         |
| 4010 103Ah          | reg_errorintrsigena                 | Error Interrupt Signal Enable Register          |
| 4010 103Ch          | reg_autocmderrsts                   | Auto CMD Error Status Register                  |
| 4010 103Eh          | reg_hostcontrol2                    | Host Control 2 Register                         |
| 4010 1040h          | reg_capabilities                    | Capabilities Register                           |
| 4010 1044h          | reg_capabilities_cont               | Capabilities Register (Continue)                |
| 4010 1048h          | reg_maxcurrentcap                   | Maximum Current Capabilities Register           |
| 4010 1050h          | reg_ForceEventforAUTOCMDErrorStatus | Force Event for Auto CMD Error Status Register  |
| 4010 1052h          | reg_forceeventforerrintsts          | Force Event for Error Interrupt Status Register |
| 4010 1054h          | reg_admaerrsts                      | ADMA Error Status Register                      |
| 4010 1058h          | reg_admasysaddr0                    | ADMA System Address Register Low                |
| 4010 105Ah          | reg_admasysaddr1                    | ADMA System Address Register High               |
| 4010 1060h          | reg_presetvalue0                    | Preset Value Register for Initialization        |
| 4010 1062h          | reg_presetvalue1                    | Preset Value Register for Default Speed         |
| 4010 1064h          | reg_presetvalue2                    | Preset Value Register for High Speed            |
| 4010 10FCh          | reg_slotintrsts                     | Slot Interrupt Status Register                  |
| 4010 10FEh          | reg_hostcontrollerver               | Host Controller Version Register                |
|                     |                                     |                                                 |

## 9.4 Register Description

### 9.4.1 reg\_sdmasysaddrlo — SDMA System Address Register Low

This register contains the Lower 16-bit of physical system memory address used for DMA transfers or the second argument for the Auto CMD23.

**Address:** 4010 0000h (SDIO1)

4010 1000h (SDIO2)



Table 9.3 reg\_sdmasysaddrlo Register Contents

| Bit Position | Bit Name        | Function                                                                            | R/W |
|--------------|-----------------|-------------------------------------------------------------------------------------|-----|
| b15 to b0    | sdma_sysaddress | This field contains the Lower 16-bit of physical system memory address used for DMA | R/W |
|              |                 | transfers or the second argument for the Auto CMD23.                                |     |

#### (1) SDMA System Address

This register contains the system memory address for a SDMA transfer. When the Host Controller (HC) stops a SDMA transfer, this register shall point to the system address of the next contiguous data position. It can be accessed only if no transaction is executing (i.e., after a transaction has stopped). Read operations during transfers may return an invalid value. The Host Driver (HD) shall initialize this register before starting a SDMA transaction. After SDMA has stopped, the next system address of the next contiguous data position can be read from this register.

The SDMA transfer waits at the every boundary specified by the Host SDMA Buffer Boundary in the Block Size Register. The HC generates DMA Interrupt to request the HD to update this register. The HD sets the next system address of the next data position to this register.

When the most upper byte of this register (003h) is written, the HC restarts the SDMA transfer. When restarting SDMA by the Resume command or by setting Continue Request in the Block Gap Control Register, the HC shall start at the next contiguous address stored here in the SDMA System Address Register. ADMA does not use this register.

#### (2) Argument 2

This register is used with the Auto CMD23 to set a 32-bit block count value to the argument of the CMD23 while executing Auto CMD23. If Auto CMD23 is used with ADMA, the full 32-bit block count value can be used. If Auto CMD23 is used without ADMA, the available block count value is limited by the Block Count Register. 65535 blocks are the maximum value in this case.

## 9.4.2 reg\_sdmasysaddrhi — SDMA System Address Register High

This register contains the Higher 16-bit of physical system memory address used for DMA transfers or the second argument for the Auto CMD23.

**Address:** 4010 0002h (SDIO1)

4010 1002h (SDIO2)



Table 9.4 reg\_sdmasysaddrhi Register Contents

| Bit Position | Bit Name        | Function                                                                                                                                                 | R/W |
|--------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b15 to b0    | sdma_sysaddress | This Field contains the Higher 16 bits of Physical system memory address used for DMA transfers. Details of this field is described in reg_admasysaddr0. | R/W |

## 9.4.3 reg\_blocksize — Block Size Register

This register is used to configure the number of bytes in a data block.

Address: 4010 0004h (SDIO1)

4010 1004h (SDIO2)



Table 9.5 reg\_blocksize Register Contents

| Bit Position | Bit Name         | Function                                                                                                                                                                                                                                                                                                                                                                          | R/W |
|--------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b15          | Reserved         |                                                                                                                                                                                                                                                                                                                                                                                   | R   |
| b14 to b12   | sdma_bufboundary | Host SDMA Buffer Boundary                                                                                                                                                                                                                                                                                                                                                         | R/W |
|              |                  | To perform long DMA transfer, SDMA System Address Register shall be updated at every system boundary during DMA transfer. These bits specify the size of contiguous buffer in the system memory. The DMA transfer shall wait at the every boundary specified by these fields and the HC generates the DMA Interrupt to request the HD to update the SDMA System Address Register. |     |
|              |                  | These bits shall support when the DMA Support in the Capabilities Register is set to 1 and this function is active when the DMA Enable in the Transfer Mode Register is set to 1.                                                                                                                                                                                                 |     |
|              |                  | 000b: 4 KB (Detects A11 Carry out)                                                                                                                                                                                                                                                                                                                                                |     |
|              |                  | 001b: 8 KB (Detects A12 Carry out)                                                                                                                                                                                                                                                                                                                                                |     |
|              |                  | 010b: 16 KB (Detects A13 Carry out)                                                                                                                                                                                                                                                                                                                                               |     |
|              |                  | 011b: 32 KB (Detects A14 Carry out)                                                                                                                                                                                                                                                                                                                                               |     |
|              |                  | 100b: 64 KB (Detects A15 Carry out)                                                                                                                                                                                                                                                                                                                                               |     |
|              |                  | 101b: 128 KB (Detects A16 Carry out)                                                                                                                                                                                                                                                                                                                                              |     |
|              |                  | 110b: 256 KB (Detects A17 Carry out)                                                                                                                                                                                                                                                                                                                                              |     |
|              |                  | 111b: 512 KB (Detects A18 Carry out)                                                                                                                                                                                                                                                                                                                                              |     |
| b11 to b0    | xfer_blocksize   | Transfer Block Size                                                                                                                                                                                                                                                                                                                                                               | R/W |
|              |                  | This field specifies the block size for block data transfers for CMD17, CMD18, CMD24, CMD25 and CMD53. It can be accessed only if no transaction is executing (i.e after a transaction has stopped). Read operations during transfer return an invalid value and write operations shall be ignored.                                                                               |     |
|              |                  | 0000h: No Data Transfer                                                                                                                                                                                                                                                                                                                                                           |     |
|              |                  | 0001h: 1 Byte                                                                                                                                                                                                                                                                                                                                                                     |     |
|              |                  | 0002h: 2 Bytes                                                                                                                                                                                                                                                                                                                                                                    |     |
|              |                  | 0003h: 3 Bytes                                                                                                                                                                                                                                                                                                                                                                    |     |
|              |                  | 0004h: 4 Bytes                                                                                                                                                                                                                                                                                                                                                                    |     |
|              |                  |                                                                                                                                                                                                                                                                                                                                                                                   |     |
|              |                  | 01FFh: 511 Bytes                                                                                                                                                                                                                                                                                                                                                                  |     |
|              |                  | 0200h: 512 Bytes                                                                                                                                                                                                                                                                                                                                                                  |     |
|              |                  |                                                                                                                                                                                                                                                                                                                                                                                   |     |
|              |                  | 0800h: 2048 Bytes                                                                                                                                                                                                                                                                                                                                                                 |     |

# 9.4.4 reg\_blockcount — Block Count Register

This register is used to configure the number of data blocks.

**Address:** 4010 0006h (SDIO1)

4010 1006h (SDIO2)



Table 9.6 reg\_blockcount Register Contents

| Bit Position | Bit Name        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                    | R/W |
|--------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b15 to b0    | xfer_blockcount | Blocks Count for Current Transfer                                                                                                                                                                                                                                                                                                                                                                                                           | R/W |
|              |                 | This register is enabled when Block Count Enable in the Transfer Mode Register is set to 1 and is valid only for multiple block transfers. The HC decrements the block count after each block transfer and stops when the count reaches zero. It can be accessed only if no transaction is executing (i.e. after a transaction has stopped). Read operations during transfer return an invalid value and write operations shall be ignored. |     |
|              |                 | When saving transfer context as a result of Suspend command, the number of blocks yet to be transferred can be determined by reading this register. When restoring transfer context prior to issuing a Resume command, the HD shall restore the previously save block count.                                                                                                                                                                |     |
|              |                 | 0000h: Stop Count                                                                                                                                                                                                                                                                                                                                                                                                                           |     |
|              |                 | 0001h: 1 block                                                                                                                                                                                                                                                                                                                                                                                                                              |     |
|              |                 | 0002h: 2 blocks                                                                                                                                                                                                                                                                                                                                                                                                                             |     |
|              |                 |                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |
|              |                 | FFFFh: 65535 blocks                                                                                                                                                                                                                                                                                                                                                                                                                         |     |

## 9.4.5 reg\_argument1lo — Argument1 Register Low

This register contains Lower bits of SD Command Argument.

**Address:** 4010 0008h (SDIO1)

4010 1008h (SDIO2)



Table 9.7 reg\_argument1lo Register Contents

| Bit Position | Bit Name          | Function                                                           | R/W |
|--------------|-------------------|--------------------------------------------------------------------|-----|
| b15 to b0    | command_argument1 | The SD Command Argument is specified as bit23-8 of Command-Format. | R/W |

## 9.4.6 reg\_argument1hi — Argument1 Register High

This register contains higher bits of SD Command Argument.

**Address:** 4010 000Ah (SDIO1)

4010 100Ah (SDIO2)



Table 9.8 reg\_argument1hi Register Contents

| Bit Position | Bit Name          | Function                                                            | R/W |
|--------------|-------------------|---------------------------------------------------------------------|-----|
| b15 to b0    | command_argument1 | The SD Command Argument is specified as bit39-24 of Command-Format. | R/W |

### 9.4.7 reg\_transfermode — Transfer Mode Register

This register is used to control the operations of data transfers.

**Address:** 4010 000Ch (SDIO1)

4010 100Ch (SDIO2)



| Bit Position | Bit Name             | Function                                                                                                                                                                                                                                                                                                                                                        | R/W |
|--------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b15 to b6    | Reserved             |                                                                                                                                                                                                                                                                                                                                                                 | R   |
| b5           | xfermode_multiblksel | Multi/Single Block Select                                                                                                                                                                                                                                                                                                                                       | R/W |
|              |                      | This bit enables multiple block data transfers.                                                                                                                                                                                                                                                                                                                 |     |
|              |                      | 0: Single Block                                                                                                                                                                                                                                                                                                                                                 |     |
|              |                      | 1: Multiple Block                                                                                                                                                                                                                                                                                                                                               |     |
| b4           | xfermode_dataxferdir | Data Transfer Direction Select                                                                                                                                                                                                                                                                                                                                  | R/W |
|              |                      | This bit defines the direction of data transfers.                                                                                                                                                                                                                                                                                                               |     |
|              |                      | 0: Write from Host to Card                                                                                                                                                                                                                                                                                                                                      |     |
|              |                      | 1: Read from Card to Host                                                                                                                                                                                                                                                                                                                                       |     |
| b3, b2       | xfermode_autocmden   | Auto CMD Enable                                                                                                                                                                                                                                                                                                                                                 | R/W |
|              | а                    | This field determines use of auto command functions.                                                                                                                                                                                                                                                                                                            |     |
|              |                      | 00b: Auto Command Disabled                                                                                                                                                                                                                                                                                                                                      |     |
|              |                      | 01b: Auto CMD12 Enabled                                                                                                                                                                                                                                                                                                                                         |     |
|              |                      | 10b: Auto CMD23 Enabled                                                                                                                                                                                                                                                                                                                                         |     |
|              |                      | 11b: Reserved                                                                                                                                                                                                                                                                                                                                                   |     |
|              |                      | There are two methods to stop Multiple-block read and write operation.                                                                                                                                                                                                                                                                                          |     |
|              |                      | (1) Auto CMD12 Enable                                                                                                                                                                                                                                                                                                                                           |     |
|              |                      | Multiple-block read and write commands for memory require CMD12 to stop the operation. When this field is set to 01b, the HC issues CMD12 automatically when last block transfer is completed. Auto CMD12 error is indicated to the Auto CMD Error Status Register. The HD shall not set this bit if the command does not require CMD12.  (2) Auto CMD23 Enable |     |
|              |                      | When this bit field is set to 10b, the HC issues a CMD23 automatically before issuing a command specified in the Command Register.                                                                                                                                                                                                                              |     |
|              |                      | The following conditions are required to use the Auto CMD23.                                                                                                                                                                                                                                                                                                    |     |

- A memory card that supports CMD23 (SCR[33]=1).
- If DMA is used, it shall be ADMA.
- Only when CMD18 or CMD25 is issued.

By writing the Command Register, the HC issues a CMD23 first and then issues a command specified by the Command Index in Command Register 32-bit block count value for CMD23 is set to SDMA System Address Register.

b1 xfermode\_blkcntena

**Block Count Enable** 

R/W

This bit is used to enable the Block Count Register, which is only relevant for multiple block transfers. When this bit is 0, the Block Count Register is disabled, which is useful in executing an infinite transfer.

- 0: To disable Block count
- 1: To enable Block Count



| Table 9.9 | reg_transferm | node Register | Contents | (2/2) | ) |
|-----------|---------------|---------------|----------|-------|---|
|-----------|---------------|---------------|----------|-------|---|

| Bit Position | Bit Name           | Function                                                                                                                                                                                              | R/W |
|--------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0           | xfermode_dmaenable | DMA Enable                                                                                                                                                                                            | R/W |
|              |                    | DMA can be enabled only if DMA Support bit in the Capabilities Register is set. If this bit is set to 1, a DMA operation shall begin when the HD writes to the upper byte of Command Register (00Fh). |     |
|              |                    | 0: To disable DMA                                                                                                                                                                                     |     |
|              |                    | 1: To enable DMA                                                                                                                                                                                      |     |

## 9.4.8 reg\_command — Command Register

This register is used to program the Command for host controller.

**Address:** 4010 000Eh (SDIO1)

4010 100Eh (SDIO2)



Table 9.10 reg command Register Contents (1/2)

| Bit Position | Dit Nama          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W |  |  |
|--------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|
|              | Bit Name          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |  |  |
| b15, b14     | Reserved          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R   |  |  |
| b13 to b8    | command_cmdindex  | Command Index                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R/W |  |  |
|              |                   | This bit shall be set to the command number (CMD0-63, ACMD0-63).                                                                                                                                                                                                                                                                                                                                                                                                                              |     |  |  |
| b7, b6       | command_cmdtype   | Command Type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R/W |  |  |
|              |                   | This bit is used for select different command types. There are three types of special commands. Suspend, Resume and Abort. These bits shall be set to 00b for all other commands.                                                                                                                                                                                                                                                                                                             |     |  |  |
|              |                   | Suspend Command:                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |  |  |
|              |                   | If the Suspend command succeeds, the HC shall assume the SD Bus has been released and that it is possible to issue the next command which uses the DAT line. The HC shall de-assert Read Wait for read transactions and stop checking busy for write transactions. The Interrupt cycle shall start, in 4-bit mode. If the Suspend command fails, the HC shall maintain its current state and the HD shall restart the transfer by setting Continue Request in the Block Gap Control Register. |     |  |  |
|              |                   | • Resume Command:                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |  |  |
|              |                   | The HD re-starts the data transfer by restoring the registers in the range of 000-00Dh. The HC shall check for busy before starting write transfers.                                                                                                                                                                                                                                                                                                                                          |     |  |  |
|              |                   | Abort Command:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |  |  |
|              |                   | If this command is set when executing a read transfer, the HC shall stop reads to the buffer. If this command is set when executing a write transfer, the HC shall stop driving the DAT line. After issuing the Abort command, the HD should issue a software reset.                                                                                                                                                                                                                          |     |  |  |
|              |                   | 00b: Normal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |  |  |
|              |                   | 01b: Suspend                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |  |  |
|              |                   | 10b: Resume                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |  |  |
|              |                   | 11b: Abort                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |     |  |  |
| b5           | command_dataprese | Data Present Select                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R/W |  |  |
|              | nt                | This bit is set to 1 to indicate that data is present and shall be transferred using the DAT line. If is set to 0 for the following:                                                                                                                                                                                                                                                                                                                                                          |     |  |  |
|              |                   | 1. Commands using only CMD line (ex. CMD52).                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |  |  |
|              |                   | <ol><li>Commands with no data transfer but using busy signal on DAT[0] line (R1b or<br/>R5b ex. CMD38).</li></ol>                                                                                                                                                                                                                                                                                                                                                                             |     |  |  |
|              |                   | 3. Resume Command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |  |  |
|              |                   | 0: Data not Present                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |  |  |
|              |                   | 1: Data present                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     |  |  |
| o4           | command_indexchke | Command Index Check Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R/W |  |  |
| -            | na                | If this bit is set to 1, the HC shall check the index field in the response to see if it has the same value as the command index. If it is not, it is reported as a Command Index Error. If this bit is set to 0, the Index field is not checked.                                                                                                                                                                                                                                             |     |  |  |
|              |                   | 0: Disable 1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |     |  |  |

Table 9.10 reg\_command Register Contents (2/2)

|              | 9(/                |                                                                                                                                                                                                   |     |  |  |  |
|--------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|
| Bit Position | Bit Name           | Function                                                                                                                                                                                          | R/W |  |  |  |
| b3           | command_crcchkena  | Command CRC Check Enable                                                                                                                                                                          | R/W |  |  |  |
|              |                    | If this bit is set to 1, the HC shall check the CRC field in the response. If an error is detected, it is reported as a Command CRC Error. If this bit is set to 0, the CRC field is not checked. |     |  |  |  |
|              |                    | 0: Disable                                                                                                                                                                                        |     |  |  |  |
|              |                    | 1: Enable                                                                                                                                                                                         |     |  |  |  |
| b2           | Reserved           |                                                                                                                                                                                                   | R   |  |  |  |
| b1, b0       | command_responsety | Response Type Select.                                                                                                                                                                             | R/W |  |  |  |
|              | ре                 | 00b: No Response                                                                                                                                                                                  |     |  |  |  |
|              |                    | 01b: Response Length 136                                                                                                                                                                          |     |  |  |  |
|              |                    | 10b: Response Length 48                                                                                                                                                                           |     |  |  |  |
|              |                    | 11b: Response Length 48, check busy after response                                                                                                                                                |     |  |  |  |

## 9.4.9 reg\_response[n] — Response Register [n] (n = 0..7)

This register is used to store responses from SD Cards.

**Address:** 4010 0010h + 2h × n (SDIO1)

4010 1010h + 2h × n (SDIO2)



Table 9.11 reg\_response[n] Register Contents

| Bit Position | Bit Name         | Function                                                                                                               | R/W |
|--------------|------------------|------------------------------------------------------------------------------------------------------------------------|-----|
| b15 to b0    | command_response | The command response from SD bus is stored to these registers according to response type.  REP[15:0] → reg_response[0] | R   |

 $\mathsf{REP}[127:111] \to \mathsf{reg\_response}[7]$ 

| Response Type                  | Meaning of Response           | Response Field | REP[]       |
|--------------------------------|-------------------------------|----------------|-------------|
| R1, R1b (Normal response)      | Card Status                   | R[39:8]        | REP[31:0]   |
| R1b (Auto CMD12 response)      | Card Status for<br>Auto CMD12 | R[39:8]        | REP[127:96] |
| R1 (Auto CMD23 response)       | Card Status for<br>Auto CMD23 | R[39:8]        | REP[127:96] |
| R2 (CID, CSD register)         | CID or CSD reg. incl.         | R[127:8]       | REP[119:0]  |
| R3 (OCR register)              | OCR reg. for memory           | R[39:8]        | REP[31:0]   |
| R4 (OCR register)              | OCR reg. for I/O, etc.        | R[39:8]        | REP[31:0]   |
| R5, R5b                        | SDIO response                 | R[39:8]        | REP[31:0]   |
| R6<br>(Published RCA response) | New published RCA[31:16] etc. | R[39:8]        | REP[31:0]   |

## 9.4.10 reg\_dataport — Buffer Data Port Register

This register is used to access internal buffer.

**Address:** 4010 0020h (SDIO1)

4010 1020h (SDIO2)



Table 9.12 reg\_dataport Register Contents

| Bit Position | Bit Name                     | Function                                                              | R/W |
|--------------|------------------------------|-----------------------------------------------------------------------|-----|
| b31 to b0    | sdhcdmactrl_piobufrd<br>data | The HC Buffer can be accessed through this 32-bit Data Port Register. | R/W |

# 9.4.11 reg\_presentstate — Present State Register

The HD can get status of the HC from this 32-bit read-only register.

**Address:** 4010 0024h (SDIO1) 4010 1024h (SDIO2)

| Bit               | b31 | b30 | b29 | b28                       | b27                             | b26                       | b25                       | b24                      | b23                       | b22                       | b21                       | b20                       | b19               | b18         | b17                                       | b16                             |
|-------------------|-----|-----|-----|---------------------------|---------------------------------|---------------------------|---------------------------|--------------------------|---------------------------|---------------------------|---------------------------|---------------------------|-------------------|-------------|-------------------------------------------|---------------------------------|
|                   |     | _   | I   | sdif_dat<br>7in_dsy<br>nc | sdif_dat<br>6in_dsy<br>nc       | sdif_dat<br>5in_dsy<br>nc | sdif_dat<br>4in_dsy<br>nc | sdif_cm<br>din_dsy<br>nc | sdif_dat<br>3in_dsy<br>nc | sdif_dat<br>2in_dsy<br>nc | sdif_dat<br>1in_dsy<br>nc | sdif_dat<br>0in_dsy<br>nc | sdif_wp<br>_dsync | n_dsynd     | sdhccar<br>ddet_st<br>atestabl<br>e_dsync |                                 |
| Value after reset | Χ   | Χ   | Χ   | 1                         | 1                               | 1                         | 1                         | 1                        | 1                         | 1                         | 1                         | 1                         | 0                 | 0           | 0                                         | 0                               |
| Bit               | b15 | b14 | b13 | b12                       | b11                             | b10                       | b9                        | b8                       | b7                        | b6                        | b5                        | b4                        | b3                | b2          | b1                                        | b0                              |
|                   |     |     | l   | 1                         | sdhcdmac<br>trl_piobufr<br>dena |                           |                           |                          |                           | _                         |                           | l                         |                   | trl_datalin | state_in                                  | present<br>state_in<br>hibitcmd |
| Value after reset | Х   | Х   | Х   | Х                         | 0                               | 0                         | 0                         | 0                        | Х                         | Х                         | Х                         | Х                         | Х                 | 0           | 0                                         | 0                               |

Table 9.13 reg\_presentstate Register Contents (1/3)

| 14516 5.15   | <u> </u>                          | egister Contents (170)                                                                                                                                                                                                                                                                                            |     |
|--------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Bit Position | Bit Name                          | Function                                                                                                                                                                                                                                                                                                          | R/W |
| b31 to b29   | Reserved                          |                                                                                                                                                                                                                                                                                                                   | R   |
| b28          | sdif_dat7in_dsync                 | This status is used to check DAT[7] line level to recover from errors, and for debugging.                                                                                                                                                                                                                         | R   |
| b27          | sdif_dat6in_dsync                 | This status is used to check DAT[6] line level to recover from errors, and for debugging.                                                                                                                                                                                                                         | R   |
| b26          | sdif_dat5in_dsync                 | This status is used to check DAT[5] line level to recover from errors, and for debugging.                                                                                                                                                                                                                         | R   |
| b25          | sdif_dat4in_dsync                 | This status is used to check DAT[4] line level to recover from errors, and for debugging.                                                                                                                                                                                                                         | R   |
| b24          | sdif_cmdin_dsync                  | This status is used to check CMD line level to recover from errors, and for debugging.                                                                                                                                                                                                                            | R   |
| b23          | sdif_dat3in_dsync                 | This status is used to check DAT[3] line level to recover from errors, and for debugging.                                                                                                                                                                                                                         | R   |
| b22          | sdif_dat2in_dsync                 | This status is used to check DAT[2] line level to recover from errors, and for debugging.                                                                                                                                                                                                                         | R   |
| b21          | sdif_dat1in_dsync                 | This status is used to check DAT[1] line level to recover from errors, and for debugging.                                                                                                                                                                                                                         | R   |
| b20          | sdif_dat0in_dsync                 | This status is used to check DAT[0] line level to recover from errors, and for debugging. This is especially useful in detecting the busy signal level from DAT[0].                                                                                                                                               | R   |
| b19          | sdif_wp_dsync                     | Write Protect Switch Pin Level  The Write Protect Switch is supported for memory and combo cards. This bit reflects the SDIO_WP pin.  0: Write protected (SDIO_WP = 1)  1: Write enabled (SDIO_WP = 0)                                                                                                            | R   |
| b18          | sdif_cd_n_dsync                   | Card Detect Pin Level  This bit reflects the inverse value of the SDIO_CD_N pin.  0: No Card present (SDIO_CD_N = 1)  1: Card present (SDIO_CD_N = 0)                                                                                                                                                             | R   |
| b17          | sdhccarddet_statesta<br>ble_dsync | Card State Stable  This bit is used for testing. If it is 0, the Card Detect Pin Level is not stable. If this bit is set to 1, it means the Card Detect Pin Level is stable. The Software Reset For All in the Software Reset Register shall not affect this bit.  0: Reset or Debouncing  1: No Card or Inserted | R   |

| Table 9.13 | rea | presentstate  | Register   | Contents  | (2/3) |
|------------|-----|---------------|------------|-----------|-------|
| Table 3.13 | ICU | Diesellistate | 1 (Cuistei | COLLECTIO | (2/01 |

| Bit Position | Bit Name                    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                               | R/W |
|--------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b16          | sdhccarddet_inserted        | Card Inserted                                                                                                                                                                                                                                                                                                                                                                                                                                          | R   |
|              | _dsync                      | This bit indicates whether a card has been inserted. Changing from 0 to 1 generates a Card Insertion interrupt in the Normal Interrupt Status Register and changing from 1 to 0 generates a Card Removal Interrupt in the Normal Interrupt Status Register. The Software Reset For All in the Software Reset Register shall not affect this bit.                                                                                                       |     |
|              |                             | If a Card is removed while its power is on and its clock is oscillating, the HC shall clear SD Bus Power in the Power Control Register and SD Clock Enable in the Clock Control Register. In addition, the HD should clear the HC by the Software Reset For All in Software Register. The card detect is active regardless of the SD Bus Power.                                                                                                        |     |
|              |                             | 0: Reset or Debouncing or No Card                                                                                                                                                                                                                                                                                                                                                                                                                      |     |
|              |                             | 1: Card Inserted                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |
| b15 to b12   | Reserved                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R   |
| b11          | sdhcdmactrl_piobufrd        | Buffer Read Enable                                                                                                                                                                                                                                                                                                                                                                                                                                     | R   |
|              | ena                         | This status is used for non-DMA read transfers. This read only flag indicates that valid data exists in the host side buffer status. If this bit is 1, readable data exists in the buffer. A change of this bit from 1 to 0 occurs when all the block data is read from the buffer. A change of this bit from 0 to 1 occurs when block data is ready in the buffer and generates the Buffer Read Ready Interrupt.  0: Read Disable                     |     |
|              |                             | 1: Read Enable                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| b10          | sdhcdmactrl_piobufwr<br>ena | Buffer Write Enable  This status is used for non-DMA write transfers. This read only flag indicates if space is available for write data. If this bit is 1, data can be written to the buffer. A change of this bit from 1 to 0 occurs when all the block data is written to the buffer. A change of this bit from 0 to 1 occurs when top of block data can be written to the buffer and generates the Buffer Write Ready Interrupt.  0: Write Disable | R   |
|              |                             | 1: Write enable                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |
| b9           | sdhcdmactrl_rdxferact       | Read Transfer Active                                                                                                                                                                                                                                                                                                                                                                                                                                   | R   |
|              | ive                         | This status is used for detecting completion of a read transfer.                                                                                                                                                                                                                                                                                                                                                                                       |     |
|              |                             | This bit is set to 1 for either of the following conditions:                                                                                                                                                                                                                                                                                                                                                                                           |     |
|              |                             | After the end bit of the read command.                                                                                                                                                                                                                                                                                                                                                                                                                 |     |
|              |                             | <ul> <li>When writing a 1 to continue Request in the Block Gap Control Register to restart a<br/>read transfer.</li> </ul>                                                                                                                                                                                                                                                                                                                             |     |
|              |                             | This bit is cleared to 0 for either of the following conditions:                                                                                                                                                                                                                                                                                                                                                                                       |     |
|              |                             | • When the last data block as specified by block length is transferred to the system.                                                                                                                                                                                                                                                                                                                                                                  |     |
|              |                             | <ul> <li>When all valid data blocks have been transferred to the system and no current<br/>block transfers are being sent as a result of the Stop At Block Gap Request set to<br/>1.</li> </ul>                                                                                                                                                                                                                                                        |     |
|              |                             | A transfer complete interrupt is generated when this bit changes to 0.  0: No valid data                                                                                                                                                                                                                                                                                                                                                               |     |
|              |                             | 1: Transferring data                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |

| Table 9.13 | reg_presentstate | Register Contents | (3/3) |
|------------|------------------|-------------------|-------|
|            |                  |                   |       |

| Bit Position | Bit Name                     | Function                                                                                                                                                                                                                                                                                                                                                                         | R/\ |
|--------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b8           | sdhcdmactrl_wrxferac<br>tive | Write Transfer Active This status indicates a write transfer is active. If this bit is 0, it means no valid write data exists in the HC.                                                                                                                                                                                                                                         | R   |
|              |                              | This bit is set in either of the following cases:                                                                                                                                                                                                                                                                                                                                |     |
|              |                              | After the end bit of the write command.                                                                                                                                                                                                                                                                                                                                          |     |
|              |                              | <ul> <li>When writing a 1 to Continue Request in the Block Gap Control Register to restart a<br/>write transfer.</li> </ul>                                                                                                                                                                                                                                                      |     |
|              |                              | This bit is cleared in either of the following cases:                                                                                                                                                                                                                                                                                                                            |     |
|              |                              | <ul> <li>After getting the CRC status of the last data block as specified by the transfer count<br/>(Single or Multiple)</li> </ul>                                                                                                                                                                                                                                              |     |
|              |                              | <ul> <li>After getting a CRC status of any block where data transmission is about to be<br/>stopped by a Stop At Block Gap Request.</li> </ul>                                                                                                                                                                                                                                   |     |
|              |                              | During a write transaction, a Block Gap Event interrupt is generated when this bit is changed to 0, as a result of the Stop At Block Gap Request being set. This status is useful for the HD in determining when to issue commands during write busy.                                                                                                                            |     |
|              |                              | 0: No valid data                                                                                                                                                                                                                                                                                                                                                                 |     |
|              |                              | 1: Transferring data                                                                                                                                                                                                                                                                                                                                                             |     |
| b7 to b3     | Reserved                     |                                                                                                                                                                                                                                                                                                                                                                                  | R   |
| b2           | sdhcdmactrl_dataline         | DAT Line Active                                                                                                                                                                                                                                                                                                                                                                  | R   |
|              | active                       | This bit indicates whether one of the DAT line on SD bus is in use.                                                                                                                                                                                                                                                                                                              |     |
|              |                              | 1: DAT line active                                                                                                                                                                                                                                                                                                                                                               |     |
| L 4          |                              | 0: DAT line inactive                                                                                                                                                                                                                                                                                                                                                             | _   |
| b1           | presentstate_innibitda<br>t  | Command Inhibit (DAT)  This status his is generated if either the DAT Line Active or the Board transfer Active is                                                                                                                                                                                                                                                                | R   |
|              |                              | This status bit is generated if either the DAT Line Active or the Read transfer Active is set to 1. If this bit is 0, it indicates the HC can issue the next SD command. Commands with busy signal belong to Command Inhibit (DAT) (ex. R1b, R5b type).                                                                                                                          |     |
|              |                              | Changing from 1 to 0 generates a Transfer Complete interrupt in the Normal Interrupt Status Register.                                                                                                                                                                                                                                                                            |     |
|              |                              | <b>Note)</b> The SD Host Driver can save registers in the range of 000-00Dh for a suspend transaction after this bit has changed from 1 to 0.                                                                                                                                                                                                                                    |     |
|              |                              | 0: Can issue command which uses the DAT line                                                                                                                                                                                                                                                                                                                                     |     |
|              |                              | 1: Cannot issue command which uses the DAT line                                                                                                                                                                                                                                                                                                                                  |     |
| b0           | presentstate_inhibitc        | Command Inhibit (CMD)                                                                                                                                                                                                                                                                                                                                                            | R   |
|              | md                           | If this bit is 0, it indicates the CMD line is not in use and the HC can issue a SD command using the CMD line.                                                                                                                                                                                                                                                                  |     |
|              |                              | This bit is set immediately after the Command Register (00Fh) is written. This bit is cleared when the command response is received.                                                                                                                                                                                                                                             |     |
|              |                              | Even if the Command Inhibit (DAT) is set to 1, Commands using only the CMD line can be issued if this bit is 0. Changing from 1 to 0 generates a Command complete interrupt in the Normal Interrupt Status Register.                                                                                                                                                             |     |
|              |                              | If the HC cannot issue the command because of a command conflict error or because of Command not Issued By Auto CMD12 Error, this bit shall remain 1 and the Command Complete is not set. Status issuing Auto CMD12 is not read from this bit.                                                                                                                                   |     |
|              |                              | Auto CMD12 and Auto CMD23 consist of two responses. In this case, this bit is not cleared by the response of CMD12 or CMD23 but cleared by the response of a read/write command. Status issuing Auto CMD12 is not read from this bit. So if a command is issued during Auto CMD12 operation, HC shall manage to issue two commands: CMD12 and a command set by Command Register. |     |

## 9.4.12 reg\_hostcontrol1 — Host Control 1 Register

This register is used to program DMA modes, LED Control, Data Transfer Width, High Speed Enable, Card detect test level and signal selection.

**Address:** 4010 0028h (SDIO1) 4010 1028h (SDIO2)



Table 9.14 reg\_hostcontrol1 Register Contents (1/2)

| Dit Docition | Dit Name Function     |                                                                                                                                                                                                                                                                                                                                                                                                 |     |  |  |  |
|--------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|
| Bit Position | Bit Name              | Function                                                                                                                                                                                                                                                                                                                                                                                        | R/W |  |  |  |
| b7           | hostctrl1_cdsigselect | Card Detect Signal Selection                                                                                                                                                                                                                                                                                                                                                                    | R/W |  |  |  |
|              |                       | This bit selects source for card detection.                                                                                                                                                                                                                                                                                                                                                     |     |  |  |  |
|              |                       | 0: SDIO_CD_N is selected (for normal use)                                                                                                                                                                                                                                                                                                                                                       |     |  |  |  |
|              |                       | 1: The card detect test level is selected                                                                                                                                                                                                                                                                                                                                                       |     |  |  |  |
| b6           | hostctrl1_cdtestlevel | Card Detect Test Level                                                                                                                                                                                                                                                                                                                                                                          | R/W |  |  |  |
|              |                       | This bit is enabled while the Card Detect Signal Selection is set to 1 and it indicates card inserted or not. Generates (card insert or card removal) interrupt when the bit of Normal Interrupt Status Enable Register is set.                                                                                                                                                                 |     |  |  |  |
|              |                       | 0: No Card                                                                                                                                                                                                                                                                                                                                                                                      |     |  |  |  |
|              |                       | 1: Card Inserted                                                                                                                                                                                                                                                                                                                                                                                |     |  |  |  |
| b5           | hostctrl1_extdatawidt | Extended Data Transfer Width                                                                                                                                                                                                                                                                                                                                                                    | R/W |  |  |  |
|              | h                     | This bit controls 8-bit bus width mode for embedded device. Support of this function is indicated in 8-bit Support for Embedded Device in the Capabilities Register. If a device supports 8-bit bus mode, this bit may be set to 1. If this bit is 0, bus width is controlled by Data Transfer Width in the Host Control 1 Register.                                                            |     |  |  |  |
|              |                       | 0: Bus width is selected by Data Transfer Width bit                                                                                                                                                                                                                                                                                                                                             |     |  |  |  |
|              |                       | 1: 8-bit bus width                                                                                                                                                                                                                                                                                                                                                                              |     |  |  |  |
| b4, b3       | hostctrl1_dmaselect   | DMA Select                                                                                                                                                                                                                                                                                                                                                                                      | R/W |  |  |  |
|              |                       | One of supported DMA modes can be selected. The host driver shall check support of DMA modes by referring the Capabilities Register.                                                                                                                                                                                                                                                            |     |  |  |  |
|              |                       | 00b: SDMA                                                                                                                                                                                                                                                                                                                                                                                       |     |  |  |  |
|              |                       | 01b: 32-bit ADMA1 address                                                                                                                                                                                                                                                                                                                                                                       |     |  |  |  |
|              |                       | 10b: 32-bit ADMA2 address                                                                                                                                                                                                                                                                                                                                                                       |     |  |  |  |
|              |                       | 11b: 64-bit ADMA2 Address                                                                                                                                                                                                                                                                                                                                                                       |     |  |  |  |
| b2           | hostctrl1_highspeede  | High Speed Enable                                                                                                                                                                                                                                                                                                                                                                               | R/W |  |  |  |
|              | na                    | This bit is optional. Before setting this bit, the HD shall check the High Speed Support in the Capabilities Register. If this bit is set to 0 (default), the HC outputs CMD line and DAT lines at the falling edge of the SD clock (up to 25 MHz/20 MHz for MMC). If this bit is set to 1, the HC outputs CMD line and DAT lines at the rising edge of the SD clock (up to 50 MHz for SD/MMC). |     |  |  |  |
|              |                       | If Preset Value Enable in the Host Control 2 Register is set to 1, HD needs to reset SD Clock Enable before changing this field to avoid generating clock glitches. After setting this field, the HD sets SD Clock Enable again.                                                                                                                                                                |     |  |  |  |
|              |                       | 0: Normal Speed Mode                                                                                                                                                                                                                                                                                                                                                                            |     |  |  |  |
|              |                       | 1: High Speed Mode                                                                                                                                                                                                                                                                                                                                                                              |     |  |  |  |
| b1           | hostctrl1_datawidth   | Data Transfer Width (SD1 or SD4)                                                                                                                                                                                                                                                                                                                                                                | R/W |  |  |  |
|              |                       | This bit selects the data width of the HC. The HD shall select it to match the data width of the SD card.                                                                                                                                                                                                                                                                                       |     |  |  |  |
|              |                       | 0: 1-bit mode                                                                                                                                                                                                                                                                                                                                                                                   |     |  |  |  |
|              |                       | 1: 4-bit mode                                                                                                                                                                                                                                                                                                                                                                                   |     |  |  |  |

Table 9.14 reg\_hostcontrol1 Register Contents (2/2)

| Bit Position | Bit Name             | Function                                                                                                                                                                                                                                                  | R/W |
|--------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0           | hostctrl1_ledcontrol | LED Control                                                                                                                                                                                                                                               | R/W |
|              |                      | This bit is used to caution the user not to remove the card while the SD card is being accessed. If the software is going to issue multiple SD commands, this bit can be set during all transactions. It is not necessary to change for each transaction. |     |
|              |                      | 0: LED Off                                                                                                                                                                                                                                                |     |
|              |                      | 1: LED On                                                                                                                                                                                                                                                 |     |

# 9.4.13 reg\_powercontrol — Power Control Register

This register is used to program the SD Bus power and voltage level.

**Address:** 4010 0029h (SDIO1) 4010 1029h (SDIO2)



Table 9.15 reg\_powercontrol Register Contents

| Bit Position | Bit Name             | Function                                                                                                                                                                                                                                                                 | R/W |
|--------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b7 to b5     | Reserved             |                                                                                                                                                                                                                                                                          | R   |
| b4           | emmc_hwreset         | Hardware Reset                                                                                                                                                                                                                                                           | R/W |
|              |                      | Hardware reset signal is generated for eMMC card when this bit is set. Not used in this LSI.                                                                                                                                                                             |     |
| b3 to b1     | pwrctrl_sdbusvoltage | SD Bus Voltage Select                                                                                                                                                                                                                                                    | R/W |
|              |                      | By setting these bits, the HD selects the voltage level for the SD card. Before setting this register, the HD shall check the voltage support bits in the Capabilities Register. If an unsupported voltage is selected, the Host System shall not supply SD bus voltage. |     |
|              |                      | 111b: 3.3 V (Flattop.)                                                                                                                                                                                                                                                   |     |
|              |                      | Others: Reserved                                                                                                                                                                                                                                                         |     |
| b0           | pwrctrl_sdbuspower   | SD Bus Power                                                                                                                                                                                                                                                             | R/W |
|              |                      | Before setting this bit, the SD host driver shall set SD Bus Voltage Select. If the HC detects the No Card State, this bit shall be cleared.                                                                                                                             |     |
|              |                      | 0: Power Off                                                                                                                                                                                                                                                             |     |
|              |                      | 1: Power On                                                                                                                                                                                                                                                              |     |
|              |                      | This bit can be set to 1 only when the sdhccarddet_inserted_dsync bit in reg_presentstate register is 1.                                                                                                                                                                 |     |

## 9.4.14 reg\_blockgapcontrol — Block Gap Control Register

This register is used to program the block gap request, read wait control and interrupt at block gap.

**Address:** 4010 002Ah (SDIO1) 4010 102Ah (SDIO2)



Table 9.16 reg\_blockgapcontrol Register Contents (1/2)

| Bit Position | Bit Name              | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | R/W |
|--------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b7 to b5     | Reserved              | Keep the initial value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R/W |
| b4           | blkgapctrl_spimode    | SPI Mode Enable Bit. 0: SD Mode 1: SPI Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R/W |
| b3           | blkgapctrl_interrupt  | Interrupt At Block Gap This bit is valid only in 4-bit mode of the SDIO card and selects a sample point in the interrupt cycle. Setting to 1 enables interrupt detection at the block gap for a multiple block transfer. If the SD card cannot signal an interrupt during a multiple block transfer, this bit should be set to 0. When the HD detects an SD card insertion, it shall set this bit according to the CCCR of the SDIO card.                                                                                                                                                                                                                                                                          | R/W |
| b2           | blkgapctrl_rdwaitctrl | Read Wait Control  The read wait function is optional for SDIO cards. If the card supports read wait, set this bit to enable use of the read wait protocol to stop read data using DAT[2] line.  Otherwise the HC has to stop the SD clock to hold read data, which restricts commands generation. When the HD detects an SD card insertion, it shall set this bit according to the CCCR of the SDIO card. If the card does not support read wait, this bit shall never be set to 1 otherwise DAT line conflict may occur. If this bit is set to 0, Suspend/Resume cannot be supported.  0: Disable Read Wait Control  1: Enable Read Wait Control                                                                 | R/W |
| b1           | blkgapctrl_continue   | Continue Request This bit is used to restart a transaction which was stopped using the Stop At Block Gap Request. To cancel stop at the block gap, set Stop At block Gap Request to 0 and set this bit to restart the transfer. The HC automatically clears this bit in either of the following cases: 1) In the case of a read transaction, the DAT Line Active changes from 0 to 1 as a read transaction restarts. 2) In the case of a write transaction, the Write transfer active changes from 0 to 1 as the write transaction restarts. Therefore, it is not necessary for Host driver to set this bit to 0. If Stop At Block Gap Request is set to 1, any write to this bit is ignored. 0: Ignore 1: Restart | R/W |

Table 9.16 reg\_blockgapcontrol Register Contents (2/2)

| Bit Position | Bit Name              | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R/W |
|--------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0           | blkgapctrl_stopatblkg | Stop At Block Gap Request                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R/W |
|              | ар                    | This bit is used to stop executing a transaction at the next block gap for non-DMA, SDMA and ADMA transfers. Until the transfer complete is set to 1, indicating a transfer completion the HD shall leave this bit set to 1. Clearing both the Stop At Block Gap Request and Continue Request shall not cause the transaction to restart. Read Wait is used to stop the read transaction at the block gap. The HC shall honor the Stop At Block Gap Request for write transfers, but for read transfers it requires that the SD card support Read Wait. Therefore, the HD shall not set this bit during read transfers unless the SD card supports Read Wait and the Read Wait Control has been set to 1. In case of write transfers in which the HD writes data to the Buffer Data Port Register, the HD shall set this bit after all block data is written. If this bit is set to 1, the HD shall not write data to Buffer Data Port Register. This bit affects Read Transfer Active, Write Transfer Active, DAT line active and Command Inhibit (DAT) in the Present State Register. |     |
|              |                       | 0: Transfer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |
|              |                       | 1: Stop                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |

## 9.4.15 reg\_wakeupcontrol — Wake-up Control Register

This register is used to program the wakeup functionality.

**Address:** 4010 002Bh (SDIO1) 4010 102Bh (SDIO2)



Table 9.17 reg\_wakeupcontrol Register Contents

| Bit Position | Bit Name               | Function                                                                                                                                                                     | R/W |
|--------------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b7 to b3     | Reserved               |                                                                                                                                                                              | R   |
| b2           | wkupctrl_cardremoval   | Wakeup Event Enable On SD Card Removal                                                                                                                                       | R/W |
|              |                        | This bit enables wakeup event via Card Removal assertion in the Normal Interrupt Status Register. FN_WUS (Wake up Support) in CIS does not affect this bit.                  |     |
|              |                        | 0: Disable                                                                                                                                                                   |     |
|              |                        | 1: Enable                                                                                                                                                                    |     |
| b1           | wkupctrl_cardinsertio  | Wakeup Event Enable On SD Card Insertion                                                                                                                                     | R/W |
|              | n                      | This bit enables wakeup event via Card Insertion assertion in the Normal Interrupt Status Register. FN_WUS (Wake up Support) in CIS does not affect this bit.                |     |
|              |                        | 0: Disable                                                                                                                                                                   |     |
|              |                        | 1: Enable                                                                                                                                                                    |     |
| b0           | wkupctrl_cardinterrupt | Wakeup Event Enable On Card Interrupt                                                                                                                                        | R/W |
|              |                        | This bit enables wakeup event via Card Interrupt assertion in the Normal Interrupt Status Register. This bit can be set to 1 if FN_WUS (Wake Up Support) in CIS is set to 1. |     |
|              |                        | 0: Disable                                                                                                                                                                   |     |
|              |                        | 1: Enable                                                                                                                                                                    |     |

## 9.4.16 reg\_clockcontrol — Clock Control Register

This register is used to program the Clock frequency select, generator select, Clock enable, Internal Clock state fields.

**Address:** 4010 002Ch (SDIO1) 4010 102Ch (SDIO2)

Bit b15 b14 b13 b12 b11 b10 b9 b8 b7 b6 b3 b0 clkctrl\_s sdhcclkge clkctrl\_i clkctrl\_sdclkfreq clkctrl\_c clkctrl\_sdclkfreqsel sel\_upperbits Ikgense dclkena ntclkena ble\_dsync Value after reset 0

Table 9.18 reg\_clockcontrol Register Contents (1/2)

| Bit Position | Bit Name                           | Function                                                                                                                                                                                                                                                                                   | R/W |
|--------------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b15 to b8    | clkctrl_sdclkfreqsel               | SDIO_CLK Frequency Select                                                                                                                                                                                                                                                                  | R/W |
|              |                                    | This field is used to select the frequency of the SDIO_CLK pin. The frequency is not programmed directly; rather this register holds the divisor of the corecfg_baseclkfreq in the Capabilities Register. Only the following settings are allowed.                                         |     |
|              |                                    | The length of divider is extended to 10 bits and all divider values shall be supported. The highest 2-bit of clock divider is assigned to clkctrl_sdclkfreqsel_upperbits of this register.                                                                                                 |     |
|              |                                    | 3FFh: 1/2046 Divided Clock                                                                                                                                                                                                                                                                 |     |
|              |                                    | N: 1/2N Divided Clock (Duty 50%)                                                                                                                                                                                                                                                           |     |
|              |                                    | 002h: 1/4 Divided Clock                                                                                                                                                                                                                                                                    |     |
|              |                                    | 001h: 1/2 Divided Clock                                                                                                                                                                                                                                                                    |     |
|              |                                    | 000h: Base Clock (10 MHz to 50 MHz)                                                                                                                                                                                                                                                        |     |
|              |                                    | Setting 000h specifies the highest frequency of the SD clock. The divider values can be calculated by the frequency that is defined by the corecfg_baseclkfreq in the Capabilities Register.                                                                                               |     |
|              |                                    | The frequency of the SDIO_CLK is set by the following formula:                                                                                                                                                                                                                             |     |
|              |                                    | Clock Frequency = (Base Clock) / divisor.                                                                                                                                                                                                                                                  |     |
|              |                                    | Thus, choose the smallest possible divisor which results in a clock frequency that is less than or equal to the target frequency.                                                                                                                                                          |     |
| b7, b6       | clkctrl_sdclkfreqsel_u<br>pperbits | This field is assigned to Highest 2-bit of clock divider in SDIO_CLK Frequency Select.                                                                                                                                                                                                     | R/W |
| b5           | clkctrl_clkgensel                  | Clock Generator Select                                                                                                                                                                                                                                                                     | R   |
|              |                                    | The Programmable Clock Mode is not supported in this HC. This bit attribute is Read Only and zero is read.                                                                                                                                                                                 |     |
|              |                                    | 0: Divided Clock Mode                                                                                                                                                                                                                                                                      |     |
| b4, b3       | Reserved                           |                                                                                                                                                                                                                                                                                            | R   |
| b2           | clkctrl_sdclkena                   | SD Clock Enable                                                                                                                                                                                                                                                                            | R/W |
|              |                                    | The HC shall stop SDIO_CLK when writing this bit to 0. SDIO_CLK frequency Select can be changed when this bit is 0. Then, the HC shall maintain the same clock frequency until SDIO_CLK is stopped (Stop at SDIO_CLK = 0). If the HC detects the No Card state, this bit shall be cleared. |     |
|              |                                    | 0: Disable                                                                                                                                                                                                                                                                                 |     |
|              |                                    | 1: Enable                                                                                                                                                                                                                                                                                  |     |
|              |                                    | This bit is cleared when the card cannot be detected, or when the pwrctrl_sdbuspower bit in reg_powercontrol register is cleared.                                                                                                                                                          |     |

Table 9.18 reg\_clockcontrol Register Contents (2/2)

| Bit Position | Bit Name              | Function                                                                                                                                                                                                                                                                                                                                                                                                      | R/W |
|--------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b1           | sdhcclkgen_intclkstab | Internal Clock Stable                                                                                                                                                                                                                                                                                                                                                                                         | R   |
|              | le_dsync              | This bit is set to 1 when SD clock is stable after writing to Internal Clock Enable in this register to 1. The SD Host Driver shall wait to set SD Clock Enable until this bit is set to 1.                                                                                                                                                                                                                   |     |
|              |                       | Note) This is useful when using PLL for a clock oscillator that requires setup time.                                                                                                                                                                                                                                                                                                                          |     |
|              |                       | 0: Not Ready                                                                                                                                                                                                                                                                                                                                                                                                  |     |
|              |                       | 1: Ready                                                                                                                                                                                                                                                                                                                                                                                                      |     |
| b0           | clkctrl_intclkena     | Internal Clock Enable                                                                                                                                                                                                                                                                                                                                                                                         | R/W |
|              |                       | This bit is set to 0 when the HD is not using the HC or the HC awaits a wakeup event. The HC should stop its internal clock to go very low power state. Still, registers shall be able to be read and written. Clock starts to oscillate when this bit is set to 1. When clock oscillation is stable, the HC shall set Internal Clock Stable in this register to 1. This bit shall not affect card detection. |     |
|              |                       | 0: Stop                                                                                                                                                                                                                                                                                                                                                                                                       |     |
|              |                       | 1: Oscillate                                                                                                                                                                                                                                                                                                                                                                                                  |     |

## 9.4.17 reg\_timeoutcontrol — Timeout Control Register

The register sets the Data Timeout counter value.

**Address:** 4010 002Eh (SDIO1) 4010 102Eh (SDIO2)



Table 9.19 reg\_timeoutcontrol Register Contents

| Bit Position | Bit Name         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R/W |
|--------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b7 to b4     | Reserved         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R   |
| b3 to b0     | timeout_ctrvalue | Data Timeout Counter Value  This value determines the interval by which DAT line time-outs are detected. Refer to the Data Time-out Error in the Error Interrupt Status Register for information on factors that dictate time-out generation. Timeout frequency will be generated by dividing the base clock (TMCLK) with this setting. The base clock (TMCLK) is defined by corecfg_timeoutclkunit bit in Capabilities Register. When setting this register, prevent inadvertent time-out events by clearing the Data Time-out Error Status Enable (in the Error Interrupt Status Enable Register).  1111b: Reserved  1110b: TMCLK × 2 <sup>27</sup> 0001b: TMCLK × 2 <sup>14</sup> 0000b: TMCLK × 2 <sup>13</sup> | R/W |

#### 9.4.18 reg\_softwarereset — Software Reset Register

This register is used to program the software reset for data, command and for all. A reset pulse is generated when writing 1 to each bit of this register. After completing the reset, the HC shall clear each bit. Because it takes some time to complete software reset, the HD shall confirm that these bits are 0.

> 4010 002Fh (SDIO1) Address: 4010 102Fh (SDIO2)



| Bit Position | Bit Name        | Function                                                                                                                                                                                                                                                                                                           | R/W |
|--------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b7 to b3     | Reserved        |                                                                                                                                                                                                                                                                                                                    | R   |
| b2           | swreset_for_dat | Software Reset for DAT Line                                                                                                                                                                                                                                                                                        | R/W |
|              |                 | Only part of data circuit is reset. The following registers and bits are cleared by this bit:                                                                                                                                                                                                                      |     |
|              |                 | Buffer Data Port Register:     Buffer is cleared and initialized.                                                                                                                                                                                                                                                  |     |
|              |                 | <ul> <li>Present State Register:         Buffer read Enable         Buffer write Enable         Read Transfer Active         Write Transfer Active         DAT Line Active</li> </ul>                                                                                                                              |     |
|              |                 | Command Inhibit (DAT)                                                                                                                                                                                                                                                                                              |     |
|              |                 | Block Gap Control Register:     Continue Request     Stop At Block Gap Request                                                                                                                                                                                                                                     |     |
|              |                 | <ul> <li>Normal Interrupt Status Register:         Buffer Read Ready         Buffer Write Ready         Block Gap Event         Transfer Complete     </li> </ul>                                                                                                                                                  |     |
|              |                 | 0: Work                                                                                                                                                                                                                                                                                                            |     |
|              |                 | 1: Reset                                                                                                                                                                                                                                                                                                           |     |
| b1           | swreset_for_cmd | Software Reset for CMD Line Only part of command circuit is reset. The following registers and bits are cleared by this bit:                                                                                                                                                                                       | R/W |
|              |                 | Present State Register: Command Inhibit (CMD).                                                                                                                                                                                                                                                                     |     |
|              |                 | Normal Interrupt Status Register: Command Complete.                                                                                                                                                                                                                                                                |     |
|              |                 | 0: Work<br>1: Reset                                                                                                                                                                                                                                                                                                |     |
| b0           | swreset_for_all | Software Reset for All                                                                                                                                                                                                                                                                                             | R/W |
|              |                 | This reset affects the entire HC except for the card detection circuit. Register bits are cleared to 0. During its initialization, the HD shall set this bit to 1 to reset the HC. The HC shall reset this bit to 0. If this bit is set to 1, the SD card shall reset itself and must be re-initialized by the HD. |     |
|              |                 | 0: Work                                                                                                                                                                                                                                                                                                            |     |
|              |                 | 1: Reset                                                                                                                                                                                                                                                                                                           |     |

#### 9.4.19 reg\_normalintrsts — Normal Interrupt Status Register

This register gives the status of all the interrupts.

The Normal Interrupt Status Enable Register affects read of this register, but Normal Interrupt Signal Enable Register does not affect these reads. An Interrupt is generated when the Normal Interrupt Signal Enable is enabled and at least one of the status bits is set to 1.

**Address:** 4010 0030h (SDIO1)

4010 1030h (SDIO2)



Table 9.21 reg\_normalintrsts Register Contents (1/3)

| Bit Position | Bit Name               | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R/W |
|--------------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b15          | reg_errorintrsts       | Error Interrupt  If any of the bits in the Error Interrupt Status Register are set, then this bit is set.  Therefore, the HD can test for an error by checking this bit first.                                                                                                                                                                                                                                                                                                                      | R   |
|              |                        | 0: No error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |
|              |                        | 1: Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |
| b14 to b9    | Reserved               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R   |
| b8           | normalintrsts_cardints | Card Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R   |
|              | ts                     | Writing this bit to 1 does not clear this bit. It is cleared by resetting the SD card interrupt factor. In 1-bit mode, the HC shall detect the Card Interrupt without SD Clock to support wakeup. In 4-bit mode, the card interrupt signal is sampled during the interrupt cycle, so there are some sample delays between the interrupt signal from the card and the interrupt to the Host system.                                                                                                  |     |
|              |                        | When this status has been set and the HD needs to start this interrupt service, Card Interrupt Status Enable in the Normal Interrupt Status Enable Register shall be set to 0 in order to clear the card interrupt statuses latched in the HC and stop driving the Host System. After completion of the card interrupt service (the reset factor in the SD card and the interrupt signal may not be asserted), set Card Interrupt Status Enable to 1 and start sampling the interrupt signal again. |     |
|              |                        | Interrupt detected by DAT[1] is supported when there is a card per slot.                                                                                                                                                                                                                                                                                                                                                                                                                            |     |
|              |                        | 0: No Card Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |
|              |                        | 1: Generate Card Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |     |
| b7           | normalintrsts_cardre   | Card Removal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R/W |
|              | msts                   | This status is set if the Card Inserted in the Present State Register changes from 1 to 0. When the HD writes this bit to 1 to clear this status, the status of the Card Inserted in the Present State Register should be confirmed. Because the card detect may possibly be changed when the HD clear this bit an Interrupt event may not be generated.                                                                                                                                            |     |
|              |                        | 0: Card State Stable or Debouncing                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |
|              |                        | 1: Card Removed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |
| b6           | normalintrsts_cardins  | Card Insertion                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W |
|              | sts                    | This status is set if the Card Inserted in the Present State Register changes from 0 to 1. When the HD writes this bit to 1 to clear this status, the status of the Card Inserted in the Present State Register should be confirmed. Because the card detect may possibly be changed when the HD clear this bit an Interrupt event may not be generated.                                                                                                                                            |     |
|              |                        | 0: Card State Stable or Debouncing                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |
|              |                        | 1: Card Inserted                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |     |

| Bit Position | Bit Name                       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R/W |
|--------------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b5           | normalintrsts_bufrdre<br>ady   | Buffer Read Ready This status is set if the Buffer Read Enable changes from 0 to 1. This bit is cleared by writing 1b.  0: Not ready to read buffer 1: Ready to read buffer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W |
| b4           | normalintrsts_bufwrre<br>ady   | Buffer Write Ready This status is set if the Buffer Write Enable changes from 0 to 1. This bit is cleared by writing 1b.  0: Not ready to write buffer 1: Ready to write buffer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | R/W |
| b3           | normalintrsts_dmainte<br>rrupt | DMA Interrupt This status is set if the HC detects the Host SDMA Buffer Boundary in the Block Size Register. This bit is cleared by writing 1b.  0: No DMA Interrupt 1: DMA Interrupt is generated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R/W |
| b2           | normalintrsts_blkgape<br>vent  | Block Gap Event  If the Stop At Block Gap Request in the Block Gap Control Register is set, this bit is set.  Read Transaction: This bit is set at the falling edge of the DAT Line Active Status (When the transaction is stopped at SD Bus timing. The Read Wait must be supported in order to use this function).  Write Transaction: This bit is set at the falling edge of Write Transfer Active Status (After getting CRC status at SD Bus timing).  This bit is cleared by writing 1b.  0: No Block Gap Event  1: Transaction stopped at Block Gap                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | R/W |
| b1           | normalintrsts_xfercom plete    | Transfer Complete This bit is set when a read/write transaction is completed. Read Transaction: This bit is set at the falling edge of Read Transfer Active Status. There are two cases in which the Interrupt is generated. The first is when a data transfer is completed as specified by data length (After the last data has been read to the Host System). The second is when data has stopped at the block gap and completed the data transfer by setting the Stop At Block Gap Request in the Block Gap Control Register (After valid data has been read to the Host System). Write Transaction: This bit is set at the falling edge of the DAT Line Active Status. There are two cases in which the Interrupt is generated. The first is when the last data is written to the card as specified by data length and Busy signal is released. The second is when data transfers are stopped at the block gap by setting Stop At Block Gap Request in the Block Gap Control Register and data transfers completed. (After valid data is written to the SD card and the busy signal is released). This bit is cleared by writing 1b.  0: No Data Transfer Complete  1: Data Transfer Complete | R/W |

Table 9.21 reg\_normalintrsts Register Contents (3/3)

| Bit Position | Bit Name                      | Function                                                                                                                                                                                                                                                                                                                                                              | R/W |
|--------------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0           | normalintrsts_cmdco<br>mplete | Command Complete This bit is set when we get the end bit of the command response (Except Auto CMD12 and Auto CMD23). This bit is cleared by writing 1b.  0: No Command Complete 1: Command Complete  Note) Command Time-out Error has higher priority than Command Complete. If both are set to 1, it can be considered that the response was not received correctly. | R/W |

b0

s\_cmdtim

#### reg\_errorintrsts — Error Interrupt Status Register 9.4.20

This register gives the status of the error interrupts.

Status defined in this register can be enabled by the Error Interrupt Status Enable Register, but not by the Error Interrupt Signal Enable Register. The interrupt is generated when the Error Interrupt Signal Enable is enabled and at least one of the statuses is set to 1.

> Address: 4010 0032h (SDIO1) 4010 1032h (SDIO2)

> > error

b13 b12 b11 b10 b9 b7 b6 b3 b2 b14 b8 b5 b4 b1 errorintr errorintr errorintrst errorintrst errorintrst errorintrst errorintrst errorintrst errorintrst errorintrst sts\_host sts\_ad

s\_currlimit

error

s\_dataen

s\_datacr

s\_datatim

s\_cmdind

\_cmdend

s\_cmdcrc

Value after reset

maerror

\_autocm

**Table 9.22** reg errorintrsts Register Contents (1/2)

Bit

b15

| 1 able 9.22  | reg_erronnusts Reg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | gister Contents (1/2)                                                                                                                                                                                                                                                                                                                                                                                                            |     |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Bit Position | Bit Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Function                                                                                                                                                                                                                                                                                                                                                                                                                         | R/W |
| b15 to b13   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                  | R   |
| b12          | errorintrsts_hosterror                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Target Response Error Occurs when detecting Host ERROR. This bit is cleared by writing 1b. 0: No error 1: Error                                                                                                                                                                                                                                                                                                                  | R/W |
| b11, b10     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                  | R   |
| b9           | errorintrsts_admaerro<br>r                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | DADMA Error  This bit is set when the HC detects errors during ADMA based data transfer. The state of the ADMA at an error occurrence is saved in the ADMA Error Status Register. This bit is cleared by writing 1b.  0: No error  1: Error                                                                                                                                                                                      |     |
| b8           | errorintrsts_autocmde<br>rror                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | autocmde Auto CMD Error  Auto CMD12 and Auto CMD23 use this error status. This bit is set when detecting that one of the bits (0 to 4) in Auto CMD Error Status Register has changed from 0 to 1. In case of Auto CMD12, this bit is set to 1, not only when the errors in Auto CMD12 occur but also when Auto CMD12 is not executed due to the previous command error This bit is cleared by writing 1b.  0: No error  1: Error |     |
| b7           | errorintrsts_currlimiter  ror  By setting the SD Bus Power bit in the Power Control Register, the HC is requeste supply power for the SD Bus. If the HC supports the Current Limit Function, it can protected from an illegal card by stopping power supply to the card in which case to bit indicates a failure status. Reading 1 means the HC is not supplying power to SI card due to some failure. Reading 0 means that the HC is supplying power and no error has occurred. This bit shall always set to be 0, if the HC does not support this function. This bit is cleared by writing 1b.  0: No error  1: Power Fail |                                                                                                                                                                                                                                                                                                                                                                                                                                  | R/W |
| b6           | errorintrsts_dataendbi<br>terror                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Data End Bit Error  Occurs when detecting 0 at the end bit position of read data which uses the DAT line or the end bit position of the CRC status. This bit is cleared by writing 1b.  0: No error  1: Error                                                                                                                                                                                                                    | R/W |

| Table 9.22 | reg_errorintrsts | Register Contents | (2/2) |
|------------|------------------|-------------------|-------|
|            |                  |                   |       |

| Bit Position | Bit Name                          | Function                                                                                                                                                                                                                                                                                                                                                                  | R/W       |
|--------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| b5           | errorintrsts_datacrcerr           | Data CRC Error                                                                                                                                                                                                                                                                                                                                                            |           |
|              | or                                | Occurs when detecting CRC error when transferring read data which uses the DAT line or when detecting the Write CRC Status having a value of other than "010b". This bit is cleared by writing 1b.                                                                                                                                                                        |           |
|              |                                   | 0: No error                                                                                                                                                                                                                                                                                                                                                               |           |
|              |                                   | 1: Error                                                                                                                                                                                                                                                                                                                                                                  |           |
| b4           | errorintrsts_datatimeo<br>uterror |                                                                                                                                                                                                                                                                                                                                                                           |           |
|              |                                   | Occurs when detecting one of following timeout conditions:                                                                                                                                                                                                                                                                                                                |           |
|              |                                   | 1. Busy Timeout for R1b, R5b type.                                                                                                                                                                                                                                                                                                                                        |           |
|              |                                   | 2. Busy Timeout after Write CRC status                                                                                                                                                                                                                                                                                                                                    |           |
|              |                                   | 3. Write CRC status Timeout                                                                                                                                                                                                                                                                                                                                               |           |
|              |                                   | 4. Read Data Timeout.                                                                                                                                                                                                                                                                                                                                                     |           |
|              |                                   | This bit is cleared by writing 1b.  0: No Error                                                                                                                                                                                                                                                                                                                           |           |
|              |                                   | 1: Timeout                                                                                                                                                                                                                                                                                                                                                                |           |
| 1.0          |                                   |                                                                                                                                                                                                                                                                                                                                                                           | D 444     |
| b3           | errorintrsts_cmdindex<br>error    | Command Index Error                                                                                                                                                                                                                                                                                                                                                       | R/W       |
|              |                                   | Occurs if a Command Index error occurs in the Command Response. This bit is cleared by writing 1b.                                                                                                                                                                                                                                                                        |           |
|              |                                   | 0: No Error                                                                                                                                                                                                                                                                                                                                                               |           |
|              |                                   | 1: Error                                                                                                                                                                                                                                                                                                                                                                  |           |
| b2           | errorintrete emdendhi             |                                                                                                                                                                                                                                                                                                                                                                           | R/W       |
| 02           | errorintrsts_cmdendbi<br>terror   | Occurs when detecting that the end bit of a command response is 0. This bit is cleared                                                                                                                                                                                                                                                                                    | 11/ / / / |
|              |                                   | by writing 1b.                                                                                                                                                                                                                                                                                                                                                            |           |
|              |                                   | 0: No Error                                                                                                                                                                                                                                                                                                                                                               |           |
|              |                                   | 1: End bit error generated                                                                                                                                                                                                                                                                                                                                                |           |
| b1           | errorintrsts_cmdcrcerr            | Command CRC Error                                                                                                                                                                                                                                                                                                                                                         | R/W       |
|              | or                                | Command CRC Error is generated in two cases.                                                                                                                                                                                                                                                                                                                              |           |
|              |                                   | 1. If a response is returned and the Command Time-out Error is set to 0, this bit is set to 1 when detecting a CRC error in the command response.                                                                                                                                                                                                                         |           |
|              |                                   | 2. The HC detects a CMD line conflict by monitoring the CMD line when a command is issued. If the HC drives the CMD line to 1 level, but detects 0 level on the CMD line at the next SDIO_CLK edge, then the HC shall abort the command (Stop driving CMD line) and set this bit to 1. The Command Timeout Error shall also be set to 1 to distinguish CMD line conflict. |           |
|              |                                   | This bit is cleared by writing 1b.                                                                                                                                                                                                                                                                                                                                        |           |
|              |                                   | 0: No Error                                                                                                                                                                                                                                                                                                                                                               |           |
|              |                                   | 1: CRC Error                                                                                                                                                                                                                                                                                                                                                              |           |
| b0           | errorintrsts_cmdtimeo             | o Command Timeout Error                                                                                                                                                                                                                                                                                                                                                   |           |
|              | uterror                           | Occurs only if the no response is returned within 64 SDIO_CLK cycles from the end bit of the command. If the HC detects a CMD line conflict, in which case Command CRC Error shall also be set. This bit shall be set without waiting for 64 SDIO_CLK cycles because the command will be aborted by the HC. This bit is cleared by writing 1b.                            |           |
|              |                                   | 0: No Error                                                                                                                                                                                                                                                                                                                                                               |           |
|              |                                   | 1: Timeout                                                                                                                                                                                                                                                                                                                                                                |           |

## 9.4.21 reg\_normalintrstsena — Normal Interrupt Status Enable Register

This register is used to enable the Normal Interrupt Status Register fields.

**Address:** 4010 0034h (SDIO1) 4010 1034h (SDIO2)



Table 9.23 reg\_normalintrstsena Register Contents

| Table 9.23   | reg_normalintrstser             | na Register Contents                                                                                                                                                                                                                                                                                                                                                                              |           |
|--------------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| Bit Position | Bit Name                        | Function                                                                                                                                                                                                                                                                                                                                                                                          | R/W       |
| b15          | normalintrsts_enabler egbit15   | This bit is fixed to 0b. The HD shall control error Interrupts using the Error Interrupt Status Enable Register.                                                                                                                                                                                                                                                                                  |           |
| b14 to b9    | Reserved                        | Keep the initial value.                                                                                                                                                                                                                                                                                                                                                                           |           |
| b8           | sdhcregset_cardintsts           | Card Interrupt Status Enable                                                                                                                                                                                                                                                                                                                                                                      | R/W       |
|              | ena                             | If this bit is set to 0, the HC shall clear interrupt request to the System. The Card Interrupt detection is stopped when this bit is cleared and restarted when this bit is set to 1. The HD may clear the Card Interrupt Status Enable before servicing the Card Interrupt and may set this bit again after all interrupt requests from the card are cleared to prevent inadvertent interrupts. |           |
|              |                                 | 0: Masked                                                                                                                                                                                                                                                                                                                                                                                         |           |
|              |                                 | 1: Enabled                                                                                                                                                                                                                                                                                                                                                                                        |           |
| b7           | • –                             | Card Removal Status Enable                                                                                                                                                                                                                                                                                                                                                                        | R/W       |
|              | sena                            | 0: Masked                                                                                                                                                                                                                                                                                                                                                                                         |           |
|              |                                 | 1: Enabled                                                                                                                                                                                                                                                                                                                                                                                        |           |
| b6           | sdhcregset_cardinsst<br>sena    | Card Insertion Status Enable                                                                                                                                                                                                                                                                                                                                                                      | R/W       |
|              | Jona                            | 0: Masked<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                           |           |
| b5           | normalintrsts_enabler           | Buffer Read Ready Status Enable                                                                                                                                                                                                                                                                                                                                                                   | R/W       |
| DO           | egbit5                          | 0: Masked                                                                                                                                                                                                                                                                                                                                                                                         | 11/ / / / |
|              |                                 | 1: Enabled                                                                                                                                                                                                                                                                                                                                                                                        |           |
| b4           | normalintrsts_enabler           | Buffer Write Ready Status Enable                                                                                                                                                                                                                                                                                                                                                                  | R/W       |
|              | egbit4                          | 0: Masked                                                                                                                                                                                                                                                                                                                                                                                         |           |
|              |                                 | 1: Enabled                                                                                                                                                                                                                                                                                                                                                                                        |           |
| b3           | normalintrsts_enabler<br>egbit3 | DMA Interrupt Status Enable                                                                                                                                                                                                                                                                                                                                                                       | R/W       |
|              |                                 | 0: Masked                                                                                                                                                                                                                                                                                                                                                                                         |           |
|              |                                 | 1: Enabled                                                                                                                                                                                                                                                                                                                                                                                        |           |
| b2           | normalintrsts_enabler<br>egbit2 | Block Gap Event Status Enable                                                                                                                                                                                                                                                                                                                                                                     | R/W       |
|              |                                 | 0: Masked                                                                                                                                                                                                                                                                                                                                                                                         |           |
|              |                                 | 1: Enabled                                                                                                                                                                                                                                                                                                                                                                                        |           |
| b1           | normalintrsts_enabler           | Transfer Complete Status Enable                                                                                                                                                                                                                                                                                                                                                                   | R/W       |
|              | egbit1                          | 0: Masked                                                                                                                                                                                                                                                                                                                                                                                         |           |
|              |                                 | 1: Enabled                                                                                                                                                                                                                                                                                                                                                                                        |           |
| b0           | normalintrsts_enabler           | •                                                                                                                                                                                                                                                                                                                                                                                                 | R/W       |
|              | egbit0                          | 0: Masked                                                                                                                                                                                                                                                                                                                                                                                         |           |
|              |                                 | 1: Enabled                                                                                                                                                                                                                                                                                                                                                                                        |           |

## 9.4.22 reg\_errorintrstsena — Error Interrupt Status Enable Register

This register is used to enable the Error Interrupt Status Register fields.

**Address:** 4010 0036h (SDIO1) 4010 1036h (SDIO2)



Table 9.24 reg\_errorintrstsena Register Contents

| l able 9.24  | reg_errorintrstsena             | Register Contents                                        |     |
|--------------|---------------------------------|----------------------------------------------------------|-----|
| Bit Position | Bit Name                        | Function                                                 | R/W |
| b15          | Reserved                        |                                                          | R   |
| b14 to b13   | Reserved                        | Keep the initial value.                                  | R/W |
| b12          | errorintrsts_enablereg<br>bit12 | Target Response Error Status Enable 0: Masked 1: Enabled | R/W |
| b11          | Reserved                        |                                                          | R   |
| b10          | Reserved                        | Keep the initial value.                                  | R/W |
| b9           | errorintrsts_enablereg<br>bit9  | ADMA Error Status Enable 0: Masked 1: Enabled            | R/W |
| b8           | errorintrsts_enablereg<br>bit8  | Auto CMD Error Status Enable 0: Masked 1: Enabled        | R/W |
| b7           | errorintrsts_enablereg<br>bit7  | Current Limit Error Status Enable 0: Masked 1: Enabled   | R/W |
| b6           | errorintrsts_enablereg<br>bit6  | Data End Bit Error Status Enable 0: Masked 1: Enabled    | R/W |
| b5           | errorintrsts_enablereg<br>bit5  | Data CRC Error Status Enable 0: Masked 1: Enabled        | R/W |
| b4           | errorintrsts_enablereg<br>bit4  | Data Timeout Error Status Enable 0: Masked 1: Enabled    | R/W |
| b3           | errorintrsts_enablereg<br>bit3  | Command Index Error Status Enable 0: Masked 1: Enabled   | R/W |
| b2           | errorintrsts_enablereg<br>bit2  | Command End Bit Error Status Enable 0: Masked 1: Enabled | R/W |
| b1           | errorintrsts_enablereg<br>bit1  | Command CRC Error Status Enable 0: Masked 1: Enabled     | R/W |
| b0           | errorintrsts_enablereg<br>bit0  | Command Timeout Error Status Enable 0: Masked 1: Enabled | R/W |

### 9.4.23 reg\_normalintrsigena — Normal Interrupt Signal Enable Register

This register is used to select which interrupt status is indicated to the Host System as the interrupt. These status bits all share the same 1-bit interrupt line (SDIF\_Int). Setting any of these bits to 1 enables interrupt generation.

**Address:** 4010 0038h (SDIO1) 4010 1038h (SDIO2)



Table 9.25 reg\_normalintrsigena Register Contents

| Bit Position | Bit Name                         | Function                                                                                                            | R/W |
|--------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------|-----|
| b15          | normalintrsig_enabler<br>egbit15 | er This bit is fixed to 0b. The HD shall control error Interrupts using the Error Interrupt Signal Enable Register. |     |
| b14 to b9    | Reserved                         | Keep the initial value.                                                                                             |     |
| b8           | normalintrsig_enabler<br>egbit8  | Card Interrupt Signal Enable 0: Masked 1: Enabled                                                                   |     |
| b7           | normalintrsig_enabler<br>egbit7  | Card Removal Signal Enable 0: Masked 1: Enabled                                                                     |     |
| b6           | normalintrsig_enabler<br>egbit6  | Card Insertion Signal Enable  0: Masked  1: Enabled                                                                 |     |
| b5           | normalintrsig_enabler<br>egbit5  | Buffer Read Ready Signal Enable 0: Masked 1: Enabled                                                                |     |
| b4           | normalintrsig_enabler<br>egbit4  | Buffer Write Ready Signal Enable 0: Masked 1: Enabled                                                               |     |
| b3           | normalintrsig_enabler<br>egbit3  | DMA Interrupt Signal Enable 0: Masked 1: Enabled                                                                    |     |
| b2           | normalintrsig_enabler<br>egbit2  | er Block Gap Event Signal Enable 0: Masked 1: Enabled                                                               |     |
| b1           | normalintrsig_enabler<br>egbit1  | Transfer Complete Signal Enable 0: Masked 1: Enabled                                                                |     |
| b0           | normalintrsig_enabler<br>egbit0  | Command Complete Signal Enable 0: Masked 1: Enabled                                                                 | R/W |

## 9.4.24 reg\_errorintrsigena — Error Interrupt Signal Enable Register

This register is used to select which interrupt status is indicated to the Host System as the Interrupt. These status bits all share the same 1-bit interrupt line (SDIF\_Int). Setting any of these bits to 1 enables Interrupt generation.

**Address:** 4010 003Ah (SDIO1) 4010 103Ah (SDIO2)



Table 9.26 reg\_errorintrsigena Register Contents

| Bit Position | Bit Name                        | Function                                                 | R/W |
|--------------|---------------------------------|----------------------------------------------------------|-----|
| b15          | Reserved                        |                                                          | R   |
| b14 to b13   | Reserved                        | Keep the initial value.                                  | R/W |
| b12          | errorintrsig_enablereg<br>bit12 | Target Response Error Signal Enable 0: Masked 1: Enabled | R/W |
| b11          | Reserved                        |                                                          | R   |
| b10          | Reserved                        | Keep the initial value.                                  | R/W |
| b9           | errorintrsig_enablereg<br>bit9  | ADMA Error Signal Enable 0: Masked 1: Enabled            | R/W |
| b8           | errorintrsig_enablereg<br>bit8  | Auto CMD Error Signal Enable 0: Masked 1: Enabled        | R/W |
| b7           | errorintrsig_enablereg<br>bit7  | Current Limit Error Signal Enable 0: Masked 1: Enabled   | R/W |
| b6           | errorintrsig_enablereg<br>bit6  | Data End Bit Error Signal Enable 0: Masked 1: Enabled    | R/W |
| b5           | errorintrsig_enablereg<br>bit5  | Data CRC Error Signal Enable 0: Masked 1: Enabled        | R/W |
| b4           | errorintrsig_enablereg<br>bit4  | Data Timeout Error Signal Enable 0: Masked 1: Enabled    | R/W |
| b3           | errorintrsig_enablereg<br>bit3  | Command Index Error Signal Enable 0: Masked 1: Enabled   | R/W |
| b2           | errorintrsig_enablereg<br>bit2  | Command End Bit Error Signal Enable 0: Masked 1: Enabled | R/W |
| b1           | errorintrsig_enablereg<br>bit1  | Command CRC Error Signal Enable 0: Masked 1: Enabled     | R/W |
| b0           | errorintrsig_enablereg<br>bit0  | Command Timeout Error Signal Enable 0: Masked 1: Enabled | R/W |

## 9.4.25 reg\_autocmderrsts — Auto CMD Error Status Register

This register is used to indicate CMD12 response error of Auto CMD12 and CMD23 response error of Auto CMD 23.

**Address:** 4010 003Ch (SDIO1) 4010 103Ch (SDIO2)



Table 9.27 reg\_autocmderrsts Register Contents

| Bit Position | Bit Name             | Function                                                                                                                                                                                                                                                                                                                                                                                                              | R/W |
|--------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b15 to b8    | Reserved             |                                                                                                                                                                                                                                                                                                                                                                                                                       | R   |
| b7           | autocmderrsts_nexter | Command Not Issued By Auto CMD12 Error                                                                                                                                                                                                                                                                                                                                                                                | R   |
|              | ror                  | Setting this bit to 1 means CMD_wo_DAT is not executed due to an Auto CMD12 error bits (4 to 1) in this register. This bit is set to 0 when Auto CMD Error is generated by Auto CMD23.                                                                                                                                                                                                                                |     |
|              |                      | 0: No Error                                                                                                                                                                                                                                                                                                                                                                                                           |     |
|              |                      | 1: Not Issued                                                                                                                                                                                                                                                                                                                                                                                                         |     |
| b6, b5       | Reserved             |                                                                                                                                                                                                                                                                                                                                                                                                                       | R   |
| b4           | autocmderrsts_indexe | Auto CMD Index Error                                                                                                                                                                                                                                                                                                                                                                                                  | R   |
|              | rror                 | Occurs if the Command Index error occurs in response to a command.                                                                                                                                                                                                                                                                                                                                                    |     |
|              |                      | 0: No Error                                                                                                                                                                                                                                                                                                                                                                                                           |     |
|              |                      | 1: Error                                                                                                                                                                                                                                                                                                                                                                                                              |     |
| b3           | autocmderrsts_endbit | Auto CMD End Bit Error                                                                                                                                                                                                                                                                                                                                                                                                | R   |
|              | error                | Occurs when detecting that the end bit of command response is 0.                                                                                                                                                                                                                                                                                                                                                      |     |
|              |                      | 0: No Error                                                                                                                                                                                                                                                                                                                                                                                                           |     |
|              |                      | 1: End Bit Error Generated                                                                                                                                                                                                                                                                                                                                                                                            |     |
| b2           | autocmderrsts_crcerr | Auto CMD CRC Error                                                                                                                                                                                                                                                                                                                                                                                                    | R   |
|              | or                   | Occurs when detecting a CRC error in the command response.                                                                                                                                                                                                                                                                                                                                                            |     |
|              |                      | 0: No Error                                                                                                                                                                                                                                                                                                                                                                                                           |     |
|              |                      | 1: CRC Error Generated                                                                                                                                                                                                                                                                                                                                                                                                |     |
| b1           | autocmderrsts_timeou | Auto CMD Timeout Error                                                                                                                                                                                                                                                                                                                                                                                                | R   |
|              | terror               | Occurs if the no response is returned within 64 SDIO_CLK cycles from the end bit of the command. If this bit is set to 1, the other error status bits (4 to 2) are meaningless.                                                                                                                                                                                                                                       |     |
|              |                      | 0: No Error                                                                                                                                                                                                                                                                                                                                                                                                           |     |
|              |                      | 1: Timeout                                                                                                                                                                                                                                                                                                                                                                                                            |     |
| b0           | autocmderrsts_notexe | Auto CMD12 Not Executed                                                                                                                                                                                                                                                                                                                                                                                               | R   |
|              | cerror               | If memory multiple block data transfer is not started due to command error, this bit is not set because it is not necessary to issue Auto CMD12. Setting this bit to 1 means the HC cannot issue Auto CMD12 to stop memory multiple block transfer due to some error. If this bit is set to 1, other error status bits (4 to 1) are meaningless. This bit is set to 0 when Auto CMD Error is generated by Auto CMD23. |     |
|              |                      | 0: Executed                                                                                                                                                                                                                                                                                                                                                                                                           |     |
|              |                      | 1: Not Executed                                                                                                                                                                                                                                                                                                                                                                                                       |     |

## 9.4.26 reg\_hostcontrol2 — Host Control 2 Register

This register is used to program Asynchronous Interrupt Enable and Preset value enable.

**Address:** 4010 003Eh (SDIO1) 4010 103Eh (SDIO2)



Table 9.28 reg\_hostcontrol2 Register Contents

| Bit Position | Bit Name              | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R/W |  |  |
|--------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|
| b15          | hostctrl2_presetvalue | Preset Value Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                   | R/W |  |  |
|              | enable                | As the operating SDIO_CLK frequency depend on the Host System implementation, it is difficult to determine these parameters in the Standard HD. When Preset Value Enable is set to 1, this bit enables the functions defined in the Preset Value Registers.                                                                                                                                                                                                           |     |  |  |
|              |                       | 0: SDIO_CLK is controlled by HD.                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |  |  |
|              |                       | 1: Automatic Selection by Preset Value are Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                   |     |  |  |
|              |                       | If this bit is set to 0, SDIO_CLK Frequency Select and Clock Generator Select in the Clock Control Register are set by HD.                                                                                                                                                                                                                                                                                                                                            |     |  |  |
|              |                       | If this bit is set to 1, SDIO_CLK Frequency Select and Clock Generator Select in the Clock Control Register are set by HC as specified in the Preset Value Registers.                                                                                                                                                                                                                                                                                                 |     |  |  |
| b14          | hostctrl2_asynchintre | Asynchronous Interrupt Enable                                                                                                                                                                                                                                                                                                                                                                                                                                         | R/W |  |  |
|              | nable                 | This bit can be set to 1 if a card support asynchronous interrupt and Asynchronous Interrupt Support is set to 1 in the Capabilities Register. Asynchronous interrupt is effective when DAT[1] interrupt is used in 4-bit SD mode. If this bit is set to 1, the HD can stop the SDIO_CLK during asynchronous interrupt period to save power. During this period, the HC continues to deliver Card Interrupt to the host when it is asserted by the Card.  0: Disabled |     |  |  |
|              |                       | 1: Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |  |  |
| b13 to b8    | Reserved              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R   |  |  |
| b7 to b0     | Reserved              | Keep the initial value.                                                                                                                                                                                                                                                                                                                                                                                                                                               | R/W |  |  |
|              |                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |  |  |

#### 9.4.27 reg\_capabilities — Capabilities Register

This register provides the host driver with information specific to the host controller implementation.

"slottype" and "baseclkfreq" are defined by CFG\_SDIO[m] register of System Control.

**Address:** 4010 0040h (SDIO1)

4010 1040h (SDIO2)



Table 9.29 reg\_capabilities Register Contents (1/2)

| Bit Position | Bit Name             | Function                                                                                                                                                                                                   | R/W |
|--------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31, b30     | corecfg_slottype     | This slot type reflects SLOTTYPE bits of CFG_SDIO[m] (m = 1 or 2) register of System Control. These bits should be set to an appropriate value since it is also used to determine the Card Detection time. | R   |
|              |                      | 00b: Removable Card Slot                                                                                                                                                                                   |     |
|              |                      | 01b: Embedded Slot for One Device                                                                                                                                                                          |     |
|              |                      | Others: Reserved                                                                                                                                                                                           |     |
| b29          | corecfg_asynchintrsu | Refer to SDIO Specification Version 3.00 about asynchronous interrupt.                                                                                                                                     | R   |
|              | pport                | 0: Asynchronous Interrupt Not Supported                                                                                                                                                                    |     |
|              |                      | 1: Asynchronous Interrupt Supported                                                                                                                                                                        |     |
| b28          | corecfg_64bitsupport | This bit indicates whether the HC supports 64-bit System Bus.                                                                                                                                              | R   |
|              |                      | 0: Does not support 64-bit system address                                                                                                                                                                  |     |
|              |                      | 1: supports 64-bit system address                                                                                                                                                                          |     |
| b27          | Reserved             |                                                                                                                                                                                                            | R   |
| b26          | corecfg_1p8voltsuppo | This bit indicates whether the HC supports 1.8 V.                                                                                                                                                          | R   |
|              | rt                   | 0: 1.8 V Not supported                                                                                                                                                                                     |     |
|              |                      | 1: 1.8 V supported (Not available in this LSI.)                                                                                                                                                            |     |
| b25          | corecfg_3p0voltsuppo | This bit indicates whether the HC supports 3.0 V.                                                                                                                                                          | R   |
|              | rt                   | 0: 3.0 V Not supported                                                                                                                                                                                     |     |
|              |                      | 1: 3.0 V supported (Not available in this LSI.)                                                                                                                                                            |     |
| b24          | corecfg_3p3voltsuppo | This bit indicates whether the HC supports 3.3 V.                                                                                                                                                          | R   |
|              | rt                   | 0: 3.3 V Not supported                                                                                                                                                                                     |     |
|              |                      | 1: 3.3 V supported                                                                                                                                                                                         |     |
| b23          | corecfg_suspressupp  | This bit indicates whether the HC supports Suspend/Resume functionality. If this bit is                                                                                                                    | R   |
|              | ort                  | 0, the Suspend and Resume mechanism are not supported and the HD shall not issue                                                                                                                           |     |
|              |                      | either Suspend/Resume commands.                                                                                                                                                                            |     |
|              |                      | 0: Not supported                                                                                                                                                                                           |     |
| 1.00         |                      | 1: supported                                                                                                                                                                                               |     |
| b22          | corecfg_sdmasupport  | This bit indicates whether the HC is capable of using DMA to transfer data between system memory and the HC directly.                                                                                      | R   |
|              |                      | 0: SDMA Not Supported                                                                                                                                                                                      |     |
|              |                      | 1: SDMA Supported                                                                                                                                                                                          |     |

| Dit Danitian | Dit Name                     | Forestica                                                                                                                                                                                                                                                                               | DAM |
|--------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Bit Position | Bit Name                     | Function                                                                                                                                                                                                                                                                                | R/W |
| b21          | corecfg_highspeedsu<br>pport | This bit indicates whether the HC and the Host System support High Speed mode and they can supply SD clock frequency from 25 MHz to 50 MHz (for SD)/20 MHz to 50 MHz (for eMMC).                                                                                                        | R   |
|              |                              | 0: High Speed Not Supported                                                                                                                                                                                                                                                             |     |
|              |                              | 1: High Speed Supported                                                                                                                                                                                                                                                                 |     |
| b20          | Reserved                     |                                                                                                                                                                                                                                                                                         | R   |
| b19          | corecfg_adma2suppo           | 0: ADMA2 Not Supported                                                                                                                                                                                                                                                                  | R   |
|              | rt                           | 1: ADMA2 Supported                                                                                                                                                                                                                                                                      |     |
| b18          | corecfg_8bitsupport          | This bit indicates whether the HC is capable of using 8-bit bus width mode.                                                                                                                                                                                                             | R   |
|              |                              | 0: Extended Media Bus Not Supported                                                                                                                                                                                                                                                     |     |
|              |                              | 1: Extended Media Bus Supported                                                                                                                                                                                                                                                         |     |
| b17, b16     | corecfg_maxblklength         | This value indicates the maximum block size that the HD can read and write to the buffer in the HC. The buffer shall transfer this block size without wait cycles.                                                                                                                      | R   |
|              |                              | 00b: 512 byte                                                                                                                                                                                                                                                                           |     |
|              |                              | 01b: 1024 byte                                                                                                                                                                                                                                                                          |     |
|              |                              | 10b: 2048 byte                                                                                                                                                                                                                                                                          |     |
|              |                              | 11b: Reserved                                                                                                                                                                                                                                                                           |     |
| b15 to b8    | corecfg_baseclkfreq          | This value indicates the base clock frequency for SDIO_CLK. (CFG_SDIO[m] register of System Control set is defined per slot.) Unit values are 1 MHz. The supported clock range is 10 MHz to 50 MHz.  32h: 50 MHz                                                                        | R   |
|              |                              | 02h: 2 MHz                                                                                                                                                                                                                                                                              |     |
|              |                              | 01h: 1 MHz                                                                                                                                                                                                                                                                              |     |
|              |                              | If the real frequency is 16.5 MHz, the lager value shall be set 11h (17 MHz) because the HD uses this value to calculate the clock divider value (Refer to the SDIO_CLK Frequency Select in the Clock Control Register.) and it shall not exceed upper limit of the SD clock frequency. |     |
| b7           | corecfg_timeoutclkuni<br>t   | This bit shows the unit of base clock (TMCLK) frequency used to detect Data Timeout Error.                                                                                                                                                                                              | R   |
|              |                              | 0: kHz                                                                                                                                                                                                                                                                                  |     |
|              |                              | 1: MHz                                                                                                                                                                                                                                                                                  |     |
| b6           | Reserved                     |                                                                                                                                                                                                                                                                                         | R   |
| b5 to b0     | corecfg_timeoutclkfre        | This bit shows the base clock frequency used to detect Data Timeout Error.  000000b: Get Information via another method                                                                                                                                                                 | R   |
|              |                              | Others: 1 kHz to 63 kHz or 1 MHz to 63 MHz                                                                                                                                                                                                                                              |     |

## 9.4.28 reg\_capabilities\_cont — Capabilities Register (Continue)

This register provides the host driver with information specific to the host controller implementation.

**Address:** 4010 0044h (SDIO1) 4010 1044h (SDIO2)



Table 9.30 reg\_capabilities\_cont Register Contents

| Bit Position | Bit Name                    | Function                                                                                                                                                                                       | R/W |
|--------------|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b26   | Reserved                    |                                                                                                                                                                                                | R   |
| b25          | corecfg_spiblkmode          | This field indicates whether SPI Block Mode is supported or not.  0: Not Supported  1: Supported                                                                                               | R   |
| b24          | corecfg_spisupport          | This field indicates whether SPI Mode is supported or not.  0: Not Supported  1: Supported                                                                                                     | R   |
| b23 to b16   | corecfg_clockmultiplie<br>r | This field indicates clock multiplier value of programmable clock generator. Setting 00h means that HC does not support programmable clock generator.  00h: Clock Multiplier is Not Supported. | R   |
| b15 to b0    | Reserved                    |                                                                                                                                                                                                | R   |

## 9.4.29 reg\_maxcurrentcap — Maximum Current Capabilities Register

This register indicates maximum current capability for each voltage.

**Address:** 4010 0048h (SDIO1)

4010 1048h (SDIO2)



Table 9.31 reg\_maxcurrentcap Register Contents

| Bit Position | Bit Name                   | Function                                                                                                                                                                                                                          | R/W |
|--------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved                   |                                                                                                                                                                                                                                   | R   |
| b23 to b16   | corecfg_maxcurrent1<br>p8v | Maximum Current for 1.8 V Not available in this LSI.                                                                                                                                                                              | R   |
| b15 to b8    | corecfg_maxcurrent3<br>p0v | Maximum Current for 3.0 V Not available in this LSI.                                                                                                                                                                              | R   |
| b7 to b0     | corecfg_maxcurrent3<br>p3v | Maximum Current for 3.3 V  Not available in this LSI.  See Note 1 in Table 11.3, Current in the RZ/N1D Group, RZ/N1S Group, RZ/N1L Group User's Manual: System Introduction, Multiplexing, Electrical and Mechanical Information. | R   |

# 9.4.30 reg\_ForceEventforAUTOCMDErrorStatus — Force Event for Auto CMD Error Status Register

This register is not physically implemented, rather used for setting any bit of Auto CMD Error Status Register, which is difficult to set intentionally.

**Address:** 4010 0050h (SDIO1) 4010 1050h (SDIO2)



Table 9.32 reg\_ForceEventforAUTOCMDErrorStatus Register Contents

| Bit Position | Bit Name                            | Bit Name Function                                                                                   |   |
|--------------|-------------------------------------|-----------------------------------------------------------------------------------------------------|---|
| b15 to b8    | Reserved                            |                                                                                                     | R |
| b7           | forcecmdnotissuedby<br>autocmd12err | Force Event for Command Not Issued by Auto CMD12 Error.  1: Interrupt is generated  0: No Interrupt | W |
| b6, b5       | Reserved                            |                                                                                                     | R |
| b4           | forceautocmdindexerr                | Force Event for Auto CMD Index Error.  1: Interrupt is generated  0: No Interrupt                   | W |
| b3           | forceautocmdendbiter<br>r           | Force Event for Auto CMD End Bit Error.  1: Interrupt is generated  0: No Interrupt                 | W |
| b2           | forceautocmdcrcerr                  | Force Event for Auto CMD CRC Error.  1: Interrupt is generated  0: No Interrupt                     | W |
| b1           | forceautocmdtimeoute<br>rr          | Force Event for Auto CMD Timeout Error.  1: Interrupt is generated  0: No Interrupt                 | W |
| b0           | forceautocmdnotexec                 | Force Event for Auto CMD12 Not Executed.  1: Interrupt is generated  0: No Interrupt                | W |

# 9.4.31 reg\_forceeventforerrintsts — Force Event for Error Interrupt Status Register

This register is not physically implemented, rather used for setting any bit of Error Interrupt Status Register, which is difficult to set intentionally.

**Address:** 4010 0052h (SDIO1) 4010 1052h (SDIO2)



Table 9.33 reg\_forceeventforerrintsts Register Contents

| Bit Position | Bit Name           | Function                               | R/W |
|--------------|--------------------|----------------------------------------|-----|
| b15 to b10   | Reserved           |                                        | R   |
| b9           | forceadmaerr       | Force Event for ADMA Error.            | W   |
|              |                    | 1: Interrupt is generated              |     |
|              |                    | 0: No Interrupt.                       |     |
| b8           | forceautocmderr    | Force Event for Auto CMD Error.        | W   |
|              |                    | 1: Interrupt is generated              |     |
|              |                    | 0: No Interrupt.                       |     |
| b7           | forcecurrlimerr    | Force Event for Current Limit Error.   | W   |
|              |                    | 1: Interrupt is generated              |     |
|              |                    | 0: No Interrupt.                       |     |
| b6           | forcedatendbiterr  | Force Event for Data End Bit Error.    | W   |
|              |                    | 1: Interrupt is generated              |     |
|              |                    | 0: No Interrupt.                       |     |
| b5           | forcedatcrcerr     | Force Event for Data CRC Error.        | W   |
|              |                    | 1: Interrupt is generated              |     |
|              |                    | 0: No Interrupt.                       |     |
| b4           | forcedattimeouterr | Force Event for Data Timeout Error.    | W   |
|              |                    | 1: Interrupt is generated              |     |
|              |                    | 0: No Interrupt.                       |     |
| b3           | forcecmdindexerr   | Force Event for Command Index Error    | W   |
|              |                    | 1: Interrupt is generated              |     |
|              |                    | 0: No Interrupt.                       |     |
| b2           | forcecmdendbiterr  | Force Event for Command End Bit Error. | W   |
|              |                    | 1: Interrupt is generated              |     |
|              |                    | 0: No Interrupt.                       |     |
| b1           | forcecmdcrcerr     | Force Event for Command CRC Error.     | W   |
|              |                    | 1: Interrupt is generated              |     |
|              |                    | 0: No Interrupt.                       |     |
| b0           | forcecmdtimeouterr | Force Event for Command Timeout Error. | W   |
|              |                    | 1: Interrupt is generated              |     |
|              |                    | 0: No Interrupt.                       |     |

## 9.4.32 reg\_admaerrsts — ADMA Error Status Register

When the ADMA Error interrupt occur, this register holds the ADMA State in ADMA Error States field and ADMA System Address holds address around the error descriptor.

**Address:** 4010 0054h (SDIO1) 4010 1054h (SDIO2)



Table 9.34 reg\_admaerrsts Register Contents

| Bit Position | Bit Name                      | Function                    |                                                                                                                                                                                               |                                            | R/W |  |  |
|--------------|-------------------------------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|-----|--|--|
| b7 to b3     | Reserved                      |                             |                                                                                                                                                                                               |                                            | R   |  |  |
| b2           | admaerrsts_admalen            | ADMA Le                     | ength Mismatch Error                                                                                                                                                                          |                                            | R   |  |  |
|              | mismatcherr                   | This error                  | This error occurs in the following 2 cases.                                                                                                                                                   |                                            |     |  |  |
|              |                               | Descri                      | <ul> <li>While Block Count Enable being set, the total data length specified by the<br/>Descriptor table is different from that specified by the Block Count and Block<br/>Length.</li> </ul> |                                            |     |  |  |
|              |                               | <ul> <li>Total d</li> </ul> | lata length cannot be divided by the b                                                                                                                                                        | lock length.                               |     |  |  |
|              |                               | 1: Erro                     | or                                                                                                                                                                                            |                                            |     |  |  |
|              |                               | 0: No                       | Error                                                                                                                                                                                         |                                            |     |  |  |
| b1, b0       | admaerrsts_admaerro<br>rstate | ADMA Er                     | ror State                                                                                                                                                                                     |                                            | R   |  |  |
|              |                               |                             | indicates the state of ADMA when en<br>This field never indicates "10b" becaus                                                                                                                | 9                                          |     |  |  |
|              |                               | Bit 1 to 0                  | ADMA Error State When Error Occurred                                                                                                                                                          | Contents of SYS_SDR Register               |     |  |  |
|              |                               | 00b                         | ST_STOP (Stop DMA)                                                                                                                                                                            | Points to next of the error descriptor     | _   |  |  |
|              |                               | 01b                         | ST_FDS (Fetch Descriptor)                                                                                                                                                                     | Points to the error descriptor             | _   |  |  |
|              |                               | 10b                         | Never set this state                                                                                                                                                                          | (Not Used).                                |     |  |  |
|              |                               | 11b                         | ST_TFR (Transfer Data)                                                                                                                                                                        | Points to the next of the error descriptor | _   |  |  |

## 9.4.33 reg\_admasysaddr0 — ADMA System Address Register Low

This register contains the Lower 16-bit of physical system memory address used for ADMA data transfer.

**Address:** 4010 0058h (SDIO1)

4010 1058h (SDIO2)



Table 9.35 reg\_admasysaddr0 Register Contents

| Bit Position | Bit Name         | Function                                                                                                                                                              |                                                                                                                                                                                                                                           | R/W |
|--------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b15 to b0    | adma_sysaddress0 | This register holds byte address of exec                                                                                                                              | uting command of the Descriptor table.                                                                                                                                                                                                    | R/W |
|              |                  | ADMA, the HD shall set start address of<br>this register address, which points to ne<br>When the ADMA Error Interrupt is gene<br>address depending on the ADMA state. | address 32-bit of this register. At the start of the Descriptor table. The ADMA increments at line, when every fetching a Descriptor line. The HD shall program Descriptor Table on 32-dress to this register. ADMA2 ignores lower 2-D0b. |     |
|              |                  |                                                                                                                                                                       |                                                                                                                                                                                                                                           |     |
|              |                  | Register Value (reg_admasysaddr1, reg_admasysaddr0)                                                                                                                   | 32-bit System Address                                                                                                                                                                                                                     |     |
|              |                  |                                                                                                                                                                       | 32-bit System Address<br>00000000h                                                                                                                                                                                                        |     |
|              |                  | (reg_admasysaddr1, reg_admasysaddr0)                                                                                                                                  | ,                                                                                                                                                                                                                                         |     |
|              |                  | (reg_admasysaddr1, reg_admasysaddr0) 0000h, 0000h                                                                                                                     | 00000000h                                                                                                                                                                                                                                 |     |

## 9.4.34 reg\_admasysaddr1 — ADMA System Address Register High

This register contains the Higher 16-bit of physical system memory address used for ADMA data transfer.

**Address:** 4010 005Ah (SDIO1)

4010 105Ah (SDIO2)



Table 9.36 reg\_admasysaddr1 Register Contents

| Bit Position | Bit Name         | Function                                                                                                                               | R/W |
|--------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------|-----|
| b15 to b0    | adma_sysaddress1 | This register holds byte address of executing command of the Descriptor table. Details of this field is described in reg_admasysaddr0. | R/W |

#### 9.4.35 reg\_presetvalue0 — Preset Value Register for Initialization

This register is used to read the SDIO\_CLK Frequency Select Value, Clock Generator Select Value for Initialization.

Address: 4010 0060h (SDIO1)

4010 1060h (SDIO2)



Table 9.37 reg\_presetvalue0 Register Contents

| Bit Position | Bit Name                      | Function                                                                                                                                                     | R/W |
|--------------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b15 to b11   | Reserved                      |                                                                                                                                                              | R   |
| b10          | ClockGeneratorSelect<br>Value | This bit is effective when HC supports programmable clock generator.  0: Host Controller Ver2.00 Compatible Clock Generator  1: Programmable Clock Generator | R   |
| b9 to b0     | SDCLKFrequencySel ectValue    | 10-bit preset value to set SDIO_CLK Frequency Select in the Clock Control Register is described by a host system.                                            | R   |

## 9.4.36 reg\_presetvalue1 — Preset Value Register for Default Speed

This register is used to read the SDIO\_CLK Frequency Select Value, Clock Generator Select Value for Default Speed.

Address: 4010 0062h (SDIO1) 4010 1062h (SDIO2)



Table 9.38 reg\_presetvalue1 Register Contents

| Bit Position | Bit Name                                                                                                                                                                                | Function | R/W |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----|
| b15 to b11   | Reserved                                                                                                                                                                                |          | R   |
| b10          | ClockGeneratorSelect This bit is effective when HC supports programmable clock generator.  Value 0: Host Controller Ver2.00 Compatible Clock Generator  1: Programmable Clock Generator |          | R   |
| b9 to b0     | SDCLKFrequencySel 10-bit preset value to set SDIO_CLK Frequency Select in the Clock Control Register is ectValue described by a host system.                                            |          | R   |

## 9.4.37 reg\_presetvalue2 — Preset Value Register for High Speed

This register is used to read the SDIO\_CLK Frequency Select Value, Clock Generator Select Value for High Speed.

**Address:** 4010 0064h (SDIO1)

4010 1064h (SDIO2)



Table 9.39 reg\_presetvalue2 Register Contents

| Bit Position | Bit Name                                                                                                                                      | Function                                                                                                                                                     | R/W |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b15 to b11   | Reserved                                                                                                                                      |                                                                                                                                                              | R   |
| b10          | ClockGeneratorSelect<br>Value                                                                                                                 | This bit is effective when HC supports programmable clock generator.  0: Host Controller Ver2.00 Compatible Clock Generator  1: Programmable Clock Generator | R   |
| b9 to b0     | b9 to b0 SDCLKFrequencySel and 10-bit preset value to set SDIO_CLK Frequency Select in the Clock Control Register described by a host system. |                                                                                                                                                              | R   |

## 9.4.38 reg\_slotintrsts — Slot Interrupt Status Register

This register is used to read the interrupt signal for each slot.

Address: 4010 00FCh (SDIO1) 4010 10FCh (SDIO2)



Table 9.40 reg\_slotintrsts Register Contents

| Bit Position | Bit Name               | Function                                                                                 | R/W |
|--------------|------------------------|------------------------------------------------------------------------------------------|-----|
| b15 to b1    | Reserved               |                                                                                          | R   |
| b0           | sdhchostif_slotintrsts | This status bit indicates the logical OR of Interrupt signal and Wakeup signal for slot. | R   |

## 9.4.39 reg\_hostcontrollerver — Host Controller Version Register

This register is used to read the vendor version number and specification version number.

**Address:** 4010 00FEh (SDIO1)

4010 10FEh (SDIO2)



Table 9.41 reg\_hostcontrollerver Register Contents

| Bit Position | Bit Name                    | Function                                                                  | R/W |
|--------------|-----------------------------|---------------------------------------------------------------------------|-----|
| b15 to b8    | SDHC_VENVERNUM              | The Vendor Version Number is set to 10h (1.0).                            | R   |
| b7 to b0     | SpecificationVersionN umber | The HC Version Number is set to 02h. (SD Host Specification Version 3.00) | R   |

## 9.5 Programming the SDIO

This chapter gives the details about various data transfer protocols and how to program the protocols.

- Non-DMA data transaction
- DMA data transaction
- ADMA data transaction
- Abort transaction (Sync and Async)

#### 9.5.1 Non-DMA Transaction

The sequence for Not Using DMA [non-DMA] is shown below.



Figure 9.2 Data Transfer Using DAT Line Sequence (Not Using DMA)

## **Non-DMA Transaction Sequence**

Table 9.42 Non-DMA Transaction

| Step | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Set the value corresponding to the executed data byte length of one block to Block Size Register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2    | Set the value corresponding to the executed data block count to Block Count Register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3    | Set the value corresponding to the issued command to Argument Register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 4    | Set the value to Multi/Single Block Select and Block Count Enable. Set the value corresponding to the issued command to Data Transfer Direction, Auto CMD12 Enable and DMA Enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5    | Set the value corresponding to the issued command to Command Register.  When writing the upper byte of Command Register, SD command is issued.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6    | Wait for the Command Complete Interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7    | Write 1 to the Command Complete in the Normal Interrupt Status Register for clearing this bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 8    | Read Response Register and get necessary information in accordance with the issued command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 9    | In the Case Where this sequence is for write to a card, go to step (10-W). In case of read from a card, go to step (10-R).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 10-W | Wait for Buffer Write Ready Interrupt.  Non-DMA Write Transfer  On receiving the Buffer Write Ready interrupt the CPU will act as a master and start transferring the data via Buffer Data Port Register (fifo_1). Transmitter starts sending the data in SD bus when a block of data is ready in fifo_1. While transmitting the data in SD bus the buffer write ready interrupt is sent to the CPU for the second block of data. The CPU will act as a master and start sending the second block of data via Buffer Data Port Register to fifo_2. Buffer write ready interrupt will be asserted only when a FIFO is empty to receive a block of data. |
| 11-W | Write 1 to the Buffer Write Ready in the Normal Interrupt Status Register for clearing this bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 12-W | Write block data (in according to the number of bytes specified at the step (1)) to Buffer Data Port Register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 13-W | Repeat until all blocks are sent and then go to step (14).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 10-R | Non-DMA Read Transfer  Buffer Read Ready interrupt is asserted whenever a block of data is ready in one of the FIFO's. On receiving the Buffer Read Ready interrupt the CPU will act as a master and start reading the data via Buffer Data Port Register (fifo_1). Receiver start reading the data from SD bus only when a FIFO is empty to receive a block of data. When both the FIFO's are full the host controller will stop the data coming from the card through read wait mechanism (if card supports read wait) or through clock stopping.  Wait for Buffer Read Ready Interrupt                                                              |
| 11-R | Write 1 to the Buffer Read Ready in the Normal Interrupt Status Register for clearing this bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 12-R | Read block data (in according to the number of bytes specified at the step (1)) from the Buffer Data Port Register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 13-R | Repeat until all blocks are received and then go to step (14).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 14   | If this sequence is for Single or Multiple Block Transfer, go to step (15). In case of Infinite Block Transfer, go to step (17).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15   | Wait for Transfer Complete Interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 16   | Write 1 to the Transfer Complete in the Normal Interrupt Status Register for clearing this bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 17   | Perform the sequence for Abort Transaction.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

#### **CAUTION**

Note: Step (1) and (2) can be executed at same time. Step (4) and (5) can be executed at same time.

#### 9.5.2 DMA Transaction

The burst types like 8-beat incrementing burst or 4-beat incrementing burst or Single transfer is used to transfer or receive the data from the system memory mainly to avoid the hold of the Host/System bus by the master for a longer time. The sequence for Using DMA is shown below.



Figure 9.3 Data Transfer Using DAT Line Sequence (Using DMA)

#### **DMA Transaction Sequence**

Table 9.43 DMA Transaction

| Step | Description                                                                                                                                                                        |  |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1    | Set the system address for DMA in the SDMA System Address Register.                                                                                                                |  |
| 2    | Set the value corresponding to the executed data byte length of one block in the Block Size Register.                                                                              |  |
| 3    | Set the value corresponding to the executed data block count in the Block Count Register.                                                                                          |  |
| 4    | Set the value corresponding to the issued command to Argument Register.                                                                                                            |  |
| 5    | Set the value to Multi/Single Block Select and Block Count Enable. Set the value corresponding to the issued command to Data Transfer Direction, Auto CMD12 Enable and DMA Enable. |  |
| 6    | Set the value corresponding to the issued command to Command Register.  When writing the upper byte of Command Register, SD command is issued.                                     |  |
| 7    | Wait for the Command Complete Interrupt.                                                                                                                                           |  |
| 8    | Write 1 to the Command Complete in the Normal Interrupt Status Register for clearing this bit.                                                                                     |  |

Read Response Register and get necessary information in accordance with the issued command.

#### **DMA** read transfer

9

On receiving the response end bit from the card for the write command (data flowing from Host to Card) the SD Host controller will act as the master and request the System/Host bus. After receiving the grant, the host controller will start reading a block of data from the system memory and fills the first FIFO. Whenever a block of data is ready the transmitter will start sending the data in SD bus. While transmitting the data in SD bus the host controller requests the bus to fill the second block in second FIFO. Ping Pong FIFO's are used to increase the throughput. Similarly, the host controller reads a block of data from the system memory whenever a FIFO is empty. This will continue till all the blocks are read from the System memory. Transfer complete Interrupt will be set only after transferring all the blocks of data to the card.

#### **DMA** write transfer

The block of data received from the Card (data flowing from Card to Host) is stored in first half of the FIFO. Whenever a block of data is ready the SD Host controller will act as the master and request the System/Host bus. After receiving the grant, the host controller will start writing a block of data into the system memory from the first FIFO. While transmitting the data into System memory the host controller will receive the second block of data and store in second FIFO. Similarly, the host controller write a block of data into the system memory whenever data is ready. This will continue till all the blocks are transferred to the System memory. Transfer complete Interrupt will be set only after transferring all the blocks of data to the System memory.

**Note)** Host controller will receive a block of data from the card only when it has room to store a block of data in FIFO. When both the FIFO's are full the host controller will stop the data coming from the card through read wait mechanism (if card supports read wait) or through clock stopping.

| 10 | Wait for the Transfer Complete Interrupt and DMA Interrupt.                                                                                                 |
|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11 | If Transfer Complete is set 1, go to Step (14) else if DMA Interrupt is set to 1, go to Step (12). Transfer Complete is higher priority than DMA Interrupt. |
| 12 | Write 1 to the DMA Interrupt in the Normal Interrupt Status Register to clear this bit.                                                                     |
| 13 | Set the next system address of the next data position to the SDMA System Address Register and go to Step (10).                                              |
| 14 | Write 1 to the Transfer Complete and DMA Interrupt in the Normal Interrupt Status Register to clear this bit.                                               |

#### CAUTION

Note: Step (2) and Step (3) can be executed at same time. Step (5) and Step (6) can also be executed at same time.

For example, if the host wants to transfer 4 KB of data to the Card. Assume the maximum block size is 512 bytes. Then the host driver will program the Block Size Register as 512 and Block Count Register with the value 8.

The AHB Master and Transmitter residing inside the Host Controller will get the information (how much data to transfer) from these registers. Using the above information, the AHB master will act as a master and initiate a data read transaction (to read a block of data -512 bytes from the system memory). Whenever a block of data is ready in FIFO, the transmitter will start transmitting the block of data (512 bytes) in SD bus. After transmitting the entire block of data to the card, the transmitter will wait for a status response from the card. Transmitter will send the next block of data



only, when it receives a good status response from the card for the previous block of data otherwise the transaction will be aborted and the host will go for a fresh transaction.

#### 9.5.3 ADMA Transactions

The following figure and table describe the ADMA transaction sequence.



Figure 9.4 ADMA Transaction Flow

#### **ADMA Transaction Flow**

Table 9.44 ADMA Transaction

| Step | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1    | Create Descriptor table for ADMA in the system memory.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| 2    | Set the Descriptor address for ADMA in the ADMA System Address Register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| 3    | Set the value corresponding to the executed data byte length of one block in the Block Size.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| 4    | Set the value corresponding to the executed data block count in the Block Count Register. If the Block Count Enable in the Transfer Mode Register is set to 1, total data length can be designated by the Block Count Register and the Descriptor Table. These two parameters shall indicate same data length. However, transfer length is limited by the 16-bit Block Coun Register. If the Block Count Enable in the Transfer Mode Register is set to 0, total data length is designated by not Block Count Register but the Descriptor Table. In this case, ADMA reads more data than length programmed in descriptor from SD card. Too much read operation is aborted asynchronously and extra read data is discarded when the ADMA is completed. |  |
| 5    | Set the argument value to the Argument Register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| 6    | Set the value to the Transfer Mode Register. The host driver determines Multi/Single Block Select, Block Count Enable, Data Transfer Direction, Auto CMD12 Enable and DMA Enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| 7    | Set the value to the Command Register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|      | Note) When writing to the upper byte [3] of the Command Register, the SD command is issued and DMA is started.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| 8    | Wait for the Command Complete Interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| 9    | Write 1 to the Command Complete in the Normal Interrupt Status Register to clear this bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| 10   | Read Response Register and get necessary information of the issued command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| 11   | Wait for the Transfer Complete Interrupt and ADMA Error Interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| 12   | If Transfer Complete is set 1, go to Step (13) else if ADMA Error Interrupt is set to 1, go to Step (14).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| 13   | Write 1 to the Transfer Complete Status in the Normal Interrupt Status Register to clear this bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| 14   | Write 1 to the ADMA Error Interrupt Status in the Error Interrupt Status Register to clear this bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| 15   | Abort ADMA operation. SD card operation should be stopped by issuing abort command. If necessary, the HD checks ADMA Error Status Register to detect why ADMA error is generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |

#### CAUTION

Note: Step (3) and Step (4) can be executed simultaneously. Step (6) and Step (7) can also be executed simultaneously.

#### 9.5.4 Abort Transaction

An Abort transaction is performed using CMD12 for a SD Memory Card and by using CMD52 for a SDIO Card. There are two cases where the HD needs to do an Abort Transaction.

- (1) When the HD stops infinite block transfers.
- (2) When HD stops transfers while a Multiple block transfer is exacting.

There are two ways to issue an Abort command. The first is an Asynchronous abort. The second is a Synchronous Abort. In an Asynchronous Abort sequence, the HD can issue an Abort Command at any time unless Command Inhibit (CMD) in the Present State Register is set to 1. In a Synchronous Abort, the HD shall issue an Abort command after the data transfer stopped by using Stop At Block Gap Request in the Block Gap Control Register.



#### 9.5.4.1 Synchronous Abort

The flow for Synchronous Abort is shown below.



Figure 9.5 Synchronous Abort

Table 9.45 Synchronous Abort Transaction

| Step | Description                                                                                                                                                                                                                                                                           |  |  |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 1    | Set the Stop At Block Gap Request in the Block Gap Control Register to 1 to stop SD transactions.                                                                                                                                                                                     |  |  |
| 2    | Wait for Transfer Complete Interrupt.                                                                                                                                                                                                                                                 |  |  |
| 3    | Set the Transfer Complete to 1 in the Normal Interrupt Status Register to clear this bit.                                                                                                                                                                                             |  |  |
| 4    | Issue Abort Command.                                                                                                                                                                                                                                                                  |  |  |
| 5    | Set both Software Reset for DAT Line and Software Reset for CMD Line to 1 in the Software Reset Register to do software reset.                                                                                                                                                        |  |  |
| 6    | Check Software Reset for DAT Line and Software Reset for CMD Line in the Software Reset Register. If both Software Reset for DAT Line and Software Reset for CMD Line are 0, go to "END". If either Software Reset for DAT Line or Software Reset for CMD Line is 1, repeat step (6). |  |  |

#### 9.5.4.2 Asynchronous Abort

The flow for asynchronous abort is shown below.



Figure 9.6 Asynchronous Abort

#### **Asynchronous Abort Sequence**

Table 9.46 Asynchronous Abort Transaction

| Step | Description                                                                                                                                                                                                                                                                          |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Issue Abort Command.                                                                                                                                                                                                                                                                 |
| 2    | Set both Software Reset For DAT Line and Software Reset For CMD Line to 1 in the Software Reset Register to do software reset.                                                                                                                                                       |
| 3    | Check Software Reset For DAT Line and Software Reset For CMD Line in the Software Reset Register. If both Software Reset For DAT Line and Software Reset For CMD Line are 0, go to "End". If either Software Reset For DAT Line or Software Reset For CMD Line is 1, go to step (3). |

## Section 10 USB 2.0 HS Host/Function Controller (USBh/USBf)

#### 10.1 Overview

The USB subsystem provides independent USB 2.0 Host controller and USB 2.0 Function controller which are fully compliant with the Universal Serial Bus specification (version 2.0). The USB subsystem can be used as 2-Host mode or 1-Host / 1-Function mode. It can be configured as one host port and one function port. The function port can be reconfigured by the firmware but the whole module must be reset (including the host port).

The USB PHY's PLL provides 48 MHz for RZ/N1 system.

#### **Host Controller Feature**

- Compliant with both the enhanced host controller interface (EHCI) specification (version 1.0) and the open host controller interface (OHCI) specification (version 1.0a)
- Supports for the following speeds:
  - High speed (HS): 480 Mbps (USB 2.0)
  - Full speed (FS): 12 Mbps (USB 1.1)
  - Low speed (LS): 1.5 Mbps (USB 1.1)
- A USB Plug Detect (UPD) which detects the connection of a device.
- Output port power switch management
- Port over current indication
- Integrated DMA
- USB PHYs (2 USB ports)
- The USB PHY shared with USB Function controller (Port1 only)
- Routing the clock of 48 MHz generated by USB PHY's PLL outside USB to reuse in the system
  - In case of change (from Host to Function mode or from Function to Host mode) via register bit (H2MODE) by firmware, this clock must be restarted.
- Transmit & Receive FIFO

#### **Function Controller Feature**

- USB PHY is shared with USB Host controller (Port1 only)
- 16 Endpoints are configured as below

| Endpoint | Direction | Туре        | Buffer | Max Packet Size |
|----------|-----------|-------------|--------|-----------------|
| EP0      | IN/OUT    | Control     | Single | 64 Byte         |
| EP1      | IN        | Bulk        | Double | 512 Byte        |
| EP2      | OUT       | Bulk        | Double | 512 Byte        |
| EP3      | IN        | Bulk        | Single | 512 Byte        |
| EP4      | OUT       | Bulk        | Single | 512 Byte        |
| EP5      | IN        | Bulk        | Single | 512 Byte        |
| EP6      | IN        | Interrupt   | Single | 1024 Byte       |
| EP7      | IN        | Interrupt   | Single | 1024 Byte       |
| EP8      | IN        | Interrupt   | Single | 1024 Byte       |
| EP9      | IN        | Interrupt   | Single | 1024 Byte       |
| EP10     | IN        | Isochronous | Double | 1024 Byte       |
| EP11     | OUT       | Isochronous | Double | 1024 Byte       |
| EP12     | IN        | Isochronous | Double | 1024 Byte       |
| EP13     | OUT       | Isochronous | Double | 1024 Byte       |
| EP14     | IN        | Isochronous | Double | 1024 Byte       |
| EP15     | OUT       | Isochronous | Double | 1024 Byte       |



Figure 10.1 USB Subsystem Interfaces and Connections



Figure 10.2 USB Subsystem Block Diagram

# 10.2 Signal Interfaces

|                 | Input  |                                                                                                                                                    |
|-----------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Signal Name     | Output | Description                                                                                                                                        |
| Clock           |        |                                                                                                                                                    |
| USB_HCLKH       | Input  | Internal bus clock (AHB) for HOST                                                                                                                  |
| USB_HCLKF       | Input  | Internal bus clock (AHB) for Function                                                                                                              |
| USB_HCLKPM      | Input  | Internal bus clock (AHB) for Power Management                                                                                                      |
| USB_PCICLK      | Input  | PCI clock for USB subsystem                                                                                                                        |
| USB_DCLK48      | Output | 48 MHz output for system, no clock gating                                                                                                          |
| Interrupt       |        |                                                                                                                                                    |
| USB2H_BIND_Int  | Output | Level sensitive interrupt, Active High. (described as U2H_BIND_INT in this section)                                                                |
| USB2F_EPC_Int   | Output | Level sensitive interrupt, Active High. (described as U2F_EPC_INT in this section)                                                                 |
| USB2F_Int       | Output | Level sensitive interrupt, Active High. (described as U2F_INT in this section)                                                                     |
| External Signal |        |                                                                                                                                                    |
| USB_DP[m]       | I/O    | Bus High Speed D+ (port m)                                                                                                                         |
| USB_DM[m]       | I/O    | Bus High Speed D- (port m)                                                                                                                         |
| USB_OC[m]       | Input  | Overcurrent status (port m) for Host, active low                                                                                                   |
| USB_PPON[m]     | Output | Port Power Control (port m) for Host                                                                                                               |
| USB_VBUS        | Input  | Port power detection pin (dedicated pin) for Function An external circuit should convert 5 V to 3 V, prevent chattering and input to USB_VBUS pin. |

Note: m = 1 or 2

#### 10.3 USBPLL Features

- The USBPLL is stopped by default after Power-On-Reset
- The USBPLL stopped if the HRESETn of the USB core is asserted
- The software needs to start USBPLL which means the DIRPD bit in CFG\_USB register (in the system controller) needs to be de-asserted, the USB module needs to come out of reset (AHB HRESETn de-asserted), the software needs to release the PLL reset bit in the internal registers of the USB core, and the software needs to enable USB DCLK48 clock (to enable the FRCLK48MOD bit in the CFG USB register).
- Routing clock of 48 MHz outside USB to reuse in the system
- In case of changing CFG\_USB.H2MODE (in the system controller), note the following:
  - In case of change (from Host to Function mode or from Function to Host mode) via register bit (H2MODE) by firmware, this clock must be restarted.
  - Port1 (Function) mode change while running port2 (Host) is not possible. Reset of the PHYs module is necessary
    and this module is common for both USB cores.
  - The USBPLL does not stop on H2MODE register bit but it does stop when the software resets the USB as a consequence of the mode change.

## 10.4 Register Map

## 10.4.1 OHCI Operation Register Map

Table 10.1 USB HC-OHCI Register Map

|            | <u>-</u>           |                              |
|------------|--------------------|------------------------------|
| Address    | Register Symbol    | Register Name                |
| 4002 0000h | HCREVISION         | HcRevision Register          |
| 4002 0004h | HCCONTROL          | HcControl Register           |
| 4002 0008h | HCCOMMANDSTATUS    | HcCommandStatus Register     |
| 4002 000Ch | HCINTERRUPTSTATUS  | HcInterruptStatus Register   |
| 4002 0010h | HCINTERRUPTENABLE  | HcInterruptEnable Register   |
| 4002 0014h | HCINTERRUPTDISABLE | HcInterruptDisable Register  |
| 4002 0018h | HCHCCA             | HcHCCA Register              |
| 4002 001Ch | HCPERIODCURRENTED  | HcPeriodicCurrentED Register |
| 4002 0020h | HCCONTROLHEADED    | HcControlHeadED Register     |
| 4002 0024h | HCCONTROLCURRENTED | HcControlCurrentED Register  |
| 4002 0028h | HCBULKHEADED       | HcBulkHeadED Register        |
| 4002 002Ch | HCBULKCURRENTED    | HcBulkCurrentED Register     |
| 4002 0030h | HCDONEHEAD         | HcDoneHead Register          |
| 4002 0034h | HCFMINTERVAL       | HcFrameInterval Register     |
| 4002 0038h | HCFMREMAINING      | HcFrameRemaining Register    |
| 4002 003Ch | HCFMNUMBER         | HcFrameNumber Register       |
| 4002 0040h | HCPERIODICSTART    | HcPeriodicStart Register     |
| 4002 0044h | HCLSTHRESHOLD      | HcLSThreshold Register       |
| 4002 0048h | HCRHDESCRIPTORA    | HcRhDescriptorA Register     |
| 4002 004Ch | HCRHDESCRIPTORB    | HcRhDescriptorB Register     |
| 4002 0050h | HCRHSTATUS         | HcRhStatus Register          |
| 4002 0054h | HCRHPORTSTATUS1    | HcRhPortStatus1 Register     |
| 4002 0058h | HCRHPORTSTATUS2    | HcRhPortStatus2 Register     |
|            |                    |                              |

## 10.4.2 EHCI Operation Register Map

Table 10.2 USB HC-EHCI Register Map

| Address    | Register Symbol  | Register Name                            |
|------------|------------------|------------------------------------------|
| 4002 1000h | CAPL_VERSION     | HCIVERSION and CAPLENGTH Register (EHCI) |
| 4002 1004h | HCSPARAMS        | HCSPARAMS Register                       |
| 4002 1008h | HCCPARAMS        | HCCPARAMS Register                       |
| 4002 100Ch | HCSP_PORTROUTE   | HCSP_PORTROUTE Register                  |
| 4002 1020h | USBCMD           | USBCMD Register                          |
| 4002 1024h | USBSTS           | USBSTS Register                          |
| 4002 1028h | USBINTR          | USBINTR Register                         |
| 4002 102Ch | FRINDEX          | Frame Index Register                     |
| 4002 1030h | CTRLDSSEGMENT    | CTRLDSSEGMENT Register                   |
| 4002 1034h | PERIODICLISTBASE | PERIODICLISTBASE Register                |
| 4002 1038h | ASYNCLISTADDR    | ASYNCLISTADDR Register                   |
| 4002 1060h | CONFIGFLAG       | CONFIGFLAG Register                      |
| 4002 1064h | PORTSC1          | PORTSC1 Register                         |
| 4002 1068h | PORTSC2          | PORTSC2 Register                         |

## 10.4.3 OHCI (PCI Configuration Space) Register Map

Table 10.3 USB CR-OHCI Register Map

| Address    | Register Symbol | Register Name                                                                    |
|------------|-----------------|----------------------------------------------------------------------------------|
| 4003 0000h | VID_DID         | Device ID - Vendor ID (OHCI)                                                     |
| 4003 0004h | CMND_STS        | Status - Command (OHCI)                                                          |
| 4003 0008h | REVID_CC        | Class Code - Revision ID (OHCI)                                                  |
| 4003 000Ch | CLS_LT_HT_BIST  | BIST - Header Type - Latency Timer - Cache Line Size (OHCI)                      |
| 4003 0010h | BASEAD          | OHCI Base Address                                                                |
| 4003 002Ch | SSVID_SSID      | Subsystem ID - Subsystem Vendor ID (OHCI)                                        |
| 4003 0030h | EROM_BASEAD     | Expansion ROM Base Address (OHCI)                                                |
| 4003 0034h | CAPPTR          | Capability Pointer (OHCI)                                                        |
| 4003 003Ch | INTR_LINE_PIN   | Max_Lat - Min_Gnt - Interrupt Pin - Interrupt Line (OHCI)                        |
| 4003 0040h | CAPID_NIP_PMCAP | Capability Identifier - Next Item Pointer - Power Management Capabilities (OHCI) |
| 4003 0044h | PMC_STS_PMCSR   | Power Management Control and Status - PMCSR Bridge Support Extensions (OHCI)     |
| 4003 00E0h | EXT1            | EXT1 Register (OHCI)                                                             |
| 4003 00E4h | EXT2            | EXT2 Register (OHCI)                                                             |
| 4003 00F4h | UTMICTRL        | USBPHY Operation Mode Control Register (OHCI)                                    |

## 10.4.4 EHCI (PCI Configuration Space) Register Map

Table 10.4 USB CR-EHCI Register Map

| Address    | Register Symbol | Register Name                                                                    |
|------------|-----------------|----------------------------------------------------------------------------------|
| 4003 0100h | VID_DID         | Device ID - Vendor ID (EHCI)                                                     |
| 4003 0104h | CMND_STS        | Status - Command (EHCI)                                                          |
| 4003 0108h | REVID_CC        | Class Code - Revision ID (EHCI)                                                  |
| 4003 010Ch | CLS_LT_HT_BIST  | BIST - Header Type - Latency Timer - Cache Line Size (EHCI)                      |
| 4003 0110h | BASEAD          | EHCI Base Address                                                                |
| 4003 012Ch | SSVID_SSID      | Subsystem ID - Subsystem Vendor ID (EHCI)                                        |
| 4003 0130h | EROM_BASEAD     | Expansion ROM Base Address (EHCI)                                                |
| 4003 0134h | CAPPTR          | Capability Pointer (EHCI)                                                        |
| 4003 013Ch | INTR_LINE_PIN   | Max_Lat - Min_Gnt - Interrupt Pin - Interrupt Line (EHCI)                        |
| 4003 0140h | CAPID_NIP_PMCAP | Capability Identifier - Next Item Pointer - Power Management Capabilities (EHCI) |
| 4003 0144h | PMC_STS_PMCSR   | Power Management Control and Status - PMCSR Bridge Support Extensions (EHCI)     |
| 4003 0160h | SBRN_FLADJ_PW   | SBRN - FLADJ - PORTWAKECAP                                                       |
| 4003 01E0h | EXT1            | EXT1 Register (EHCI)                                                             |
| 4003 01E4h | EXT2            | EXT2 Register (EHCI)                                                             |
| 4003 01F4h | UTMICTRL        | USBPHY Operation Mode Control Register (EHCI)                                    |

## 10.4.5 AHB-PCI Bridge (PCI Configuration Space) Register Map

Table 10.5 USB CR-AHBPCI Register Map

| Address    | Register Symbol | Register Name                                                         |
|------------|-----------------|-----------------------------------------------------------------------|
| 4003 0000h | VID_DID         | Device ID - Vendor ID (AHB-PCI Bridge)                                |
| 4003 0004h | CMND_STS        | Status - Command (AHB-PCI Bridge)                                     |
| 4003 0008h | REVID_CC        | Class Code - Revision ID (AHB-PCI Bridge)                             |
| 4003 000Ch | CLS_LT_HT_BIST  | BIST - Header Type - Latency Timer - Cache Line Size (AHB-PCI Bridge) |
| 4003 0010h | BASEAD          | AHB-PCI Bridge Registers Base Address                                 |
| 4003 0014h | WIN1_BASEAD     | PCI-AHB Window1 Base Address                                          |
| 4003 0018h | WIN2_BASEAD     | PCI-AHB Window2 Base Address                                          |
| 4003 002Ch | SSVID_SSID      | Subsystem ID - Subsystem Vendor ID (AHB-PCI Bridge)                   |
| 4003 003Ch | INTR_LINE_PIN   | Max_Lat - Min_Gnt - Interrupt Pin - Interrupt Line (AHB-PCI Bridge)   |

## 10.4.6 AHB-PCI Bridge (PCI Communication Space) Register Map

Table 10.6 USB HC-AHBPCI Register Map

| Address    | Register Symbol | Register Name                   |
|------------|-----------------|---------------------------------|
| 4003 0800h | PCIAHB_WIN1_CTR | PCIAHB Window1 Control Register |
| 4003 0804h | PCIAHB_WIN2_CTR | PCIAHB Window2 Control Register |
| 4003 0810h | AHBPCI_WIN1_CTR | AHBPCI Window1 Control Register |
| 4003 0814h | AHBPCI_WIN2_CTR | AHBPCI Window2 Control Register |
| 4003 0820h | PCI_INT_ENABLE  | PCI Interrupt Enable Register   |
| 4003 0824h | PCI_INT_STATUS  | PCI Interrupt Status Register   |
| 4003 0830h | AHB_BUS_CTR     | AHB Bus Control Register        |
| 4003 0834h | USBCTR          | USB Control Register            |
| 4003 0840h | PCI_ARBITER_CTR | PCI Arbiter Control Register    |

## 10.4.7 EPC Register Map

Table 10.7 USB FC-EPC Register Map

| Address                    | Register Symbol                       | Register Name                          |
|----------------------------|---------------------------------------|----------------------------------------|
| 4001 E000h                 | USB_CONTROL                           | USB Control Register                   |
| 4001 E004h                 | USB_STATUS                            | USB Status Register                    |
| 4001 E008h                 | USB_ADDRESS                           | Frame Number & USB Address Register    |
| 4001 E010h                 | TEST_CONTROL                          | Test Control Register                  |
| 4001 E018h                 | SETUP_DATA0                           | Setup Data0 Register                   |
| 4001 E01Ch                 | SETUP_DATA1                           | Setup Data1 Register                   |
| 4001 E020h                 | USB_INT_STA                           | USB Interrupt Status Register          |
| 4001 E024h                 | USB_INT_ENA                           | USB Interrupt Enable Register          |
| 4001 E028h                 | EP0_CONTROL                           | EP0 Control Register                   |
| 4001 E02Ch                 | EP0_STATUS                            | EP0 Status Register                    |
| 4001 E030h                 | EP0_INT_ENA                           | EP0 Interrupt Enable Register          |
| 4001 E034h                 | EP0_LENGTH                            | EP0 OUT Data Length Register           |
| 4001 E038h                 | EP0_READ                              | EP0 Read Register                      |
| 4001 E03Ch                 | EP0_WRITE                             | EP0 Write Register                     |
| 4001 E040h + 20h × (m - 1) | $EP[m]$ _CONTROL (m = 115)            | EP[m] Control Register                 |
| 4001 E044h + 20h × (m - 1) | $EP[m]_STATUS (m = 115)$              | EP[m] Status Register                  |
| 4001 E048h + 20h × (m - 1) | EP[m]_INT_ENA (m = 115)               | EP[m] Interrupt Enable Register        |
| 4001 E04Ch + 20h × (m - 1) | $EP[m]_DMA_CTRL (m = 115)$            | EP[m] DMA Control Register             |
| 4001 E050h + 20h × (m - 1) | EP[m]_PCKT_ADRS (m = 115)             | EP[m] MaxPacket & BaseAddress Register |
| 4001 E054h + 20h × (m − 1) | $EP[m]_{LEN_{DCNT}}$ (m = 115)        | EP[m] Length & DMA Count Register      |
| 4001 E058h + 20h × (m - 1) | EP[m]_READ (m = 115)                  | EP[m] Read Register                    |
| 4001 E05Ch + 20h × (m − 1) | EP[m]_WRITE (m = 115)                 | EP[m] Write Register                   |
|                            | · · · · · · · · · · · · · · · · · · · | · · · · · · · · · · · · · · · · · · ·  |

## 10.4.8 AHB-EPC Bridge Register Map

Table 10.8 USB FC-AHBEPC Register Map

| Address                    | Register Symbol   | Register Name                                |
|----------------------------|-------------------|----------------------------------------------|
| 4001 F000h                 | AHBSCTR           | AHB Slave Controller Configuration Register  |
| 4001 F004h                 | AHBMCTR           | AHB Master Controller Configuration Register |
| 4001 F008h                 | AHBBINT           | AHB-EPC Bridge Interrupt Source Register     |
| 4001 F00Ch                 | AHBBINTEN         | AHB-EPC Bridge Interrupt Enable Register     |
| 4001 F010h                 | EPCTR             | EPC and Transceiver Control Register         |
| 4001 F020h                 | USBSSVER          | USBf Version Register                        |
| 4001 F024h                 | USBSSCONF         | Endpoint Configuration Register              |
| 4001 F110h + 10h × (m − 1) | EP[m]DCR1 (m=115) | Endpoint[m] DMA Setting Register1            |
| 4001 F114h + 10h × (m − 1) | EP[m]DCR2 (m=115) | Endpoint[m] DMA Setting Register2            |
| 4001 F118h + 10h × (m - 1) | EP[m]TADR (m=115) | Endpoint[m] DMA Start Address Register       |

## 10.5 Register Description

## 10.5.1 OHCI Operation Register Description

## 10.5.1.1 HCREVISION — HcRevision Register

Address: 4002 0000h



Table 10.9 HCREVISION Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                               | R/W |
|--------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b8    | Reserved |                                                                                                                                                                        | R   |
| b7 to b0     | REVISION | The version of the HCI Specification implemented in this host controller.  These bits show 10h, which indicates that this host controller is compliant with OHCI 1.0a. | R   |

## 10.5.1.2 HCCONTROL — HcControl Register

Address: 4002 0004h



Table 10.10 HCCONTROL Register Contents (1/2)

| Table 10.10  | HCCONTROL Register Contents (1/2) |                                                                                                                                                                                                                                                                                                                                            |      |
|--------------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| Bit Position | Bit Name                          | Function                                                                                                                                                                                                                                                                                                                                   | R/W  |
| b31 to b11   | Reserved                          |                                                                                                                                                                                                                                                                                                                                            | R    |
| b10          | RWE                               | Remote Wakeup Enable  If this bit is 1b, PME is asserted when bit 3 (RD) of the HcInterruptStatus register is                                                                                                                                                                                                                              | R/W  |
|              |                                   | 1b.                                                                                                                                                                                                                                                                                                                                        |      |
|              |                                   | 0: PME is not asserted when Resume is detected. (PME disabled)                                                                                                                                                                                                                                                                             |      |
|              |                                   | 1: PME is asserted when Resume is detected. (PME enabled).                                                                                                                                                                                                                                                                                 |      |
| b9           | RWC                               | Remote WakeUp Connect.                                                                                                                                                                                                                                                                                                                     | R/W  |
|              |                                   | Set this bit during initialization if the system supports Remote WakeUp.                                                                                                                                                                                                                                                                   |      |
|              |                                   | 0: Remote WakeUp is not supported                                                                                                                                                                                                                                                                                                          |      |
|              |                                   | 1: Remote WakeUp is supported.                                                                                                                                                                                                                                                                                                             |      |
| b8           | IR                                | Interrupt Routing.                                                                                                                                                                                                                                                                                                                         | R/W  |
|              |                                   | Specify the path to report a generated interrupt source to the HcInterruptStatus register. Use this bit with the initial value because this module does not support SMI.                                                                                                                                                                   |      |
|              |                                   | 0: INTA                                                                                                                                                                                                                                                                                                                                    |      |
|              |                                   | 1: SMI (not available)                                                                                                                                                                                                                                                                                                                     |      |
| b7, b6       | HCFS                              | Host Controller Functional State.                                                                                                                                                                                                                                                                                                          | R/W  |
|              |                                   | When the host controller enters the USB operational state, it starts managing frames split into 1 ms. This state is always controlled by software except when moving from the USB suspend state to the USB resume state triggered by Remote WakeUp. This bit is set to 00b when a hardware reset ends, and 11b when a software reset ends. |      |
|              |                                   | 00b: USB reset 01b: USB resume                                                                                                                                                                                                                                                                                                             |      |
|              |                                   | 10b: USB operational                                                                                                                                                                                                                                                                                                                       |      |
|              |                                   | 11b: USB suspend.                                                                                                                                                                                                                                                                                                                          |      |
| b5           | BLE                               | Bulk List Enable.                                                                                                                                                                                                                                                                                                                          | R/W  |
| 50           | BEE                               | Specify whether to process the bulk list. The setting of this bit is applied from the next frame. When correcting the bulk list, this bit must be 0b.                                                                                                                                                                                      | 1000 |
|              |                                   | 0: Do not process the bulk list                                                                                                                                                                                                                                                                                                            |      |
|              |                                   | 1: Process the bulk list.                                                                                                                                                                                                                                                                                                                  |      |
| b4           | CLE                               | Control List Enable.                                                                                                                                                                                                                                                                                                                       | R/W  |
|              |                                   | Specify whether to process the control list. The setting of this bit is applied from the next frame. When correcting the control list, this bit must be 0b.                                                                                                                                                                                |      |
|              |                                   | 0: Do not process the control list                                                                                                                                                                                                                                                                                                         |      |
|              |                                   | 1: Process the control list.                                                                                                                                                                                                                                                                                                               |      |

Table 10.10 HCCONTROL Register Contents (2/2)

| Bit Position | Bit Name | Function                                                                                                                                                                                                               | R/W |
|--------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b3           | IE       | Isochronous Enable.                                                                                                                                                                                                    | R/W |
|              |          | Specify whether to process the isochronous ED list. The setting of this bit is applied from the next frame. Specify whether to process the isochronous ED list when an isochronous ED is found during list processing. |     |
|              |          | 0: Do not process Isochronous transfer                                                                                                                                                                                 |     |
|              |          | 1: Process Isochronous transfer.                                                                                                                                                                                       |     |
| b2           | PLE      | Periodic List Enable.                                                                                                                                                                                                  | R/W |
|              |          | Specify whether to process the periodic frame list. The setting of this bit is applied from the next frame.                                                                                                            |     |
|              |          | 0: Do not process the periodic frame list,                                                                                                                                                                             |     |
|              |          | 1: Process the periodic frame list.                                                                                                                                                                                    |     |
| b1, b0       | CBSR     | Control Bulk Service Ratio.                                                                                                                                                                                            | R/W |
|              |          | Specify the service ratio between control and bulk EDs. When processing the periodic frame list, the ratio specified by this bit is held and used for transfer.                                                        |     |
|              |          | 00b: 1:1 = BulkED:ControlED                                                                                                                                                                                            |     |
|              |          | 01b: 2:1                                                                                                                                                                                                               |     |
|              |          | 10b: 3:1                                                                                                                                                                                                               |     |
|              |          | 11b: 4:1                                                                                                                                                                                                               |     |

## 10.5.1.3 HCCOMMANDSTATUS — HcCommandStatus Register

Address: 4002 0008h



Table 10.11 HCCOMMANDSTATUS Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | R/W |
|--------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b18   | Reserved |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R   |
| b17, b16     | SOC      | Scheduling Overrun Count.  Indicates the number of times a scheduling overrun has occurred. This bit is incremented each time a scheduling overrun is detected and reset to 00b when the count reaches 11b. This bit is incremented when a scheduling overrun is detected even if bit 0 (SO) in the HcInterruptStatus register has already been set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | R   |
| b15 to b4    | Reserved |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R   |
| b3           | OCR      | Ownership Change Request.  This bit is used to change ownership of the host controller.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R/W |
| b2           | BLF      | Bulk List Field.  Indicates whether a TD exists in a bulk list. The host controller checks this bit when starting processing of the first ED in the bulk list. The host controller does not start list processing if this bit is 0b. If this bit is 1b, the host controller starts bulk list processing and then sets the bit to 0b. When the host controller detects a TD in the list, it sets this bit to 1b again and continues bulk list processing. The host controller sets this bit to 0b when list processing finishes. If no TD has been found in the list or if this bit is not set to 1b by software, this bit remains 0b and list processing stops. When restructuring the list before executing list processing, set bit 5 (BLE) of the HcCommand register and set this bit before starting list processing.                  | R/W |
| b1           | CLF      | Control List Field.  Indicates whether a TD exists in a control list. The host controller checks this bit when starting processing of the first ED in the control list. The host controller does not start list processing if this bit is 0b. If this bit is 1b, the host controller starts control list processing and then sets the bit to 0b.  When the host controller detects a TD in the list, it sets this bit to 1b again and continues control list processing. The host controller sets this bit to 0b when list processing finishes. If no TD has been found in the list or if this bit is not set to 1b by software, this bit remains 0b and list processing stops.  When restructuring the list before executing list processing, set bit 4 (CLE) of the HcCommand register and set this bit before starting list processing. | R/W |
| b0           | HCR      | Host Controller Reset  This bit is used to trigger a software reset for the host controller. If this bit is set, the host controller enters the USB suspend state, regardless of its functional state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R/W |

## 10.5.1.4 HCINTERRUPTSTATUS — HcInterruptStatus Register

Address: 4002 000Ch



Table 10.12 HCINTERRUPTSTATUS Register Contents (1/2)

| Dit Desition |          | PTSTATUS Register Contents (1/2)                                                                                                                                                                                                                                                                                                                                                                        | DAM   |  |
|--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--|
| Bit Position | Bit Name | Function                                                                                                                                                                                                                                                                                                                                                                                                | R/W   |  |
| b31 to b7    | Reserved | Keep the initial value                                                                                                                                                                                                                                                                                                                                                                                  | R/W   |  |
| b6           | RHSC     | Root Hub Status Change.  This is an interrupt bit indicating that a setting of the HcRhStatus or HcRhPortStatus register has been changed. This bit is set when an HcRhStatus or HcRhPortStatus register setting has been changed by a hardware interrupt source. The interrupt source is cleared when this bit is set to 1b.  0: RHSC interrupt has not occurred  1: RHSC interrupt has occurred.      | R/W   |  |
| b5           | FNO      | Frame Number Overflow.                                                                                                                                                                                                                                                                                                                                                                                  | R/W   |  |
| 55           | TNO      | This is an interrupt bit indicating that the MSB of bits [15:0] (FrameNumber) of the HcFrameNumber register has been changed. This bit is set after HccaFrameNumber is updated for the frame in which the MSB of the FrameNumber bit changes from 0b to 1b or 1b to 0b. The interrupt source is cleared when this bit is set to 1b.  0: No FNO interrupt has occurred  1: An FNO interrupt has occurred | TO VV |  |
| b4           | UE       | Unrecoverable Error.                                                                                                                                                                                                                                                                                                                                                                                    | R/W   |  |
|              |          | This is an interrupt bit indicating that a system error not related to the USB has been detected on the PCI bus. The interrupt source is cleared when this bit is set to 1b.  0: UE interrupt has not occurred  1: UE interrupt has occurred.                                                                                                                                                           |       |  |
| b3           | RD       | Resume Detected                                                                                                                                                                                                                                                                                                                                                                                         | R/W   |  |
|              |          | This is an interrupt bit indicating that resume signaling has been detected. This bit is set when the host controller detects that a device on the USB is asserting resume signaling. This bit is not set when software asserts USB resume signaling. The interrupt source is cleared when this bit is set to 1b.  0: RD interrupt has not occurred 1: RD interrupt has occurred.                       |       |  |
| h0           | CE.      | ·                                                                                                                                                                                                                                                                                                                                                                                                       | DAM   |  |
| b2           | SF       | Start Of Frame  This is an interrupt bit indicating that HccaFrameNumber was updated when a frame started. The host controller updates HccaFrameNumber when the SOF packet is transmitted and then sets this bit. The interrupt source is cleared when this bit is set to 1b.                                                                                                                           | R/W   |  |
|              |          | 0: SF interrupt has not occurred.                                                                                                                                                                                                                                                                                                                                                                       |       |  |
|              |          | 1: SF interrupt has occurred.                                                                                                                                                                                                                                                                                                                                                                           |       |  |
| b1           | WDH      | Writeback Done Head This is an interrupt bit indicating that the host controller has updated the HccaDoneHead contents. The host controller sets this bit immediately after updating HccaDoneHead and does not update HccaDoneHead until it is cleared. The interrupt source is cleared when this bit is set to 1b.  0: WDH interrupt has not occurred 1: WDH interrupt has occurred.                   | R/W   |  |

Table 10.12 HCINTERRUPTSTATUS Register Contents (2/2)

| Bit Position | Bit Name | Function                                                                                                                                                                                                                                                                                                                                       | R/W |
|--------------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b0           | SO       | Scheduling Overrun.                                                                                                                                                                                                                                                                                                                            | R/W |
|              |          | This is an interrupt bit indicating that USB scheduling has overrun in a frame. This bit is set after HccaFrameNumber of the next frame is updated, when the USB schedule overruns. When this bit is set, bits [17:16] (SOC) of the HcCommandStatus register are also incremented. The interrupt source is cleared when this bit is set to 1b. |     |
|              |          | 0: SO interrupt has not occurred                                                                                                                                                                                                                                                                                                               |     |
|              |          | 1: SO interrupt has occurred.                                                                                                                                                                                                                                                                                                                  |     |

## 10.5.1.5 HCINTERRUPTENABLE — HcInterruptEnable Register

Address: 4002 0010h



Table 10.13 HCINTERRUPTENABLE Register Contents

| Bit Position | Bit Name | Function                                                                                  | R/W |
|--------------|----------|-------------------------------------------------------------------------------------------|-----|
| b31          | MIE      | Master Interrupt Enable                                                                   | R/W |
|              |          | Enable bit for bits [6:0] in this register. If this bit is 0b, all interrupts are masked. |     |
|              |          | Writing function is as follows.                                                           |     |
|              |          | 0: Ignored                                                                                |     |
|              |          | 1: Enable the specified interrupt                                                         |     |
| b30 to b7    | Reserved | Keep the initial value                                                                    | R/W |
| b6           | RHSCE    | Root Hub Status Change Enable. Writing function is as follows.                            | R/W |
|              |          | 0: Ignored                                                                                |     |
|              |          | 1: Enable the RHSC interrupt                                                              |     |
| b5           | FNOE     | Frame Number Overflow Enable. Writing function is as follows.                             | R/W |
|              |          | 0: Ignored                                                                                |     |
|              |          | 1: Enable the FNO interrupt                                                               |     |
| b4           | UEE      | Unrecoverable Error Enable. Writing function is as follows.                               | R/W |
|              |          | 0: Ignored                                                                                |     |
|              |          | 1: Enable the UE interrupt                                                                |     |
| b3           | RDE      | Resume Detected Enable. Writing function is as follows.                                   | R/W |
|              |          | 0: Ignored                                                                                |     |
|              |          | 1: Enable the RD interrupt                                                                |     |
| b2           | SFE      | Start Of Frame Enable. Writing function is as follows.                                    | R/W |
|              |          | 0: Ignored                                                                                |     |
|              |          | 1: Enable the SF interrupt                                                                |     |
| b1           | WDHE     | Writeback Done Head Enable. Writing function is as follows.                               | R/W |
|              |          | 0: Ignored                                                                                |     |
|              |          | 1: Enable the WDH interrupt                                                               |     |
| b0           | SOE      | Scheduling Overrun Enable. Writing function is as follows.                                | R/W |
|              |          | 0: Ignored                                                                                |     |
|              |          | 1: Enable the SO interrupt                                                                |     |

NOTE

The interrupt enable bits are cleared by writing 1b to the corresponding bit in the HcInterruptDisable register.

## 10.5.1.6 HCINTERRUPTDISABLE — HcInterruptDisable Register

Address: 4002 0014h



Table 10.14 HCINTERRUPTDISABLE Register Contents

| Bit Position | Bit Name | Function                                                                                                    | R/W |
|--------------|----------|-------------------------------------------------------------------------------------------------------------|-----|
| b31          | MID      | Master Interrupt Disable.                                                                                   | R/W |
|              |          | Disable bit for bits [6:0] in the HcInterruptEnable register. If this bit is 0b, all interrupts are masked. |     |
|              |          | Writing function is as follows.                                                                             |     |
|              |          | 0: Ignored                                                                                                  |     |
|              |          | 1: Disable the specified interrupt                                                                          |     |
| b30 to b7    | Reserved | Keep the initial value                                                                                      | R/W |
| b6           | RHSCD    | Root Hub Status Change Disable. Writing function is as follows.                                             | R/W |
|              |          | 0: Ignored                                                                                                  |     |
|              |          | 1: Disable the RHSC interrupt.                                                                              |     |
| b5           | FNOD     | Frame Number Overflow Disable. Writing function is as follows.                                              | R/W |
|              |          | 0: Ignored                                                                                                  |     |
|              |          | 1: Disable the FNO interrupt.                                                                               |     |
| b4           | UED      | Unrecoverable Error Disable. Writing function is as follows.                                                | R/W |
|              |          | 0: Ignored                                                                                                  |     |
|              |          | 1: Disable the UE interrupt                                                                                 |     |
| b3           | RDD      | Resume Detected Disable. Writing function is as follows.                                                    | R/W |
|              |          | 0: Ignored                                                                                                  |     |
|              |          | 1: Disable the RD interrupt                                                                                 |     |
| b2           | SFD      | Start Of Frame Disable. Writing function is as follows.                                                     | R/W |
|              |          | 0: Ignored                                                                                                  |     |
|              |          | 1: Disable the SF interrupt                                                                                 |     |
| b1           | WDHD     | Writeback Done Head Disable. Writing function is as follows.                                                | R/W |
|              |          | 0: Ignored                                                                                                  |     |
|              |          | 1: Disable the WDH interrupt                                                                                |     |
| b0           | SOD      | Scheduling Overrun Disable. Writing function is as follows.                                                 | R/W |
|              |          | 0: Ignore                                                                                                   |     |
|              |          | 1: Disable the SO interrupt                                                                                 |     |

## 10.5.1.7 HCHCCA — HcHCCA Register

Address: 4002 0018h

| Bit               | b31    | b30    | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|--------|--------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
|                   |        | HCHCCA |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Value after reset | 0      | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15    | b14    | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                   | HCHCCA |        |     |     |     |     |     |     | _   | _   | _   | _   | _   | _   | _   | _   |
| Value after reset | 0      | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 10.15 HCHCCA Register Contents

| Bit Position | Bit Name | Function                                                                                                                       | R/W |
|--------------|----------|--------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b8    | HCHCCA   | RAM base address setting for Host Controller Communication Area (HCCA) Set the value during an initialization.                 | R/W |
|              |          | The host controller requests allocation of a 256-byte area for HCCA starting from the base address specified by this register. |     |
| b7 to b0     | Reserved |                                                                                                                                | R   |

# 10.5.1.8 HCPERIODCURRENTED — HcPeriodicCurrentED Register

Address: 4002 001Ch



Table 10.16 HCPERIODCURRENTED Register Contents

| Bit Position | Bit Name | Function                                                                    | R/W |
|--------------|----------|-----------------------------------------------------------------------------|-----|
| b31 to b4    |          | Physical address of current ED in the periodic list.                        | R   |
|              | ED       | The host controller updates these bits when ED list processing is finished. |     |
| b3 to b0     | Reserved |                                                                             | R   |

## 10.5.1.9 HCCONTROLHEADED — HcControlHeadED Register

Address: 4002 0020h

| Bit               | b31           | b30           | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|---------------|---------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
|                   |               | CONTROLHEADED |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Value after reset | 0             | 0             | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15           | b14           | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                   | CONTROLHEADED |               |     |     |     |     |     |     |     |     |     |     | _   | _   | _   | _   |
| Value after reset | 0             | 0             | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 10.17 HCCONTROLHEADED Register Contents

| Bit Position | Bit Name      | Function                                                                                                                                                 | R/W |
|--------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b4    | CONTROLHEADED | Physical address of the first ED in the control list.  To execute a control transfer, set this bit before setting bit 4 (CLE) of the HcControl register. | R/W |
| b3 to b0     | Reserved      |                                                                                                                                                          | R   |

## 10.5.1.10 HCCONTROLCURRENTED — HcControlCurrentED Register

**Address:** 4002 0024h



Table 10.18 HCCONTROLCURRENTED Register Contents

| Bit Position | Bit Name             | Function                                                                                                                                                                                                                                                                                                                                                            | R/W |
|--------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b4    | CONTROLCURRENT<br>ED | Physical address of the current ED in the control list.  The host controller updates this bit each time control ED list processing finishes.  When structuring a new list, set this bit to 00000000h, which means the end of the list.  Make sure that the ED pointed to by the link pointer of this field actually exists when suspending and resuming a transfer. | R/W |
| b3 to b0     | Reserved             |                                                                                                                                                                                                                                                                                                                                                                     | R   |

## 10.5.1.11 HCBULKHEADED — HcBulkHeadED Register

Address: 4002 0028h

| Bit               | b31        | b30        | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|------------|------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
|                   |            | BULKHEADED |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Value after reset | 0          | 0          | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15        | b14        | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                   | BULKHEADED |            |     |     |     |     |     |     |     |     |     |     | _   | _   | _   | _   |
| Value after reset | 0          | 0          | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 10.19 HCBULKHEADED Register Contents

| Bit Position | Bit Name   | Function                                                                                                                                   | R/W |
|--------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b4    | BULKHEADED | Physical address of the first ED in the bulk list.  To execute a bulk transfer, set these bits before setting bit 5 (BLE) of the HcControl | R/W |
| b3 to b0     | Reserved   | register.                                                                                                                                  | R   |

## 10.5.1.12 HCBULKCURRENTED — HcBulkCurrentED Register

Address: 4002 002Ch



Table 10.20 HCBULKCURRENTED Register Contents

| Bit Position | Bit Name      | Function                                                                                                                                                                                                                                                                                                                                                         | R/W |
|--------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b4    | BULKCURRENTED | Physical address of the current ED in the bulk list.  The host controller updates this bit each time bulk ED list processing finishes. When structuring a new list, set this bit to 00000000h, which means the end of the list. Make sure that an ED which is pointed by the link pointer of these bits actually exists when it suspends and resumes a transfer. | R/W |
| b3 to b0     | Reserved      |                                                                                                                                                                                                                                                                                                                                                                  | R   |

# 10.5.1.13 HCDONEHEAD — HcDoneHead Register

Address: 4002 0030h



Table 10.21 HCDONEHEAD Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                  | R/W |
|--------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b4    | DONEHEAD | Physical address of HcDoneHead in the host controller.  This field shows the physical address of the TD that was added to a Done queue and finished last. | R   |
| b3 to b0     | Reserved |                                                                                                                                                           | R   |

# 10.5.1.14 HCFMINTERVAL — HcFrameInterval Register

Address: 4002 0034h



Table 10.22 HCFMINTERVAL Register Contents

| Dit Docition | Dit Nama | Function                                                                                                                                                                                                                                                                                                                          | DAM |
|--------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Bit Position | Bit Name | Function                                                                                                                                                                                                                                                                                                                          | R/W |
| b31          | FIT      | Frame Interval Toggle.                                                                                                                                                                                                                                                                                                            | R/W |
|              |          | Use this bit to synchronize the frame value between the software and the host controller. This bit should be toggled by software when it updates FI bit.                                                                                                                                                                          |     |
|              |          | When loading FI bits, the host controller reflects FIT value to bit 31 (FRT) of the HcFrameRemaining register. Software compares the value of this bit specified when writing a value to FI bits with the read FRT bit to confirm that the new FI bits value has been reflected.                                                  |     |
| b30 to b16   | FSMPS    | FS Largest Data Packet.                                                                                                                                                                                                                                                                                                           | R/W |
|              |          | Specify the maximum size of data that can be transmitted or received without causing a scheduling overrun. The host controller compares the current frame position with the specified value to determine up to which part of a frame can be transferred. The value is set by software, because it depends on system bus capacity. |     |
| b15, b14     | Reserved |                                                                                                                                                                                                                                                                                                                                   | R   |
| b13 to b0    | FI       | Frame Interval.                                                                                                                                                                                                                                                                                                                   | R/W |
|              |          | Specify the frame length (bit time) for FS transfer.                                                                                                                                                                                                                                                                              |     |
|              |          | Set 2EDFh to satisfy one frame (= 1 ms) as defined in the USB specification                                                                                                                                                                                                                                                       |     |

# 10.5.1.15 HCFMREMAINING — HcFrameRemaining Register

Address: 4002 0038h



Table 10.23 HCFMREMAINING Register Contents

| Bit Position                | Bit Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | R/W |  |
|-----------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|
| Us<br>co<br>bit<br>co<br>co |          | Frame Remaining Toggle.  Use this bit to synchronize the frame value between the software and the host controller. When the FR bits are set to 0000h, the host controller copies the value of bits [13:0] (FI) of the HcFrameInterval register to the FR bits, and at the same time, copies the value of bit 31 (FIT) of the HcFrameInterval register to this bit. Software compares the value of the FIT bits with the value of this FRT bit to confirm that the new FI bit value has been applied to the FR bits. | R   |  |
| b30 to b14                  | Reserved |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R   |  |
| b13 to b0                   | FR       | Frame Remaining.  14-bit down counter that shows the current frame value. As time passes, the value of this bit is decremented. When the count reaches 0000h, the frame value is reloaded. The host controller then copies the value of bits [13:0] (FI) of the HcFrameInterval register to this bit, and counting down starts again.                                                                                                                                                                               | R   |  |

# 10.5.1.16 HCFMNUMBER — HcFrameNumber Register

**Address:** 4002 003Ch



Table 10.24 HCFMNUMBER Register Contents

| Bit Position | Bit Name    | Function | R/W |  |  |
|--------------|-------------|----------|-----|--|--|
| b31 to b16   | Reserved    |          | R   |  |  |
| b15 to b0    | FRAMENUMBER |          |     |  |  |

## 10.5.1.17 HCPERIODICSTART — HcPeriodicStart Register

Address: 4002 0040h



Table 10.25 HCPERIODICSTART Register Contents

| Bit Position | Bit Name      | Function                                                                                                                                                                                                                                                                                                                                                                        | R/W |
|--------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b14   | Reserved      |                                                                                                                                                                                                                                                                                                                                                                                 | R   |
| b13 to b0    | PERIODICSTART | The time when the host controller starts periodic frame list processing within a frame. Specify a value for these bits by using software during host controller initialization. If the value of bits [13:0] (FR) of the HcFrameRemaining register is larger than the value specified for these bits, the non-periodic frame list takes precedence over the periodic frame list. | R/W |
|              |               | The OHCI standard recommends the value of this field to be about 90% of the value of bits [13:0] (FI) of the HcFrameInterval register. Therefore, the recommended value is 2A2Fh.                                                                                                                                                                                               |     |

# 10.5.1.18 HCLSTHRESHOLD — HcLSThreshold Register

Address: 4002 0044h



Table 10.26 HCLSTHRESHOLD Register Contents

| Bit Position | Bit Name      | Function                                                                                                                                                                                                                                   | R/W |
|--------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b12   | Reserved      |                                                                                                                                                                                                                                            | R   |
| b11 to b0    | HCLSTHRESHOLD | These bits are used to make a threshold value which shows whether a transferring is possible in comparison with remaining frame time in a LS transfer.  A LS transfer can be started when the FmRemaining value is larger than this value. | R/W |

# 10.5.1.19 HCRHDESCRIPTORA — HcRhDescriptorA Register

Address: 4002 0048h



Table 10.27 HCRHDESCRIPTORA Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                                                                                                                                                                                                                           | R/W |
|--------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | POTPGT   | Power On To Power Good Time.  Indicates the time software has to wait to access after the root hub port is turned on.                                                                                                                                                                                                                                              | R/W |
| h00 to h10   | Doggrand | The time is shown in 2 ms units. Therefore, the wait time is POTPGT x 2 ms.                                                                                                                                                                                                                                                                                        | R   |
| b23 to b13   | Reserved | Should be 0 at writing.                                                                                                                                                                                                                                                                                                                                            |     |
| b12          | NOCP     | No Over Current Protection.                                                                                                                                                                                                                                                                                                                                        | R/W |
|              |          | Specify whether to support the overcurrent status on the root hub port.                                                                                                                                                                                                                                                                                            |     |
|              |          | 0: Support overcurrent status                                                                                                                                                                                                                                                                                                                                      |     |
|              |          | 1: Not support overcurrent status.                                                                                                                                                                                                                                                                                                                                 |     |
| b11          | OCPM     | Over Current Protection Mode.                                                                                                                                                                                                                                                                                                                                      | R/W |
|              |          | Specify how the overcurrent status on the root hub port is reported. This bit must reflect the mode specified for the PSM bit. This bit is valid only when the NOCP bit is cleared.                                                                                                                                                                                |     |
|              |          | 0: The overcurrent status is reported for all ports                                                                                                                                                                                                                                                                                                                |     |
|              |          | 1: The overcurrent status is reported on a per-port basis.                                                                                                                                                                                                                                                                                                         |     |
| b10          | DT       | Device Type.                                                                                                                                                                                                                                                                                                                                                       | R   |
|              |          | Indicates that the root hub is not a compound device. Because the root hub is not permitted to be a compound device, this bit is always read as 0b.                                                                                                                                                                                                                |     |
| b9           | NPS      | No Power Switching.                                                                                                                                                                                                                                                                                                                                                | R/W |
|              |          | Specify how to control the port power.                                                                                                                                                                                                                                                                                                                             |     |
|              |          | 0: The power can be switched on or off                                                                                                                                                                                                                                                                                                                             |     |
|              |          | 1: The power remains on while the host controller is operating.                                                                                                                                                                                                                                                                                                    |     |
| b8           | PSM      | Power Switching Mode.                                                                                                                                                                                                                                                                                                                                              | R/W |
|              |          | Specify how to control the power switch for each port off the root hub. If bits [18:17] (PPCM) of the HcRhDescriptorB register are set, each port responds to port power commands (Set/ClearPortPower) only. If the bits are cleared, each port is controlled by the global power switch Set/ClearGlobalPower. This bit is valid only when the NPS bit is cleared. |     |
|              |          | 0: All ports are powered at the same time                                                                                                                                                                                                                                                                                                                          |     |
|              |          | 1: Each port is powered individually.                                                                                                                                                                                                                                                                                                                              |     |
| b7 to b0     | NDP      | Number Downstream Port.                                                                                                                                                                                                                                                                                                                                            | R   |
|              |          | Specify the number of downstream ports supported by the root hub in the host controller.                                                                                                                                                                                                                                                                           |     |
|              |          | 01h: 1-Host mode                                                                                                                                                                                                                                                                                                                                                   |     |
|              |          | 02h: 2-Host mode                                                                                                                                                                                                                                                                                                                                                   |     |

# 10.5.1.20 HCRHDESCRIPTORB — HcRhDescriptorB Register

Address: 4002 004Ch



Table 10.28 HCRHDESCRIPTORB Register Contents

| Bit Position | Bit Name | Function                                                                                                         | R/W |  |
|--------------|----------|------------------------------------------------------------------------------------------------------------------|-----|--|
| b31 to b19   | Reserved |                                                                                                                  | R   |  |
| b18, b17     | PPCM     | Port Power Control Mask.                                                                                         | R/W |  |
|              |          | Power control command (Set/ClearGlobalPower) setting bit. Bit 17 $\rightarrow$ port1, Bit18 $\rightarrow$ port2. |     |  |
|              |          | This bit is valid when bit 8 (PSM) of the HcRhDescriptorA register is set.                                       |     |  |
|              |          | 0: All ports are controlled                                                                                      |     |  |
|              |          | 1: Only a corresponding port is controlled                                                                       |     |  |
|              |          | Value after reset 01b: 1-Host mode, 11b: 2-Host mode                                                             |     |  |
| b16 to b3    | Reserved |                                                                                                                  | R   |  |
| b2, b1       | DR       | Device Removable.                                                                                                | R/W |  |
|              |          | Indicates whether each root hub port is removable. Bit 1 $\rightarrow$ port1, Bit2 $\rightarrow$ port2.          |     |  |
|              |          | 0: Not Removable                                                                                                 |     |  |
|              |          | 1: Removable                                                                                                     |     |  |
| b0           | Reserved |                                                                                                                  | R   |  |

# 10.5.1.21 HCRHSTATUS — HcRhStatus Register

Address: 4002 0050h

| Bit               | b31                  | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17  | b16                  |
|-------------------|----------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|------|----------------------|
|                   | CRWE                 | _   |     |     |     |     | ı   |     | ı   | ı   | ı   | ı   |     | l   | OCIC | R_LPS<br>CW_<br>SGP  |
| Value after reset | 0                    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0                    |
| Bit               | b15                  | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1   | b0                   |
|                   | R_DRW<br>EW_<br>SRWE | _   |     |     |     |     | l   |     | l   | l   | l   | l   |     | l   | OCI  | R_LPS_<br>_W_CG<br>P |
| Value after reset | 0                    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0                    |

| Table 10.29  | HCRHSTATUS Register Contents (1/2) |                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                        |                                                           |     |  |  |  |
|--------------|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-----------------------------------------------------------|-----|--|--|--|
| Bit Position | Bit Name                           | Function                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                        |                                                           | R/W |  |  |  |
| b31          | CRWE                               |                                                                                                                                                                                                                                                                                                                                                         | oit to clear                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | eup Enable<br>the DRWE | bit. Setting this bit clears the DRWE bit. Writing 0b has | W   |  |  |  |
| b30 to b18   | Reserved                           | Should b                                                                                                                                                                                                                                                                                                                                                | e 0 at writii                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ng.                    |                                                           | R   |  |  |  |
| b17          | OCIC                               | Over Current Indicate Change. Indicates that the OCI bit setting has changed. This bit is set when the OCI bit setting has changed. If 1b is written to this bit when it is already 1b, this bit is cleared. Writing 0b has no effect.  0: The overcurrent status has not changed 1: The overcurrent status has changed.                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                        |                                                           |     |  |  |  |
| b16          | R_LPSCW_SGP                        | [On Read] Local Power Status Change.  Because the local power status feature is not supported, this bit is always read as 0b.  [On Write] Set Global Power.  When this bit is set to 1b, ports are turned on. bit 8 (PSM) of the HcRhDescriptorA register and bits [18:17] (PPCM) of the HcRhDescriptorB register defines which port will be turned on. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                        |                                                           |     |  |  |  |
|              |                                    | Value                                                                                                                                                                                                                                                                                                                                                   | PSM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | PPCM[1:0]              | Note                                                      |     |  |  |  |
|              |                                    | 0                                                                                                                                                                                                                                                                                                                                                       | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | _                      | No Change                                                 |     |  |  |  |
|              |                                    | 1                                                                                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | _                      | PPS in HcRhPortStatus1/HcRhPortStatus2 are set            |     |  |  |  |
|              |                                    |                                                                                                                                                                                                                                                                                                                                                         | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 00b                    | PPS in HcRhPortStatus1/HcRhPortStatus2 are set            |     |  |  |  |
|              |                                    |                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 10b                    | PPS in HcRhPortStatus1 are set                            |     |  |  |  |
|              |                                    |                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 01b                    | PPS in HcRhPortStatus2 are set                            |     |  |  |  |
|              |                                    |                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 11b                    | No Change                                                 |     |  |  |  |
| b15          | R_DRWEW_SRW<br>E                   | Specify w<br>register a<br>bit is set,<br>a Resum<br>0: Cor<br>1: Cor<br>[On Write                                                                                                                                                                                                                                                                      | [On Read] Device Remote Wakeup Enable.  Specify whether to include a source specified by bit 16 (CSC) of the HcRhPortStatus1 register as a remote wakeup event. If a ConnectStatusChange event occurs while this bit is set, the operating status changes from USB Suspend to USB Resume, and then a Resume Detect interrupt occurs.  0: ConnectStatusChange is not a Remote Wakeup event 1: ConnectStatusChange is a Remote Wakeup event.  [On Write] Set Remote Wakeup Enable.  Use this bit to set the DRWE bit. Setting this bit sets the DRWE bit. Writing 0b has no |                        |                                                           |     |  |  |  |
| b14 to b2    | Reserved                           | Oncot.                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                        |                                                           | R   |  |  |  |

Table 10.29 HCRHSTATUS Register Contents (2/2)

| Bit Position | Bit Name   | Function                                                                                                                                                                                        | R/W |
|--------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b1           | OCI        | Over Current Indicator.                                                                                                                                                                         | R   |
|              |            | Indicates the overcurrent status in global overcurrent detection mode. If per-port overcurrent protection is specified, this bit is always 0b.                                                  |     |
|              |            | 0: The port is normal                                                                                                                                                                           |     |
|              |            | 1: The port is in the overcurrent state                                                                                                                                                         |     |
| b0           | R_LPSW_CGP | [On Read] Local Power Status.                                                                                                                                                                   | R/W |
|              |            | Because the local power status feature is not supported, this bit is always read as 0b.                                                                                                         |     |
|              |            | [On Write] Clear Global Power.                                                                                                                                                                  |     |
|              |            | When this bit is set to 1b, ports are turned off. Which port is turned on is determined by bit 8 (PSM) of the HcRhDescriptorA register and bits [18:17] (PPCM) of the HcRhDescriptorB register. |     |

# 10.5.1.22 HCRHPORTSTATUS1/ HCRHPORTSTATUS2 — HcRhPortStatus1/ HcRhPortStatus2 Register

Address: HCRHPORTSTATUS1: 4002 0054h

HCRHPORTSTATUS2: 4002 0058h



Table 10.30 HCRHPORTSTATUS1/ HCRHPORTSTATUS2 Register Contents (1/3)

| Bit Position | Bit Name | Function                                                                                                                                                                                                                                                                                                                                                                                                                             | R/W |
|--------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b21   | Reserved | Should be 0 at writing.                                                                                                                                                                                                                                                                                                                                                                                                              | R   |
| b20          | PRSC     | Port Reset Status Change.                                                                                                                                                                                                                                                                                                                                                                                                            | R/W |
|              |          | Indicates the end of a port reset. The host controller set this bit when a 10 ms hardware reset finishes. When the software sets this bit to 1b, this bit is cleared.  0: The port reset has not finished or PRS has not changed                                                                                                                                                                                                     |     |
|              |          | 1: The port reset has finished.                                                                                                                                                                                                                                                                                                                                                                                                      |     |
| b19          | OCIC     | Over Current Indicate Change.                                                                                                                                                                                                                                                                                                                                                                                                        | R/W |
|              |          | Indicates that a port has been detected in the overcurrent state. This bit is valid when reporting the overcurrent state on a per-port basis is specified (OCPM of HcRhDescriptorA register = 1). When the software sets this bit to 1b, this bit is cleared.                                                                                                                                                                        |     |
|              |          | 0: The overcurrent status has not changed                                                                                                                                                                                                                                                                                                                                                                                            |     |
|              |          | 1: The overcurrent status has changed.                                                                                                                                                                                                                                                                                                                                                                                               |     |
| b18          | PSSC     | Port Suspend Status Change.                                                                                                                                                                                                                                                                                                                                                                                                          | R/W |
|              |          | Indicates the end of a resume sequence. This bit is set when all resume processing by hardware has finished. When the software sets this bit to 1b, this bit is cleared. This bit is also cleared when the PRSC bit is set.                                                                                                                                                                                                          |     |
|              |          | 0: Resume processing has not finished                                                                                                                                                                                                                                                                                                                                                                                                |     |
|              |          | 1: Resume processing has finished.                                                                                                                                                                                                                                                                                                                                                                                                   |     |
| b17          | PESC     | Port Enable Status Change.                                                                                                                                                                                                                                                                                                                                                                                                           | R/W |
|              |          | Indicates that the PES bit setting has changed. This bit is set when the port status has changed due to a hardware event such as an overcurrent state, disconnection, power off, or babble error. When the software sets this bit to 1b, this bit is cleared.  0: The PES status has not changed                                                                                                                                     |     |
|              |          | 1: The PES status has changed.                                                                                                                                                                                                                                                                                                                                                                                                       |     |
| b16          | CSC      | Connect Status Change.                                                                                                                                                                                                                                                                                                                                                                                                               | R/W |
|              |          | Indicates that the CCS bit setting has changed. The host controller sets this bit when the CCS changes when a device is connected or disconnected. The host controller also sets this bit when a request such as port reset, port suspend, and port enable is received when a device is being disconnected, in order to make software re-evaluate the device connection. When the software sets this bit to 1b, this bit is cleared. |     |
|              |          | 0: CCS status has not changed                                                                                                                                                                                                                                                                                                                                                                                                        |     |
|              |          | 1: CCS status has changed.                                                                                                                                                                                                                                                                                                                                                                                                           |     |
| b15 to b10   | Reserved |                                                                                                                                                                                                                                                                                                                                                                                                                                      | R   |

Table 10.30 HCRHPORTSTATUS1/ HCRHPORTSTATUS2 Register Contents (2/3)

| Bit Position | Bit Name    | Function                                                                                                                                                                                                                                                                                                                                                                                        | R/W |
|--------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b9           | R_LSDAW_CPP | Read: Low Speed Device Attached. Indicates the speed of the device connected to the port. This bit is valid when the CCS bit is set.  0: FS device 1: LS device. Write: Clear Port Power.                                                                                                                                                                                                       | R/W |
|              |             | Use this bit to turn off the port power when power control on a per-port basis is specified. The port power is turned off by writing 1b. Writing 0b has no effect.                                                                                                                                                                                                                              |     |
| b8           | R_PPSW_SPP  | Read: Port Power Status.                                                                                                                                                                                                                                                                                                                                                                        | R/W |
|              |             | Indicates the port power status. This bit is cleared when an overcurrent is detected.                                                                                                                                                                                                                                                                                                           |     |
|              |             | 0: Port power is off                                                                                                                                                                                                                                                                                                                                                                            |     |
|              |             | 1: Port power is on.                                                                                                                                                                                                                                                                                                                                                                            |     |
|              |             | Write: Set Port Power.                                                                                                                                                                                                                                                                                                                                                                          |     |
|              |             | Use this bit to turn on the port power when power control on a per-port basis is specified. The port power is turned on by writing 1b. Writing 0b has no effect.                                                                                                                                                                                                                                |     |
| b7 to b5     | Reserved    |                                                                                                                                                                                                                                                                                                                                                                                                 | R   |
| b4           | R_PRSW_SPR  | Read: Port Reset Status.                                                                                                                                                                                                                                                                                                                                                                        | R/W |
|              |             | Indicates the port reset status. This bit is cleared when the PRSC bit is set on completion of a 10 ms port reset. When the CCS bit is cleared (device disconnected), this bit cannot be set.                                                                                                                                                                                                   |     |
|              |             | 0: Port reset not performed                                                                                                                                                                                                                                                                                                                                                                     |     |
|              |             | 1: Port reset in progress                                                                                                                                                                                                                                                                                                                                                                       |     |
|              |             | Write: Set Port Reset.                                                                                                                                                                                                                                                                                                                                                                          |     |
|              |             | Use this bit to request a port reset for the downstream port. Writing 1b to this bit starts a 10 ms port reset. If this bit is written while the CCS bit is cleared, the PRS bit cannot be written. The host controller sets the CSC bit and reports to software that a reset was attempted on a port to which no device was connected. Writing 0b has no effect.                               |     |
| b3           | R_POCIW_CSS | Read: Port Over Current Indicator.                                                                                                                                                                                                                                                                                                                                                              | R/W |
|              |             | Indicates that an overcurrent has occurred on the downstream port. This bit is valid when reporting the overcurrent state on a per-port basis is specified (OCPM of HcRhDescriptorA register = 1). This bit is set to 0b when reporting the overcurrent state collectively for all ports is specified.                                                                                          |     |
|              |             | 0: The port is normal                                                                                                                                                                                                                                                                                                                                                                           |     |
|              |             | 1: The port is in the overcurrent state.                                                                                                                                                                                                                                                                                                                                                        |     |
|              |             | Write: Clear Suspend Status. Use this bit to end the suspend state and start the resume sequence. Writing 1b to this bit starts the resume sequence. Writing 0b has no effect. The resume sequence starts only when the PSS bit is set.                                                                                                                                                         |     |
| 02           | R_PSSW_SPS  | Read: Port Suspend Status.                                                                                                                                                                                                                                                                                                                                                                      | R/W |
|              |             | Indicates that a port is in the suspend state or the resume sequence has started. This bit is set by writing to the SPS bit. This bit cannot be set while the CCS bit is cleared (no device is connected). This bit is cleared at the following timing: - When the resume sequence finishes and the PSSC bit is set - When a port reset ends and the PRSC bit is set - In the USB Resume state: |     |
|              |             | 0: Port is used for transfer normally                                                                                                                                                                                                                                                                                                                                                           |     |
|              |             | 1: Port is in the suspend state.                                                                                                                                                                                                                                                                                                                                                                |     |
|              |             | Write: Set Port Suspend.                                                                                                                                                                                                                                                                                                                                                                        |     |
|              |             | Use this bit to shift the port to the suspend state. Writing 1b to this bit shifts the port to the suspend state. Writing 0b has no effect. If this bit is written while the CCS bit is cleared, the CSC bit is set to notify the driver that an attempt was made to suspend a disconnected port.                                                                                               |     |

Table 10.30 HCRHPORTSTATUS1/ HCRHPORTSTATUS2 Register Contents (3/3)

| Bit Position | Bit Name    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R/W |
|--------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b1           | R_PESW_SPE  | Read: Port Enable Status.  Indicates the port enable/disable status. The host controller clears this bit when an event such as the overcurrent state, disconnection, power off, and babble error is detected. The PESC bit is set at this time. This bit cannot be set while the CCS bit is cleared (no device is connected). This bit is set by the host controller when a port reset ends or the port suspend state ends.  0: Port is disabled  1: Port is enabled.  Write: Set Port Enable.  Use this bit to set the PES bit. Writing 1b to this bit enables ports. Writing 0b has no effect. Note: Shift the port state by using bit 4 (SPR) of the HcRhPortStatus1 register. The OHCI standard supports enabling ports by using the SPE bit, but the USB specification does not. | R/W |
| b0           | R_CCS_W_CPE | Read: Current Connect Status. Indicates the current status of connection on the downstream port.  0: No device is connected  1: A device is connected.  Write: Clear Port Enable.  Use this bit to clear the PES bit. Writing 1b to this bit disables ports. Writing 0b has no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | R/W |

# 10.5.2 EHCI Operation Register Description

# 10.5.2.1 CAPL\_VERSION — HCIVERSION and CAPLENGTH Register (EHCI)

Address: 4002 1000h



Table 10.31 CAPL\_VERSION Register Contents

| Bit Position | Bit Name                        | Function                                                                                                                                                     | R/W |
|--------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | INTERFACE_VERSI<br>ON_NUMBER    | Indicates the version of the EHCI Specification implemented in this host controller. "0100h" means this host controller is compliant with the EHCI Rev. 1.0. | R   |
| b15 to b8    | Reserved                        |                                                                                                                                                              | R   |
| b7 to b0     | CAPABILITY_REGIS<br>TERS_LENGTH | Indicates the start address of the host controller operational register.  "20h" means that operational registers are allocated from address 20h.             | R   |

## 10.5.2.2 HCSPARAMS — HCSPARAMS Register

Address: 4002 1004h



Table 10.32 HCSPARAMS Register Contents

| Bit Position | Bit Name               | Function                                                                                                                                                                                                              | R/W |
|--------------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved               |                                                                                                                                                                                                                       | R   |
| b23 to b20   | DEBUG_PORT_NUM<br>BER  | Indicates that the host controller ports are provided for debugging.  "0000b" means that there is no debugging port.                                                                                                  | R   |
| b19 to b17   | Reserved               |                                                                                                                                                                                                                       | R   |
| b16          | P_INDICATOR            | Indicates whether the host controller supports port indicator control.  "0b" means that this host controller does not support port indicator control.                                                                 | R   |
| b15 to b12   | N_CC                   | Indicates the number of OHCI host controllers related to the EHCI host controller.  "1b" means that one OHCI host controller is embedded.                                                                             | R   |
| b11 to b8    | N_PCC                  | Indicates the number of ports supported by one OHCI host controller.  This bit reflects the setting of bits [1:0] (PORT_NO) of the PCI Configuration EXT1 register.                                                   | R   |
| b7           | PORT_ROUTING_R<br>ULES | Indicates how each port is mapped on the OHCI host controller.  "1b" means that mapping is shown in the HCSP_PORTROUTE register.                                                                                      | R   |
| b6, b5       | Reserved               |                                                                                                                                                                                                                       | R   |
| b4           | PPC                    | Indicates how the host controller controls the port power.  This bit reflects the setting of bit 2 (PPCNT) of the PCI Configuration EXT1 register.  "1b" means that this USB subsystem supports power supply control. | R   |
| b3 to b0     | N_PORTS                | Indicates the number of physical downstream ports used in this USB subsystem.  This bit reflects the setting of bits [1:0] (PORT_NO) of the PCI Configuration EXT1 register.                                          | R   |

## 10.5.2.3 HCCPARAMS — HCCPARAMS Register

Address: 4002 1008h



Table 10.33 HCCPARAMS Register Contents

| Bit Position | Bit Name                                      | Function                                                                                                                                                                                                                                                                                  | R/W |
|--------------|-----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | Reserved                                      |                                                                                                                                                                                                                                                                                           | R   |
| b15 to b8    | EECP                                          | Indicates the offset address of the EHCI Extend Capabilities Registers. Indicates that an extend register is allocated to address E8h in the EHCI configuration space.                                                                                                                    | R   |
|              |                                               | Since the host controller does not support legacy features, these bits do not have a meaning.                                                                                                                                                                                             |     |
| b7 to b4     | ISOCHRONOUS_SC<br>HEDULING_THRESH<br>OLD      | "0b" means that the host controller does not support the isochronous data structure cache of the overall frame.                                                                                                                                                                           | R   |
| b3           | Reserved                                      |                                                                                                                                                                                                                                                                                           | R   |
| b2           | ASYNCHRONOUS_S<br>CHEDULE_PARK_C<br>APABILITY | Indicates whether Park mode for High Speed QH (Queue Head) in the asynchronous schedule is supported. "1b" means that the host controller supports the feature.                                                                                                                           | R   |
| b1           | PROGRAMMING_FR<br>AME_LIST_FLAG               | Indicates the setting for the frame list size that can be used by software. This bit shows 1b. If this bit is set to 1b, the usable frame list size can be specified by using bits [3:2] (FRAME_LIST_SIZE) of the USBCMD register. A frame list size of 4 KB or smaller can be specified. | R   |
| b0           | BIT64_ADDRESSING<br>_CAPABILITY               | Indicates whether the data structure uses memory pointers of 32-bit address or 64-bit address. This bit shows 0b, which indicates that the host controller supports the data structure that uses 32-bit address memory pointers. 64-bit address memory pointers are not supported.        | R   |

# 10.5.2.4 HCSP\_PORTROUTE — HCSP\_PORTROUTE Register

Address: 4002 100Ch

| Bit<br>r          | b31 | b30 | b29 | b28 | b27 | b26 | b25  | b24     | b23    | b22   | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|------|---------|--------|-------|-----|-----|-----|-----|-----|-----|
|                   |     |     |     |     |     |     | COMP | 'ANION_ | PORT_F | ROUTE |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0       | 0      | 0     | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9   | b8      | b7     | b6    | b5  | b4  | b3  | b2  | b1  | b0  |
|                   |     |     |     |     |     |     | COMP | 'ANION_ | PORT_F | ROUTE |     |     |     |     |     |     |
| Value after recet | Λ   | 0   | 0   | 0   | Λ   | Λ   | Λ    | Λ       | Λ      | Λ     | 0   | 0   | Λ   | Λ   | Λ   | 0   |

Table 10.34 HCSP\_PORTROUTE Register Contents

| Bit Position | Bit Name       | Function                                                                           | R/W |
|--------------|----------------|------------------------------------------------------------------------------------|-----|
| b31 to b0    | COMPANION_PORT | Indicates the port for which the OHCI host controller is responsible.              | R   |
|              | _ROUTE         | Since one OHCI controller is embedded in the host controller, these bits are ALLO. |     |

# 10.5.2.5 USBCMD — USBCMD Register

Address: 4002 1020h

| Bit               | b31 | b30 | b29 | b28 | b27                                                        | b26 | b25                              | b24             | b23                                         | b22    | b21    | b20    | b19    | b18           | b17         | b16 |
|-------------------|-----|-----|-----|-----|------------------------------------------------------------|-----|----------------------------------|-----------------|---------------------------------------------|--------|--------|--------|--------|---------------|-------------|-----|
|                   | ı   | _   | _   | _   | _                                                          | _   | _                                | _               |                                             | IN     | ΓERRUP | T_THRE | SHOLD  | _CONTR        | OL          |     |
| Value after reset | 0   | 0   | 0   | 0   | 0                                                          | 0   | 0                                | 0               | 0                                           | 0      | 0      | 0      | 1      | 0             | 0           | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11                                                        | b10 | b9                               | b8              | b7                                          | b6     | b5     | b4     | b3     | b2            | b1          | b0  |
|                   |     | _   | _   | _   | ASYNCH<br>RONOUS<br>_SCHED<br>ULE_PAR<br>K_MODE<br>_ENABLE | _   | ASYNC<br>US_SCH<br>_PARK_<br>COI | HEDULE<br>MODE_ | LIGHT_H<br>OST_CO<br>NTROLL<br>ER_RES<br>ET | SYNC_A | _SCHED | C_SCHE | FRAME. | _LIST_S<br>ĽE | HCRES<br>ET | RS  |
| Value after reset | 0   | 0   | 0   | 0   | 1                                                          | 0   | 1                                | 1               | 0                                           | 0      | 0      | 0      | 0      | 0             | 0           | 0   |

Table 10.35 USBCMD Register Contents (1/2)

| 1 4010 10.00 | OODOMD Register                                | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |     |
|--------------|------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Bit Position | Bit Name                                       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R/W |
| b31 to b24   | Reserved                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R   |
| b23 to b16   | INTERRUPT_THRES<br>HOLD_CONTROL                | Indicates the maximum rate until the host controller generates an interrupt. Setting a value other than those shown below is not guaranteed.  00h: Reserved 01h: 1 micro-frame 02h: 2 micro-frames 04h: 4 micro-frames 08h: 8 micro-frames (1 ms) 10h: 16 micro-frames (2 ms) 20h: 32 micro-frames (4 ms) 40h: 64 micro-frames (8 ms).                                                                                                                                                                                                                                                                                                                                                   | R/W |
| b15 to b12   | Reserved                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | R   |
| b11          | ASYNCHRONOUS_S<br>CHEDULE_PARK_M<br>ODE_ENABLE | Specify whether to enable or disable Park mode. 0: Disable 1: Enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | R/W |
| b10          | Reserved                                       | Should be 0 at writing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R   |
| b9, b8       | ASYNCHRONOUS_S<br>CHEDULE_PARK_M<br>ODE_COUNT  | Specify the number of transactions that can be executed successively from one QH (queue head). The valid setting value is 1h to 3h.  This bit is valid when bit 11  (ASYNCHRONOUS_SCHEDULE_PARK_MODE_ENABLE) is 1b.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W |
| b7           | LIGHT_HOST_CONT<br>ROLLER_RESET                | Indicates the status of executing a light host controller reset.  This bit is fixed to 0b because the host controller does not support light host controller reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W |
| b6           | INTERRUPT_ON_AS<br>YNC_ADVANCE_DO<br>ORBELL    | This bit is used by software as a doorbell.  This bit is set to 1b by software to generate an interrupt when advancing to the next QH (queue head) processing. When bit 5 (INTERRUPT_ON_ASYNC_ADVANCE_ENABLE) of the USBINTR register is 1b, an interrupt is generated at the first timing to generate an interrupt after this bit is set to 1.  Operation is not guaranteed if this bit is set while bit 5 (INTERRUPT_ON_ASYNC_ADVANCE_ENABLE) of the USBINTR register is 0b.  This bit is cleared by the host controller.  When one QH process is completed, the host controller clears this bit to 0b, and then sets bit 5 (INTERRUPT_ON_ASYNC_ADVANCE) of the USBSTS register to 1b. | R/W |

Table 10.35 USBCMD Register Contents (2/2)

| Bit Position | Bit Name        | Function                                                                                                                                                                                                                                                                                                                                                               | R/W |  |  |  |  |  |  |  |
|--------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|--|--|
| b5           | ASYNCHRONOUS_S  | Specify whether to continue or skip asynchronous list processing.                                                                                                                                                                                                                                                                                                      |     |  |  |  |  |  |  |  |
|              | CHEDULE_ENABLE  | 0: Do not continue (skip) asynchronous list processing                                                                                                                                                                                                                                                                                                                 |     |  |  |  |  |  |  |  |
|              |                 | <ol> <li>Continue (do not skip) asynchronous list processing by using the<br/>ASYNCLISTADDR register.</li> </ol>                                                                                                                                                                                                                                                       |     |  |  |  |  |  |  |  |
| b4           | PERIODIC_SCHEDU | Specify whether to continue or skip periodic list processing.                                                                                                                                                                                                                                                                                                          | R/W |  |  |  |  |  |  |  |
|              | LE_ENABLE       | 0: Do not continue (skip) periodic list processing                                                                                                                                                                                                                                                                                                                     |     |  |  |  |  |  |  |  |
|              |                 | 1: Continue (do not skip) periodic list processing by using the PERIODICLISTBASE register. This bit should be set to 1 in this controller.                                                                                                                                                                                                                             |     |  |  |  |  |  |  |  |
| b3, b2       | FRAME_LIST_SIZE | Specify the frame list size. The value set to this bit determines the size of the Frame List Current index in the FRINDEX register.                                                                                                                                                                                                                                    | R/W |  |  |  |  |  |  |  |
|              |                 | 00b: 1024 elements (4096 bytes)                                                                                                                                                                                                                                                                                                                                        |     |  |  |  |  |  |  |  |
|              |                 | 01b: 512 elements (2048 bytes)                                                                                                                                                                                                                                                                                                                                         |     |  |  |  |  |  |  |  |
|              |                 | 10b: 256 elements (1024 bytes)                                                                                                                                                                                                                                                                                                                                         |     |  |  |  |  |  |  |  |
|              |                 | 11b: Reserved.                                                                                                                                                                                                                                                                                                                                                         |     |  |  |  |  |  |  |  |
| b1           | HCRESET         | Host Controller Reset.                                                                                                                                                                                                                                                                                                                                                 | R/W |  |  |  |  |  |  |  |
|              |                 | Use this bit to initialize the host controller. If this bit is set to 1b, the host controller initializes the internal pipelines and state machines. Communication being performed on the USB stops immediately. At this time, USB reset signaling for the downstream port is not performed.                                                                           |     |  |  |  |  |  |  |  |
|              |                 | PCI configuration registers are not initialized by this reset, but EHCI operational registers are, and the port owner returns to the OHCI host controller.                                                                                                                                                                                                             |     |  |  |  |  |  |  |  |
|              |                 | The host controller resets this bit to 0b when the reset ends. Writing 0b to this bit by software cannot stop the reset.                                                                                                                                                                                                                                               |     |  |  |  |  |  |  |  |
|              |                 | Set this bit when bit 12 (HCHALTED) of the USBSTS register is 1b.                                                                                                                                                                                                                                                                                                      |     |  |  |  |  |  |  |  |
| b0           | RS              | Run/Stop.                                                                                                                                                                                                                                                                                                                                                              | R/W |  |  |  |  |  |  |  |
|              |                 | Use this bit to run and stop the EHCl host controller. If this bit is set to 1b, the host controller starts operating. The host controller continues operating while this bit is 1b. Set this bit to 1b when the host controller is in the halt state. Bit 12 (HCHALTED) of the USBSTS register indicates that the host controller finished a transaction and stopped. |     |  |  |  |  |  |  |  |
|              |                 | 0: Stop (The host controller finished a transaction and has halted.)                                                                                                                                                                                                                                                                                                   |     |  |  |  |  |  |  |  |
|              |                 | 1: Run (The host controller executes scheduling.)                                                                                                                                                                                                                                                                                                                      |     |  |  |  |  |  |  |  |

## 10.5.2.6 USBSTS — USBSTS Register

Address: 4002 1024h



Table 10.36 USBSTS Register Contents (1/2)

| Bit Name                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Dit Name                         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Reserved                         | Should be 0 at writing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| ASYNCHRONOUS_S<br>CHEDULE_STATUS | Indicates the current asynchronous scheduling status.  Asynchronous scheduling is enabled (1b) or disabled (0b) when the value of this bit and bit 5 (ASYNCHRONOUS_SCHEDULE_ENABLE) of the USBCMD register is the same.  0: Invalid 1: Valid                                                                                                                                                                                                                                                                                                                                                                                                    | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| PERIODIC_SCHEDU<br>LE_STATUS     | Indicates the current periodic scheduling status.  Periodic scheduling is enabled (1b) or disabled (0b) when the value of this bit and bit 4 (PERIODIC_SCHEDULE_ENABLE) of the USBCMD register is the same.  0: Invalid  1: Valid                                                                                                                                                                                                                                                                                                                                                                                                               | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| RECLAMATION                      | Use this bit to detect an empty asynchronous schedule. After a reset or when fetching a queue head in which $H=1b$ , the host controller clears this bit to 0b. The host controller sets this bit to 1b when executing an asynchronous transaction or when a trigger event has been detected. When a queue head with $H=1b$ is fetched while this bit is 0b, the host controller shifts to Async Sched Sleeping mode.                                                                                                                                                                                                                           | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| HCHALTED                         | This bit shows 0b when bit 0 (RS) of the USBCMD register is 1b. When the RS bit is set to 0b by the host controller or software, the EHCl host controller stops executing and this bit is set to 1b by the host controller.  0: EHCl host controller is running 1: EHCl host controller is in halt                                                                                                                                                                                                                                                                                                                                              | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Reserved                         | Should be 0 at writing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| INTERRUPT_ON_AS<br>YNC_ADVANCE   | Indicates the Async Advance interrupt status.  When a queue head is fetched, the host controller checks bit 6 (INTERRUPT_ON_ASYNC_ADVANCE_DOORBELL (IAAD)) of the USBCMD register. If the IAAD bit is 1b, the host controller clears the IAAD bit when processing of the queue head finishes and then sets this bit. If bit 5 (INTERRUPT_ON_ASYNC_ADVANCE_ENABLE) of the USBINTR register is 1b, an Async Advance interrupt is generated by this interrupt source at the first timing to generate an interrupt after this bit is set to 1b. Writing 1b by software clears this bit. Writing 0b has no effect.  0: No Async Advance has occurred | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                  | ASYNCHRONOUS_S CHEDULE_STATUS  PERIODIC_SCHEDU LE_STATUS  RECLAMATION  HCHALTED  Reserved INTERRUPT_ON_AS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ASYNCHRONOUS_S CHEDULE_STATUS  Asynchronous scheduling is enabled (1b) or disabled (0b) when the value of this bit and bit 5 (ASYNCHRONOUS_SCHEDULE_ENABLE) of the USBCMD register is the same.  O: Invalid 1: Valid  PERIODIC_SCHEDU LE_STATUS  Indicates the current periodic scheduling status.  Periodic scheduling is enabled (1b) or disabled (0b) when the value of this bit and bit 4 (PERIODIC_SCHEDULE_ENABLE) of the USBCMD register is the same. O: Invalid 1: Valid  RECLAMATION  RECLAMATION  We this bit to detect an empty asynchronous schedule.  After a reset or when fetching a queue head in which H = 1b, the host controller clears this bit to 0b. The host controller sets this bit to 1b when executing an asynchronous transaction or when a trigger event has been detected.  When a queue head with H = 1b is fetched while this bit is 0b, the host controller shifts to Async Sched Sleeping mode.  HCHALTED  This bit shows 0b when bit 0 (RS) of the USBCMD register is 1b. When the RS bit is set to 0b by the host controller or software, the EHCI host controller stops executing and this bit is set to 1b by the host controller.  O: EHCI host controller is running 1: EHCI host controller is in halt  Reserved  Indicates the Async Advance interrupt status.  When a queue head is fetched, the host controller checks bit 6 (INTERRUPT_ON_ASYNC_ADVANCE_DOORBELL (IAAD)) of the USBCMD register. If the IAAD bit is 1b, the host controller clears the IAAD bit when processing of the queue head finishes and then sets this bit. If bit 5 (INTERRUPT_ON_ASYNC_ADVANCE_ENABLE) of the USBINTR register is 1b, an Async Advance interrupt is generated by this interrupt source at the first tirning to generate an interrupt after this bit is set to 1b. Writing 1b by software clears this bit. Writing 0b has no effect. |

Table 10.36 USBSTS Register Contents (2/2)

| Bit Position | Bit Name Function       |                                                                                                                                                                                                                                                                                                                                                                                            |            |  |  |  |
|--------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--|--|--|
| b4           | HOST_SYSTEM_ER<br>ROR   | This bit is set to 1b when a serious error, such as a parity error in the PCI system, occurs on the host controller. When such an error occurs, the host controller clears bit 0 (RS) of the USBCMD register to 0b so that subsequent TD processing is not executed. Writing 1b by software clears this bit. Writing 0b has no effect.                                                     | R/W<br>R/W |  |  |  |
|              |                         | 0: No system error has occurred                                                                                                                                                                                                                                                                                                                                                            |            |  |  |  |
|              |                         | 1: A system error has occurred                                                                                                                                                                                                                                                                                                                                                             |            |  |  |  |
| b3           | FRAME_LIST_ROLL<br>OVER | The host controller sets this bit to 1b when the Frame Index bit of the FRINDEX register rolled over from its maximum value to 000h. The maximum value at which a rollover occurs depends on the setting of bits [3:2] (FRAME_LIST_SIZE) of the USBCMD register. Writing 1b by software clears this bit. Writing 0b has no effect.  0: The frame list count has not rolled over to be 000h | R/W        |  |  |  |
|              |                         | 1: The frame list count rolled over to be 000h                                                                                                                                                                                                                                                                                                                                             |            |  |  |  |
| b2           | PORT_CHANGE_DE          | Indicates the change in the port status.                                                                                                                                                                                                                                                                                                                                                   | R/W        |  |  |  |
|              | TECT                    | The host controller sets this bit to 1b when a port for which bit 13 (PORT_OWNER) of the PORTSC[n] register is set to 0b satisfies any of the following conditions.                                                                                                                                                                                                                        |            |  |  |  |
|              |                         | <ul> <li>Bit 1 (Connect Status Change) of the PORTSC[n] changed from 0b to 1b<br/>(connection or disconnection of a device was detected)</li> </ul>                                                                                                                                                                                                                                        |            |  |  |  |
|              |                         | <ul> <li>Bit 3 (Port Enable/Disable Change) of the PORTSC[n] changed from 0b to 1b<br/>(the port enable status was changed)</li> </ul>                                                                                                                                                                                                                                                     |            |  |  |  |
|              |                         | <ul> <li>Bit 5 (Over-current Change) of the PORTSC[n] changed from 0b to 1b<br/>(an overcurrent was detected)</li> </ul>                                                                                                                                                                                                                                                                   |            |  |  |  |
|              |                         | <ul> <li>Bit 6 (Force Port Resume) of the PORTSC[n] changed from 0b to 1b<br/>(a J-K transition was detected on a suspended port).</li> </ul>                                                                                                                                                                                                                                              |            |  |  |  |
|              |                         | Writing 1b by software clears this bit. Writing 0b has no effect.                                                                                                                                                                                                                                                                                                                          |            |  |  |  |
| b1           | USBERRINT               | USB Error Interrupt.                                                                                                                                                                                                                                                                                                                                                                       | R/W        |  |  |  |
|              |                         | Indicates the termination of a USB transaction due to an error. The host controller sets this bit to 1b when a USB transaction terminated due to an error such as an underflow of the error counter. Writing 1b by software clears this bit. Writing 0b has no effect.                                                                                                                     |            |  |  |  |
|              |                         | 0: The USB transaction normally completed                                                                                                                                                                                                                                                                                                                                                  |            |  |  |  |
|              |                         | 1: The USB transaction terminated due to an error                                                                                                                                                                                                                                                                                                                                          |            |  |  |  |
| 00           | USBINT                  | USB Interrupt.                                                                                                                                                                                                                                                                                                                                                                             | R/W        |  |  |  |
|              |                         | Indicates the normal completion of a USB transfer. The host controller sets this bit to 1b when any of the following events occurs.                                                                                                                                                                                                                                                        |            |  |  |  |
|              |                         | <ul> <li>Completion of a USB transfer</li> </ul>                                                                                                                                                                                                                                                                                                                                           |            |  |  |  |
|              |                         | <ul> <li>Reception of a short packet.</li> </ul>                                                                                                                                                                                                                                                                                                                                           |            |  |  |  |
|              |                         | This bit is also set to 1b if IOC (Interrupt On Complete) of the TD is 1b, even if a USB transfer terminated due to an error. Writing 1b by software clears this bit. Writing 0b has no effect.                                                                                                                                                                                            |            |  |  |  |
|              |                         | 0: The USB transfer has not completed                                                                                                                                                                                                                                                                                                                                                      |            |  |  |  |
|              |                         | 1: The USB transfer completed                                                                                                                                                                                                                                                                                                                                                              |            |  |  |  |

## 10.5.2.7 USBINTR — USBINTR Register

Address: 4002 1028h



Table 10.37 USBINTR Register Contents

| Bit Position | Bit Name                                  | Function                                                                                            | R/W |
|--------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------|-----|
| b31 to b6    | Reserved                                  | Should be 0 at writing.                                                                             | R   |
| b5           | INTERRUPT_ON_AS<br>YNC_ADVANCE_EN<br>ABLE | Enable of bit 5 of USBSTS.  To clear the interrupt, use the USBSTS register.  0: Disable  1: Enable | R/W |
| b4           | HOST_SYSTEM_ER<br>ROR_ENABLE              | Enable of bit 4 of USBSTS.  To clear the interrupt, use the USBSTS register.  0: Disable  1: Enable | R/W |
| b3           | FRAME_LIST_ROLL<br>OVER_ENABLE            | Enable of bit 3 of USBSTS.  To clear the interrupt, use the USBSTS register.  0: Disable  1: Enable | R/W |
| b2           | PORT_CHANGE_INT<br>ERRUPT_ENABLE          | Enable of bit 2 of USBSTS.  To clear the interrupt, use the USBSTS register.  0: Disable  1: Enable | R/W |
| b1           | USB_ERROR_INTER<br>RUPT_ENABLE            | Enable of bit 1 of USBSTS.  To clear the interrupt, use the USBSTS register.  0: Disable  1: Enable | R/W |
| ь0           | USB_INTERRUPT_E<br>NABLE                  | Enable of bit 0 of USBSTS.  To clear the interrupt, use the USBSTS register.  0: Disable  1: Enable | R/W |

## 10.5.2.8 FRINDEX — Frame Index Register

Address: 4002 102Ch

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23   | b22    | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-------|--------|-----|-----|-----|-----|-----|-----|
|                   | _   | _   | _   | _   | _   | _   | _   | _   | _     | _      | _   | _   | _   | _   | _   | _   |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0      | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7    | b6     | b5  | b4  | b3  | b2  | b1  | b0  |
|                   | _   | _   |     |     |     |     |     |     | FRAME | _INDEX |     |     |     |     |     |     |
| Value after reset | Λ   | ^   | 0   | Λ   | Λ   | 0   | 0   | 0   | 0     | 0      | 0   | 0   | Λ   | 0   | Λ   | 0   |

Table 10.38 FRINDEX Register Contents

| Bit Position | Bit Name    | Function                  |                                                                                         |                         |                     | R/W |
|--------------|-------------|---------------------------|-----------------------------------------------------------------------------------------|-------------------------|---------------------|-----|
| b31 to b14   | Reserved    | Should be 0 at writ       | ing.                                                                                    |                         |                     | R   |
| b13 to b0    | FRAME_INDEX | These bits are use        | d to allocate an index to p                                                             | periodic frame list.    |                     | R/W |
|              |             | The bits are incren       | nented at the end of a mid                                                              | cro-frame.              |                     |     |
|              |             | before moving to the      | bits are used as the current<br>ne next index, the current<br>mined by bits [3:2] (FRAN | frame list is access    | ed eight times. The |     |
|              |             | Frame List Size           | Number Elements                                                                         | N                       |                     |     |
|              |             | 00b                       | (1024)                                                                                  | 12                      | =                   |     |
|              |             | 01b                       | (512)                                                                                   | 11                      | =                   |     |
|              |             | 10b                       | (256)                                                                                   | 10                      | =                   |     |
|              |             | 11b                       | Reserved                                                                                |                         | =                   |     |
|              |             | Accessing this register = | ister only when the host of a 1b).                                                      | controller stops (bit 1 | 2 (HCHALTED) of the |     |
|              |             | The value of this b       | it is reflected to SOF fram                                                             | ne number in the SC     | F token.            |     |

# 10.5.2.9 CTRLDSSEGMENT — CTRLDSSEGMENT Register

Address: 4002 1030h



Table 10.39 CTRLDSSEGMENT Register Contents

| Bit Position | Bit Name      | Function                                                                                   | R/W |
|--------------|---------------|--------------------------------------------------------------------------------------------|-----|
| b31 to b0    | CTRLDSSEGMENT | This register is not used because this host controller does not support 64-bit addressing. | R   |

## 10.5.2.10 PERIODICLISTBASE — PERIODICLISTBASE Register

Address: 4002 1034h

| Bit               | b31 | b30   | b29    | b28 | b27 | b26 | b25 | b24   | b23    | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-------|--------|-----|-----|-----|-----|-------|--------|-----|-----|-----|-----|-----|-----|-----|
|                   |     |       |        |     |     |     |     | BASEA | DDRESS |     |     |     |     |     |     |     |
| Value after reset | 0   | 0     | 0      | 0   | 0   | 0   | 0   | 0     | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14   | b13    | b12 | b11 | b10 | b9  | b8    | b7     | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                   |     | BASEA | DDRESS |     | _   | _   | _   | _     | _      | _   | _   | _   | _   | _   | _   | _   |
| Value after reset | 0   | 0     | 0      | 0   | 0   | 0   | 0   | 0     | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 10.40 PERIODICLISTBASE Register Contents

| Bit Position | Bit Name    | Function                                                                                                                          | R/W |
|--------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b12   | BASEADDRESS | Indicates the base address of the periodic frame list on a system memory.                                                         | R/W |
|              |             | The value of this register is loaded by software before the host controller starts list processing.                               |     |
|              |             | The host controller determines the frame list to process based on these bits and Frame Index (bit[13:0]) of the FRINDEX register. |     |
|              |             | Align the periodic frame list address on 4 KB boundary.                                                                           |     |
|              |             | No guarantee if these bits are changed during operation.                                                                          |     |
| b11 to b0    | Reserved    | Should be 0 at writing.                                                                                                           | R   |

# 10.5.2.11 ASYNCLISTADDR — ASYNCLISTADDR Register

**Address:** 4002 1038h



Table 10.41 ASYNCLISTADDR Register Contents

| Bit Position | Bit Name | Function                                                                                   | R/W |
|--------------|----------|--------------------------------------------------------------------------------------------|-----|
| b31 to b5    | LPL      | Link Pointer Low.                                                                          | R/W |
|              |          | Indicates a system memory address of asynchronous queue head which will be processed next. |     |
|              |          | Align the asynchronous queue head address on 32-byte boundary.                             |     |
| b4 to b0     | Reserved | Should be 0 at writing.                                                                    | R   |

# 10.5.2.12 CONFIGFLAG — CONFIGFLAG Register

Address: 4002 1060h



Table 10.42 CONFIGFLAG Register Contents

| Bit Position | Bit Name | Function                                                                                                                               | R/W |
|--------------|----------|----------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b1    | Reserved | Should be 0 at writing.                                                                                                                | R   |
| b0           | CF       | Configure Flag:                                                                                                                        | R/W |
|              |          | Use this bit to control default port routing, OHCl or EHCl.  Software sets this bit to 1b at the end of host controller configuration. |     |
|              |          | 0: OHCI host controller                                                                                                                |     |
|              |          | 1: EHCl host controller                                                                                                                |     |

## 10.5.2.13 PORTSC1/PORTSC2 — PORTSC1/PORTSC2 Register

Address: PORTSC1: 4002 1064h PORTSC2: 4003 1068h



Table 10.43 PORTSC1/PORTSC2 Register Contents (1/3)

| 14016 10.40  |                            | Oz Negister Contents (175)                                                                                                                                                                                                                                                                                         |     |
|--------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Bit Position | Bit Name                   | Function                                                                                                                                                                                                                                                                                                           | R/W |
| b31 to b23   | Reserved                   |                                                                                                                                                                                                                                                                                                                    | R   |
| b22          | WKOC_E                     | Wake on Over-current Enable.  If this bit is set to 1, an overcurrent state can be detected as a wakeup event.  This bit does not affect the host controller operation.  This bit is 0 when PP=0                                                                                                                   | R/W |
| b21          | WKDSCNNT_E                 | Wake on Disconnect Enable.  If this bit is set to 1, disconnecting a device can be detected as a wakeup event.  This bit does not affect the host controller operation.  This bit is 0 when PP=0                                                                                                                   | R/W |
| b20          | WKCNNT_E                   | Wake on Connect Enable.  If this bit is set to 1, connecting a device can be detected as a wakeup event.  This bit does not affect the host controller operation.  This bit is 0 when PP=0                                                                                                                         | R/W |
| b19 to b16   | PORT_TEST_CONT<br>ROL      | Port Test Control[3:0] 0000b: Normal 0001b: Test J_STATE 0010b: Test K_STATE 0011b: Test SE0_NAK 0100b: Test Packet 0101b: Test FORCE_ENABLE Other: Reserved                                                                                                                                                       | R/W |
| b15, b14     | PORT_INDICATOR_<br>CONTROL | Port Indicator Control[1:0]  These bits show 00b, which indicates that the host controller does not support port indicator control.                                                                                                                                                                                | R   |
| b13          | PORT_OWNER                 | Port Owner  0: EHCl host controller  1: OHCl host controller.  This bit is cleared when CF(bit0) of CONFIGFLAG register changes from 0 to 1. If CF = 0, this bit is set to 1. If the connected device is not a high-speed device, software set this bit to 1 to change port ownership to the OHCl host controller. | R/W |

| Table 10.43 PORTSC1/PORTSC2 Register Contents (2/3 | C2 Register Contents (2/3) | PORTSC1/PORTSC2 | Table 10.43 |
|----------------------------------------------------|----------------------------|-----------------|-------------|
|----------------------------------------------------|----------------------------|-----------------|-------------|

|              |                | _                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                              |      |  |  |
|--------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--|--|
| Bit Position | Bit Name       | Function                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                              | R/W  |  |  |
| 012          | PP             | Port Power                                                                                                                                                                                               | er                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                              | R/W  |  |  |
|              |                | 0: Not supply power to ports                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                              |      |  |  |
|              |                | 1: Supply power to ports.                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                              |      |  |  |
|              |                |                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | not function and therefore                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                              |      |  |  |
|              |                |                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | to 0, which stops power                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | s detected when this bit is                                                                                                                                  |      |  |  |
|              |                |                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | the value of PPC of the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                              |      |  |  |
|              |                | PPC                                                                                                                                                                                                      | PP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Title value of 1.1 C of tile                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | TICOT AINAINIO TEGISTET.                                                                                                                                     |      |  |  |
|              |                |                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1 and newer in always aventi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ad to the next                                                                                                                                               |      |  |  |
|              |                | 0                                                                                                                                                                                                        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1 and power is always supplie                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                              |      |  |  |
|              |                | 1                                                                                                                                                                                                        | 0 or 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Power suppi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | y to the port depends on the se                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | etting of this bit                                                                                                                                           |      |  |  |
| b11, b10     | LINE_STATUS    | Line Statu                                                                                                                                                                                               | us[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                              | R    |  |  |
|              |                | Bit11(D+)                                                                                                                                                                                                | Bit10(D-)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | USB State                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                              |      |  |  |
|              |                | 0                                                                                                                                                                                                        | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | SE0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Not low-speed device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                              |      |  |  |
|              |                | 0                                                                                                                                                                                                        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | K-state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Low-speed device is connec                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ted                                                                                                                                                          |      |  |  |
|              |                | <u> </u>                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Releases port owner ship fro                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | om EHCI to OHCI                                                                                                                                              |      |  |  |
|              |                | 1                                                                                                                                                                                                        | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | J-state                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Not low-speed device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | _                                                                                                                                                            |      |  |  |
|              |                |                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Performs EHCI port reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                              |      |  |  |
|              |                | 1                                                                                                                                                                                                        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Undefined                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Not low-speed device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                              |      |  |  |
|              |                |                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Performs EHCI port reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                              |      |  |  |
|              |                | Use this b                                                                                                                                                                                               | oit to detect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | LS device be                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | fore starting a port reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | sequence or a port enable                                                                                                                                    |      |  |  |
|              |                | sequence. This bit is valid when PORT_ENABLE_DISABLE_CHANGE = 0 and                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                              |      |  |  |
|              |                | CURRENT_CONNECT_STATUS = 1.                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                              |      |  |  |
|              |                | This bit is                                                                                                                                                                                              | 0 when PP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | = 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                              |      |  |  |
| b9           | Reserved       |                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                              | R    |  |  |
| - O          | PORT_RESET     | Port Rese                                                                                                                                                                                                | <u> </u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                              | DAA  |  |  |
| 00           | I OILI_ILEGE I | LOIL IVES                                                                                                                                                                                                | , ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                              | K/VV |  |  |
| DO           | TOKT_KEGET     |                                                                                                                                                                                                          | t is not bein                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | g reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                              | K/VV |  |  |
| b8           | TOKT_KEGET     | 0: Por                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                              | K/VV |  |  |
| Do           | T OKT_KEGET    | 0: Por<br>1: Por                                                                                                                                                                                         | t is not being<br>t is being re                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0 causes USB bus reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | sequence. It is necessary                                                                                                                                    | K/VV |  |  |
| DO           | TOKT_KEGET     | 0: Port<br>1: Port<br>Writing 1<br>to write 0                                                                                                                                                            | t is not being<br>t is being re<br>to this bit w<br>in order to f                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | set.<br>hile the bit is<br>finish the bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | reset. Note that this bit n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | nust be kept as 1 until bus                                                                                                                                  | K/VV |  |  |
| Do           | TOKT_KEGET     | 0: Port<br>1: Port<br>Writing 1<br>to write 0<br>reset seq                                                                                                                                               | t is not being<br>t is being re<br>to this bit w<br>in order to f<br>uence finish                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | set. hile the bit is finish the bus nes according                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | reset. Note that this bit n<br>to USB 2.0 specification                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | nust be kept as 1 until bus                                                                                                                                  | K/VV |  |  |
| БО           | TOKT_KEGET     | 0: Port<br>1: Port<br>Writing 1<br>to write 0<br>reset seq<br>If HCHAL                                                                                                                                   | t is not being<br>t is being re<br>to this bit w<br>in order to f<br>uence finish<br>TED (bit12)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | set. hile the bit is finish the bus nes according of USBSTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | reset. Note that this bit note to USB 2.0 specification register is 1, software mu                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | nust be kept as 1 until bus<br>st not reset the port.                                                                                                        | K/VV |  |  |
| БО           | TOKT_KEGET     | 0: Port<br>1: Port<br>Writing 1<br>to write 0<br>reset seq<br>If HCHAL                                                                                                                                   | t is not being<br>t is being re<br>to this bit w<br>in order to f<br>uence finish<br>TED (bit12)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | set. hile the bit is finish the bus nes according of USBSTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | reset. Note that this bit n<br>to USB 2.0 specification                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | nust be kept as 1 until bus<br>st not reset the port.                                                                                                        | R/VV |  |  |
| DO           | TOKT_KEGET     | 0: Port<br>1: Port<br>Writing 1<br>to write 0<br>reset seq<br>If HCHAL                                                                                                                                   | t is not being<br>t is being re<br>to this bit w<br>in order to f<br>uence finish<br>TED (bit12)<br>set to 0 if a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | set. hile the bit is finish the bus nes according of USBSTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | reset. Note that this bit note to USB 2.0 specification register is 1, software mu                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | nust be kept as 1 until bus<br>st not reset the port.                                                                                                        | R/VV |  |  |
| DO           | TOKT_KEGET     | 0: Port<br>1: Port<br>Writing 1<br>to write 0<br>reset seq<br>If HCHAL<br>This bit is<br>– PP                                                                                                            | t is not being<br>t is being re<br>to this bit w<br>in order to f<br>uence finish<br>TED (bit12)<br>set to 0 if a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | set. hile the bit is finish the bus according of USBSTS any of the follo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | reset. Note that this bit note to USB 2.0 specification register is 1, software mu                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | nust be kept as 1 until bus<br>st not reset the port.                                                                                                        | R/VV |  |  |
| 00           | TOKT_KEGET     | 0: Port 1: Port Writing 1 to write 0 reset seq If HCHAL This bit is - PP - PO                                                                                                                            | t is not being<br>t is being re<br>to this bit w<br>in order to f<br>uence finish<br>TED (bit12)<br>set to 0 if a<br>= 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | set. hile the bit is finish the bus according of USBSTS any of the follo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | reset. Note that this bit note USB 2.0 specification register is 1, software musuring conditions is satisfications.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | nust be kept as 1 until bus<br>st not reset the port.                                                                                                        | R/VV |  |  |
|              |                | 0: Port 1: Port Writing 1 to write 0 reset seq If HCHAL This bit is - PP - PO - CU                                                                                                                       | t is not being<br>t is being re<br>to this bit w<br>in order to f<br>uence finish<br>TED (bit12)<br>set to 0 if a<br>= 0<br>RT_OWNE<br>RRENT_CO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | set. hile the bit is finish the bus nes according of USBSTS any of the follo  R = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | reset. Note that this bit note USB 2.0 specification register is 1, software musuring conditions is satisfications.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | nust be kept as 1 until bus<br>st not reset the port.                                                                                                        |      |  |  |
|              | SUSPEND        | 0: Port 1: Port Vriting 1 to write 0 reset seq If HCHAL This bit is - PP - PO - CU                                                                                                                       | t is not being re to this bit w in order to fuence finish TED (bit12) set to 0 if a = 0 RT_OWNE RRENT_CC end status.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | set. hile the bit is finish the bus nes according of USBSTS any of the follow R = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | reset. Note that this bit note USB 2.0 specification register is 1, software musuring conditions is satisfications.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | nust be kept as 1 until bus<br>st not reset the port.                                                                                                        |      |  |  |
|              |                | 0: Port 1: Port Viriting 1 to write 0 reset seq If HCHAL This bit is - PP - PO - CU Port susp 0: Not                                                                                                     | t is not being re to this bit w in order to fuence finish TED (bit12) set to 0 if a = 0 RT_OWNE RRENT_CO end status. suspend st                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | set. hile the bit is finish the bus nes according of USBSTS any of the follow R = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | reset. Note that this bit note USB 2.0 specification register is 1, software musuring conditions is satisfications.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | nust be kept as 1 until bus<br>st not reset the port.                                                                                                        |      |  |  |
|              |                | 0: Port 1: Port Writing 1 to write 0 reset seq If HCHAL This bit is - PP - PO - CU  Port susp 0: Not 1: Sus                                                                                              | t is not being re to this bit w in order to fuence finish TED (bit12) set to 0 if a = 0 RT_OWNE RRENT_CO end status. suspend state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | set. hile the bit is finish the bus hes according of USBSTS any of the follo  R = 1  DNNECT_ST  atte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | reset. Note that this bit note use 2.0 specification register is 1, software must be wing conditions is satisfied.  ATUS = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | nust be kept as 1 until bus<br>st not reset the port.<br>ed.                                                                                                 |      |  |  |
|              |                | 0: Port 1: Port Writing 1 to write 0 reset seq If HCHAL This bit is - PP - PO - CU Port susp 0: Not 1: Sus This bit an                                                                                   | t is not being re to this bit w in order to fuence finish TED (bit12) set to 0 if a = 0 RT_OWNE RRENT_CC end status. suspend steend PORT_E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | set. hile the bit is finish the bus hes according of USBSTS any of the follo  R = 1 DNNECT_ST  ate  ABLED_DI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | reset. Note that this bit note to USB 2.0 specification register is 1, software muswing conditions is satisfications.  ATUS = 0  SABLED determine the position of the satisfication is satisfication.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ort status.                                                                                                                                                  |      |  |  |
|              |                | 0: Port 1: Port Viriting 1 to write 0 reset seq If HCHAL This bit is - PP - PO - CU Port susp 0: Not 1: Sus This bit an                                                                                  | t is not being re to this bit w in order to fuence finish TED (bit12) set to 0 if a = 0 RT_OWNE RRENT_CO end status. suspend state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | set. hile the bit is finish the bus hes according of USBSTS any of the follo  R = 1 DNNECT_ST  ate  ABLED_DI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | reset. Note that this bit note to USB 2.0 specification register is 1, software must be wing conditions is satisfied.  ATUS = 0  SABLED determine the page of the suspend series of the USB points.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | nust be kept as 1 until bus st not reset the port. ed.  ort status. ort state                                                                                |      |  |  |
|              |                | 0: Port 1: Port Viriting 1 to write 0 reset seq If HCHAL This bit is - PP - PO - CU Port susp 0: Not 1: Sus This bit at PORT_EN                                                                          | t is not being re to this bit w in order to fuence finish TED (bit12) set to 0 if a = 0 RT_OWNE RRENT_CC end status. suspend steend PORT_E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | set. hile the bit is finish the bus hes according of USBSTS any of the follo  R = 1 DNNECT_ST  ate  ABLED_DI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | reset. Note that this bit m to USB 2.0 specification register is 1, software mu owing conditions is satisfication  ATUS = 0  SABLED determine the p Suspend Po X Di                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ort status.                                                                                                                                                  | R/W  |  |  |
| b7           |                | 0: Port 1: Port Writing 1 to write 0 reset seq If HCHAL This bit is - PP - PO - CU  Port susp 0: Not 1: Sus This bit at PORT_EN                                                                          | t is not being re to this bit w in order to fuence finish TED (bit12) set to 0 if a = 0 RT_OWNE RRENT_CC end status. suspend steend PORT_E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | set. hile the bit is finish the bus hes according of USBSTS any of the follo  R = 1 DNNECT_ST  ate  ABLED_DI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | reset. Note that this bit note to USB 2.0 specification register is 1, software must be satisfied as a second seco | ort status.                                                                                                                                                  |      |  |  |
|              |                | 0: Port 1: Port Viriting 1 to write 0 reset seq If HCHAL This bit is - PP - PO - CU Port susp 0: Not 1: Sus This bit at PORT_EN                                                                          | t is not being re to this bit w in order to fuence finish TED (bit12) set to 0 if a = 0 RT_OWNE RRENT_CC end status. suspend steend PORT_E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | set. hile the bit is finish the bus hes according of USBSTS any of the follo  R = 1 DNNECT_ST  ate  ABLED_DI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | reset. Note that this bit note to USB 2.0 specification register is 1, software must be satisfied as a second seco | ort status.                                                                                                                                                  |      |  |  |
|              |                | 0: Port 1: Port Writing 1 to write 0 reset seq If HCHAL This bit is - PP - PO - CU  Port susp 0: Not 1: Sus This bit ar  PORT_EN 0 1 In suspen reset. If the                                             | t is not being to this bit which in order to fuence finish TED (bit12) set to 0 if a = 0 RT_OWNE RRENT_CCO end status. suspend state. Ind PORT_E ABLED_DISA and state, dat his bit is set to data to the control of the  | set. hile the bit is finish the bus nes according of USBSTS any of the followard for | reset. Note that this bit in to USB 2.0 specification register is 1, software musually specification is satisficated by satisfication in the position of the position is specificated by satisfication in the position is specification in the position in  | ort status.  ort status.  ort state sable lable                                                                                                              | R/W  |  |  |
|              |                | 0: Port 1: Port Writing 1 to write 0 reset seq If HCHAL This bit is - PP - PO - CU  Port susp 0: Not 1: Sus This bit at PORT_EN 0 1 In susper reset. If the                                              | t is not being to this bit win order to fuence finish TED (bit12) set to 0 if a = 0 RT_OWNE RRENT_CO end status. suspend status. suspend state. and PORT_E ABLED_DISA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | set. hile the bit is finish the bus according of USBSTS any of the folkood is set to be set to b | reset. Note that this bit in to USB 2.0 specification register is 1, software muturing conditions is satisfication.  ATUS = 0  SABLED determine the part of the downstream port is bedata transfer, the status insfer finished.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ort status.  ort status.  ort state sable lable lspend locked except for port reflection and data transfer                                                   | R/W  |  |  |
|              |                | 0: Port 1: Port Writing 1 to write 0 reset seq If HCHAL This bit is - PP - PO - CU  Port susp 0: Not 1: Sus This bit at PORT_EN 0 1 In susper reset. If the will be blo This bit is                      | t is not being to this bit we in order to fuence finish TED (bit12) set to 0 if a = 0 RT_OWNE RRENT_CO end status. suspend status. suspend state. and PORT_E ABLED_DISA and state, dat his bit is set to 1 by                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | set. hile the bit is finish the bus according of USBSTS any of the folkood in the | reset. Note that this bit in to USB 2.0 specification register is 1, software muturing conditions is satisfication.  ATUS = 0  SABLED determine the part of the downstream port is bedata transfer, the status insfer finished.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ort status.  ort status.  ort state  sable lable lspend  locked except for port reflection and data transfer                                                 | R/W  |  |  |
|              |                | 0: Port 1: Port Writing 1 to write 0 reset seq If HCHAL This bit is - PP - PO - CU  Port susp 0: Not 1: Sus This bit at PORT_EN 0 1 In susper reset. If the will be blo This bit is and CUR              | t is not being to this bit win order to fuence finish TED (bit12) set to 0 if a = 0 PRT_OWNE RRENT_CO end status. suspend status. suspend state. Ind PORT_EABLED_DISA and state, dath is bit is set to 1 by RENT_CON TENT_CON TENT_C | set. hile the bit is finish the bus hes according of USBSTS any of the folkood in | reset. Note that this bit in to USB 2.0 specification register is 1, software muture wing conditions is satisfication.  ATUS = 0  SABLED determine the part is but the downstream port is but data transfer, the status insfer finished.  If it is possible only when                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ort status.  ort status.  ort status.  ort state  sable  labele lspend  locked except for port reflection and data transfer  PP=1, PORT_OWNER =0, registers. | R/W  |  |  |
|              |                | 0: Port 1: Port Writing 1 to write 0 reset seq If HCHAL This bit is - PP - PO - CU  Port susp 0: Not 1: Sus This bit an  PORT_EN 0 1 In suspen reset. If the will be blo This bit is and CUR This bit is | t is not being re to this bit w in order to fuence finish TED (bit12) set to 0 if a = 0 RT_OWNE RENT_CC end status. suspend state. and PORT_E ABLED_DISA and state, dath his bit is set to 1 by RENT_CON uncondition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | set. hile the bit is finish the bus hes according of USBSTS any of the followard for the formal for the followard for th | reset. Note that this bit in to USB 2.0 specification register is 1, software mutually specification register is 1, software mutually specification register is 1, software mutually specification is satisficated.  SABLED determine the part of the  | ort status.  ort status.  ort status.  ort state  sable  labele lspend  locked except for port reflection and data transfer  PP=1, PORT_OWNER =0, registers. | R/W  |  |  |

This bit is 0 when PP = 0.

Table 10.43 PORTSC1/PORTSC2 Register Contents (3/3)

| Bit Position | Bit Name           | Function                                                                                                                                                                                                                                                                                   | R/W |  |  |  |  |  |
|--------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|
|              |                    |                                                                                                                                                                                                                                                                                            | R/W |  |  |  |  |  |
| b6           | FORCE_PORT_RES UME | Force Port Resume  0: No resume signal (K state) has been detected or output                                                                                                                                                                                                               |     |  |  |  |  |  |
|              | OWL                | No resume signal (K state) has been detected or output.  1: Resume signal (K state) has been detected or output.                                                                                                                                                                           |     |  |  |  |  |  |
|              |                    | If the port state moves from J to K during the suspend state (Remote WakeUp), the                                                                                                                                                                                                          |     |  |  |  |  |  |
|              |                    | host controller sets this bit and PORT_CHANGE_DETECT (bit2) of USBSTS register to 1. In addition, software sets this bit to 1 in order to output a resume signal. At this time, do not set the PORT_CHANGE_DETECT bit.                                                                     |     |  |  |  |  |  |
|              |                    | While this bit is 1, a resume signal (FS K State) is driven to the USB port. This bit must be cleared to 0 after an appropriate time has passed.  Writing 0 to this bit while the bit is 1, the port returns to HS Idle. This bit is 1 until the port returns to HS Idle.                  |     |  |  |  |  |  |
|              |                    |                                                                                                                                                                                                                                                                                            |     |  |  |  |  |  |
|              |                    | This bit is 0 when PP = 0.                                                                                                                                                                                                                                                                 |     |  |  |  |  |  |
| b5           | OVER_CURRENT_C     | Over-Current Change                                                                                                                                                                                                                                                                        |     |  |  |  |  |  |
|              | HANGE              | 0: No change                                                                                                                                                                                                                                                                               |     |  |  |  |  |  |
|              |                    | 1: OVER_CURRENT_ACTIVE has changed.                                                                                                                                                                                                                                                        |     |  |  |  |  |  |
|              |                    | This bit can be cleared by writing 1 by software. Writing 0 has no effect.                                                                                                                                                                                                                 |     |  |  |  |  |  |
| b4           | OVER_CURRENT_A     | Over-Current Active 0: Not overcurrent state 1: Overcurrent state.                                                                                                                                                                                                                         |     |  |  |  |  |  |
|              | CTIVE              |                                                                                                                                                                                                                                                                                            |     |  |  |  |  |  |
|              |                    |                                                                                                                                                                                                                                                                                            |     |  |  |  |  |  |
|              |                    | The host controller clears the PP and related bits, then sets this bit to 1 when an overcurrent status is detected. This bit is cleared when the overcurrent state ends.                                                                                                                   |     |  |  |  |  |  |
| b3           | PORT_ENABLE_DIS    | t Enable/Disable Change                                                                                                                                                                                                                                                                    |     |  |  |  |  |  |
|              | ABLE_CHANGE        | 0: No change                                                                                                                                                                                                                                                                               |     |  |  |  |  |  |
|              |                    | 1: Port status has changed from Enable to Disable.                                                                                                                                                                                                                                         |     |  |  |  |  |  |
|              |                    | The host controller disables the port, then sets this bit to 1 when a frame babble is detected.                                                                                                                                                                                            |     |  |  |  |  |  |
|              |                    | This bit can be cleared by writing 1 by software. Writing 0 has no effect.                                                                                                                                                                                                                 |     |  |  |  |  |  |
|              |                    | This bit is 0 when PP = 0.                                                                                                                                                                                                                                                                 |     |  |  |  |  |  |
| b2           | PORT_ENABLED_DI    | Port Enabled/Disabled                                                                                                                                                                                                                                                                      |     |  |  |  |  |  |
|              | SABLED             | 0: Port disable                                                                                                                                                                                                                                                                            |     |  |  |  |  |  |
|              |                    | 1: Port enable                                                                                                                                                                                                                                                                             |     |  |  |  |  |  |
|              |                    | When the host controller resets the port and recognizes that the connected device is a HS device, it enables the port and then sets this bit to 1. This bit can't be set to 1 by software.                                                                                                 |     |  |  |  |  |  |
|              |                    | When the host controller detects a disconnection of a device or an error, it disables the ports and then clears this bit to 0. The port is also disabled when this bit is set to 0 by software. Note that writing to this bit is not reflected until the port status is changed in actual. |     |  |  |  |  |  |
|              |                    | ata transfer for the downstream port is blocked, except for port reset when the port is sabled.                                                                                                                                                                                            |     |  |  |  |  |  |
|              |                    | This bit is 0 when PP=0.                                                                                                                                                                                                                                                                   |     |  |  |  |  |  |
|              |                    | Port is enabled regardless of the port status, and this bit is set to 1 when PORT_TEST_CONTROL [3:0] = 0101b (Test FORCE_ENABLE).                                                                                                                                                          |     |  |  |  |  |  |
| b1           | CONNECT_STATUS     | Connect Status Change 0: No change 1: CURRENT_CONNECT_STATUS has changed.                                                                                                                                                                                                                  |     |  |  |  |  |  |
|              | _CHANGE            |                                                                                                                                                                                                                                                                                            |     |  |  |  |  |  |
|              |                    | This bit can be cleared by writing 1 by software. Writing 0 has no effect.                                                                                                                                                                                                                 |     |  |  |  |  |  |
|              |                    | This bit is 0 when PP=0.                                                                                                                                                                                                                                                                   |     |  |  |  |  |  |
| b0           | CURRENT_CONNEC     | Current Connect Status                                                                                                                                                                                                                                                                     | R   |  |  |  |  |  |
|              | T_STATUS           | 0: No device is connected to the port                                                                                                                                                                                                                                                      |     |  |  |  |  |  |
|              |                    | 1: Device is connected to the port                                                                                                                                                                                                                                                         |     |  |  |  |  |  |
|              |                    | Even if no device is connected, this bit is 1 when PORT_TEST_CONTROL[3:0] = 0101b (Test FORCE_ENABLE).                                                                                                                                                                                     |     |  |  |  |  |  |
|              |                    | This bit is 0 when PP=0 or PORT_OWNER=0.                                                                                                                                                                                                                                                   |     |  |  |  |  |  |

# 10.5.3 OHCI (PCI Configuration Space) Register Description

# 10.5.3.1 VID\_DID — Device ID - Vendor ID (OHCI)

Address: 4003 0000h



Table 10.44 VID\_DID Register Contents

| Bit Position | Bit Name  | Function                                                                                              | R/W |
|--------------|-----------|-------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | DEVICE_ID | Indicates the device type.  This field is used to select a driver specified by the PCI specification. | R   |
|              |           | It is not necessary for this host controller.                                                         |     |
| b15 to b0    | VENDOR_ID | Indicates the device vendor.                                                                          | R   |
|              |           | This field is used to select a driver specified by the PCI specification.                             |     |
|              |           | It is not necessary for this host controller.                                                         |     |

# 10.5.3.2 CMND\_STS — Status - Command (OHCI)

Address: 4003 0004h

| Bit               | b31             | b30                               | b29            | b28            | b27            | b26         | b25    | b24                                    | b23               | b22                               | b21            | b20                                                | b19                   | b18            | b17                  | b16           |
|-------------------|-----------------|-----------------------------------|----------------|----------------|----------------|-------------|--------|----------------------------------------|-------------------|-----------------------------------|----------------|----------------------------------------------------|-----------------------|----------------|----------------------|---------------|
|                   | TED_P<br>ARITY_ | SIGNAL<br>ED_SY<br>STEM_<br>ERROR | ED_MA<br>STER_ | ED_TA<br>RGET_ | ED_TA<br>RGET_ | DEVSEL<br>G | _TIMIN | DATA_PA<br>RITY_ER<br>ROR_DE<br>TECTED | CK_TO_B<br>ACK_CA | _                                 | l              | CAPABI<br>LITIES_<br>LIST                          | _                     | l              | ١                    |               |
| Value after reset | 0               | 0                                 | 0              | 0              | 0              | 0           | 1      | 0                                      | 0                 | 0                                 | 0              | 1                                                  | 0                     | 0              | 0                    | 0             |
| Bit               | b15             | b14                               | b13            | b12            | b11            | b10         | b9     | b8                                     | b7                | b6                                | b5             | b4                                                 | b3                    | b2             | b1                   | b0            |
|                   | _               | _                                 | 1              | l              | _              | _           |        | <b>ENABL</b>                           | CYCLE<br>_CONT    | PARITY<br>_ERRO<br>R_RES<br>PONSE | ALETT<br>E_SNO | MEMORY<br>_WRITE_<br>AND_INV<br>ALIDATE<br>_ENABLE | SPECIA<br>L_CYC<br>LE | BUS_M<br>ASTER | MEMO<br>RY_SP<br>ACE | I_O_SP<br>ACE |
| Value after reset | 0               | 0                                 | 0              | 0              | 0              | 0           | 0      | 0                                      | 0                 | 0                                 | 0              | 0                                                  | 0                     | 0              | 0                    | 0             |

Table 10.45 CMND\_STS Register Contents (1/2)

| Bit Position | Bit Name                       | Function                                                                                                                                                                                               | R/W |  |  |  |  |  |
|--------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|
| b31          | DETECTED_PARITY                | Indicates the parity error status.                                                                                                                                                                     |     |  |  |  |  |  |
|              | _ERROR                         | This bit is set when an address or data parity error is detected, cleared when 1b is written via the PCI bus.                                                                                          |     |  |  |  |  |  |
| b30          | SIGNALED_SYSTEM                | Indicates the SERR status.                                                                                                                                                                             | R/W |  |  |  |  |  |
|              | _ERROR                         | This bit is set when a system error occurs, cleared when 1b is written via the PCI bus.                                                                                                                |     |  |  |  |  |  |
| b29          | RECEIVED_MASTER                | Indicates the Master-Master Abort status.                                                                                                                                                              |     |  |  |  |  |  |
|              | _ABORT                         | This bit is set to 1b when the bus cycle executed by the host controller serving as a master terminates due to Master Abort signaling, cleared when 1b is written via the PCI bus.                     |     |  |  |  |  |  |
| b28          | RECEIVED_TARGET                | Indicates the Master-Target Abort status.                                                                                                                                                              |     |  |  |  |  |  |
|              | _ABORT                         | This bit is set to 1b when the bus cycle executed by the host controller serving as a master terminates due to Target Abort signaling, cleared when 1b is written via the PCI bus.                     |     |  |  |  |  |  |
| b27          | SIGNALED_TARGET                | Indicates the Slave Target Abort status.                                                                                                                                                               |     |  |  |  |  |  |
|              | _ABORT                         | This bit is set to 1b when the bus cycle of the host controller serving as a slave being accessed is terminated due to Target Abort signaling. This bit is cleared when 1b is written via the PCI bus. |     |  |  |  |  |  |
| b26, b25     | DEVSEL_TIMING                  | Indicates the DEVSEL response speed.                                                                                                                                                                   |     |  |  |  |  |  |
|              |                                | This bit is fixed to 01b (mid-speed response).                                                                                                                                                         |     |  |  |  |  |  |
|              | DATA_PARITY_ERR<br>OR_DETECTED | This bit is set when the host controller serving as a master detects a parity error, cleared when 1b is written via the PCI bus.                                                                       | R/W |  |  |  |  |  |
|              |                                | This bit is fixed to 0b when the Parity Error Response bit is set to 0.                                                                                                                                |     |  |  |  |  |  |
| b23          | FAST_BACK_TO_BA<br>CK_CAPABLE  | Indicates whether Fast Back to Back is supported. This bit is fixed to 0b because Fast Back to Back is not supported.                                                                                  |     |  |  |  |  |  |
| b22, b21     | Reserved                       | Should be 0 at writing.                                                                                                                                                                                | R   |  |  |  |  |  |
| b20          | CAPABILITIES_LIST              | Indicates whether power management mode is supported.                                                                                                                                                  |     |  |  |  |  |  |
|              |                                | This bit is fixed to 1b.                                                                                                                                                                               |     |  |  |  |  |  |
| b19 to b10   | Reserved                       | Should be 0 at writing.                                                                                                                                                                                | R   |  |  |  |  |  |
| b9           | FAST_BACK_TO_BA                | Use this bit to enable Fast Back to Back.                                                                                                                                                              |     |  |  |  |  |  |
|              | CK_ENABLE                      | This bit is fixed to 0b because the host controller does not support Fast Back to Back.                                                                                                                |     |  |  |  |  |  |
| b8           | SERR_ENABLE                    | Use this bit to enable system error response.                                                                                                                                                          |     |  |  |  |  |  |
|              |                                | 0: Do not assert SERR0                                                                                                                                                                                 |     |  |  |  |  |  |
|              |                                | 1: Assert SERR0                                                                                                                                                                                        |     |  |  |  |  |  |
|              |                                | Set this bit to 1b to signal the system error by using the SERR signal.                                                                                                                                |     |  |  |  |  |  |

Table 10.45 CMND\_STS Register Contents (2/2)

| Bit Position | Bit Name                                   | Function                                                                                                                               |     |  |  |  |  |  |
|--------------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|
| b7           | WAIT_CYCLE_CONT<br>ROL                     | Use this bit to enable wait cycle control. This bit is fixed to 0b because the host controller does not support Address/Data Stepping. |     |  |  |  |  |  |
| b6           | PARITY_ERROR_RE                            | Use this bit to enable parity error response.                                                                                          | R/W |  |  |  |  |  |
|              | SPONSE                                     | 0: Do not assert PERR0                                                                                                                 |     |  |  |  |  |  |
|              |                                            | 1: Assert PERR0                                                                                                                        |     |  |  |  |  |  |
|              |                                            | The DETECTED_PARITY_ERROR bit is set to 1b even if this bit is 0 when a parity error is detected.                                      |     |  |  |  |  |  |
| b5           | VGA_PALETTE_SNO                            | Use this bit to enable VGA Palette Snoop.                                                                                              | R   |  |  |  |  |  |
|              | OP                                         | This bit is fixed to 0b (not supported)                                                                                                |     |  |  |  |  |  |
| b4           | MEMORY_WRITE_A<br>ND_INVALIDATE_EN<br>ABLE | Use this bit to enable Memory Write and Invalidate.                                                                                    | R/W |  |  |  |  |  |
|              |                                            | This bit should be remained as initial value,0                                                                                         |     |  |  |  |  |  |
| b3           | SPECIAL_CYCLE                              | Use this bit to enable Special Cycle.                                                                                                  | R   |  |  |  |  |  |
|              |                                            | This bit is fixed to 0b (not supported)                                                                                                |     |  |  |  |  |  |
| b2           | BUS_MASTER                                 | Use this bit to enable the bus master.                                                                                                 | R/W |  |  |  |  |  |
|              |                                            | This is a signal to enable master access to the PCI bus. Set this bit to 1b when accessing SRAM on the system bus.                     |     |  |  |  |  |  |
|              |                                            | Set this bit to 1b during initialization.                                                                                              |     |  |  |  |  |  |
| b1           | MEMORY_SPACE                               | Use this bit to enable accessing to the memory spaces.                                                                                 |     |  |  |  |  |  |
|              |                                            | This is a signal to enable memory access prescribed in the PCI specification.                                                          |     |  |  |  |  |  |
|              |                                            | Set this bit to 1b during initialization.                                                                                              |     |  |  |  |  |  |
| b0           | I_O_SPACE                                  | Use this bit to enable accessing to the I/O spaces.                                                                                    | R   |  |  |  |  |  |
|              |                                            | This bit is fixed to 0b because the host controller does not acknowledge I/O accesses.                                                 |     |  |  |  |  |  |

#### 10.5.3.3 REVID\_CC — Class Code - Revision ID (OHCI)

Address: 4003 0008h

| Bit               | b31 | b30             | b29 | b28   | b27   | b26 | b25 | b24 | b23 | b22 | b21 | b20   | b19    | b18 | b17 | b16 |
|-------------------|-----|-----------------|-----|-------|-------|-----|-----|-----|-----|-----|-----|-------|--------|-----|-----|-----|
|                   |     |                 |     | BASE_ | CLASS |     |     |     |     |     |     | SUB_0 | CLASS  |     |     |     |
| Value after reset | 0   | 0               | 0   | 0     | 1     | 1   | 0   | 0   | 0   | 0   | 0   | 0     | 0      | 0   | 1   | 1   |
| Bit               | b15 | b14             | b13 | b12   | b11   | b10 | b9  | b8  | b7  | b6  | b5  | b4    | b3     | b2  | b1  | b0  |
|                   |     | PROGRAMMING_I_F |     |       |       |     |     |     |     |     |     | REVIS | ION_ID |     |     |     |
| Value after reset | 0   | 0               | 0   | 1     | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0      | 0   | 0   | 1   |

Table 10.46 REVID\_CC Register Contents

| Bit Position | Bit Name        | Function                                                          | R/W |
|--------------|-----------------|-------------------------------------------------------------------|-----|
| b31 to b24   | BASE_CLASS      | Indicates the base class defined in the PCI specification.        | R   |
|              |                 | "0Ch" means that a serial peripheral bus controller.              |     |
| b23 to b16   | SUB_CLASS       | Indicates the subclass defined in the PCI specification.          | R   |
|              |                 | "03h" means that USB device.                                      |     |
| b15 to b8    | PROGRAMMING_I_F | Indicates the program interface defined in the PCI specification. | R   |
|              |                 | "10h" means that OHCI.                                            |     |
| b7 to b0     | REVISION_ID     | Indicates the host controller revision.                           | R   |
|              |                 | This bit is fixed to 01h.                                         |     |

## 10.5.3.4 CLS\_LT\_HT\_BIST — BIST - Header Type - Latency Timer - Cache Line Size (OHCI)

Address: 4003 000Ch



Table 10.47 CLS\_LT\_HT\_BIST Register Contents

| Bit Position | Bit Name        | Function                                                                            | R/W |
|--------------|-----------------|-------------------------------------------------------------------------------------|-----|
| b31 to b24   | BIST            | This bit is used for self-testing.                                                  | R   |
|              |                 | This bit is fixed to 00h because the host controller does not support self-testing. |     |
| b23 to b16   | HEADER_TYPE     | Use this bit to report the header type to the system.                               | R   |
|              |                 | Bits [22:16] are fixed to 00h because the header type is Type0.                     |     |
|              |                 | Bit 23 is fixed to 1b because the multifunction device is used.                     |     |
| b15 to b8    | LATENCY_TIMER   | Use this bit to report the latency timer to the system.                             | R/W |
|              |                 | The lowest 2 bits are fixed to 00b.                                                 |     |
| b7 to b0     | CACHE_LINE_SIZE | Use this bit to report the cache line size to the system.                           | R/W |

#### 10.5.3.5 BASEAD — OHCI Base Address

Address: 4003 0010h



Table 10.48 BASEAD Register Contents

| Bit Position | Bit Name                   | Function                                                                                                                                                                                                                    | R/W |
|--------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b4    | OHCI_BASE_ADDRE<br>SS      | Use bits [31:12] to specify the base address of the operational register.  Set the operational register base address value.  Bits [11:4] is fixed to 00h. i.e. operational registers are allocated to a 4 KB address space. | R/W |
| b3           | PREFETCHABLE               | This bit is fixed to 0b because the host controller does not support prefetching in memory read cycles.                                                                                                                     | R   |
| b2, b1       | TYPE                       | Indicates that the base address of the OHCl operational registers is 32-bit width, and thus the registers can be allocated to any location in a 32-bit memory space.  This field is fixed to 00h.                           | R   |
| b0           | MEMORY_SPACE_I<br>NDICATOR | Indicates that the OHCI operational registers are mapped on a system memory space. This bit is fixed to 0b.                                                                                                                 | R   |

#### 10.5.3.6 SSVID\_SSID — Subsystem ID - Subsystem Vendor ID (OHCI)

Address: 4003 002Ch

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25  | b24    | b23     | b22  | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|------|--------|---------|------|-----|-----|-----|-----|-----|-----|
|                   |     |     |     |     |     |     |      | SUBSYS | STEM_ID | )    |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0      | 0       | 0    | 1   | 1   | 0   | 1   | 0   | 1   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9   | b8     | b7      | b6   | b5  | b4  | b3  | b2  | b1  | b0  |
|                   |     |     |     |     |     |     | SUBS | SYSTEM | _VENDO  | R_ID |     |     |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 1   | 0   | 0   | 0    | 0      | 0       | 0    | 1   | 1   | 0   | 0   | 1   | 1   |

Table 10.49 SSVID\_SSID Register Contents

| Bit Position | Bit Name                | Function                                                                                                                                               | R/W |
|--------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | SUBSYSTEM_ID            | Indicates the device type.  This field is used to select a driver specified by the PCI specification.  It is not necessary for this host controller.   | R   |
| b15 to b0    | SUBSYSTEM_VEND<br>OR_ID | Indicates the device vendor.  This field is used to select a driver specified by the PCI specification.  It is not necessary for this host controller. | R   |

#### 10.5.3.7 EROM\_BASEAD — Expansion ROM Base Address (OHCI)

Address: 4003 0030h



Table 10.50 EROM\_BASEAD Register Contents

| Bit Position | Bit Name                       | Function                                                                         | R/W |
|--------------|--------------------------------|----------------------------------------------------------------------------------|-----|
| b31 to b10   | EXPANSION_ROM_<br>BASE_ADDRESS | This field is fixed to 000000h because decoding the expansion ROM is prohibited. | R   |
| b9 to b1     | Reserved                       |                                                                                  | R   |
| b0           | ROM_DECODE_ENA<br>BLE          | This bit is fixed to 0b because decoding the expansion ROM is prohibited.        | R   |

#### 10.5.3.8 CAPPTR — Capability Pointer (OHCI)

Address: 4003 0034h

| Bit               | b31 | b30         | b29 | b28 | b27         | b26 | b25        | b24 | b23        | b22 | b21 | b20     | b19     | b18 | b17 | b16 |
|-------------------|-----|-------------|-----|-----|-------------|-----|------------|-----|------------|-----|-----|---------|---------|-----|-----|-----|
|                   | _   | _           | _   | _   | _           | _   | _          | _   | _          | _   | _   | _       | _       | _   | _   | _   |
| Value after reset | 0   | 0           | 0   | 0   | 0           | 0   | 0          | 0   | 0          | 0   | 0   | 0       | 0       | 0   | 0   | 0   |
| Dia               | h15 | <b>h</b> 44 | h40 | h40 | <b>h</b> 11 | h10 | <b>b</b> 0 | b0  | <b>b</b> 7 | h.C | b.E | h.4     | h0      | b0  | h.1 | h0  |
| Bit<br>[          | b15 | b14         | b13 | b12 | b11         | b10 | b9         | b8  | b7         | b6  | b5  | b4      | b3      | b2  | b1  | b0  |
|                   | _   | _           | _   | _   | _           | _   | _          | _   |            |     | CA  | PABILIT | Y_POINT | ER  |     |     |
| Value after reset | 0   | 0           | 0   | 0   | 0           | 0   | 0          | 0   | 0          | 1   | 0   | 0       | 0       | 0   | 0   | 0   |

Table 10.51 CAPPTR Register Contents

| Bit Position | Bit Name               | Function                                                                                                                     | R/W |
|--------------|------------------------|------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b8    | Reserved               |                                                                                                                              | R   |
| b7 to b0     | CAPABILITY_POINT<br>ER | This is a pointer to the capability identifier.  "40h" means that the identifier is allocated to 40h in the host controller. | R   |

### 10.5.3.9 INTR\_LINE\_PIN — Max\_Lat - Min\_Gnt - Interrupt Pin - Interrupt Line (OHCI)

Address: 4003 003Ch



Table 10.52 INTR\_LINE\_PIN Register Contents

| Bit Position | Bit Name       | Function                                                    | R/W |
|--------------|----------------|-------------------------------------------------------------|-----|
| b31 to b24   | MAX_LATENCY    | Indicates the maximum acquisition frequency of the PCI bus. | R   |
|              |                | This host controller is implemented as 2Ah                  |     |
| b23 to b16   | MIN_GNT        | Indicates the minimum burst transfer time.                  | R   |
|              |                | This host controller is implemented as 01h                  |     |
| b15 to b8    | INTERRUPT_PIN  | Indicates the interrupt output pin.                         | R   |
|              |                | This bit is fixed at 01h since INTA is used.                |     |
| b7 to b0     | INTERRUPT_LINE | Indicates the interrupt line.                               | R/W |
|              |                | Keep 00h in this host controller                            |     |

## 10.5.3.10 CAPID\_NIP\_PMCAP — Capability Identifier - Next Item Pointer - Power Management Capabilities (OHCI)

Address: 4003 0040h



Table 10.53 CAPID\_NIP\_PMCAP Register Contents

| Bit Position | Bit Name                  | Function                                                                                                                                                                                                                                                 | R/W |
|--------------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b27   | PME_SUPPORT               | [31]: Indicates whether the D3 Cold state is supported. This bit is fixed to 0b because the D3 Cold state is not supported [30:27]: Indicates that PME interrupt generation is supported in all PCI power states (D0 to D3). This bit is fixed to 1111b. | R   |
| b26          | D2_SUPPORT                | Power Management Capabilities - Indicates that the PCI power state D2 is supported. This bit is fixed to 1b.                                                                                                                                             | R   |
| b25          | D1_SUPPORT                | Power Management Capabilities - Indicates that the PCI power state D1 is supported. This bit is fixed to 1b.                                                                                                                                             | R   |
| b24 to b22   | AUX_CURRENT               | Power Management Capabilities - Indicates the specified current value required for the 3.3 V auxiliary power supply. Generating PME interrupts in the D3 Cold state is not supported, therefore these bits are fixed to 000b.                            | R   |
| b21          | DSI                       | Power Management Capabilities - Indicates that no special initialization is required for using power management.  This bit is fixed to 0b.                                                                                                               | R   |
| b20          | Reserved                  |                                                                                                                                                                                                                                                          | R   |
| b19          | PME_CLK                   | Power Management Capabilities - Indicates that USB_PCICLK is not required for generating PME interrupts.  This bit is fixed to 0b.                                                                                                                       | R   |
| b18 to b16   | VERSION                   | Power Management Capabilities - Indicates that this system is compliant with PCI power management interface specification release 1.1.  This bit is fixed to 010b.                                                                                       | R   |
| b15 to b8    | NEXT_ITEM_POINTE<br>R     | Indicates that there is no subsequent item. This bit is fixed to 00h.                                                                                                                                                                                    | R   |
| b7 to b0     | CAPABILITY_IDENTI<br>FIER | Indicates the PCI power management register ID. This bit is fixed to 01h.                                                                                                                                                                                | R   |

# 10.5.3.11 PMC\_STS\_PMCSR — Power Management Control and Status - PMCSR Bridge Support Extensions (OHCI)

Address: 4003 0044h

| Bit               | b31            | b30 | b29 | b28   | b27   | b26 | b25 | b24            | b23                 | b22 | b21 | b20 | b19 | b18 | b17   | b16    |
|-------------------|----------------|-----|-----|-------|-------|-----|-----|----------------|---------------------|-----|-----|-----|-----|-----|-------|--------|
|                   |                |     |     | DA    | ·ΤΑ   |     |     |                | BPCC_<br>ENABL<br>E |     | _   | ı   | ı   | l   | _     | _      |
| Value after reset | 0              | 0   | 0   | 0     | 0     | 0   | 0   | 0              | 0                   | 0   | 0   | 0   | 0   | 0   | 0     | 0      |
| Bit               | b15            | b14 | b13 | b12   | b11   | b10 | b9  | b8             | b7                  | b6  | b5  | b4  | b3  | b2  | b1    | b0     |
|                   | PME_S<br>TATUS |     |     | DATA_ | SCALE |     |     | PME_E<br>NABLE |                     | _   | _   | _   | _   | _   | POWER | R_STAT |
| Value after reset | 0              | 0   | 0   | 0     | 0     | 0   | 0   | 0              | 0                   | 0   | 0   | 0   | 0   | 0   | 0     | 0      |

Table 10.54 PMC\_STS\_PMCSR Register Contents

| Bit Position | Bit Name    | Function                                                                                                                                                                                                                                                                  | R/W |
|--------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | DATA        | This bit is fixed to 00h. This is an optional field in the PCI specification and is not supported in this host controller.                                                                                                                                                | R   |
| b23          | BPCC_ENABLE | This bit is fixed to 0b. This is a bit for the bridge and is not supported in this host controller.                                                                                                                                                                       | R   |
| b22          | B2_B3       | This bit is fixed to 0b. This is a bit for the bridge and is not supported in this host controller.                                                                                                                                                                       | R   |
| b21 to b16   | Reserved    | Should be 0 at writing.                                                                                                                                                                                                                                                   | R   |
| b15          | PME_STATUS  | PME interrupt status.                                                                                                                                                                                                                                                     | R/W |
|              |             | This bit is set to 1b when a PME generation condition is satisfied. PME generation condition: Bit 3 (RD) of the HcInterruptStatus register is set to 1b while bit 10 (RWE) of the HcControl register is 1b. This bit is cleared to 0b when 1b is written via the PCI bus. |     |
| b14 to b9    | DATA_SCALE  | This bit is fixed to 00b. This is an optional field in the PCI specification and is not supported in this host controller.                                                                                                                                                | R   |
| b8           | PME_ENABLE  | Enable of PME.  If this bit is set to 1b, a PME interrupt is generated when the system returns from power management.                                                                                                                                                     | R/W |
| b7 to b2     | Reserved    | Should be 0 at writing.                                                                                                                                                                                                                                                   | R   |
| b1, b0       | POWER_STATE | Indicates the PCI power status.  00b: D0 State  01b: D1 State  10b: D2 State  11b: D3 hot State.                                                                                                                                                                          | R/W |

### 10.5.3.12 EXT1 — EXT1 Register (OHCI)

Address: 4003 00E0h

| Bit               | b31 | b30 | b29                                            | b28 | b27 | b26 | b25 | b24 | b23                     | b22    | b21          | b20    | b19    | b18   | b17  | b16  |
|-------------------|-----|-----|------------------------------------------------|-----|-----|-----|-----|-----|-------------------------|--------|--------------|--------|--------|-------|------|------|
|                   |     |     |                                                | POT | PGT |     |     |     | HYPER_                  | _SPEED | _TRANS<br>_2 | FER_CO | ONTROL | _     | 1    | _    |
| Value after reset | 0   | 0   | 0                                              | 0   | 1   | 1   | 1   | 1   | 0                       | 0      | 0            | 1      | 0      | 1     | 0    | 0    |
| Bit               | b15 | b14 | b13                                            | b12 | b11 | b10 | b9  | b8  | b7                      | b6     | b5           | b4     | b3     | b2    | b1   | b0   |
|                   | _   | I   | HYPER_<br>SPEED_T<br>RANSFE<br>R_CONT<br>ROL_1 | _   |     |     |     |     | ID_WRI<br>TE_EN<br>ABLE |        | ı            |        |        | PPCNT | PORT | г_NO |
| Value after reset | 0   | 0   | 1                                              | 1   | 0   | 0   | 1   | 1   | 0                       | 0      | 0            | 1      | 1      | 1     | Х    | Х    |

Table 10.55 EXT1 Register Contents

| Table 10.55  | EXTT Register Cor                      | nems                                                                                                                                                                                          |     |
|--------------|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Bit Position | Bit Name                               | Function                                                                                                                                                                                      | R/W |
| b31 to b24   | POTPGT                                 | Specify the setting for bits [31:24] (POTPGT) of the OHCI HcRhDescriptorA register. POTPGT is the required waiting time for software access after root hub is powered on.                     | R/W |
| b23 to b19   | HYPER_SPEED_TR<br>ANSFER_CONTROL<br>_2 | Setting other than 02h (HS Asynchronous FIFO threshold = 64 bytes) is prohibited.                                                                                                             | R/W |
| b18 to b14   | Reserved                               | Keep the initial value                                                                                                                                                                        | R/W |
| b13          | HYPER_SPEED_TR                         | HS Async OUT advance Mode                                                                                                                                                                     | R/W |
|              | ANSFER_CONTROL<br>_1                   | Specify the hyper-speed transfer mode feature used for asynchronous OUT transfer. Setting this bit to 1b enables this feature (thus increasing the transfer rate).                            |     |
| b12 to b8    | Reserved                               | Keep the initial value                                                                                                                                                                        | R/W |
| b7           | ID_WRITE_ENABLE                        | Control write protection for parameters Subsystem ID, Subsystem Vendor ID, Max Latency, and Min Gnt.                                                                                          | R/W |
|              |                                        | 0: Write protected                                                                                                                                                                            |     |
|              |                                        | 1: Enable write.                                                                                                                                                                              |     |
| b6 to b3     | Reserved                               | Keep the initial value                                                                                                                                                                        | R/W |
| b2           | PPCNT                                  | Specify the setting for bit 4 (PPC) of the EHCI HCSPARAMS register.                                                                                                                           | R/W |
|              |                                        | <ol> <li>Set the PPC bit to 0b. This indicates that the system that incorporates the host<br/>controller does not have port power control switches and port power is always<br/>on</li> </ol> |     |
|              |                                        | 1: Set the PPC bit to 1b. This indicates that the system that incorporates the host controller has a port power control switch.                                                               |     |
|              |                                        | Set this bit to 0b if the port power is always on, or set bit 9 (NPS) of the OHCI HcRhDescriptorA register to 1b.                                                                             |     |
| b1, b0       | PORT_NO                                | Specify the number of valid USB downstream ports. Setting / Valid port                                                                                                                        | R/W |
|              |                                        | 1h: Port 1                                                                                                                                                                                    |     |
|              |                                        | 2h: Ports 1 and 2                                                                                                                                                                             |     |
|              |                                        | Other: Reserved.                                                                                                                                                                              |     |
|              |                                        | Do not use a value other than 1h or 2h                                                                                                                                                        |     |
|              |                                        | Value after reset                                                                                                                                                                             |     |
|              |                                        | 1-Host mode: 1h                                                                                                                                                                               |     |
|              |                                        | 2-Host mode: 2h                                                                                                                                                                               |     |

## 10.5.3.13 EXT2 — EXT2 Register (OHCI)

Address: 4003 00E4h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24                                    | b23 | b22 | b21 | b20 | b19 | b18            | b17                                            | b16                                   |
|-------------------|-----|-----|-----|-----|-----|-----|-----|----------------------------------------|-----|-----|-----|-----|-----|----------------|------------------------------------------------|---------------------------------------|
|                   | ı   | _   | _   | _   | _   | _   | _   | PLL_U<br>NLOCK<br>_ACCE<br>SS_MO<br>DE | _   | _   | _   |     | _   | ONNEC<br>T_CHE | NNECT_<br>CHECK_                               | RUN_R<br>AM_CO<br>NNECT<br>_CHEC<br>K |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                                      | 0   | 0   | 0   | 0   | 0   | 0              | 0                                              | 0                                     |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8                                     | b7  | b6  | b5  | b4  | b3  | b2             | b1                                             | b0                                    |
|                   | ı   |     |     | _   | _   | _   | _   | _                                      | _   | _   | _   |     | _   | _              | HYPER_<br>SPEED_T<br>RANSFE<br>R_CONT<br>ROL_3 | MV CK                                 |
| Value after reset | 0   | 1   | 1   | 0   | 1   | 1   | 0   | 0                                      | 0   | 0   | 0   | 0   | 0   | 0              | 1                                              | 0                                     |

Table 10.56 EXT2 Register Contents

| Bit Position | Bit Name                               | Function                                                                                                                                                                                                                                                                                                                                                                                                        | R/W |
|--------------|----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b25   | Reserved                               | Should be 0 at writing.                                                                                                                                                                                                                                                                                                                                                                                         | R   |
| b24          | PLL_UNLOCK_ACCE<br>SS_MODE             | Set the response mode for register access during USBPLL unlock 0: Wait until USBPLL lock 1: Return dummy value until USBPLL has been locked                                                                                                                                                                                                                                                                     | R/W |
| b23 to b19   | Reserved                               | Keep the initial value                                                                                                                                                                                                                                                                                                                                                                                          | R/W |
| b18          | RAM_CONNECT_CH<br>ECK_RESULT           | Indicates the result of RAM connection check.  0: NG  1: OK  This bit is valid when the RAM_CONNECT_CHECK_END_FLAG bit is 1b. Once a connection check is performed, this flag is not cleared until the RUN_RAM_CONNECT_CHECK bit changes from 0b to 1b.                                                                                                                                                         | R   |
| b17          | RAM_CONNECT_CH<br>ECK_END_FLAG         | Indicates the end of RAM connection check.  0: Connection check has not been performed/has not finished  1: Connection check finished.  After the RUN_RAM_CONNECT_CHECK bit is set to 1b, RAM connection check starts, a certain period (about 2 us) passes, and then this bit is asserted.                                                                                                                     | R   |
| b16          | RUN_RAM_CONNEC<br>T_CHECK              | Use this bit to trigger a RAM connection check. Set this bit to 1b to start a RAM connection check. This bit is not cleared automatically when the check finishes. To execute checking again, write 0b to this bit to clear it, and then write 1b again. The connection check circuit is reset when this bit is set to 1b, and the RAM_CONNECT_CHECK_END_FLAG bit and RAM_CONNECT_CHECK_RESULT bit are cleared. | R/W |
| b15 to b2    | Reserved                               | Keep the initial value                                                                                                                                                                                                                                                                                                                                                                                          | R/W |
| b1           | HYPER_SPEED_TR<br>ANSFER_CONTROL<br>_3 | Specify the hyper-speed transfer mode feature used for asynchronous IN/OUT transfer. Setting this bit to 1b enables this feature (thus increasing the transfer rate).                                                                                                                                                                                                                                           | R/W |
| b0           | EHCI_MASK                              | Mask (enable) of EHCI host controller.  0: Enable the EHCI host controller  1: Disable the EHCI host controller.  If this bit is set to 1, accessing registers in PCI configuration space and memory space in the EHCI is disabled, so the EHCI host controller does not run.                                                                                                                                   | R/W |

### 10.5.3.14 UTMICTRL — USBPHY Operation Mode Control Register (OHCI)

Address: 4003 00F4h



Table 10.57 UTMICTRL Register Contents

| Bit Position | Bit Name | Function                                                                                                                            | R/W |
|--------------|----------|-------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b18   | Reserved | Keep the initial value                                                                                                              | R/W |
| b17, b16     | REPSEL   | Specify the interval of periodic terminal resistance adjustment.  Set this bit to 00b during initialization of the host controller. | R/W |
| b15 to b0    | Reserved | Keep the initial value                                                                                                              | R/W |

## 10.5.4 EHCI (PCI Configuration Space) Register Description

#### 10.5.4.1 VID\_DID — Device ID - Vendor ID (EHCI)

Address: 4003 0100h



Table 10.58 VID\_DID Register Contents

| Bit Position | Bit Name  | Function                                                                                                                                               | R/W |
|--------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | DEVICE_ID | Indicates the device type.  This field is used to select a driver specified by the PCI specification.  It is not necessary for this host controller.   | R   |
| b15 to b0    | VENDOR_ID | Indicates the device vendor.  This field is used to select a driver specified by the PCI specification.  It is not necessary for this host controller. | R   |

## 10.5.4.2 CMND\_STS — Status - Command (EHCI)

Address: 4003 0104h

| Bit               | b31             | b30                               | b29            | b28            | b27            | b26         | b25    | b24                                    | b23               | b22                               | b21            | b20                       | b19                   | b18            | b17                  | b16           |
|-------------------|-----------------|-----------------------------------|----------------|----------------|----------------|-------------|--------|----------------------------------------|-------------------|-----------------------------------|----------------|---------------------------|-----------------------|----------------|----------------------|---------------|
|                   | TED_P<br>ARITY_ | SIGNAL<br>ED_SY<br>STEM_<br>ERROR | ED_MA<br>STER_ | ED_TA<br>RGET_ | ED_TA<br>RGET_ | DEVSEL<br>G | _TIMIN | DATA_PA<br>RITY_ER<br>ROR_DE<br>TECTED | CK_TO_B<br>ACK_CA | _                                 |                | CAPABI<br>LITIES_<br>LIST | _                     | l              | 1                    | _             |
| Value after reset | 0               | 0                                 | 0              | 0              | 0              | 0           | 1      | 0                                      | 0                 | 0                                 | 0              | 1                         | 0                     | 0              | 0                    | 0             |
| Bit               | b15             | b14                               | b13            | b12            | b11            | b10         | b9     | b8                                     | b7                | b6                                | b5             | b4                        | b3                    | b2             | b1                   | b0            |
|                   | _               | _                                 | ı              | ı              | _              | _           |        | SERR_<br>ENABL<br>E                    | CYCLE<br>_CONT    | PARITY<br>_ERRO<br>R_RES<br>PONSE | ALETT<br>E_SNO | _WRITE_                   | SPECIA<br>L_CYC<br>LE | BUS_M<br>ASTER | MEMO<br>RY_SP<br>ACE | I_O_SP<br>ACE |
| Value after reset | 0               | 0                                 | 0              | 0              | 0              | 0           | 0      | 0                                      | 0                 | 0                                 | 0              | 0                         | 0                     | 0              | 0                    | 0             |

Table 10.59 CMND\_STS Register Contents (1/2)

| Bit Position | Bit Name                       | Function                                                                                                                                                                                                                                         | R/W |
|--------------|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31          | DETECTED_PARITY<br>_ERROR      | Indicates the parity error status.  This bit is set when an address or data parity error is detected, cleared when 1b is written via the PCI bus.                                                                                                | R/W |
| b30          | SIGNALED_SYSTEM<br>_ERROR      | Indicates the SERR status.  This bit is set when a system error occurs, cleared when 1b is written via the PCI bus.                                                                                                                              | R/W |
| b29          | RECEIVED_MASTER<br>_ABORT      | Indicates the Master-Master Abort status.  This bit is set to 1b when the bus cycle executed by the host controller serving as a master terminates due to Master Abort signaling, cleared when 1b is written via the PCI bus.                    | R/W |
| b28          | RECEIVED_TARGET<br>_ABORT      | Indicates the Master-Target Abort status.  This bit is set to 1b when the bus cycle executed by the host controller serving as a master terminates due to Target Abort signaling, cleared when 1b is written via the PCI bus.                    | R/W |
| b27          | SIGNALED_TARGET<br>_ABORT      | Indicates the Slave Target Abort status.  This bit is set to 1b when the bus cycle of the host controller serving as a slave being accessed is terminated due to Target Abort signaling. This bit is cleared when 1b is written via the PCI bus. | R/W |
| b26, b25     | DEVSEL_TIMING                  | Indicates the DEVSEL response speed. This bit is fixed to 01b (mid-speed response).                                                                                                                                                              | R   |
| b24          | DATA_PARITY_ERR<br>OR_DETECTED | This bit is set when the host controller serving as a master detects a parity error, cleared when 1b is written via the PCI bus.  This bit is fixed to 0b when the Parity Error Response bit is set to 0.                                        | R/W |
| b23          | FAST_BACK_TO_BA<br>CK_CAPABLE  | Indicates whether Fast Back to Back is supported. This bit is fixed to 0b because Fast Back to Back is not supported.                                                                                                                            | R   |
| b22          | Reserved                       | Should be 0 at writing.                                                                                                                                                                                                                          | R   |
| b21          | MHZ66_CAPABLE                  | Indicates 66 MHz operation capability. This bit is fixed at 0b, i.e. 33 MHz only.                                                                                                                                                                | R   |
| b20          | CAPABILITIES_LIST              | Indicates whether power management mode is supported. This bit is fixed to 1b.                                                                                                                                                                   | R   |
| b19 to b10   | Reserved                       | Should be 0 at writing.                                                                                                                                                                                                                          | R   |
| b9           | FAST_BACK_TO_BA<br>CK_ENABLE   | Use this bit to enable Fast Back to Back.  This bit is fixed to 0b because the host controller does not support Fast Back to Back.                                                                                                               | R   |

Table 10.59 CMND\_STS Register Contents (2/2)

| Table 10.59  | CIVIND_515 Regist                          | er contents (2/2)                                                                                                                                                                                     |     |
|--------------|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Bit Position | Bit Name                                   | Function                                                                                                                                                                                              | R/W |
| b8           | SERR_ENABLE                                | Use this bit to enable system error response.  0: Do not assert SERR0  1: Assert SERR0                                                                                                                | R/W |
|              |                                            | Set this bit to 1b to signal the system error by using the SERR signal.                                                                                                                               |     |
| b7           | WAIT_CYCLE_CONT<br>ROL                     | Enables Wait Cycle Control. This bit is always 0b since the host controller does not support Address or Data Stepping.                                                                                | R   |
| b6           | PARITY_ERROR_RE<br>SPONSE                  | Use this bit to enable parity error response.  0: Do not assert PERR0  1: Assert PERR0  The DETECTED_PARITY_ERROR bit is set to 1b even if this bit is 0 when a parity error is detected.             | R/W |
| b5           | VGA_PALETTE_SNO<br>OP                      | Use this bit to enable VGA Palette Snoop.  This bit is fixed to 0b (not supported)                                                                                                                    | R   |
| b4           | MEMORY_WRITE_A<br>ND_INVALIDATE_EN<br>ABLE | Use this bit to enable Memory Write and Invalidate. This bit should be remained as initial value,0                                                                                                    | R/W |
| b3           | SPECIAL_CYCLE                              | Use this bit to enable Special Cycle. This bit is fixed to 0b (not supported)                                                                                                                         | R   |
| b2           | BUS_MASTER                                 | Use this bit to enable the bus master.  This is a signal to enable master access to the PCI bus. Set this bit to 1b when accessing SRAM on the system bus.  Set this bit to 1b during initialization. | R/W |
| b1           | MEMORY_SPACE                               | Use this bit to enable accessing to the memory spaces.  This is a signal to enable memory access prescribed in the PCI specification.  Set this bit to 1b during initialization.                      | R/W |
| b0           | I_O_SPACE                                  | Use this bit to enable accessing to the I/O spaces.  This bit is fixed to 0b because the host controller does not acknowledge I/O accesses.                                                           | R   |

#### 10.5.4.3 REVID\_CC — Class Code - Revision ID (EHCI)

Address: 4003 0108h

| Bit               | b31 | b30 | b29 | b28    | b27     | b26 | b25 | b24 | b23 | b22 | b21 | b20   | b19    | b18 | b17 | b16 |
|-------------------|-----|-----|-----|--------|---------|-----|-----|-----|-----|-----|-----|-------|--------|-----|-----|-----|
|                   |     |     |     | BASE_  | CLASS   |     |     |     |     |     |     | SUB_0 | CLASS  |     |     |     |
| Value after reset | 0   | 0   | 0   | 0      | 1       | 1   | 0   | 0   | 0   | 0   | 0   | 0     | 0      | 0   | 1   | 1   |
| Bit               | b15 | b14 | b13 | b12    | b11     | b10 | b9  | b8  | b7  | b6  | b5  | b4    | b3     | b2  | b1  | b0  |
|                   |     |     | PI  | ROGRAN | MMING_I | _F  |     |     |     |     |     | REVIS | ION_ID |     |     |     |
| Value after reset | 0   | 0   | 1   | 0      | 0       | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0      | 0   | 0   | 1   |

Table 10.60 REVID\_CC Register Contents

| Bit Position | Bit Name        | Function                                                          | R/W |
|--------------|-----------------|-------------------------------------------------------------------|-----|
| b31 to b24   | BASE_CLASS      | Indicates the base class defined in the PCI specification.        | R   |
|              |                 | "0Ch" means that a serial peripheral bus controller.              |     |
| b23 to b16   | SUB_CLASS       | Indicates the subclass defined in the PCI specification.          | R   |
|              |                 | "03h" means that USB device.                                      |     |
| b15 to b8    | PROGRAMMING_I_F | Indicates the program interface defined in the PCI specification. | R   |
|              |                 | "20h" means that EHCI.                                            |     |
| b7 to b0     | REVISION_ID     | Indicates the host controller revision.                           | R   |
|              |                 | This bit is fixed to 01h.                                         |     |

## 10.5.4.4 CLS\_LT\_HT\_BIST — BIST - Header Type - Latency Timer - Cache Line Size (EHCI)

Address: 4003 010Ch



Table 10.61 CLS\_LT\_HT\_BIST Register Contents

| Bit Position | Bit Name        | Function                                                                            | R/W |
|--------------|-----------------|-------------------------------------------------------------------------------------|-----|
| b31 to b24   | BIST            | This bit is used for self-testing.                                                  | R   |
|              |                 | This bit is fixed to 00h because the host controller does not support self-testing. |     |
| b23 to b16   | HEADER_TYPE     | Use this bit to report the header type to the system.                               | R   |
|              |                 | Bits [22:16] are fixed to 00h because the header type is Type0.                     |     |
|              |                 | Bit 23 is fixed to 0b because the multifunction device is not used.                 |     |
| b15 to b8    | LATENCY_TIMER   | Use this bit to report the latency timer to the system.                             | R/W |
|              |                 | The lowest 2 bits are fixed to 00b.                                                 |     |
| b7 to b0     | CACHE_LINE_SIZE | Use this bit to report the cache line size to the system.                           | R/W |

#### 10.5.4.5 BASEAD — EHCI Base Address

Address: 4003 0110h

| Bit               | b31                                                 | b30               | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18                                | b17 | b16 |
|-------------------|-----------------------------------------------------|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|------------------------------------|-----|-----|
|                   |                                                     | EHCI_BASE_ADDRESS |     |     |     |     |     |     |     |     |     |     |     |                                    |     |     |
| Value after reset | 0                                                   | 0                 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                                  | 0   | 0   |
| Bit               | b15                                                 | b14               | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2                                 | b1  | b0  |
|                   | EHCI_BASE_ADDRESS   PREFE   SF   TCHAB   TYPE   INI |                   |     |     |     |     |     |     |     |     |     |     |     | MEMORY<br>_SPACE_<br>INDICAT<br>OR |     |     |
| Value after reset | 0                                                   | 0                 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                                  | 0   | 0   |

Table 10.62 BASEAD Register Contents

| Bit Position | Bit Name                   | Function                                                                                                                                                                                                                      | R/W |
|--------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b4    | EHCI_BASE_ADDRE<br>SS      | Use bits [31:8] to specify the base address of the operational register.  Set the operational register base address value.  Bits [7:4] is fixed to 00h. i.e. operational registers are allocated to a 256-byte address space. | R/W |
| b3           | PREFETCHABLE               | This bit is fixed to 0b because the host controller does not support prefetching in memory read cycles.                                                                                                                       | R   |
| b2, b1       | TYPE                       | Indicates that the base address of the EHCl operational registers is 32-bit width, and thus the registers can be allocated to any location in a 32-bit memory space.  This field is fixed to 00b.                             | R   |
| b0           | MEMORY_SPACE_I<br>NDICATOR | Indicates that the EHCl operational registers are mapped on a system memory space. This bit is fixed to 0b.                                                                                                                   | R   |

## 10.5.4.6 SSVID\_SSID — Subsystem ID - Subsystem Vendor ID (EHCI)

Address: 4003 012Ch



Table 10.63 SSVID\_SSID Register Contents

| Bit Position | Bit Name       | Function                                                                  | R/W |  |  |  |  |  |  |
|--------------|----------------|---------------------------------------------------------------------------|-----|--|--|--|--|--|--|
| b31 to b16   | SUBSYSTEM_ID   | Indicates the device type.                                                | R   |  |  |  |  |  |  |
|              |                | This field is used to select a driver specified by the PCI specification. |     |  |  |  |  |  |  |
|              |                | It is not necessary for this host controller.                             |     |  |  |  |  |  |  |
| b15 to b0    | SUBSYSTEM_VEND | Indicates the device vendor.                                              | R   |  |  |  |  |  |  |
|              | OR_ID          | This field is used to select a driver specified by the PCI specification. |     |  |  |  |  |  |  |
|              |                | It is not necessary for this host controller.                             |     |  |  |  |  |  |  |

#### 10.5.4.7 EROM\_BASEAD — Expansion ROM Base Address (EHCI)

Address: 4003 0130h

| Bit               | b31                        | b30                        | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16                       |
|-------------------|----------------------------|----------------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---------------------------|
|                   |                            | EXPANSION_ROM_BASE_ADDRESS |     |     |     |     |     |     |     |     |     |     |     |     |     |                           |
| Value after reset | 0                          | 0                          | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                         |
| Bit               | b15                        | b14                        | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0                        |
|                   | EXPANSION_ROM_BASE_ADDRESS |                            |     |     |     |     |     | _   | _   | _   | _   | _   | _   | _   | _   | ROM_DE<br>CODE_E<br>NABLE |
| Value after reset | 0                          | 0                          | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                         |

Table 10.64 EROM\_BASEAD Register Contents

| Bit Position | Bit Name                       | Function                                                                         | R/W |
|--------------|--------------------------------|----------------------------------------------------------------------------------|-----|
| b31 to b10   | EXPANSION_ROM_<br>BASE_ADDRESS | This field is fixed to 000000h because decoding the expansion ROM is prohibited. | R   |
| 1.0 to 1.4   |                                |                                                                                  | _   |
| b9 to b1     | Reserved                       |                                                                                  | R   |

### 10.5.4.8 CAPPTR — Capability Pointer (EHCI)

Address: 4003 0134h



Table 10.65 CAPPTR Register Contents

| Bit Position | Bit Name               | Function                                                                                                                     | R/W |
|--------------|------------------------|------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b8    | Reserved               |                                                                                                                              | R   |
| b7 to b0     | CAPABILITY_POINT<br>ER | This is a pointer to the capability identifier.  "40h" means that the identifier is allocated to 40h in the host controller. | R/W |

### 10.5.4.9 INTR\_LINE\_PIN — Max\_Lat - Min\_Gnt - Interrupt Pin - Interrupt Line (EHCI)

Address: 4003 013Ch

| Bit               | b31           | b30 | b29 | b28    | b27    | b26 | b25 | b24 | b23     | b22 | b21 | b20    | b19     | b18 | b17 | b16 |  |
|-------------------|---------------|-----|-----|--------|--------|-----|-----|-----|---------|-----|-----|--------|---------|-----|-----|-----|--|
|                   |               |     |     | MAX_LA | ATENCY |     |     |     | MIN_GNT |     |     |        |         |     |     |     |  |
| Value after reset | 0             | 0   | 1   | 0      | 0      | 0   | 1   | 0   | 0       | 0   | 0   | 1      | 0       | 0   | 0   | 0   |  |
| Bit               | b15           | b14 | b13 | b12    | b11    | b10 | b9  | b8  | b7      | b6  | b5  | b4     | b3      | b2  | b1  | b0  |  |
|                   | INTERRUPT_PIN |     |     |        |        |     |     |     |         |     | I   | NTERRU | JPT_LIN | E   |     |     |  |
| Value after reset | 0             | 0   | 0   | 0      | 0      | 0   | 1   | 0   | 0       | 0   | 0   | 0      | 0       | 0   | 0   | 0   |  |

Table 10.66 INTR\_LINE\_PIN Register Contents

| Bit Position | Bit Name       | Function                                                    | R/W |
|--------------|----------------|-------------------------------------------------------------|-----|
| b31 to b24   | MAX_LATENCY    | Indicates the maximum acquisition frequency of the PCI bus. | R   |
|              |                | This host controller is implemented as 22h                  |     |
| b23 to b16   | MIN_GNT        | Indicates the minimum burst transfer time.                  | R   |
|              |                | This host controller is implemented as 10h                  |     |
| b15 to b8    | INTERRUPT_PIN  | Indicates the interrupt output pin.                         | R   |
|              |                | This bit is fixed at 02h since INTB is used.                |     |
| b7 to b0     | INTERRUPT_LINE | Indicates the interrupt line.                               | R/W |
|              |                | Keep 00h in this host controller                            |     |

# 10.5.4.10 CAPID\_NIP\_PMCAP — Capability Identifier - Next Item Pointer - Power Management Capabilities (EHCI)

Address: 4003 0140h

| Bit                    | b31            | b30 | b29 | b28     | b27    | b26 | b25            | b24 | b23 | b22 | b21     | b20     | b19                | b18 | b17 | b16 |
|------------------------|----------------|-----|-----|---------|--------|-----|----------------|-----|-----|-----|---------|---------|--------------------|-----|-----|-----|
|                        | PME_SUPPORT PP |     |     |         |        |     | D1_SU<br>PPORT |     |     |     | DSI     | _       | PME_C<br>LK VERSIO |     |     | 1   |
| Value after reset      | 0              | 1   | 1   | 1       | 1      | 1   | 1              | 0   | 0   | 0   | 0       | 0       | 0                  | 0   | 1   | 0   |
| Bit                    | b15            | b14 | b13 | b12     | b11    | b10 | b9             | b8  | b7  | b6  | b5      | b4      | b3                 | b2  | b1  | b0  |
|                        |                |     | NE  | XT_ITEN | /_POIN | TER |                |     |     | CAP | ABILITY | _IDENTI | FIER               |     |     |     |
| ا<br>Value after reset | 0              | 0   | 0   | 0       | 0      | 0   | 0              | 0   | 0   | 0   | 0       | 0       | 0                  | 0   | 0   | 1   |

Table 10.67 CAPID\_NIP\_PMCAP Register Contents

| Bit Position | Bit Name          | Function                                                                                                                                                                                                         | R/W |
|--------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b27   | PME_SUPPORT       | [31]:                                                                                                                                                                                                            | R   |
|              |                   | Indicates whether the D3 Cold state is supported.                                                                                                                                                                |     |
|              |                   | This bit is fixed to 0b because the D3 Cold state is not supported                                                                                                                                               |     |
|              |                   | [30:27]:                                                                                                                                                                                                         |     |
|              |                   | Indicates that PME interrupt generation is supported in all PCI power states                                                                                                                                     |     |
|              |                   | (D0 to D3). This bit is fixed to 1111b.                                                                                                                                                                          |     |
| b26          | D2_SUPPORT        | Power Management Capabilities - Indicates that the PCI power state D2 is supported. This bit is fixed to 1b.                                                                                                     | R   |
| b25          | D1_SUPPORT        | Power Management Capabilities - Indicates that the PCI power state D1 is supported. This bit is fixed to 1b.                                                                                                     | R   |
| b24 to b22   | AUX_CURRENT       | Power Management Capabilities - Indicates the specified current value required for the 3.3 V auxiliary power supply. Generating PME interrupts in the D3 Cold state is not supported. This bit is fixed to 000b. | R   |
| b21          | DSI               | Power Management Capabilities - Indicates that no special initialization is required for using power management.                                                                                                 | R   |
|              |                   | This bit is fixed to 0b.                                                                                                                                                                                         |     |
| b20          | Reserved          |                                                                                                                                                                                                                  | R   |
| b19          | PME_CLK           | Power Management Capabilities - Indicates that USB_PCICLK is not required for generating PME interrupts.  This bit is fixed to 0b.                                                                               | R   |
| b18 to b16   | VERSION           | Power Management Capabilities - Indicates that this system is compliant with PCI power management interface specification release 1.1.                                                                           | R   |
|              |                   | This bit is fixed to 010b.                                                                                                                                                                                       |     |
| b15 to b8    | NEXT_ITEM_POINTE  | Indicates that there is no subsequent item.                                                                                                                                                                      | R   |
|              | R                 | This bit is fixed to 00h.                                                                                                                                                                                        |     |
| b7 to b0     | CAPABILITY_IDENTI | Indicates the PCI power management register ID.                                                                                                                                                                  | R   |
|              | FIER              | This bit is fixed to 01h.                                                                                                                                                                                        |     |

# 10.5.4.11 PMC\_STS\_PMCSR — Power Management Control and Status - PMCSR Bridge Support Extensions (EHCI)

Address: 4003 0144h

| Bit               | b31              | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23                 | b22 | b21 | b20 | b19 | b18 | b17   | b16    |
|-------------------|------------------|-----|-----|-----|-----|-----|-----|-----|---------------------|-----|-----|-----|-----|-----|-------|--------|
|                   |                  |     |     | DA  | ·ΤΑ |     |     |     | BPCC_<br>ENABL<br>E |     | _   | ı   | ı   | l   | _     | _      |
| Value after reset | 0                | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                   | 0   | 0   | 0   | 0   | 0   | 0     | 0      |
| Bit               | b15              | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7                  | b6  | b5  | b4  | b3  | b2  | b1    | b0     |
|                   | PME_S DATA_SCALE |     |     |     |     |     |     |     | _                   | _   | _   | _   | _   | _   | POWER | R_STAT |
| Value after reset | 0                | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0                   | 0   | 0   | 0   | 0   | 0   | 0     | 0      |

Table 10.68 PMC\_STS\_PMCSR Register Contents

| Bit Position | Bit Name    | Function                                                                                                                                                                                                                                                                  | R/W |
|--------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | DATA        | This bit is fixed to 00h. This is an optional field in the PCI specification and is not supported in this host controller.                                                                                                                                                | R   |
| b23          | BPCC_ENABLE | This bit is fixed to 0b. This is a bit for the bridge and is not supported in this host controller.                                                                                                                                                                       | R   |
| b22          | B2_B3       | This bit is fixed to 0b. This is a bit for the bridge and is not supported in this host controller.                                                                                                                                                                       | R   |
| b21 to b16   | Reserved    | Should be 0 at writing.                                                                                                                                                                                                                                                   | R   |
| b15          | PME_STATUS  | PME interrupt status.                                                                                                                                                                                                                                                     | R/W |
|              |             | This bit is set to 1b when a PME generation condition is satisfied. PME generation condition: Bit 3 (RD) of the HcInterruptStatus register is set to 1b while bit 10 (RWE) of the HcControl register is 1b. This bit is cleared to 0b when 1b is written via the PCI bus. |     |
| b14 to b9    | DATA_SCALE  | This bit is fixed to 00b. This is an optional field in the PCI specification and is not supported in this host controller.                                                                                                                                                | R   |
| b8           | PME_ENABLE  | Enable of PME.  If this bit is set to 1b, a PME interrupt is generated when the system returns from power management.                                                                                                                                                     | R/W |
| b7 to b2     | Reserved    | Should be 0 at writing.                                                                                                                                                                                                                                                   | R   |
| b1, b0       | POWER_STATE | Indicates the PCI power status.                                                                                                                                                                                                                                           | R/W |
|              |             | 00b: D0 State                                                                                                                                                                                                                                                             |     |
|              |             | 01b: D1 State                                                                                                                                                                                                                                                             |     |
|              |             | 10b: D2 State                                                                                                                                                                                                                                                             |     |
|              |             | 11b: D3 hot State.                                                                                                                                                                                                                                                        |     |

#### 10.5.4.12 SBRN\_FLADJ\_PW — SBRN - FLADJ - PORTWAKECAP

Address: 4003 0160h



Table 10.69 SBRN\_FLADJ\_PW Register Contents

| Bit Position | Bit Name    | Function                                                                                                                                                    | R/W |
|--------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | PORTWAKECAP | This bit is used to mask which port's wakeup event is used, among connected devices. The setting of this bit does not affect the host controller operation. | R/W |
| b15 to b8    | FLADJ       | Use this bit to adjust the length of 1 micro-frame in 16 HS bit time units.  The initial value is 20h (60000d HS bit time).                                 | R/W |
| b7 to b0     | SBRN        | Indicates the serial bus release number. This bit is fixed to 20h.                                                                                          | R   |

#### 10.5.4.13 EXT1 — EXT1 Register (EHCI)

The entity of this register is identical to EXT1 Register in OHCI configuration.

#### 10.5.4.14 EXT2 — EXT2 Register (EHCI)

The entity of this register is identical to EXT2 Register in OHCI configuration.

However, bit[0] (EHCI\_MASK) cannot be accessed from the EHCI side.

#### 10.5.4.15 UTMICTRL — USBPHY Operation Mode Control Register (EHCI)

The entity of this register is identical to USBPHY Operation Mode Control Register in OHCI configuration.

## 10.5.5 AHB-PCI Bridge (PCI Configuration Space) Register Description

#### 10.5.5.1 VID\_DID — Device ID - Vendor ID (AHB-PCI Bridge)

Address: 4003 0000h

| Bit               | b31       | b30 | b29 | b28 | b27 | b26 | b25 | b24  | b23   | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----------|-----|-----|-----|-----|-----|-----|------|-------|-----|-----|-----|-----|-----|-----|-----|
|                   |           |     |     |     |     |     |     | DEVI | CE_ID |     |     |     |     |     |     |     |
| Value after reset | 0         | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit r             | b15       | b14 | b13 | b12 | b11 | b10 | b9  | b8   | b7    | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                   | VENDOR_ID |     |     |     |     |     |     |      |       |     |     |     |     |     |     |     |
| Value after reset | 0         | 0   | 0   | 1   | 0   | 0   | 0   | 0    | 0     | 0   | 1   | 1   | 0   | 0   | 1   | 1   |

Table 10.70 VID\_DID Register Contents

| Bit Position | Bit Name  | Function                                                                                                                          | R/W |
|--------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | DEVICE_ID | Device type.  Use this field to select a driver specified by the PCI specification  These bits are not used for embedded hosts.   | R   |
| b15 to b0    | VENDOR_ID | Device vendor.  Use this field to select a driver specified by the PCI specification  These bits are not used for embedded hosts. | R   |

### 10.5.5.2 CMND\_STS — Status - Command (AHB-PCI Bridge)

Address: 4003 0004h

| Ві               | t b31       | b30         | b29          | b28          | b27           | b26 | b25        | b24        | b23         | b22        | b21         | b20         | b19          | b18          | b17   | b16  |
|------------------|-------------|-------------|--------------|--------------|---------------|-----|------------|------------|-------------|------------|-------------|-------------|--------------|--------------|-------|------|
|                  | DETPE<br>RR | SIGSE<br>RR | REMAB<br>ORT | RETAB<br>ORT | SIGTAB<br>ORT | DE\ | /TIM       | MDPER<br>R | FBTBC<br>AP | ı          | M66_C<br>AP | CAPLIS<br>T | ı            | I            | ı     | _    |
| Value after rese | t 0         | 0           | 0            | 0            | 0             | 0   | 1          | 0          | 0           | 0          | 0           | 0           | 0            | 0            | 0     | 0    |
| Bi               | t b15       | b14         | b13          | b12          | b11           | b10 | b9         | b8         | b7          | b6         | b5          | b4          | b3           | b2           | b1    | b0   |
|                  | _           | _           | _            | _            | _             | _   | FBTBE<br>N | SERRE<br>N | STEPC<br>TR | PERRE<br>N | VGAPS<br>NP | MWINV<br>EN | SPECIA<br>LC | MASTE<br>REN | MEMEN | IOEN |
| Value after rese | t 0         | 0           | 0            | 0            | 0             | 0   | 0          | 0          | 0           | 0          | 0           | 0           | 0            | 0            | 0     | 0    |

Table 10.71 CMND\_STS Register Contents (1/2)

| Bit Position | Bit Name  | Function                                                                                            | R/W |
|--------------|-----------|-----------------------------------------------------------------------------------------------------|-----|
| b31          | DETPERR   | Parity error status bit.                                                                            | R/W |
|              |           | This bit is set when an address or data parity error has been detected, cleared by writing 1b.      |     |
| b30          | SIGSERR   | SERR status bit.                                                                                    | R/W |
|              |           | This bit is set when a system error occurs, cleared by writing 1b.                                  |     |
| b29          | REMABORT  | Master Abort status bit.                                                                            | R/W |
|              |           | This bit is set when Master Abort has been received, cleared by writing 1b                          |     |
| b28          | RETABORT  | Master Target Abort status bit.                                                                     | R/W |
|              |           | This bit is set when Target Abort has been received, cleared by writing 1b.                         |     |
| b27          | SIGTABORT | Slave Target Abort status bit.                                                                      | R/W |
|              |           | This bit is set when Target Abort has been sent, cleared by writing 1b.                             |     |
| b26, b25     | DEVTIM    | Indicates a DEVSEL response speed. It is implemented as 01b (Medium Mode).                          | R   |
| b24          | MDPERR    | Parity error detection bit                                                                          | R/W |
|              |           | This bit is set when parity error has been detected during Master operation, cleared by writing 1b. |     |
| b23          | FBTBCAP   | Fast Back to Back capability. This bit is fixed at 0b. (Fast Back to Back is not supported)         | R   |
| b22          | Reserved  | Should be 0 at writing.                                                                             | R   |
| b21          | M66_CAP   | 66 MHz operation capability. This bit is fixed at 0b. (66 MHz is no supported)                      | R   |
| b20          | CAPLIST   | Support of Capabilities List. This bit is fixed at 0b. (Capabilities List is not supported)         | R   |
| b19 to b10   | Reserved  | Should be 0 at writing.                                                                             | R   |
| b9           | FBTBEN    | Enables Fast Back to Back. This bit is fixed at 0b.                                                 | R   |
| b8           | SERREN    | Set the operation when a system error is detected.                                                  | R/W |
|              |           | 0: Ignored (initial value)                                                                          |     |
|              |           | 1: SERR# is asserted.                                                                               |     |
|              |           | Set 1b at initialization of this host controller                                                    |     |
| b7           | STEPCTR   | Address Stepping control bit.                                                                       | R   |
|              |           | This bit is fixed at 0b. (Address Stepping is not supported)                                        |     |
| b6           | PERREN    | Set the operation when a parity error is detected.                                                  | R/W |
|              |           | 0: Ignored (initial value)                                                                          |     |
|              |           | 1: PERR# is asserted.                                                                               |     |
|              |           | Set 1b at initialization of this host controller                                                    |     |
| b5           | VGAPSNP   | Enable of VGA Palette Snoop. This bit is fixed at 0b.                                               | R   |
| b4           | MWINVEN   | Enable of Memory Write and Invalidate. This bit is fixed at 0b.                                     | R   |
| b3           | SPECIALC  | Enable of Special Cycle.                                                                            | R   |
|              |           | This bit is fixed at 0b.                                                                            |     |

Table 10.71 CMND\_STS Register Contents (2/2)

| Bit Position | Bit Name | Function                                                  | R/W |
|--------------|----------|-----------------------------------------------------------|-----|
| b2           | MASTEREN | Enable of PCI Master operation.                           | R/W |
|              |          | 0: Master operation is not permitted (initial value)      |     |
|              |          | 1: Master operation is permitted.                         |     |
|              |          | Set 1b at initialization of this host controller          |     |
| b1           | MEMEN    | Enable of PCI Slave operation.                            | R/W |
|              |          | 0: Memory cycle reception is not possible (initial value) |     |
|              |          | 1: Memory cycle reception is possible.                    |     |
|              |          | Set 1b at initialization of this host controller          |     |
| b0           | IOEN     | Enables access to the I/O space.                          | R   |
|              |          | This bit is fixed at 0b.                                  |     |

#### 10.5.5.3 REVID\_CC — Class Code - Revision ID (AHB-PCI Bridge)

Address: 4003 0008h

| Bit               | b31        | b30        | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20   | b19    | b18 | b17 | b16 |
|-------------------|------------|------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-------|--------|-----|-----|-----|
|                   | CLASS_CODE |            |     |     |     |     |     |     |     |     |     |       |        |     |     |     |
| Value after reset | 0          | 0          | 0   | 0   | 0   | 1   | 1   | 0   | 0   | 0   | 0   | 0     | 0      | 0   | 0   | 0   |
| Bit               | b15        | b14        | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4    | b3     | b2  | b1  | b0  |
|                   |            | CLASS_CODE |     |     |     |     |     |     |     |     |     | REVIS | ION_ID |     |     |     |
| Value after reset | 0          | 0          | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0      | 0   | 0   | 1   |

Table 10.72 REVID\_CC Register Contents

| Bit Position | Bit Name    | Function           | R/W |
|--------------|-------------|--------------------|-----|
| b31 to b8    | CLASS_CODE  | Indicates 060000h. | R   |
| b7 to b0     | REVISION_ID | Indicates 01h.     | R   |

## 10.5.5.4 CLS\_LT\_HT\_BIST — BIST - Header Type - Latency Timer - Cache Line Size (AHB-PCI Bridge)

**Address:** 4003 000Ch



Table 10.73 CLS\_LT\_HT\_BIST Register Contents

| Bit Position | Bit Name        | Function                                                                                                     | R/W |
|--------------|-----------------|--------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | BIST            | Indicates 00h (BIST is not implemented).                                                                     | R   |
| b23 to b16   | HEADER_TYPE     | Indicates 00h (Single Function Device).                                                                      | R   |
| b15 to b8    | LATENCY_TIMER   | This bit is used to notify Latency Timer to the system.  Keep the initial value 00h in this host controller. | R/W |
| b7 to b0     | CACHE_LINE_SIZE | Indicates 00h (Cache is not supported).                                                                      | R   |

#### 10.5.5.5 BASEAD — AHB-PCI Bridge Registers Base Address

Address: 4003 0010h



Table 10.74 BASEAD Register Contents

| Bit Position | Bit Name       | Function                                                                                                                                                   | R/W |
|--------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b10   | PCICOM_BASEADR | Sets the base address of the AHB-PCI Bridge PCI Communication Register area.  Upper 22 bits are used as the base address since the 1-KB space is required. | R/W |
| b9 to b4     | Reserved       | Should be 0 at writing.                                                                                                                                    | R   |
| b3           | PREFETCH       | Indicates whether or not data prefetch is possible.  This bit is fixed at 0b. (Data prefetch disabled)                                                     | R   |
| b2, b1       | TYPE           | Indicates the base address Type. "00b" means that the address can be allocated to any address of 4-GB space.                                               | R   |
| b0           | MEM            | Indicates that the bits specified with the base address are the memory space. This bit is fixed at 0b.                                                     | R   |

#### 10.5.5.6 WIN1\_BASEAD — PCI-AHB Window1 Base Address

Address: 4003 0014h



Table 10.75 WIN1\_BASEAD Register Contents

| Bit Position | Bit Name        | Function                                                                                                           | R/W |
|--------------|-----------------|--------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b28   | PCI_WIN1_BASEAD | Specify the base address of the PCI-AHB Window 1 space.                                                            | R/W |
|              | R               | PCI-AHB Window 1 space can be accessible after setting of bits [11:10] (PCI_AHB_WIN1_SIZE) of the USBCTR register. |     |
|              |                 | Accessible size is defined as below.                                                                               |     |
|              |                 | 256 MB: Bits [31:28] specify a base address                                                                        |     |
|              |                 | 512 MB: Bits [31:29] specify a base address                                                                        |     |
|              |                 | 1 GB: Bits [31:30] specify a base address                                                                          |     |
|              |                 | 2 GB: Bits [31] specify a base address                                                                             |     |
| b27 to b4    | Reserved        | Should be 0 at writing.                                                                                            | R   |
| b3           | PREFETCH        | Indicates whether prefetching data is enabled or disabled.                                                         | R   |
|              |                 | This bit is fixed to 1b. (Prefetching data is enabled.)                                                            |     |
| b2, b1       | TYPE            | Indicates the base address type.                                                                                   | R   |
|              |                 | "00b" means that the address can be allocated to any address of 4-GB space.                                        |     |
| b0           | MEM             | Indicates that the field specified by the base address is in the memory space.                                     | R   |
|              |                 | This bit is fixed to 0b.                                                                                           |     |

#### 10.5.5.7 WIN2\_BASEAD — PCI-AHB Window2 Base Address

Address: 4003 0018h

| Bit               | b31 | b30      | b29    | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19          | b18 | b17 | b16 |
|-------------------|-----|----------|--------|-----|-----|-----|-----|-----|-----|-----|-----|-----|--------------|-----|-----|-----|
|                   | PC  | CI_WIN2_ | _BASEA | DR  | _   | _   | _   | _   | _   | _   | _   | _   | _            | _   | _   | _   |
| Value after reset | 0   | 0        | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0            | 0   | 0   | 0   |
| Bit               | b15 | b14      | b13    | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3           | b2  | b1  | b0  |
|                   | _   | _        | _      | _   | _   | _   | _   | _   | _   | _   | _   | _   | PREFE<br>TCH | TY  | PE  | MEM |
| Value after reset | 0   | 0        | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0            | 0   | 0   | 0   |

Table 10.76 WIN2\_BASEAD Register Contents

| Bit Position | Bit Name             | Function                                                                                                                                                    | R/W |
|--------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b28   | PCI_WIN2_BASEAD<br>R | Specify the base address of the PCI-AHB Window 2 space. Fixed 256 MB is used in this host controller, therefore upper 4 bits are used for the base address. | R/W |
| b27 to b4    | Reserved             | Should be 0 at writing.                                                                                                                                     | R   |
| b3           | PREFETCH             | Indicates whether prefetching data is enabled or disabled.                                                                                                  | R   |
| b2, b1       | TYPE                 | Indicates the base address type. "00b" means that the address can be allocated to any address of 4-GB space.                                                | R   |
| b0           | MEM                  | Indicates that Indicates that the field specified by the base address is in the memory space. This bit is fixed to 0b.                                      | R   |

#### 10.5.5.8 SSVID\_SSID — Subsystem ID - Subsystem Vendor ID (AHB-PCI Bridge)

Address: 4003 002Ch



Table 10.77 SSVID\_SSID Register Contents

| Bit Position | Bit Name             | Function         | R/W |
|--------------|----------------------|------------------|-----|
| b31 to b16   | SUBSYS_ID            | Indicates 0000h. | R   |
| b15 to b0    | SUBSYS_VENDOR_I<br>D | Indicates 1033h. | R   |

# 10.5.5.9 INTR\_LINE\_PIN — Max\_Lat - Min\_Gnt - Interrupt Pin - Interrupt Line (AHB-PCI Bridge)

Address: 4003 003Ch

| Bit               | b31     | b30 | b29 | b28 | b27 | b26 | b25 | b24      | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|---------|-----|-----|-----|-----|-----|-----|----------|-----|-----|-----|-----|-----|-----|-----|-----|
|                   | MAX_LAT |     |     |     |     |     |     | MIN_GNT  |     |     |     |     |     |     |     |     |
| Value after reset | 0       | 0   | 0   | 0   | 0   | 0   | 0   | 0        | 0   | 0   | 0   | 0   | 0   | 0   | 1   | 0   |
| Bit               | b15     | b14 | b13 | b12 | b11 | b10 | b9  | b8       | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                   | INT_PIN |     |     |     |     |     |     | INT_LINE |     |     |     |     |     |     |     |     |
| Value after reset | 0       | 0   | 0   | 0   | 0   | 0   | 0   | 1        | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 10.78 INTR\_LINE\_PIN Register Contents

| Bit Position | Bit Name | Function                                                                                   | R/W |
|--------------|----------|--------------------------------------------------------------------------------------------|-----|
| b31 to b24   | MAX_LAT  | "00h" means that no bus utilization request                                                | R   |
| b23 to b16   | MIN_GNT  | Indicates the maximum burst transfer time. "02h" means that latency timer request 16 burst | R   |
| b15 to b8    | INT_PIN  | Indicates the interrupt output pin.  This bit is fixed to 01h because INTA# is used.       | R   |
| b7 to b0     | INT_LINE | Indicates the interrupt line.  Keep the initial value, 00h, in this host controller.       | R/W |

## 10.5.6 AHB-PCI Bridge (PCI Communication Space) Register Description

#### 10.5.6.1 PCIAHB\_WIN1\_CTR — PCIAHB Window1 Control Register

Address: 4003 0800h



Table 10.79 PCIAHB\_WIN1\_CTR Register Contents

| Bit Position | Bit Name    | Function                                                                                                                                                                         | R/W |  |  |  |  |
|--------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|
| b31 to b28   | AHB_BASEADR | Specify the base address of the AHB when the host controller access the PCI-AHB Window 1 space.                                                                                  | R/W |  |  |  |  |
|              |             | PCI-AHB Window1 space (256 MB/512 MB/1 GB/2 GB) can be accessible after setting of bits [11:10] (PCI_AHB_WIN1_SIZE) of the USBCTR register. Accessible size is defined as below. |     |  |  |  |  |
|              |             | 256 MB: Bits [31:28] specify a base address                                                                                                                                      |     |  |  |  |  |
|              |             | 512 MB: Bits [31:29] specify a base address                                                                                                                                      |     |  |  |  |  |
|              |             | 1 GB: Bits [31:30] specify a base address                                                                                                                                        |     |  |  |  |  |
|              |             | 2 GB: Bit [31] specify a base address.                                                                                                                                           |     |  |  |  |  |
| b27 to b9    | Reserved    | Should be 0 at writing.                                                                                                                                                          | R/W |  |  |  |  |
| b8 to b6     | ENDIAN_CTR  | Specify convert type of endianness on AHB.                                                                                                                                       |     |  |  |  |  |
|              |             | This value should be changed during an initialization only.                                                                                                                      |     |  |  |  |  |
|              |             | 000b: No conversion (little endian)                                                                                                                                              |     |  |  |  |  |
|              |             | 001b: Access type data swapping                                                                                                                                                  |     |  |  |  |  |
|              |             | 010b: Byte data swapping (bit endian)                                                                                                                                            |     |  |  |  |  |
|              |             | 011b: Halfword swapping                                                                                                                                                          |     |  |  |  |  |
|              |             | 100b: Address conversion                                                                                                                                                         |     |  |  |  |  |
|              |             | Others: Prohibited.                                                                                                                                                              |     |  |  |  |  |
| b5 to b2     | Reserved    | Should be 0 at writing.                                                                                                                                                          | R   |  |  |  |  |
| b1, b0       | PREFETCH    | Specify enable of prefetch on AHB for a read request from the host controller.                                                                                                   | R/W |  |  |  |  |
|              |             | 11b: Enable prefetch (Up to 16 burst)                                                                                                                                            |     |  |  |  |  |
|              |             | Others: Reserved (not for use)                                                                                                                                                   |     |  |  |  |  |

#### 10.5.6.2 PCIAHB\_WIN2\_CTR — PCIAHB Window2 Control Register

Address: 4003 0804h



Table 10.80 PCIAHB\_WIN2\_CTR Register Contents

| Bit Position | Bit Name    | Function                                                                                                           | R/W |
|--------------|-------------|--------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b28   | AHB_BASEADR | Specify the base address of the AHB when the host controller access the PCI-AHB Window 2 space.                    | R/W |
|              |             | PCI-AHB Window2 space (256 MB) can be accessible after setting of bits 9 (PCI_AHB_WIN2_EN) of the USBCTR register. |     |
| b27 to b9    | Reserved    | Should be 0 at writing.                                                                                            | R/W |
| b8 to b6     | ENDIAN_CTR  | Specify convert type of endianness on AHB.                                                                         | R/W |
|              |             | This value should be changed during an initialization only.                                                        |     |
|              |             | 000b: No conversion (little endian)                                                                                |     |
|              |             | 001b: Access type data swapping                                                                                    |     |
|              |             | 010b: Byte data swapping (bit endian)                                                                              |     |
|              |             | 011b: Halfword swapping                                                                                            |     |
|              |             | 100b: Address conversion                                                                                           |     |
|              |             | Others: Prohibited.                                                                                                |     |
| b5 to b2     | Reserved    | Should be 0 at writing.                                                                                            | R   |
| b1, b0       | PREFETCH    | Specify enable of prefetch on AHB for a read request from the host controller.                                     | R/W |
|              |             | 11b: Enable prefetch (Up to 16 burst)                                                                              |     |
|              |             | Others: Reserved (not for use)                                                                                     |     |

#### 10.5.6.3 AHBPCI\_WIN1\_CTR — AHBPCI Window1 Control Register

Address: 4003 0810h



Table 10.81 AHBPCI\_WIN1\_CTR Register Contents

| Bit Position | Bit Name        | Function                                                                                                                                                                                                 | R/W |
|--------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b11   | PCIWIN1_BASEADR | Specify the base address of the PCI bus when it accesses AHB-PCI Window 1 space from AHB. Setting this register is required for accessing host controller and PCI configuration space in AHB-PCI bridge. | R/W |
| b10 to b4    | Reserved        | Should be 0 at writing.                                                                                                                                                                                  | R/W |
| b3 to b1     | PCICMD          | Specify the PCI bus cycle type.                                                                                                                                                                          | R/W |
|              |                 | 101b: Configuration Read/Configuration Write                                                                                                                                                             |     |
|              |                 | Others: Reserved (not for use)                                                                                                                                                                           |     |
| b0           | Reserved        | Should be 0 at writing.                                                                                                                                                                                  | R   |

#### 10.5.6.4 AHBPCI\_WIN2\_CTR — AHBPCI Window2 Control Register

Address: 4003 0814h



Table 10.82 AHBPCI\_WIN2\_CTR Register Contents

| Bit Position | Bit Name        | Function                                                                                                                                                                  | R/W |
|--------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b16   | PCIWIN2_BASEADR | Specify the base address of the PCI bus when it accesses AHB-PCI Window 2 space from AHB. Setting this register is required for accessing OHCI operational register area. | R/W |
| b15 to b6    | Reserved        | Should be 0 at writing.                                                                                                                                                   | R/W |
| b5           | BURST_EN        | Enable of burst transfer on the PCI bus.  0b: Disable burst transfer  Others: Reserved (not for use)                                                                      | R/W |
| b4           | Reserved        | Should be 0 at writing.                                                                                                                                                   | R/W |
| b3 to b1     | PCICMD          | Specify the PCI bus cycle type. 011b: Memory Read/Memory Write Others: Reserved (not for use)                                                                             | R/W |
| b0           | Reserved        | Should be 0 at writing.                                                                                                                                                   | R/W |

## 10.5.6.5 PCI\_INT\_ENABLE — PCI Interrupt Enable Register

Address: 4003 0820h

| Bit               | b31 | b30 | b29    | b28                       | b27 | b26 | b25 | b24 | b23 | b22 | b21                  | b20 | b19            | b18 | b17 | b16                     |
|-------------------|-----|-----|--------|---------------------------|-----|-----|-----|-----|-----|-----|----------------------|-----|----------------|-----|-----|-------------------------|
|                   | _   | _   | _      | _                         | _   | _   | _   | _   | _   | _   | _                    | _   | USBH_<br>PMEEN |     |     | USBH_I<br>NTAEN         |
| Value after reset | 0   | 0   | 0      | 0                         | 0   | 0   | 0   | 0   | 0   | 0   | 0                    | 0   | 0              | 0   | 0   | 0                       |
| Bit               | b15 | b14 | b13    | b12                       | b11 | b10 | b9  | b8  | b7  | b6  | b5                   | b4  | b3             | b2  | b1  | b0                      |
|                   | _   | _   | _WIN2_ | PCIAHB<br>_WIN1_<br>INTEN | _   | _   | _   | _   | _   | _   | RESER<br>R_INTE<br>N |     |                |     |     | SIGTAB<br>ORT_IN<br>TEN |
| Value after reset | 0   | 0   | 0      | 0                         | 0   | 0   | 0   | 0   | 0   | 0   | 0                    | 0   | 0              | 0   | 0   | 0                       |

Table 10.83 PCI\_INT\_ENABLE Register Contents (1/2)

| Bit Position | Bit Name         | Function                  | R/W |
|--------------|------------------|---------------------------|-----|
| b31 to b20   | Reserved         | Should be 0 at writing.   | R   |
| b19          | USBH_PMEEN       | Enable of USBH_PME        | R/W |
|              |                  | 0: Disable                |     |
|              |                  | 1: Enable                 |     |
| b18          | Reserved         | Should be 0 at writing.   | R/W |
| b17          | USBH_INTBEN      | Enable of USBH_INTB       | R/W |
|              |                  | 0: Disable                |     |
|              |                  | 1: Enable                 |     |
| b16          | USBH_INTAEN      | Enable of USBH_INTA       | R/W |
|              |                  | 0: Disable                |     |
|              |                  | 1: Enable                 |     |
| b15, b14     | Reserved         | Should be 0 at writing.   | R/W |
| b13          | PCIAHB_WIN2_INTE | Enable of PCIAHB_WIN2_INT | R/W |
|              | N                | 0: Disable                |     |
|              |                  | 1: Enable                 |     |
| b12          | PCIAHB_WIN1_INTE | Enable of PCIAHB_WIN1_INT | R/W |
|              | N                | 0: Disable                |     |
|              |                  | 1: Enable                 |     |
| b11 to b6    | Reserved         | Should be 0 at writing.   | R/W |
| b5           | RESERR_INTEN     | Enable of RESERR_INT      | R/W |
|              |                  | 0: Disable                |     |
|              |                  | 1: Enable                 |     |
| b4           | SIGSERR_INTEN    | Enable of SIGSERR_INT     | R/W |
|              |                  | 0: Disable                |     |
|              |                  | 1: Enable                 |     |
| b3           | PERR_INTEN       | Enable of PERR_INT        | R/W |
|              |                  | 0: Disable                |     |
|              |                  | 1: Enable                 |     |
| b2           | REMARBORT_INTE   | Enable of REMABORT_INT    | R/W |
|              | N                | 0: Disable                |     |
|              |                  | 1: Enable                 |     |
| b1           | RETABORT_INTEN   | Enable of RETABORT_INT    | R/W |
|              |                  | 0: Disable                |     |
|              |                  | 1: Enable                 |     |

Table 10.83 PCI\_INT\_ENABLE Register Contents (2/2)

| Bit Position | Bit Name        | Function                | R/W |
|--------------|-----------------|-------------------------|-----|
| b0           | SIGTABORT_INTEN | Enable of SIGTABORT_INT | R/W |
|              |                 | 0: Disable              |     |
|              |                 | 1: Enable               |     |

#### 10.5.6.6 PCI\_INT\_STATUS — PCI Interrupt Status Register

Address: 4003 0824h



Table 10.84 PCI\_INT\_STATUS Register Contents (1/2)

| Dit Docition |                 | Register Contents (1/2)                                                                                              | D/M |
|--------------|-----------------|----------------------------------------------------------------------------------------------------------------------|-----|
| Bit Position | Bit Name        | Function                                                                                                             | R/W |
| b31 to b20   | Reserved        |                                                                                                                      | R   |
| b19          | USBH_PME        | Status of PME# interrupt from the host controller. It can be cleared in the host controller.  0: No PME has occurred | R   |
|              |                 | 1: An PME has occurred                                                                                               |     |
| b18          | Reserved        | Should be 0 at writing.                                                                                              | R/W |
| b17          | USBH_INTB       | Status of INTB# interrupt from the host controller. It can be cleared in the host controller.                        | R   |
|              |                 | 0: No INTB has occurred 1: An INTB has occurred                                                                      |     |
| b16          | USBH_INTA       | Status of INTA# interrupt from the host controller. It can be cleared in the host controller.                        | R   |
|              |                 | 0: No INTA has occurred 1: An INTA has occurred                                                                      |     |
| b15, b14     | Reserved        | Should be 0 at writing.                                                                                              | R/W |
| b13          | PCIAHB_WIN2_INT | Indicates that an AHB bus error has occurred in PCIAHB Window 2. This bit is cleared when 1b is written.             | R/W |
|              |                 | 0: No AHB bus error has occurred                                                                                     |     |
|              |                 | 1: An AHB bus error has occurred                                                                                     |     |
| b12          | PCIAHB_WIN1_INT | Indicates that an AHB bus error has occurred in PCIAHB Window 1. This bit is cleared when 1b is written.             | R/W |
|              |                 | 0: No AHB bus error has occurred                                                                                     |     |
|              |                 | 1: An AHB bus error has occurred                                                                                     |     |
| b11 to b6    | Reserved        | Should be 0 at writing.                                                                                              |     |
| b5           | RESERR_INT      | Indicates the status of the interrupt caused by SERR# input. This bit is cleared when 1b is written.                 | R/W |
|              |                 | 0: SERR# assertion has not been detected                                                                             |     |
|              |                 | 1: SERR# assertion has been detected                                                                                 |     |
| b4           | SIGSERR_INT     | Indicates the status of the interrupt caused by SERR# output. This bit is cleared when 1b is written.                | R/W |
|              |                 | 0: SERR# has not been asserted                                                                                       |     |
|              |                 | 1: SERR# has been asserted                                                                                           |     |
| b3           | PERR_INT        | Indicates the status of the interrupt caused by PERR# input or output. This bit is cleared when 1b is written.       | R/W |
|              |                 | 0: PERR# has not been asserted                                                                                       |     |
|              |                 | 1: PERR# has been asserted                                                                                           |     |

Table 10.84 PCI\_INT\_STATUS Register Contents (2/2)

| Bit Position | Bit Name      | Function                                                                                                     | R/W |
|--------------|---------------|--------------------------------------------------------------------------------------------------------------|-----|
| b2           | REMABORT_INT  | Indicates that Master Abort is received during PCI master operation. This bit is cleared when 1b is written. | R/W |
|              |               | 0: Master Abort has not been received                                                                        |     |
|              |               | 1: Master Abort has been received                                                                            |     |
| b1           | RETABORT_INT  | Indicates that Target Abort is reported during PCI master operation. This bit is cleared when 1b is written. | R/W |
|              |               | 0: Target Abort has not been reported                                                                        |     |
|              |               | 1: Target Abort has been reported                                                                            |     |
| b0           | SIGTABORT_INT | Indicates that Target Abort is reported during PCI slave operation. This bit is cleared when 1b is written.  | R/W |
|              |               | 0: Target Abort has not been reported                                                                        |     |
|              |               | 1: Target Abort has been reported                                                                            |     |

#### 10.5.6.7 AHB\_BUS\_CTR — AHB Bus Control Register

Address: 4003 0830h



Table 10.85 AHB\_BUS\_CTR Register Contents

| Bit Position | Bit Name             | Function                                                                                                                        | R/W |
|--------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b18   | Reserved             | Should be 0 at writing.                                                                                                         | R   |
| b17          | SMODE_READY_CT<br>R  | Wait cycle control type for AHB slave.  0: Reserved (not for use)  1: Wait cycle is controlled by HREADY=0                      | R/W |
| b16 to b8    | Reserved             | Should be 0 at writing.                                                                                                         | R/W |
| b7           | MMODE_HBUSREQ        | HBUSREQ de-assert timing for the AHB master 0: Reserved (not for use) 1: Release at first cycle of HGRANT=1 & HREADY=1          | R/W |
| b6 to b3     | Reserved             | Should be 0 at writing.                                                                                                         | R/W |
| b2           | MMODE_WR_INCR        | AHB INCR burst use condition at write for the AHB master 0: Reserved (not for use) 1: INCR4/8/16, or INCR for 2/3 beat          | R/W |
| b1           | MMODE_BYTE_BUR<br>ST | Burst mode setting in 16 bit/8 bit transfer for the AHB Master 0: Reserved (not for use) 1: No burst for 16 bit/8 bit transfer. | R/W |
| b0           | MMODE_HTRANS         | HTRANS behavior setting for the AHB Master 0: Reserved (not for use) 1: IDLE and HBUSREQ assertion during cycle separation      | R/W |

### 10.5.6.8 USBCTR — USB Control Register

Address: 4003 0834h



Table 10.86 USBCTR Register Contents

| Bit Position | Bit Name              | Function                                                                                                                                                                                                                                                                                   | R/W |
|--------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b12   | Reserved              | Should be 0 at writing.                                                                                                                                                                                                                                                                    | R   |
| b11, b10     | PCI_AHB_WIN1_SIZ<br>E | Use this bit to control the PCI-AHB Window 1 area. Accessing Host Controller Registers. This value should be changed only in the initialization.  00b: 256 MB  01b: 512 MB  10b: 1 GB  11b: 2 GB                                                                                           | R/W |
| b9           | PCI_AHB_WIN2_EN       | Use this bit to enable the PCI-AHB Window 2. Accessing Host Controller Registers.  This value should be changed only in the initialization. In this host controller, the PCI-AHB Window 2 area is fixed to 256 MB.  0: PCI-AHB Window 2 is not available  1: PCI-AHB Window 2 is available | R/W |
| b8           | DIRPD                 | If this bit is set to 1b, USB subsystem moves to power-down state.  Bit 12 (DIRPD) of the EPCTR register and the DIRPD of CFG_USB in the system controller have same function.  0: Normal operation  1: Direct power-down state                                                            | R/W |
| b7 to b3     | Reserved              | Keep the initial value                                                                                                                                                                                                                                                                     | R/W |
| b2           | PLL_RST               | Reset of USBPLL The USBPLL is shared between the host and function controllers. Reset to the USBPLL is asserted when both PLL_RST in host and function controllers are 1b.  0: Release USBPLL reset 1: Assert USBPLL reset                                                                 | R/W |
| b1           | PCICLK_MASK           | Use this bit to control PCI clock (USB_PCICLK) supply in the host controller. If this bit is set to 1b, the host controller is not accessible.  0: Supply the PCI clock 1: Stop the PCI clock                                                                                              | R/W |
| b0           | USBH_RST              | Use this bit to control the reset signal supplied to the host controller.  Access to the host controller becomes valid after 3 USB_PCICLK cycles from end of the reset.  0: Release host controller reset  1: Assert host controller reset                                                 | R/W |

### 10.5.6.9 PCI\_ARBITER\_CTR — PCI Arbiter Control Register

Address: 4003 0840h



Table 10.87 PCI\_ARBITER\_CTR Register Contents

| Bit Position | Bit Name   | Function                                                                          | R/W |
|--------------|------------|-----------------------------------------------------------------------------------|-----|
| b31 to b13   | Reserved   | Keep the initial value                                                            | R/W |
| b12          | PCIBP_MODE | PCI bus master in the bus parking                                                 | R/W |
|              |            | 0: This unit                                                                      |     |
|              |            | 1: Last accessed master                                                           |     |
|              |            | Set 1b during initialization of this host controller and do not change the value. |     |
| b11 to b2    | Reserved   | Keep the initial value                                                            | R/W |
| b1           | PCIREQ1    | Enable of PCI bus request1 signal                                                 | R/W |
|              |            | 0: Disable the request signal                                                     |     |
|              |            | 1: Enable the request signal                                                      |     |
|              |            | Set 1b during initialization of this host controller and do not change the value. |     |
| b0           | PCIREQ0    | Enable of PCI bus request0 signal                                                 | R/W |
|              |            | 0: Disable the request signal                                                     |     |
|              |            | 1: Enable the request signal                                                      |     |
|              |            | Set 1b during initialization of this host controller and do not change the value. |     |

#### 10.5.7 **EPC Register Description**

#### 10.5.7.1 USB\_CONTROL — USB Control Register

Address: 4001 E000h

| Bit               | b31 | b30 | b29 | b28 | b27                  | b26         | b25         | b24         | b23         | b22         | b21  | b20         | b19          | b18  | b17   | b16 |
|-------------------|-----|-----|-----|-----|----------------------|-------------|-------------|-------------|-------------|-------------|------|-------------|--------------|------|-------|-----|
|                   |     | 1   | -   | l   | 1                    | -           | ı           | _           | 1           | 1           | ı    | ı           | I            | USB  | TESTM | ODE |
| Value after reset | 0   | 0   | 0   | 0   | 0                    | 0           | 0           | 0           | 0           | 0           | 0    | 0           | 0            | 0    | 0     | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11                  | b10         | b9          | b8          | b7          | b6          | b5   | b4          | b3           | b2   | b1    | b0  |
|                   |     | ı   | _   | _   | SOF_C<br>LK_MO<br>DE | INT_SE<br>L | FORCE<br>FS | SOF_R<br>CV | RSUM_<br>IN | SUSPE<br>ND | CONF | DEFAU<br>LT | CONNE<br>CTB | PUE2 | _     | _   |
| Value after reset | 0   | 0   | 0   | 0   | 0                    | 0           | 0           | 1           | 0           | 0           | 0    | 0           | 1            | 0    | 0     | 0   |

| Dit Desition | Dit Name     | Function                                                                                                                                                                                                                         | D/\/ |
|--------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| Bit Position | Bit Name     | Function                                                                                                                                                                                                                         | R/W  |
| b31 to b19   | Reserved     |                                                                                                                                                                                                                                  | R    |
| b18 to b16   | USBTESTMODE  | Set these bits after the status stage of the SET_FEATURE_TEST_MODE request has finished normally.                                                                                                                                | R/W  |
|              |              | After setting this field to other than 000b, set bit 1 (CS_TESTMODEEN) of Test Control Register.                                                                                                                                 |      |
|              |              | Test_J, Test_K, Test_SE0_NAK tests:                                                                                                                                                                                              |      |
|              |              | After setting this field, the USBPHY enters test mode in HS mode as soon as CS_TESTMODEEN is set to 1b.                                                                                                                          |      |
|              |              | Test_Packet test:                                                                                                                                                                                                                |      |
|              |              | When HS connection to the Host is established, Test_Packet is transmitted by setting CS_TESTMODEEN to 1b after setting this field.                                                                                               |      |
|              |              | When HS Connection to the Host is not established, Test_Packet is transmitted by setting as follows                                                                                                                              |      |
|              |              | USBTESTMODE = Test_J→CS_TESTMODEEN = 1→CS_TESTMODEEN = 0 →USBTESTMODE = Test_K→CS_TESTMODEEN = 1→CS_TESTMODEEN = 0 →USBTESTMODE = Test_SE0_NAK→CS_TESTMODEEN = 1 →CS_TESTMODEEN = 0 →USBTESTMODE = Test_Packet→CS_TESTMODEEN = 1 |      |
|              |              | 000b: Normal                                                                                                                                                                                                                     |      |
|              |              | 001b: Test_J                                                                                                                                                                                                                     |      |
|              |              | 010b: Test_K                                                                                                                                                                                                                     |      |
|              |              | 011b: Test_SE0_NAK                                                                                                                                                                                                               |      |
|              |              | 100b: Test_Packet                                                                                                                                                                                                                |      |
| b15 to b12   | Reserved     | Should be 0 at writing.                                                                                                                                                                                                          | R    |
| o11          | SOF_CLK_MODE | Operating mode select for SOF output pin in HS mode.                                                                                                                                                                             | R/W  |
|              |              | Set this bit during initialization. The operation is not guaranteed if this bit is set at any other time.                                                                                                                        |      |
|              |              | 0: Invert signal when SOF/uSOF packet is received                                                                                                                                                                                |      |
|              |              | 1: Invert signal when SOF packet is received (no inversion by uSOF)                                                                                                                                                              |      |
| o10          | INT_SEL      | U2F_EPC_INT interrupt output type select                                                                                                                                                                                         | R/W  |
|              |              | Setting is common for all interrupt sources.                                                                                                                                                                                     |      |
|              |              | 0: Pulse output. (not for use)                                                                                                                                                                                                   |      |
|              |              | <ol> <li>Level output. If there are multiple interrupt sources, the interrupt output keeps<br/>being asserted until the all sources are cleared.</li> </ol>                                                                      |      |
| b9           | FORCEFS      | 0: Normal operation                                                                                                                                                                                                              | R/W  |
|              |              | 1: Not for use                                                                                                                                                                                                                   |      |

Table 10.88 USB\_CONTROL Register Contents (2/2)

| Bit Position | Bit Name | Function                                                                                                                                                        | R/W |
|--------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b8           | SOF_RCV  | Enable bit for automatic recovery at SOF reception error                                                                                                        | R/W |
|              |          | 0: Disable (not for use)                                                                                                                                        |     |
|              |          | 1: Enable                                                                                                                                                       |     |
| b7           | RSUM_IN  | Remote wakeup trigger                                                                                                                                           | R/W |
|              |          | [Caution] In case of disabling clock supply to EPC, SIE and USBPHY in suspend state, the clocks should be resumed before setting this bit.                      |     |
|              |          | 0: Not send the resume signal                                                                                                                                   |     |
|              |          | 1: Send the resume signal                                                                                                                                       |     |
| b6           | SUSPEND  | When the state is Suspend, clock supply for EPC, SIE, USBPHY can be stopped by setting this bit to 1b.                                                          | R/W |
|              |          | This bit is cleared to 0b automatically when RESUME is detected.                                                                                                |     |
|              |          | 0: Supply clocks                                                                                                                                                |     |
|              |          | 1: Stop clocks                                                                                                                                                  |     |
| b5           | CONF     | Enable bit for Endpoints other than Endpoint 0.                                                                                                                 | R/W |
|              |          | This bit is cleared to 0b automatically when it receives BusReset.                                                                                              |     |
|              |          | If this bit is 0b, the state is Default or Address state except Suspend.                                                                                        |     |
|              |          | If this bit is 1b, the state is Configured except Suspend                                                                                                       |     |
|              |          | 0: Disable Endpoints other than Endpoint 0. (No response is returned for tokens)                                                                                |     |
|              |          | 1: Enable Endpoints other than Endpoint 0.                                                                                                                      |     |
| b4           | DEFAULT  | Enable bit for Endpoint 0.                                                                                                                                      | R/W |
|              |          | This bit is set to 1b automatically when it receives BusReset.                                                                                                  |     |
|              |          | If this bit is 0b, the state is Attached or Powered as defined in the USB specification.                                                                        |     |
|              |          | If this bit is 1b, it depends on bit 5 (CONF).                                                                                                                  |     |
|              |          | 0: Disable Endpoint0. (No response for tokens)                                                                                                                  |     |
|              |          | 1: Enable Endpoint0.                                                                                                                                            |     |
| b3           | CONNECTB | By setting this bit to 1b when Un-Plugged, it can prevent the occurrence of a pseudo bus reset or suspend signal due to unstable D+/D- signals on the USB port. | R/W |
|              |          | When this bit is set to 1b, the SIE enters the Suspend state and SPND_INT of USB                                                                                |     |
|              |          | Interrupt Status Register occurs.                                                                                                                               |     |
|              |          | 0: Enable the USB signals to the SIE block                                                                                                                      |     |
|              |          | 1: Disable the USB signals to the SIE block                                                                                                                     |     |
| b2           | PUE2     | Control bit for D+ pull-up.                                                                                                                                     | R/W |
|              |          | 0: Not pull up D+ signal                                                                                                                                        |     |
|              |          | 1: Pull up D+ signal                                                                                                                                            |     |
| b1, b0       | Reserved | Keep the initial value                                                                                                                                          | R/W |
|              |          | ·                                                                                                                                                               |     |

# 10.5.7.2 USB\_STATUS — USB Status Register

Address: 4001 E004h

| Bit               | b31                      | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22            | b21  | b20         | b19         | b18          | b17          | b16 |
|-------------------|--------------------------|-----|-----|-----|-----|-----|-----|-----|-----|----------------|------|-------------|-------------|--------------|--------------|-----|
|                   | SOF_DEL<br>AY_STAT<br>US | _   | ı   | _   | ı   | ı   | _   | _   |     | _              | ı    | _           | ı           |              | _            | _   |
| Value after reset | 0                        | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0              | 0    | 0           | 0           | 0            | 0            | 0   |
| Bit               | b15                      | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6             | b5   | b4          | b3          | b2           | b1           | b0  |
|                   | _                        | _   | _   | _   | _   | _   | _   | _   | _   | SPEED<br>_MODE | CONF | DEFAU<br>LT | USB_R<br>ST | SPND_<br>OUT | RSUM_<br>OUT | _   |
| Value after reset | 0                        | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0              | 0    | 0           | 0           | 0            | 0            | 0   |

Table 10.89 USB\_STATUS Register Contents

| Bit Position | Bit Name             | Function                                                                                                                                                                                                                                                                        | R/W |
|--------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31          | SOF_DELAY_STATU<br>S | This bit is set to 1 if a SOF is ignored during SOF unacceptable period. This bit is updated each time a SOF is received. For more details about SOF unacceptable period, see bit 31 (SOF_DELAY_MODE) of the Frame Number & USB Address Register.  0: SOF was received normally | R   |
|              |                      | 1: SOF was ignored                                                                                                                                                                                                                                                              |     |
| b30 to b7    | Reserved             |                                                                                                                                                                                                                                                                                 | R   |
| b6           | SPEED_MODE           | Indicates USB port speed. 0: FS (Full-Speed) 1: HS (High-Speed)                                                                                                                                                                                                                 | R   |
| b5           | CONF                 | Status of Endpoints other than Endpoint 0 are enabled.  This bit is equal to bit 5 (CONF) of the USB Control Register.  0: Disabled (No response for tokens)  1: Enabled                                                                                                        | R   |
| b4           | DEFAULT              | Status of Endpoint 0.  This bit is equal to bit 4 (DEFAULT) of the USB Control Register.  0: Disabled (No response for tokens)  1: Enabled                                                                                                                                      | R   |
| b3           | USB_RST              | Indication of BusReset state 0: Not BusReset state 1: BusReset state                                                                                                                                                                                                            | R   |
| b2           | SPND_OUT             | Indication of Suspend state 0: Not Suspend state 1: Suspend state                                                                                                                                                                                                               | R   |
| b1           | RSUM_OUT             | Indication of Resume status 0: Resume is not being received 1: Resume is being received                                                                                                                                                                                         | R   |
| b0           | Reserved             |                                                                                                                                                                                                                                                                                 | R   |

# 10.5.7.3 USB\_ADDRESS — Frame Number & USB Address Register

Address: 4001 E008h

| Bit               | b31                    | b30 | b29    | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21   | b20 | b19    | b18 | b17 | b16 |
|-------------------|------------------------|-----|--------|-----|-----|-----|-----|-----|-----|-----|-------|-----|--------|-----|-----|-----|
|                   | SOF_D<br>ELAY_<br>MODE | _   | _      | 1   | ı   | ı   |     |     | ı   |     |       | U   | SB_ADD | R   |     |     |
| Value after reset | 0                      | 0   | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0   | 0      | 0   | 0   | 0   |
| Bit               | b15                    | b14 | b13    | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5    | b4  | b3     | b2  | b1  | b0  |
|                   | SOF_S<br>TATUS         |     | UFRAME |     | I   |     |     |     |     |     | FRAME |     |        |     |     |     |
| Value after reset | 0                      | Λ   | Λ      | Λ   | Ω   | 0   | Λ   | Λ   | Λ   | Λ   | Λ     | Λ   | Λ      | Λ   | Λ   | 0   |

Table 10.90 USB\_ADDRESS Register Contents

| Bit Position | Bit Name       | Function                                                                                                                           | R/W |
|--------------|----------------|------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31          | SOF_DELAY_MODE | Setting of SOF unacceptable                                                                                                        | R/W |
|              |                | If this bit is set to 1b, SOF which comes within 64 cycle@60 MHz after normal SOF or SOF recovery is ignored as illegal SOF token. |     |
|              |                | 0: SOF is valid regardless of when it is received                                                                                  |     |
|              |                | 1: Ignore SOF during unacceptable period                                                                                           |     |
| b30 to b23   | Reserved       | Should be 0 at writing.                                                                                                            | R   |
| b22 to b16   | USB_ADDR       | The written value is used as USB address after status stage of SET_ADDRESS request is completed normally.                          | R/W |
|              |                | Write these bits before the status stage of SET_ADDRESS request is completed.                                                      |     |
|              |                | These bits are cleared to 0b when it receives BusReset.                                                                            |     |
| b15          | SOF_STATUS     | SOF/uSOF reception status.                                                                                                         | R   |
|              |                | This bit is updated each time a SOF or uSOF is received.                                                                           |     |
|              |                | 0: SOF or uSOF was received normally                                                                                               |     |
|              |                | 1: SOF or uSOF reception error occurred                                                                                            |     |
| b14 to b12   | UFRAME         | The number of times for received uSOF within a frame.                                                                              | R   |
|              |                | If bit 8 (SOF_RCV) of the USB Control Register is 1b, these bits are updated even if an automatic uSOF recovery occurs.            |     |
|              |                | These bits are valid only when bit 5 (CONF) of the USB Control Register is 1b.                                                     |     |
| b11          | Reserved       | Should be 0 at writing.                                                                                                            | R   |
| b10 to b0    | FRAME          | The frame number of the SOF.                                                                                                       | R   |
|              |                | If bit 8 (SOF_RCV) of the USB Control Register is 1b, these bits are updated even if                                               |     |
|              |                | an automatic SOF recovery occurs.                                                                                                  |     |
|              |                | These bits are valid only when bit 5 (CONF) of the USB Control Register is 1b.                                                     |     |

# 10.5.7.4 TEST\_CONTROL — Test Control Register

Address: 4001 E010h



Table 10.91 TEST\_CONTROL Register Contents

| Bit Position | Bit Name      | Function                                                                                                                       | R/W |
|--------------|---------------|--------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b3    | Reserved      | Should be 0 at writing.                                                                                                        | R/W |
| b2           | FORCEHS       | By setting this bit to 1b the subsystem is set to HS mode by force. This bit is only used for LSI design.                      | R/W |
|              |               | 0: Normal operation                                                                                                            |     |
|              |               | 1: Fix the operating mode to HS mode (not for use)                                                                             |     |
| b1           | CS_TESTMODEEN | If this bit is set to 1b, the settings of bits 18 to 16 (USBTESTMODE[2:0]) of the USB Control Register becomes valid promptly. | R/W |
|              |               | This bit should be set to 1b after setting of USBTESTMODE, set to 0b after end of each test.                                   |     |
|              |               | 0: Normal operating mode                                                                                                       |     |
|              |               | 1: Enable USB test mode                                                                                                        |     |
| b0           | LOOPBACK      | Enable bit for hardware loopback on logic side.                                                                                | R/W |
|              |               | 0: Normal operating mode                                                                                                       |     |
|              |               | 1: Hardware loopback on the logic side                                                                                         |     |

### 10.5.7.5 SETUP\_DATA0 — Setup Data0 Register

Address: 4001 E018h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
|                   |     |     |     | SET | UP4 |     |     |     |     |     |     | SET | UP3 |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2  | b1  | b0  |
|                   |     |     |     | SET | UP2 |     |     |     |     |     |     | SET | UP1 |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Table 10.92 SETUP\_DATA0 Register Contents

| Bit Position | Bit Name | Function                                                       | R/W |
|--------------|----------|----------------------------------------------------------------|-----|
| b31 to b24   | SETUP4   | 4th byte of the received SETUP data.                           | R   |
|              |          | These bits are updated when it receives SETUP data every time. |     |
| b23 to b16   | SETUP3   | 3rd byte of the received SETUP data.                           | R   |
|              |          | These bits are updated when it receives SETUP data every time. |     |
| b15 to b8    | SETUP2   | 2nd byte of the received SETUP data.                           | R   |
|              |          | These bits are updated when it receives SETUP data every time. |     |
| b7 to b0     | SETUP1   | 1st byte of the received SETUP data.                           | R   |
|              |          | These bits are updated when it receives SETUP data every time. |     |

### 10.5.7.6 SETUP\_DATA1 — Setup Data1 Register

Address: 4001 E01Ch



Table 10.93 SETUP\_DATA1 Register Contents

| Bit Position | Bit Name | Function                                                       | R/W |
|--------------|----------|----------------------------------------------------------------|-----|
| b31 to b24   | SETUP8   | 8th byte of the received SETUP data.                           | R   |
|              |          | These bits are updated when it receives SETUP data every time. |     |
| b23 to b16   | SETUP7   | 7th byte of the received SETUP data.                           | R   |
|              |          | These bits are updated when it receives SETUP data every time. |     |
| b15 to b8    | SETUP6   | 6th byte of the received SETUP data.                           | R   |
|              |          | These bits are updated when it receives SETUP data every time. |     |
| b7 to b0     | SETUP5   | 5th byte of the received SETUP data.                           | R   |
|              |          | These bits are updated when it receives SETUP data every time. |     |

### 10.5.7.7 USB\_INT\_STA — USB Interrupt Status Register

Address: 4001 E020h



Table 10.94 USB\_INT\_STA Register Contents

| Table 10.94  | USB_INT_STA Re    | gister Contents                                                                        |     |  |  |  |  |  |
|--------------|-------------------|----------------------------------------------------------------------------------------|-----|--|--|--|--|--|
| Bit Position | Bit Name          | Function                                                                               | R/W |  |  |  |  |  |
| b31 to b24   | Reserved          | Should be 0 at writing.                                                                | R   |  |  |  |  |  |
| b23 to b8    | EP[m]_INT/EP0_INT |                                                                                        |     |  |  |  |  |  |
|              | (m = 115)         | Interrupt factors can be confirmed by EP0/EP[m] Status Register.                       |     |  |  |  |  |  |
|              |                   | These bits are cleared when interrupt factors in EP0/EP[m] Status Register are cleared |     |  |  |  |  |  |
|              |                   | 0: No interrupt of Endpoint0/[m] occurred                                              |     |  |  |  |  |  |
|              |                   | 1: Interrupt of Endpoint0/[m] occurred                                                 |     |  |  |  |  |  |
| b7           | Reserved          | Should be 0 at writing.                                                                | R   |  |  |  |  |  |
| b6           | SPEED_MODE_INT    | Interrupt for speed mode change                                                        | R/W |  |  |  |  |  |
|              |                   | This bit is cleared by writing 0b.                                                     |     |  |  |  |  |  |
|              |                   | 0: The speed mode has not changed from FS to HS                                        |     |  |  |  |  |  |
|              |                   | 1: The speed mode has changed from FS to HS                                            |     |  |  |  |  |  |
| b5           | SOF_ERROR_INT     | Interrupt for SOF/uSOF reception error.                                                | R/W |  |  |  |  |  |
|              |                   | This bit is set to 1b if SOF or uSOF is not received within following period           |     |  |  |  |  |  |
|              |                   | HS mode: 125 µs + 0.0625 µs.                                                           |     |  |  |  |  |  |
|              |                   | FS mode: 1 ms + 0.0005 ms.                                                             |     |  |  |  |  |  |
|              |                   | This bit is cleared by writing 0b.                                                     |     |  |  |  |  |  |
|              |                   | This bit is invalid when bit 5 (CONF) of the USB Control Register is 0b.               |     |  |  |  |  |  |
|              |                   | 0: No SOF or uSOF reception error has occurred                                         |     |  |  |  |  |  |
|              |                   | 1: An SOF or uSOF reception error has occurred                                         |     |  |  |  |  |  |
| b4           | SOF_INT           | Interrupt for SOF/uSOF reception                                                       | R/W |  |  |  |  |  |
|              |                   | This bit is cleared by writing 0b.                                                     |     |  |  |  |  |  |
|              |                   | This bit is invalid when bit 5 (CONF) of the USB Control Register is 0b.               |     |  |  |  |  |  |
|              |                   | 0: SOF or uSOF has not been received                                                   |     |  |  |  |  |  |
|              |                   | 1: SOF or uSOF has been received                                                       |     |  |  |  |  |  |
| b3           | USB_RST_INT       | Interrupt for BusReset.                                                                | R/W |  |  |  |  |  |
|              |                   | This bit is cleared by writing 0b.                                                     |     |  |  |  |  |  |
|              |                   | 0: BusReset has not been issued                                                        |     |  |  |  |  |  |
|              |                   | 1: BusReset has been issued                                                            |     |  |  |  |  |  |
| b2           | SPND_INT          | Interrupt for Suspend state.                                                           | R/W |  |  |  |  |  |
|              |                   | This bit is cleared by writing 0b.                                                     |     |  |  |  |  |  |
|              |                   | 0: Not in Suspend state                                                                |     |  |  |  |  |  |
|              |                   | 1: Entered to Suspend state                                                            |     |  |  |  |  |  |
| b1           | RSUM_INT          | Interrupt for Resume reception                                                         | R/W |  |  |  |  |  |
|              |                   | This bit is cleared by writing 0b.                                                     |     |  |  |  |  |  |
|              |                   | 0: Resume is not being received                                                        |     |  |  |  |  |  |
|              |                   | 1: Resume is being received                                                            |     |  |  |  |  |  |
| b0           | Reserved          | Should be 0 at writing.                                                                | R   |  |  |  |  |  |

### 10.5.7.8 USB\_INT\_ENA — USB Interrupt Enable Register

If each field is disabled, the corresponding interrupt is not asserted even if USB Interrupt Status Register is set.

Address: 4001 E024h



Table 10.95 USB\_INT\_ENA Register Contents

| Bit Position | Bit Name        | Function                         | R/W |
|--------------|-----------------|----------------------------------|-----|
| b31 to b24   | Reserved        | Should be 0 at writing.          | R   |
| b23 to b8    | EP[m]_EN/EP0_EN | Enable bit for EP[m]_INT/EP0_INT | R/W |
|              | (m = 115)       | 0: Disable                       |     |
|              |                 | 1: Enable                        |     |
| b7           | Reserved        | Should be 0 at writing.          | R   |
| b6           | SPEED_MODE_EN   | Enable bit for SPEED_MODE_INT    | R/W |
|              |                 | 0: Disable                       |     |
|              |                 | 1: Enable                        |     |
| b5           | SOF_ERROR_EN    | Enable bit for SOF_ERROR_INT     | R/W |
|              |                 | 0: Disable                       |     |
|              |                 | 1: Enable                        |     |
| b4           | SOF_EN          | Enable bit for SOF_INT           | R/W |
|              |                 | 0: Disable                       |     |
|              |                 | 1: Enable                        |     |
| b3           | USB_RST_EN      | Enable bit for USB_RST_INT       | R/W |
|              |                 | 0: Disable                       |     |
|              |                 | 1: Enable                        |     |
| b2           | SPND_EN         | Enable bit for SPND_INT          | R/W |
|              |                 | 0: Disable                       |     |
|              |                 | 1: Enable                        |     |
| b1           | RSUM_EN         | Enable bit for RSUM_INT          | R/W |
|              |                 | 0: Disable                       |     |
|              |                 | 1: Enable                        |     |
| b0           | Reserved        | Should be 0 at writing.          | R   |

# 10.5.7.9 EP0\_CONTROL — EP0 Control Register

Address: 4001 E028h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25            | b24          | b23          | b22 | b21 | b20             | b19                      | b18            | b17                 | b16          |
|-------------------|-----|-----|-----|-----|-----|-----|----------------|--------------|--------------|-----|-----|-----------------|--------------------------|----------------|---------------------|--------------|
|                   | _   | ı   | _   | _   | _   | _   | _              | _            |              | ı   |     | _               | ı                        | EP0_ST<br>GSEL | EP0_O<br>VERSE<br>L | EP0_A<br>UTO |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0              | 0            | 0            | 0   | 0   | 0               | 0                        | 0              | 0                   | 0            |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9             | b8           | b7           | b6  | b5  | b4              | b3                       | b2             | b1                  | b0           |
|                   | _   | _   | _   | _   | _   | _   | EP0_PI<br>DCLR | EP0_B<br>CLR | EP0_D<br>END | EP0 | _DW | EP0_IN<br>AK_EN | EP0_PER<br>R_NAK_<br>CLR | EP0_ST<br>L    | EP0_IN<br>AK        | EP0_O<br>NAK |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0              | 0            | 0            | 0   | 0   | 0               | 0                        | 0              | 1                   | 1            |

Table 10.96 EP0\_CONTROL Register Contents (1/2)

| 1 able 10.90 | E1 0_00111110E | Register Contents (1/2)                                                                                                                                                                                                                                                                         |     |
|--------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Bit Position | Bit Name       | Function                                                                                                                                                                                                                                                                                        | R/W |
| b31 to b19   | Reserved       | Should be 0 at writing.                                                                                                                                                                                                                                                                         | R   |
| b18          | EP0_STGSEL     | Select the operation when data other than null data is received in status stage.                                                                                                                                                                                                                | R/W |
|              |                | If this bit is changed during a transfer, the operation is not guaranteed.                                                                                                                                                                                                                      |     |
|              |                | <ol> <li>Normal reception. Data other than null data is discarded and it is handled as null<br/>data. No response for overrun, and it depends on EP0_OVERSEL</li> </ol>                                                                                                                         |     |
|              |                | 1: STALL response (not for use)                                                                                                                                                                                                                                                                 |     |
| b17          | EP0_OVERSEL    | Select the operation for next OUT token when an overrun occurs in OUT transfer. (No response for overrun packet.)                                                                                                                                                                               | R/W |
|              |                | If this bit is changed during a transfer, the operation is not guaranteed.                                                                                                                                                                                                                      |     |
|              |                | 0: STALL response for the next packet                                                                                                                                                                                                                                                           |     |
|              |                | 1: Handle the next packet as a retry (not for use)                                                                                                                                                                                                                                              |     |
| b16          | EP0_AUTO       | Select whether to send a packet automatically when maximum size (64 byte) is written to EP0 Write Register (transmission buffer).                                                                                                                                                               | R/W |
|              |                | There is a case when this function should be disabled, maximum packet size - 1, 2, or 3 bytes, as shown in the example below. (If this function is not disabled, all data becomes valid at writing maximum packet size) If last data includes invalid data, clear this bit and use EP0_DW[1:0]. |     |
|              |                | For example, when sending 61 to 63 bytes of data, it is handled as 64 bytes.                                                                                                                                                                                                                    |     |
|              |                | 0: Not set EP0_DEND automatically                                                                                                                                                                                                                                                               |     |
|              |                | 1: Set EP0_DEND automatically                                                                                                                                                                                                                                                                   |     |
|              |                | Caution) Change this bit while the buffer is empty.                                                                                                                                                                                                                                             |     |
| b15 to b10   | Reserved       | Should be 0 at writing.                                                                                                                                                                                                                                                                         | R/W |
| b9           | EP0_PIDCLR     | Use this bit to initialize DATA PID for Endpoint 0. Both transmission and reception PIDs are initialized to DATA1 by writing 1b.                                                                                                                                                                | W   |
|              |                | If this bit is written during a USB transaction for Endpoint 0, the write is held until the transaction finishes. DATA PID is initialized when it receives BusReset or SETUP token.                                                                                                             |     |
|              |                | This bit is write-only. Read as 0.                                                                                                                                                                                                                                                              |     |
| b8           | EP0_BCLR       | Use this bit to clear both EP0 Write and EP0 Read Registers.                                                                                                                                                                                                                                    | W   |
|              |                | Both transmission and reception buffer are initialized by writing 1b.                                                                                                                                                                                                                           |     |
|              |                | If this bit is written during a USB transaction for Endpoint 0, the write is held until the transaction finishes. In case of using this bit, it needs to check EP0_IN_DATA=0 and EP0_IN_EMPTY=1 of EP0 Status Register before writing next data.                                                |     |
|              |                | Caution) EP0 Write and EP0 Read Registers are not cleared even if USB BusReset is received.                                                                                                                                                                                                     |     |

Table 10.96 EP0\_CONTROL Register Contents (2/2)

| Bit Position | Bit Name        | Function                                                                                                                         | R/W |
|--------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------|-----|
| b7           | EP0_DEND        | Transmission enable of EP0 Write Register                                                                                        | W   |
|              |                 | The transmission data is enabled by writing 1b.                                                                                  |     |
|              |                 | When it sends null data, make sure bit 8 (EP0_IN_EMPTY) of EP0 Status Register is                                                |     |
|              |                 | 1b, then write 1b to this bit.                                                                                                   |     |
|              |                 | This bit is write-only. Read as 0.                                                                                               |     |
| b6, b5       | EP0_DW          | Valid data size for last data written in EP0 Write Register (transmission buffer).                                               | W   |
|              |                 | Set these bits together with EP0_DEND=1.                                                                                         |     |
|              |                 | 00b: 4                                                                                                                           |     |
|              |                 | 01b: 1                                                                                                                           |     |
|              |                 | 10b: 2                                                                                                                           |     |
|              |                 | 11b: 3                                                                                                                           |     |
|              |                 | This field is write-only. Read as 0.                                                                                             |     |
| b4           | EP0_INAK_EN     | Write enable bit of EP0_INAK                                                                                                     | W   |
|              |                 | When writing to EP0_INAK, set 1b at the same time.                                                                               |     |
|              |                 | This bit is write-only. Read as 0.                                                                                               |     |
|              |                 | Note) This bit is used to prevent EP0_INAK from being cleared unintentionally when                                               |     |
|              |                 | set EP0_INAK by hardware and accessing this register by the software occurs                                                      |     |
|              |                 | at the same time.                                                                                                                |     |
| b3           | EP0_PERR_NAK_CL | Write 1b to this bit to cancel forced NAK state by illegal token.                                                                | W   |
|              | R               | Generally, this bit is not used since the STALL state is set by EP0_STL when it occurs                                           |     |
|              |                 | forced NAK state.                                                                                                                |     |
|              |                 | This bit is write-only. Read as 0.                                                                                               |     |
| b2           | EP0_STL         | STALL response control bit for IN/OUT/PING token to Endpoint0.                                                                   | R/W |
|              |                 | If this bit is set to 1b, STALL is returned to all IN, OUT, and PING tokens during data                                          |     |
|              |                 | stage and status stages. Even if this bit is cleared, STALL response is not canceled.                                            |     |
|              |                 | This bit is cleared to 0b automatically when it receives SETUP token. This bit has a priority over EP0_ONAK and EP0_INAK.        |     |
|              |                 | This bit is set to 1b in following case                                                                                          |     |
|              |                 | <ul> <li>Data other than null data is received at status stage while EP0_STGSEL is 1b,</li> </ul>                                |     |
|              |                 | Overrun occurs while EP0_OVERSEL is 0b.                                                                                          |     |
|              |                 | 0: Not return STALL.                                                                                                             |     |
|              |                 | 1: Return STALL.                                                                                                                 |     |
| L 4          | EDO INAK        |                                                                                                                                  | DAM |
| b1           | EP0_INAK        | NAK response control bit for IN token to Endpoint0.  Generally ACK, NAK are issued automatically according to status of EP0 Read | R/W |
|              |                 | Register (reception buffer).                                                                                                     |     |
|              |                 | Write 1b to this bit to send a NAK by force.                                                                                     |     |
|              |                 | This bit is set to 1b at the end of normal completion SETUP transaction.                                                         |     |
|              |                 | 0: Transmit data if data exists in the transmission buffer                                                                       |     |
|              |                 | 1: Return a NAK even if data exists in the transmission buffer                                                                   |     |
| b0           | EP0_ONAK        | NAK response control bit for OUT/PING token to Endpoint0.                                                                        | R/W |
|              |                 | Generally ACK, NAK, and NYET are issued automatically according to status of EP0                                                 | ,   |
|              |                 | Read Register (reception buffer).                                                                                                |     |
|              |                 | Write 1b to this bit to send a NAK by force.                                                                                     |     |
|              |                 | This bit is set to 1b at the end of normal completion SETUP transaction.                                                         |     |
|              |                 | 0: Receive data if there is available space in the reception buffer                                                              |     |
|              |                 | 1: Return a NAK even if there is available space in the reception buffer                                                         |     |

# 10.5.7.10 EP0\_STATUS — EP0 Status Register

Address: 4001 E02Ch

| Bit               | b31 | b30 | b29 | b28                   | b27 | b26             | b25      | b24 | b23 | b22 | b21             | b20            | b19                   | b18             | b17                   | b16                      |
|-------------------|-----|-----|-----|-----------------------|-----|-----------------|----------|-----|-----|-----|-----------------|----------------|-----------------------|-----------------|-----------------------|--------------------------|
|                   | _   | _   | ı   | ı                     | ı   | _               | _        | _   | _   | _   | ı               | ı              | ı                     | EP0_PI<br>D     | ERR_N                 | EP0_P<br>ERR_N<br>AK_INT |
| Value after reset | 0   | 0   | 0   | 0                     | 0   | 0               | 0        | 0   | 0   | 0   | 0               | 0              | 0                     | 1               | 0                     | 0                        |
|                   |     |     |     |                       |     |                 |          |     |     |     |                 |                |                       |                 |                       |                          |
| Bit               | b15 | b14 | b13 | b12                   | b11 | b10             | b9       | b8  | b7  | b6  | b5              | b4             | b3                    | b2              | b1                    | b0                       |
|                   |     |     |     | EP0_O<br>UT_EM<br>PTY |     | EP0_IN<br>_DATA | LF U_IIN |     |     |     | EP0_O<br>UT_INT | EP0_IN<br>_INT | EP0_ST<br>ALL_IN<br>T | STG_E<br>ND_INT | STG_S<br>TART_I<br>NT | SETUP<br>_INT            |
| Value after reset | 0   | 0   | 0   | 1                     | 0   | 0               | 0        | 1   | 0   | 0   | 0               | 0              | 0                     | 0               | 0                     | 0                        |

Table 10.97 EP0\_STATUS Register Contents (1/3)

| 51.5 1.1     | BI: N                |                                                                                                                                                                                                                                                                                                                                                                 |     |
|--------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Bit Position | Bit Name             | Function                                                                                                                                                                                                                                                                                                                                                        | R/W |
| 31 to b19    | Reserved             | Should be 0 at writing.                                                                                                                                                                                                                                                                                                                                         | R   |
| 18           | EP0_PID              | Next DATA PID                                                                                                                                                                                                                                                                                                                                                   | R   |
|              |                      | 0: DATA0                                                                                                                                                                                                                                                                                                                                                        |     |
|              |                      | 1: DATA1                                                                                                                                                                                                                                                                                                                                                        |     |
| o17          | EP0_PERR_NAK         | This bit is set to 1b when it enters to forced NAK state due to reception of illegal token at Endpoint0.                                                                                                                                                                                                                                                        | R   |
|              |                      | "illegal token" means                                                                                                                                                                                                                                                                                                                                           |     |
|              |                      | <ul> <li>IN/OUT token reception before SETUP token is received (no setup stage)</li> </ul>                                                                                                                                                                                                                                                                      |     |
|              |                      | OUT token reception at Control Read data stage                                                                                                                                                                                                                                                                                                                  |     |
|              |                      | <ul> <li>IN or invalid OUT token reception at Control Read status stage</li> </ul>                                                                                                                                                                                                                                                                              |     |
|              |                      | <ul> <li>IN or invalid OUT token reception at Control Write data stage</li> </ul>                                                                                                                                                                                                                                                                               |     |
|              |                      | <ul> <li>OUT or PING token reception at Control Write status stage</li> </ul>                                                                                                                                                                                                                                                                                   |     |
|              |                      | OUT token reception at No Data Control status stage                                                                                                                                                                                                                                                                                                             |     |
|              |                      | While this bit is 1b, forced NAK is sent for IN/OUT/ PING token to Endpoint 0. If this bit is set, set bit 2 (EP0_STL) of the EP0 Control Register so that the Endpoint becomes STALL state. This bit is cleared to 0b when it receives SETUP token. This bit is also cleared to 0b when 1b is written to bit 3 (EP0_PERR_NAK_CLR) of the EP0 Control Register. |     |
|              |                      | 0: Not forced NAK state by illegal token                                                                                                                                                                                                                                                                                                                        |     |
|              |                      | 1: Forced NAK state by illegal token                                                                                                                                                                                                                                                                                                                            |     |
| o16          | EP0_PERR_NAK_IN<br>T | This bit is set to 1b when forced NAK response due to reception of illegal token at Endpoint0.                                                                                                                                                                                                                                                                  | R/W |
|              |                      | If this bit is set, set bit 2 (EP0_STL) of the EP0 Control Register so that the Endpoint becomes STALL state.                                                                                                                                                                                                                                                   |     |
|              |                      | This bit is cleared by writing 0b.                                                                                                                                                                                                                                                                                                                              |     |
|              |                      | 0: Illegal token was not received                                                                                                                                                                                                                                                                                                                               |     |
|              |                      | 1: Illegal token was received, and NAK was sent                                                                                                                                                                                                                                                                                                                 |     |
| 15           | EP0_OUT_NAK_INT      | This bit is set to 1b when NAK was sent for OUT/PING token to Endpoint 0.                                                                                                                                                                                                                                                                                       | R/V |
|              |                      | This bit is cleared by writing 0b.                                                                                                                                                                                                                                                                                                                              |     |
|              |                      | 0: NAK was not set for OUT/PING token                                                                                                                                                                                                                                                                                                                           |     |
|              |                      | 1: NAK was sent for OUT/PING token                                                                                                                                                                                                                                                                                                                              |     |
| 14           | EP0_OUT_NULL         | This bit is set to 1b when null data to Endpoint 0 is received.                                                                                                                                                                                                                                                                                                 | R   |
|              |                      | This bit is updated when valid OUT data is stored in EP0 Read Register (reception buffer).                                                                                                                                                                                                                                                                      |     |
|              |                      | 0: Null data was not received                                                                                                                                                                                                                                                                                                                                   |     |
|              |                      | 1: Null data was received.                                                                                                                                                                                                                                                                                                                                      |     |

Table 10.97 EP0\_STATUS Register Contents (2/3)

| Bit Position | Bit Name         | Function                                                                                                                                                               | R/W    |
|--------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| b13          | EP0_OUT_FULL     | EP0 Read Register (reception buffer) full status                                                                                                                       | R      |
|              |                  | This bit is updated according to the buffer status.                                                                                                                    |        |
|              |                  | 0: Reception buffer is not full                                                                                                                                        |        |
|              |                  | 1: Reception buffer is full, Maxpacketsize (64 Byte)                                                                                                                   |        |
| b12          | EP0_OUT_EMPTY    | EP0 Read Register (reception buffer) empty status                                                                                                                      | R      |
|              |                  | This bit is updated according to the buffer status.                                                                                                                    |        |
|              |                  | 0: Reception buffer is not empty                                                                                                                                       |        |
|              |                  | 1: Reception buffer is empty                                                                                                                                           |        |
| b11          | EP0_IN_NAK_INT   | This bit is set to 1b when a NAK is sent in response to an IN token for Endpoint0. This bit is cleared by writing 0b.                                                  | R/W    |
|              |                  | 0: NAK has not been sent in response to an IN token                                                                                                                    |        |
|              |                  | 1: NAK was sent in response to an IN token                                                                                                                             |        |
| b10          | EP0_IN_DATA      | EP0 Write Register (transmission buffer) data valid                                                                                                                    | R      |
|              |                  | This bit is not set 1b while bit 7 (EP0_DEND) of the EP0 Control Register is 0b.                                                                                       |        |
|              |                  | This bit is updated according to the buffer status.                                                                                                                    |        |
|              |                  | 0: There is no waiting data in the transmission buffer.                                                                                                                |        |
|              |                  | 1: There is a waiting data in the transmission buffer.                                                                                                                 |        |
| b9           | EP0_IN_FULL      | EP0 Write Register (transmission buffer) full status.                                                                                                                  | R      |
|              |                  | This bit is updated according to the buffer status.                                                                                                                    |        |
|              |                  | 0: Transmission buffer is not full                                                                                                                                     |        |
|              |                  | 1: Transmission buffer is full                                                                                                                                         |        |
| b8           | EP0_IN_EMPTY     | EP0 Write Register (transmission buffer) empty status.                                                                                                                 | R      |
|              |                  | This bit is updated according to the buffer status.                                                                                                                    |        |
|              |                  | 0: Transmission buffer is not empty                                                                                                                                    |        |
|              |                  | 1: Transmission buffer is empty                                                                                                                                        |        |
| b7           | EP0_OUT_NULL_INT | This bit is set to 1b when received null data is stored in the EP0 Read Register (reception buffer). This bit is cleared by writing 0b.                                | R/W    |
|              |                  | 0: Null data has not been received                                                                                                                                     |        |
|              |                  | 1: Null data was received                                                                                                                                              |        |
| b6           | EP0_OUT_OR_INT   | This bit is set to 1b if overrun occurs while Endpoint0 receives a data.                                                                                               | R/W    |
|              |                  | This bit is cleared by writing 0b.                                                                                                                                     |        |
|              |                  | 0: No overrun occurred.                                                                                                                                                |        |
|              |                  | 1: Overrun occurred.                                                                                                                                                   |        |
| b5           | EP0_OUT_INT      | This bit is set to 1b when valid data is stored to EP0 Read Register (reception buffer)                                                                                | R/W    |
|              |                  | This bit is cleared by writing 0b.                                                                                                                                     |        |
|              |                  | 0: Not ready to read from reception buffer                                                                                                                             |        |
|              |                  | 1: Ready to read from reception buffer                                                                                                                                 |        |
| b4           | EP0_IN_INT       | This bit is set to 1b when data is sent from EP0 Write Register (transmission buffer)                                                                                  | R/W    |
|              |                  | normally.  This bit is cleared by writing 0b.                                                                                                                          |        |
|              |                  | Transmission buffer has not become writable yet.                                                                                                                       |        |
|              |                  | Transmission buffer becomes writable.  1: Transmission buffer becomes writable.                                                                                        |        |
| h2           | FDO CTALL INT    |                                                                                                                                                                        | D/M    |
| b3           | EP0_STALL_INT    | This bit is set to 1b when Endpoint0 moves to STALL state.  While bit 17 (EP0_OVERSEL) of the EP0 Control Register is 0, this bit is set to 1b when an overrun occurs. | R/W    |
|              |                  | This bit is cleared by writing 0b.                                                                                                                                     |        |
|              |                  | 0: Processing at Endpoint0 is not stalled                                                                                                                              |        |
|              |                  | 1: Processing at Endpoint0 is stalled                                                                                                                                  |        |
| b2           | STG_END_INT      | This bit is set to 1b when the status stage of Control transfer completes normally.                                                                                    | R/W    |
| U <u>L</u>   | G I G_LIND_IIN I | This bit is cleared by writing 0b.                                                                                                                                     | 13/ 7/ |
|              |                  | This bit is cleared by writing ob.  This bit is cleared when it receives next SETUP token.                                                                             |        |
|              |                  | Status stage has not completed normally                                                                                                                                |        |
|              |                  | Status stage completed normally                                                                                                                                        |        |

Table 10.97 EP0\_STATUS Register Contents (3/3)

| Bit Position | Bit Name      | Function                                                                                                    | R/W |
|--------------|---------------|-------------------------------------------------------------------------------------------------------------|-----|
| b1           | STG_START_INT | This bit is set to 1b when the status stage of Control transfer starts.                                     | R/W |
|              |               | This bit is cleared by writing 0b, or cleared when it receives next SETUP token.                            |     |
|              |               | 0: Status stage is not started                                                                              |     |
|              |               | 1: Status stage is started                                                                                  |     |
| b0           | SETUP_INT     | This bit is set to 1b when valid SETUP data is received.                                                    | R/W |
|              |               | Clear this bit before starting request procedure to prepare next SETUP data reception during the procedure. |     |
|              |               | This bit is cleared by writing 0b.                                                                          |     |
|              |               | 0: Valid SETUP data has not been received                                                                   |     |
|              |               | 1: Valid SETUP data was received                                                                            |     |

### 10.5.7.11 EP0\_INT\_ENA — EP0 Interrupt Enable Register

If each field is disabled, the corresponding interrupt is not asserted even if EPO Status Register is set.

Address: 4001 E030h



Table 10.98 EP0\_INT\_ENA Register Contents (1/2)

| Bit Position | Bit Name        | Function                                                                            | R/W |
|--------------|-----------------|-------------------------------------------------------------------------------------|-----|
| b31 to b17   | Reserved        | Should be 0 at writing.                                                             | R   |
| b16          | EP0_PERR_NAK_EN | Enable for bit 16 (EP0_PERR_NAK_INT) of EP0 Status Register.  0: Disable  1: Enable | R/W |
| b15          | EP0_OUT_NAK_EN  | Enable for bit 15 (EP0_OUT_NAK_INT) of EP0 Status Register.  0: Disable  1: Enable  | R/W |
| b14 to b12   | Reserved        |                                                                                     | R   |
| b11          | EP0_IN_NAK_EN   | Enable for bit 11 (EP0_IN_NAK_INT) of EP0 Status Register.  0: Disable  1: Enable   | R/W |
| b10 to b8    | Reserved        |                                                                                     | R   |
| b7           | EP0_OUT_NULL_EN | Enable for bit 7 (EP0_OUT_NULL_INT) of EP0 Status Register.  0: Disable  1: Enable  | R/W |
| b6           | EP0_OUT_OR_EN   | Enable for bit 6 (EP0_OUT_OR_INT) of EP0 Status Register.  0: Disable  1: Enable    | R/W |
| b5           | EP0_OUT_EN      | Enable for bit 5 (EP0_OUT_INT) of EP0 Status Register.  0: Disable  1: Enable       | R/W |
| b4           | EP0_IN_EN       | Enable for bit 4 (EP0_IN_INT) of EP0 Status Register.  0: Disable  1: Enable        | R/W |
| b3           | EP0_STALL_EN    | Enable for bit 3 (EP0_STALL_INT) of EP0 Status Register.  0: Disable  1: Enable     | R/W |
| b2           | STG_END_EN      | Enable for bit 2 (STG_END_INT) of EP0 Status Register. 0: Disable 1: Enable         | R/W |

Table 10.98 EP0\_INT\_ENA Register Contents (2/2)

| Bit Position | Bit Name     | Function                                                 | R/W |
|--------------|--------------|----------------------------------------------------------|-----|
| b1           | STG_START_EN | Enable for bit 1 (STG_START_INT) of EP0 Status Register. | R/W |
|              |              | 0: Disable                                               |     |
|              |              | 1: Enable                                                |     |
| b0           | SETUP_EN     | Enable for bit 0 (SETUP_INT) of EP0 Status Register.     | R/W |
|              |              | 0: Disable                                               |     |
|              |              | 1: Enable                                                |     |

### 10.5.7.12 EP0\_LENGTH — EP0 OUT Data Length Register

Address: 4001 E034h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19    | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|--------|-----|-----|-----|
|                   | _   | _   | _   | _   | _   | _   | _   | _   | _   | _   | _   | _   | _      | _   | _   | _   |
|                   |     |     |     |     |     |     |     |     |     |     |     |     |        |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0   | 0   | 0   |
|                   |     |     |     |     |     |     |     |     |     |     |     |     |        |     |     |     |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3     | b2  | b1  | b0  |
|                   |     |     |     |     |     |     |     |     |     |     |     |     |        |     |     |     |
|                   | _   | _   | _   | _   | _   | _   | _   | _   | _   |     |     | E   | P0_LDA | ГА  |     |     |
|                   |     |     |     |     |     |     |     |     |     |     |     |     |        |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0   | 0   | 0   |

Table 10.99 EP0\_LENGTH Register Contents

| Bit Position | Bit Name  | Function                                                                                                                         | R/W |
|--------------|-----------|----------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b7    | Reserved  |                                                                                                                                  | R   |
| b6 to b0     | EP0_LDATA | If OUT data is received in the EP0 Read Register (reception buffer) normally, this field indicates the number of received bytes. | R   |
|              |           | The value is decremented by reading EP0 Read Register, and it indicates number of the remaining data.                            |     |

### 10.5.7.13 EP0\_READ — EP0 Read Register

Address: 4001 E038h



Table 10.100 EP0\_READ Register Contents

| Bit Position | Bit Name   | Function                | R/W |
|--------------|------------|-------------------------|-----|
| b31 to b24   | EP0_RDATA4 | Endpoint0 received data | R   |
| b23 to b16   | EP0_RDATA3 | Endpoint0 received data | R   |
| b15 to b8    | EP0_RDATA2 | Endpoint0 received data | R   |
| b7 to b0     | EP0_RDATA1 | Endpoint0 received data | R   |

# 10.5.7.14 EP0\_WRITE — EP0 Write Register

Address: 4001 E03Ch

| Bit               | b31 | b30 | b29 | b28   | b27   | b26 | b25 | b24 | b23 | b22 | b21 | b20   | b19    | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-------|-------|-----|-----|-----|-----|-----|-----|-------|--------|-----|-----|-----|
|                   |     |     |     | EP0_W | DATA4 |     |     |     |     |     |     | EP0_W | /DATA3 |     |     |     |
| Value after reset | 0   | 0   | 0   | 0     | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0      | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12   | b11   | b10 | b9  | b8  | b7  | b6  | b5  | b4    | b3     | b2  | b1  | b0  |
|                   |     |     |     | EP0_W | DATA2 |     |     |     |     |     |     | EP0_W | /DATA1 |     |     |     |
| Value after reset | 0   | 0   | 0   | 0     | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0      | 0   | 0   | 0   |

Table 10.101 EP0\_WRITE Register Contents

| Bit Position | Bit Name   | Function                | R/W |
|--------------|------------|-------------------------|-----|
| b31 to b24   | EP0_WDATA4 | Endpoint0 transmit data | W   |
| b23 to b16   | EP0_WDATA3 | Endpoint0 transmit data | W   |
| b15 to b8    | EP0_WDATA2 | Endpoint0 transmit data | W   |
| b7 to b0     | EP0_WDATA1 | Endpoint0 transmit data | W   |

# 10.5.7.15 EP[m]\_CONTROL — EP[m] Control Register (m = 1..15)

Address: 4001 E040h + 20h × (m - 1)

| Ві               | t b31        | b30                    | b29 | b28 | b27               | b26                   | b25            | b24             | b23            | b22  | b21  | b20                   | b19            | b18            | b17                   | b16            |
|------------------|--------------|------------------------|-----|-----|-------------------|-----------------------|----------------|-----------------|----------------|------|------|-----------------------|----------------|----------------|-----------------------|----------------|
|                  | EP[m]_<br>EN | EP[m]_<br>BUF_T<br>YPE | _   | _   | _                 | EP[m]_<br>DIR0        | EP[m]_         | _MODE           | _              | 1    | _    | _                     | _              | 1              | EP[m]_<br>OVERS<br>EL |                |
| Value after rese | t 0          | Х                      | 0   | 0   | 0                 | 0                     | Х              | Х               | 0              | 0    | 0    | 0                     | 0              | 0              | 0                     | 0              |
|                  |              |                        |     |     |                   |                       |                |                 |                |      |      |                       |                |                |                       |                |
| Bi               | t b15        | b14                    | b13 | b12 | b11               | b10                   | b9             | b8              | b7             | b6   | b5   | b4                    | b3             | b2             | b1                    | b0             |
|                  | _            | -                      | _   | _   | EP[m]_I<br>PIDCLR | EP[m]_<br>OPIDCL<br>R | EP[m]_<br>BCLR | EP[m]_<br>CBCLR | EP[m]_<br>DEND | EP[m | ]_DW | EP[m]_<br>OSTL_<br>EN | EP[m]_I<br>STL | EP[m]_<br>OSTL | _                     | EP[m]_<br>ONAK |
| Value after rese | t 0          | 0                      | 0   | 0   | 0                 | 0                     | 0              | 0               | 0              | 0    | 0    | 0                     | 0              | 0              | 0                     | 1              |

Table 10.102 EP[m]\_CONTROL Register Contents (1/3)

| Bit Position | Bit Name       | Function                                                                                                                                                                                                                                                                                                                                                                                                                 | R/W |
|--------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31          | EP[m]_EN       | Enable of Endpoint[m]  If this bit is set while bit 5 (CONF) of USB Control Register is 1b, the corresponding Endpoint can respond to USB transactions. When this bit is 0b, the EP[m] Write/Read Register (transmission/reception buffer) is cleared. If this bit is written during a USB transaction for Endpoint[m], the write is held until the transaction finishes.  0: Disable Endpoint[m]  1: Enable Endpoint[m] | R/W |
|              |                | Caution) This bit is assumed to be changed only when it receives BusReset, USB request (such as Set Interface), or it initializes. No DATA PID initialization occurs even if this bit is cleared.                                                                                                                                                                                                                        |     |
| b30          | EP[m]_BUF_TYPE | Buffer type of EP[m] buffering. Read-only. 0: Single buffering 1: Double buffering                                                                                                                                                                                                                                                                                                                                       | R   |
| b29 to b27   | Reserved       | Should be 0 at writing.                                                                                                                                                                                                                                                                                                                                                                                                  | R   |
| b26          | EP[m]_DIR0     | Direction of Endpoint[m] 0: IN 1: OUT                                                                                                                                                                                                                                                                                                                                                                                    | R/W |
|              |                | <b>Caution)</b> This bit is assumed to be changed during initialization only. If this bit is changed during a transfer, the operation is not guaranteed.                                                                                                                                                                                                                                                                 |     |
| b25, b24     | EP[m]_MODE     | Transfer type of Endpoint[m]. Read only.  00b: Bulk  01b: Interrupt  10b: Isochronous  11b: Reserved                                                                                                                                                                                                                                                                                                                     | R   |
| b23 to b18   | Reserved       | Should be 0 at writing.                                                                                                                                                                                                                                                                                                                                                                                                  | R   |
| b17          | EP[m]_OVERSEL  | Select the operation for next OUT token when an overrun occurs in OUT transfer.  If this bit is changed during a transfer, the operation is not guaranteed. Invalid for Isochronous transfer.  0: Return a STALL for the next packet  1: Handle the next packet as a retry (not for use)                                                                                                                                 | R/W |

Table 10.102 EP[m]\_CONTROL Register Contents (2/3)

| Bit Position | Bit Name      | Function                                                                                                                                                                                                                                                                                          | R/W |
|--------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b16          | EP[m]_AUTO    | Select whether to send a packet automatically when MaxPacketSize data is written to EP[m] Write Register (transmission buffer).                                                                                                                                                                   | R/W |
|              |               | There is a case when this function should be disabled, maximum packet size - 1, 2, or 3 bytes, as shown in the example below. (If this function is not disabled, all data becomes valid at writing maximum packet size) If last data includes invalid data, clear this bit and use EP[m]_DW[1:0]. |     |
|              |               | <ul> <li>Ex1) 32 bit CPU MaxPacketSize = 512, transmit size = 509 to 511 (Valid data size will be 512 bytes)</li> <li>Ex2) 32 bit CPU MaxPacketSize = 511, transmit size = 509,510 (Valid data size</li> </ul>                                                                                    |     |
|              |               | will be 511 bytes) 0: Not set EP[m]_DEND automatically                                                                                                                                                                                                                                            |     |
|              |               | Set EP[m]_DEND automatically  Caution) Setting this bit is prohibited if bit 4 (EP[m]_DMA_EN) of the EP[m] DMA Control Register is 1b. In addition, do not use this bit if MaxPacketSize=000h.                                                                                                    |     |
| b15 to b12   | Reserved      | Should be 0 at writing.                                                                                                                                                                                                                                                                           | R   |
| b11          | EP[m]_IPIDCLR | Use this bit to initialize transmission DATA PID for Endpoint[m]. The transmission DATA PID is initialized by writing 1b.                                                                                                                                                                         | W   |
|              |               | If this bit is written during a USB transaction for Endpoint[m], the write is held until the transaction finishes.                                                                                                                                                                                |     |
|              |               | This bit is write-only. Read as 0.                                                                                                                                                                                                                                                                |     |
|              |               | Caution) DATA PID is initialized when it receives BusReset.                                                                                                                                                                                                                                       |     |
| b10          | EP[m]_OPIDCLR | Use this bit to initialize receive DATA PID for Endpoint[m]. The receive DATA PID is initialized by writing 1b.                                                                                                                                                                                   | W   |
|              |               | If this bit is written during a USB transaction for Endpoint[m], the write is held until the transaction finishes.                                                                                                                                                                                |     |
|              |               | This bit is write-only. Read as 0.                                                                                                                                                                                                                                                                |     |
|              |               | Caution) DATA PID is initialized when it receives BusReset.                                                                                                                                                                                                                                       |     |
| b9           | EP[m]_BCLR    | Use this bit to clear both EP[m] Write and EP[m] Read Registers on CPU side and USB side. Both transmission and reception buffers on CPU side and USB side are initialized by writing 1b.                                                                                                         | W   |
|              |               | If this bit is written during a USB transaction for Endpoint[m], the write is held until the transaction finishes. In case of EP[m]_DIR0=0, it needs to check EP[m]_IN_DATA =0 and EP[m]_IN_EMPTY=1 of EP[m] Status Register after setting this bit.  This bit is write-only. Read as 0.          |     |
|              |               | Caution) Setting this bit together with EP[m]_CBCLR is prohibited. In addition, setting this bit is prohibited if bit 4 (EP[m]_DMA_EN) of the EP[m] DMA Control Register is 1b. EP[m] Write and EP[m] Read Registers are not cleared even if USB BusReset is received.                            |     |
| b8           | EP[m]_CBCLR   | Use this bit to clear both EP[m] Write and EP[m] Read Registers on CPU side. Both transmission and reception buffer on CPU side are initialized by writing 1b.  This bit is invalid in single buffer case.  This bit is write-only. Read as 0.                                                    | W   |
|              |               | Caution) Setting this bit together with EP[m]_BCLR is prohibited. In addition, setting this bit is prohibited if bit 4 (EP[m]_DMA_EN) of the EP[m] DMA Control Register is 1b.                                                                                                                    |     |

Table 10.102 EP[m]\_CONTROL Register Contents (3/3)

| Bit Position | Bit Name      | Function                                                                                                                                                                                                                                                                                                                                                                       | R/W |
|--------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b7           | EP[m]_DEND    | Transmission enable of EP[m] write Register The transmission data is enabled by writing 1b. When it sends null data, make sure bit 0 (EP[m]_IN_EMPTY) of the EP[m] Status Register is 1b, then write 1b to this bit. This bit is write-only. Read as 0.                                                                                                                        | W   |
|              |               | <b>Caution)</b> Setting this bit is prohibited if bit 4 (EP[m]_DMA_EN) of the EP[m] DMA Control Register is 1b.                                                                                                                                                                                                                                                                |     |
| b6, b5       | EP[m]_DW      | Valid data size for last data written in EP[m] Write Register (transmission buffer).  Set these bits together with EP[m]_DEND=1.  00b: 4  01b: 1  10b: 2  11b: 3                                                                                                                                                                                                               | W   |
|              | EDI I COTI EN | This field is write-only. Read as 0.                                                                                                                                                                                                                                                                                                                                           | 147 |
| b4           | EP[m]_OSTL_EN | Write enable bit of EP[m]_OSTL  When writing to EP[m]_OSTL, set 1b at the same time.                                                                                                                                                                                                                                                                                           | W   |
|              |               | This bit is write-only. Read as 0.                                                                                                                                                                                                                                                                                                                                             |     |
| b3           | EP[m]_ISTL    | STALL response control bit for IN token to Endpoint[m] 0: Not return STALL for IN token 1: Return STALL for IN token                                                                                                                                                                                                                                                           | R/W |
| b2           | EP[m]_OSTL    | STALL response control bit for OUT/PING token to Endpoint[m] EP[m]_OSTL_EN should be 1 together when it writes 1 to this bit. This bit is set to 1b if overrun occur when EP[m]_OVERSEL=0.  0: Not return STALL for OUT/PING token  1: Return STALL for OUT/PING token                                                                                                         | R/W |
| b1           | Reserved      | Should be 0 at writing.                                                                                                                                                                                                                                                                                                                                                        | R   |
| b0           | EP[m]_ONAK    | NAK response control bit for OUT/PING token to Endpoint[m].  Generally ACK, NAK, and NYET are issued automatically according to status of EP[m] Read Register (reception buffer).  Write 1b to this bit to send a NAK by force.  0: Receive data if there is available space in the reception buffer  1: Return a NAK even if there is available space in the reception buffer | R/W |

# 10.5.7.16 EP[m]\_STATUS — EP[m] Status Register (m = 1..15)

Address: 4001 E044h + 20h × (m - 1)

| Bit               | b31 | b30 | b29                      | b28            | b27                     | b26              | b25                    | b24              | b23                      | b22   | b21                           | b20                        | b19              | b18                   | b17               | b16                     |
|-------------------|-----|-----|--------------------------|----------------|-------------------------|------------------|------------------------|------------------|--------------------------|-------|-------------------------------|----------------------------|------------------|-----------------------|-------------------|-------------------------|
|                   | _   |     | EP[m]_I<br>SO_PID<br>ERR | EP[m]_<br>OPID | EP[m]_<br>OUT_N<br>OTKN | EP[m]_I<br>SO_OR | l                      | SO_CR            | OUT_E                    | OUT_O | EP[m]_O<br>UT_NAK_<br>ERR_INT | UT_STAL                    |                  |                       |                   | EP[m]_<br>OUT_E<br>MPTY |
| Value after reset | 0   | 0   | 0                        | 0              | 0                       | 0                | 0                      | 0                | 0                        | 0     | 0                             | 0                          | 0                | 0                     | 0                 | 1                       |
| Bit               | b15 | b14 | b13                      | b12            | b11                     | b10              | b9                     | b8               | b7                       | b6    | b5                            | b4                         | b3               | b2                    | b1                | b0                      |
|                   | 1   | _   | _                        | _              | _                       |                  | EP[m]_l<br>N_NOT<br>KN | EP[m]_I<br>SO_UR | EP[m]_I<br>N_END<br>_INT | _     | EP[m]_IN<br>_NAK_ER<br>R_INT  | EP[m]_I<br>N_STA<br>LL_INT | EP[m]_I<br>N_INT | EP[m]_I<br>N_DAT<br>A | EP[m]_I<br>N_FULL | EP[m]_I<br>N_EMP<br>TY  |
| Value after reset | 0   | 0   | 0                        | 0              | 1                       | 0                | 0                      | 0                | 0                        | 0     | 0                             | 0                          | 0                | 0                     | 1                 | 1                       |

Table 10.103 EP[m]\_STATUS Register Contents (1/4)

| Bit Position | Bit Name         | Function                                                                           | R/W |
|--------------|------------------|------------------------------------------------------------------------------------|-----|
| b31, b30     | Reserved         | Should be 0 at writing.                                                            | R   |
| b29          | EP[m]_ISO_PIDERR | For Isochronous Endpoint:                                                          | R   |
|              |                  | This bit is set if it receives illegal DATA PID.                                   |     |
|              |                  | In HS mode, this bit is set when received DATA PID is DATA1, DATA2, or MDATA.      |     |
|              |                  | In FS mode, this bit is set when received DATA PID is DATA1.                       |     |
|              |                  | 0: No invalid DATA PID has been received                                           |     |
|              |                  | 1: Invalid DATA PID was received                                                   |     |
|              |                  | For Interrupt/Bulk Endpoint:                                                       |     |
|              |                  | Always 0                                                                           |     |
| b28          | EP[m]_OPID       | Indicates next expected DATA PID.                                                  | R   |
|              |                  | 0: DATA0                                                                           |     |
|              |                  | 1: DATA1                                                                           |     |
| b27          | EP[m]_OUT_NOTKN  | For Isochronous Endpoint:                                                          | R   |
|              |                  | This bit is set if no OUT token is received in the interval between SOFs or uSOFs. |     |
|              |                  | This bit is updated each time SOF or uSOF is received.                             |     |
|              |                  | 0: OUT token was received between SOFs or uSOFs                                    |     |
|              |                  | 1: No OUT tokens have been received between SOFs or uSOFs                          |     |
|              |                  | For Interrupt/Bulk Endpoint:                                                       |     |
|              |                  | Always 0                                                                           |     |
| b26          | EP[m]_ISO_OR     | For Isochronous Endpoint:                                                          | R   |
|              |                  | This bit is set when OUT token is received while there is no room in EP[m] Read    |     |
|              |                  | Register (reception buffer) and OUT data is discarded.                             |     |
|              |                  | This bit is updated each time data is received.                                    |     |
|              |                  | 0: No OUT data has been discarded                                                  |     |
|              |                  | 1: The received OUT data was discarded                                             |     |
|              |                  | For Interrupt/Bulk Endpoint:                                                       |     |
|              |                  | Always 0                                                                           |     |
| b25          | Reserved         | Should be 0 at writing.                                                            | R   |

Table 10.103 EP[m]\_STATUS Register Contents (2/4)

| Bit Position | Bit Name                | Function                                                                                                                                                                                                              | R/W |
|--------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b24          | EP[m]_ISO_CRC           | • For Isochronous Endpoint:                                                                                                                                                                                           | R   |
|              |                         | This bit is set if the received data includes a CRC error.                                                                                                                                                            |     |
|              |                         | If the data is not required, set bit 8 (EP[m]_CBCLR) of the EP[m] Control Register to clear the received data. Note that received null data is cleared automatically.                                                 |     |
|              |                         | This bit is updated each time data is received.                                                                                                                                                                       |     |
|              |                         | This bit is cleared when the reception buffer is cleared.                                                                                                                                                             |     |
|              |                         | 0: The received data does not include a CRC error                                                                                                                                                                     |     |
|              |                         | 1: The received data includes a CRC error                                                                                                                                                                             |     |
|              |                         | For Interrupt/Bulk Endpoint:                                                                                                                                                                                          |     |
|              |                         | Always 0                                                                                                                                                                                                              |     |
| b23          | EP[m]_OUT_END_IN        | This bit is set when buffer read DMA for OUT-direction Endpoint[m] completes.                                                                                                                                         | R/W |
|              | Т                       | If this bit is set, bit 4 (EP[m]_DMA_EN) of the EP[m] DMA Control Register is cleared together.                                                                                                                       |     |
|              |                         | This bit is set when it receives a short packet if bit 11 (EP[m]_STOP_MODE) and bit 8 (EP[m]_STOP_SET) of the EP[m] DMA Control Register are 1b                                                                       |     |
|              |                         | This bit is cleared by writing 0b.                                                                                                                                                                                    |     |
|              |                         | 0: Buffer read DMA not completed                                                                                                                                                                                      |     |
|              |                         | 1: Buffer read DMA completed                                                                                                                                                                                          |     |
| b22          | EP[m]_OUT_OR_INT        | This bit is set to 1b if an overrun occurs when it receives a data at Endpoint[m]                                                                                                                                     | R/W |
| ~            | []_000                  | This bit is cleared by writing 0b.                                                                                                                                                                                    |     |
|              |                         | 0: No overrun occurred                                                                                                                                                                                                |     |
|              |                         | 1: Overrun occurred                                                                                                                                                                                                   |     |
| b21          | EP[m]_OUT_NAK_E         | For Interrupt/Bulk Endpoint:                                                                                                                                                                                          | R/W |
| J_ 1         | RR_INT                  | 0: No NAK response for OUT/PING token                                                                                                                                                                                 |     |
|              |                         | 1: NAK was sent for OUT/PING token                                                                                                                                                                                    |     |
|              |                         | • For Isochronous Endpoint:                                                                                                                                                                                           |     |
|              |                         | 0: No reception error occurred                                                                                                                                                                                        |     |
|              |                         | 1: Reception error occurred                                                                                                                                                                                           |     |
|              |                         | Detail of the error can be checked by EP[m]_ISO_PIDERR, EP[m]_OUT_NOTKN,                                                                                                                                              |     |
|              |                         | EP[m]_ISO_OR, EP[m]_ISO_CRC                                                                                                                                                                                           |     |
|              |                         | This bit is cleared by writing 0b.                                                                                                                                                                                    |     |
| b20          | EP[m]_OUT_STALL_I<br>NT | This bit is set when Endpoint[m] becomes STALL while bit 26 (EP[m]_DIR0) of USB Control Register is 1b (OUT direction).                                                                                               | R/W |
|              |                         | This bit is cleared by writing 0b.                                                                                                                                                                                    |     |
|              |                         | 0: EP[m] is OUT and not in STALL                                                                                                                                                                                      |     |
|              |                         | 1: EP[m] is OUT and in STALL                                                                                                                                                                                          |     |
| b19          | EP[m]_OUT_INT           | This bit is set when valid data other than null has been received normally in EP[m] Read Register (reception buffer) and CPU side buffer becomes readable. If null data is received, EP[m]_OUT_NULL_INT is set.       | R/W |
|              |                         | This bit is cleared by writing 0b.                                                                                                                                                                                    |     |
|              |                         | 0: Reception buffer has not become readable yet.                                                                                                                                                                      |     |
|              |                         | 1: Reception buffer becomes readable.                                                                                                                                                                                 |     |
| b18          | EP[m]_OUT_NULL_I        | This bit is set when null data is received in EP[m] Read Register (reception buffer)                                                                                                                                  | R/W |
|              | NT                      | normally. In case of double-buffer, this bit is set when null data packets are toggled to CPU side. The null data packet is cleared when this bit is set. (The reception buffer become ready to receive next packet.) |     |
|              |                         | This bit is cleared by writing 0b.                                                                                                                                                                                    |     |
|              |                         | 0: Null data has not been received                                                                                                                                                                                    |     |
|              |                         | 1: Null data was received                                                                                                                                                                                             |     |
| b17          | EP[m]_OUT_FULL          | EP[m] Read Register (reception buffer) full status.                                                                                                                                                                   | R   |
| ~ 1 1        |                         | In case of double-buffer, this bit is set if CPU side buffer is full.                                                                                                                                                 |     |
|              |                         | This bit is updated according to the buffer status.                                                                                                                                                                   |     |
|              |                         | This bit is apacted according to the bullet status.                                                                                                                                                                   |     |
|              |                         | 0: Reception buffer is not full                                                                                                                                                                                       |     |

Table 10.103 EP[m]\_STATUS Register Contents (3/4)

| Bit Position | Bit Name               | Function                                                                                                                                                           | R/W  |  |  |  |  |  |
|--------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--|--|--|--|--|
| b16          | EP[m]_OUT_EMPTY        | EP[m] Read Register (reception buffer) empty status.                                                                                                               | R    |  |  |  |  |  |
|              |                        | In case of double-buffer, this bit is set if CPU side buffer is empty.                                                                                             |      |  |  |  |  |  |
|              |                        | This bit is updated according to the reception buffer status.                                                                                                      |      |  |  |  |  |  |
|              |                        | 0: Reception buffer is not empty                                                                                                                                   |      |  |  |  |  |  |
|              |                        | 1: Reception buffer is empty                                                                                                                                       |      |  |  |  |  |  |
| b15 to b11   | Reserved               | Keep the initial value                                                                                                                                             | R/W  |  |  |  |  |  |
| b10          | EP[m]_IPID             | Indicates next DATA PID.                                                                                                                                           | R    |  |  |  |  |  |
|              |                        | 0: DATA0                                                                                                                                                           |      |  |  |  |  |  |
|              |                        | 1: DATA1                                                                                                                                                           |      |  |  |  |  |  |
| b9           | EP[m]_IN_NOTKN         | For Isochronous Endpoint:                                                                                                                                          | R    |  |  |  |  |  |
|              |                        | This bit is set if no IN token is received in the interval between SOFs or uSOFs                                                                                   |      |  |  |  |  |  |
|              |                        | This bit is updated each time SOF or uSOF is received.                                                                                                             |      |  |  |  |  |  |
|              |                        | 0: IN token was received between SOFs or uSOFs                                                                                                                     |      |  |  |  |  |  |
|              |                        | 1: No IN tokens have been received between SOFs or uSOFs                                                                                                           |      |  |  |  |  |  |
| b8           | EP[m]_ISO_UR           | For Isochronous Endpoint:                                                                                                                                          | R    |  |  |  |  |  |
|              |                        | This bit is set when IN token is received before data has prepared in EP[m] Write                                                                                  |      |  |  |  |  |  |
|              |                        | Register (transmission buffer) and null data is sent automatically.                                                                                                |      |  |  |  |  |  |
|              |                        | This bit is updated each time data is sent.                                                                                                                        |      |  |  |  |  |  |
|              |                        | 0: Null data has not been sent automatically                                                                                                                       |      |  |  |  |  |  |
|              |                        | Null data was sent automatically     For Interrupt/Bulk Endpoint:                                                                                                  |      |  |  |  |  |  |
|              |                        | Always 0                                                                                                                                                           |      |  |  |  |  |  |
| b7           | EP[m]_IN_END_INT       | This bit is set when buffer write DMA for IN-direction Endpoint[m] completes.                                                                                      | R/W  |  |  |  |  |  |
| 07           | EP[III]_IIN_EIND_IIN I | If this bit is set, bit 4 (EP[m]_DMA_EN) of the EP[m] DMA Control Register is cleared                                                                              | K/VV |  |  |  |  |  |
|              |                        | together. This bit is cleared by writing 0b.                                                                                                                       |      |  |  |  |  |  |
|              |                        | 0: Buffer write DMA not completed                                                                                                                                  |      |  |  |  |  |  |
|              |                        | 1: Buffer write DMA completed                                                                                                                                      |      |  |  |  |  |  |
| b6           | Reserved               | Should be 0 at writing.                                                                                                                                            | R    |  |  |  |  |  |
| b5           | EP[m]_IN_NAK_ERR       | For Interrupt/Bulk Endpoint:                                                                                                                                       |      |  |  |  |  |  |
|              | _INT                   | 0: No NAK response for IN token                                                                                                                                    |      |  |  |  |  |  |
|              |                        | 1: NAK was sent for IN token                                                                                                                                       |      |  |  |  |  |  |
|              |                        | For Isochronous Endpoint:                                                                                                                                          |      |  |  |  |  |  |
|              |                        | 0: No transmission error occurred                                                                                                                                  |      |  |  |  |  |  |
|              |                        | 1: Transmission error occurred                                                                                                                                     |      |  |  |  |  |  |
|              |                        | Detail of the error can be checked by EP[m]_IN_NOTKN and EP[m]_ISO_UR                                                                                              |      |  |  |  |  |  |
|              |                        | This bit is cleared by writing 0b.                                                                                                                                 |      |  |  |  |  |  |
| b4           | EP[m]_IN_STALL_IN<br>T | This bit is set when Endpoint[m] becomes STALL while bit 26 (EP[m]_DIR0) of USB Control Register is 0b (IN direction).                                             | R/W  |  |  |  |  |  |
|              |                        | 0: EP[m] is IN and not in STALL                                                                                                                                    |      |  |  |  |  |  |
|              |                        | 1: EP[m] is IN and in STALL                                                                                                                                        |      |  |  |  |  |  |
|              |                        | This bit is cleared by writing 0b.                                                                                                                                 |      |  |  |  |  |  |
| b3           | EP[m]_IN_INT           | This bit is set when next data can be written to CPU side of EP[m] Write Register (transmission buffer).                                                           | R/W  |  |  |  |  |  |
|              |                        | In case of single buffer, this bit is set when data transmitted normally for IN transactions. In case of double-buffer, this bit is set when CPU side transmission |      |  |  |  |  |  |
|              |                        | buffer data that granted permission has been toggled to USB side.                                                                                                  |      |  |  |  |  |  |
|              |                        | 0: Transmission buffer has not become writable yet.                                                                                                                |      |  |  |  |  |  |
|              |                        | 1: Transmission buffer becomes writable.                                                                                                                           |      |  |  |  |  |  |
| b2           | EP[m]_IN_DATA          | EP[m] Write Register (transmission buffer) data valid                                                                                                              | R    |  |  |  |  |  |
|              |                        | This bit is updated according to the buffer status.                                                                                                                |      |  |  |  |  |  |
|              |                        | 0: There is no waiting data in the transmission buffer.                                                                                                            |      |  |  |  |  |  |
|              |                        | 1: There is a waiting data in the transmission buffer.                                                                                                             |      |  |  |  |  |  |

Table 10.103 EP[m]\_STATUS Register Contents (4/4)

| Bit Position | Bit Name       | Function                                                                                                                 | R/W |  |  |  |
|--------------|----------------|--------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|
| b1           | EP[m]_IN_FULL  | EP[m] Write Register (transmission buffer) full status.                                                                  | R   |  |  |  |
|              |                | This bit is cleared when bit 7 (EP[m]_DEND) of the EP[m] Control Register is set to 1b and data transmission is enabled. |     |  |  |  |
|              |                | This bit is updated according to the buffer status.                                                                      |     |  |  |  |
|              |                | 0: Transmission buffer is not full                                                                                       |     |  |  |  |
|              |                | 1: Transmission buffer is full                                                                                           |     |  |  |  |
| b0           | EP[m]_IN_EMPTY | EP[m] Write Register (transmission buffer) empty status.                                                                 | R   |  |  |  |
|              |                | This bit is updated according to the buffer status.                                                                      |     |  |  |  |
|              |                | 0: Transmission buffer is not empty                                                                                      |     |  |  |  |
|              |                | 1: Transmission buffer is empty                                                                                          |     |  |  |  |

### 10.5.7.17 EP[m]\_INT\_ENA — EP[m] Interrupt Enable Register (m = 1..15)

If each field is disabled, the corresponding interrupt is not asserted even if EP[m] Status Register is set.

Address: 4001 E048h + 20h × (m - 1)



Table 10.104 EP[m]\_INT\_ENA Register Contents

| Bit Position | Bit Name                 | Function                                                                                   | R/W |
|--------------|--------------------------|--------------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved                 | Should be 0 at writing.                                                                    | R   |
| b23          | EP[m]_OUT_END_E<br>N     | Enable for bit 23 (EP[m]_OUT_END_INT) of EP[m] Status Register.  0: Disable  1: Enable     | R/W |
| b22          | EP[m]_OUT_OR_EN          | Enable for bit 22 (EP[m]_OUT_OR_INT) of EP[m] Status Register.  0: Disable  1: Enable      | R/W |
| b21          | EP[m]_OUT_NAK_E<br>RR_EN | Enable for bit 21 (EP[m]_OUT_NAK_ERR_INT) of EP[m] Status Register.  0: Disable  1: Enable | R/W |
| b20          | EP[m]_OUT_STALL_<br>EN   | Enable for bit 20 (EP[m]_OUT_STALL_INT) of EP[m] Status Register.  0: Disable  1: Enable   | R/W |
| b19          | EP[m]_OUT_EN             | Enable for bit 19 (EP[m]_OUT_INT) of EP[m] status Register.  0: Disable  1: Enable         | R/W |
| b18          | EP[m]_OUT_NULL_E<br>N    | Enable for bit 18 (EP[m]_OUT_NULL_INT) of EP[m] Status Register.  0: Disable  1: Enable    | R/W |
| b17 to b8    | Reserved                 | Should be 0 at writing.                                                                    | R   |
| b7           | EP[m]_IN_END_EN          | Enable for bit 7 (EP[m]_IN_END_INT) of EP[m] Status register.  0: Disable  1: Enable       | R/W |
| b6           | Reserved                 | Should be 0 at writing.                                                                    | R   |
| b5           | EP[m]_IN_NAK_ERR<br>_EN  | Enable for bit 5 (EP[m]_IN_NAK_ERR_INT) of EP[m] Status Register.  0: Disable  1: Enable   | R/W |
| b4           | EP[m]_IN_STALL_EN        | Enable for bit 4 (EP[m]_IN_STALL_INT) of EP[m] Status Register.  0: Disable  1: Enable     | R/W |
| b3           | EP[m]_IN_EN              | Enable for bit 3 (EP[m]_IN_INT) of EP[m] Status Register.  0: Disable  1: Enable           | R/W |
| b2 to b0     | Reserved                 | Should be 0 at writing.                                                                    | R   |

# 10.5.7.18 EP[m]\_DMA\_CTRL — EP[m] DMA Control Register (m = 1..15)

**Address:** 4001 E04Ch + 20h × (m − 1)

| Bit               | b31 | b30 | b29 | b28 | b27                     | b26 | b25                     | b24                    | b23 | b22 | b21 | b20                  | b19 | b18 | b17 | b16                    |
|-------------------|-----|-----|-----|-----|-------------------------|-----|-------------------------|------------------------|-----|-----|-----|----------------------|-----|-----|-----|------------------------|
|                   | _   | _   | _   | _   | _                       | _   | _                       | _                      | _   | _   | -   | _                    | _   | _   | _   | _                      |
| Value after reset | 0   | 0   | 0   | 0   | 0                       | 0   | 0                       | 0                      | 0   | 0   | 0   | 0                    | 0   | 0   | 0   | 0                      |
| Bit               | b15 | b14 | b13 | b12 | b11                     | b10 | b9                      | b8                     | b7  | b6  | b5  | b4                   | b3  | b2  | b1  | b0                     |
|                   | _   | _   | _   | _   | EP[m]_<br>STOP_<br>MODE |     | EP[m]_<br>BURST<br>_SET | EP[m]_<br>STOP_<br>SET | _   | -   | _   | EP[m]_<br>DMA_E<br>N | _   | _   | _   | EP[m]_<br>DMAM<br>ODE0 |
| Value after reset | 0   | 0   | 0   | 0   | 0                       | 0   | 0                       | 0                      | 0   | 0   | 0   | 0                    | 0   | 0   | 0   | 0                      |

Table 10.105 EP[m]\_DMA\_CTRL Register Contents (1/2)

| 14016 10.103 |                 | Negister Contents (1/2)                                                                                                                                                                                                                         |     |
|--------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Bit Position | Bit Name        | Function                                                                                                                                                                                                                                        | R/W |
| b31 to b12   | Reserved        | Should be 0 at writing.                                                                                                                                                                                                                         | R/W |
| b11          | EP[m]_STOP_MODE | DMA stop conditions setting when bit 8 (EP[m]_STOP_SET) is 1b.                                                                                                                                                                                  | R/W |
|              |                 | 0: DMA stops when a short packet is received, and the DMA transfer completed.                                                                                                                                                                   |     |
|              |                 | 1: DMA stops when a short packet is received and it is ready to read.                                                                                                                                                                           |     |
|              |                 | (DMA does not stop if EP[m]_DMA_EN is set after the received short packet is ready to read)                                                                                                                                                     |     |
| b10          | EP[m]_DEND_SET  | Specify whether to enable setting bit 7 (EP[m]_DEND) of the EP[m] Control Register                                                                                                                                                              | R/W |
|              |                 | to 1b when a DMA completion from AHB-EPC bridge is received when bit 26                                                                                                                                                                         |     |
|              |                 | (EP[m]_DIR0) of the USB Control Register is 0. This bit is invalid for OUT transactions.                                                                                                                                                        |     |
|              |                 | Note that data less than 32 bit cannot be transferred, if this bit is used.                                                                                                                                                                     |     |
|              |                 | 0: Not set EP[m]_DEND automatically                                                                                                                                                                                                             |     |
|              |                 | 1: Set EP[m]_DEND automatically                                                                                                                                                                                                                 |     |
| b9           | EP[m]_BURST_SET | Specify whether to clear EP[m]_DMA_EN each time one DMA packet completion                                                                                                                                                                       | R/W |
|              |                 | 0: Clear EP[m]_DMA_EN automatically                                                                                                                                                                                                             |     |
|              |                 | 1: Not clear EP[m]_DMA_EN automatically                                                                                                                                                                                                         |     |
|              |                 | [Notes on DMA write]                                                                                                                                                                                                                            |     |
|              |                 | Set this bit and bit 16 (EP[m]_AUTO) of the EP[m] Control Register to 1b when                                                                                                                                                                   |     |
|              |                 | successively transferring data of the maximum packet size by DMA.                                                                                                                                                                               |     |
|              |                 | Clear this bit when transferring a short packet.                                                                                                                                                                                                |     |
|              |                 | If a last packet contains fractional data, write the data by PIO.  [Notes on DMA read]                                                                                                                                                          |     |
|              |                 | If a short packet that includes null data is received when bit 8 (EP[m]_STOP_SET) is                                                                                                                                                            |     |
|              |                 | 1b, EP[m]_DMA_EN is cleared even if this bit is 1b.                                                                                                                                                                                             |     |
|              |                 | Set this bit to 1b when successively transferring data of the MaxPacketSize by DMA.                                                                                                                                                             |     |
|              |                 | Clear this bit when transferring a short packet.                                                                                                                                                                                                |     |
|              |                 | If a last packet contains fractional data, read the data by PIO                                                                                                                                                                                 |     |
| b8           | EP[m]_STOP_SET  | Select whether to clear bit 4 (EP[m]_DMA_EN) 0b and send the DMA completion notice to AHB-EPC bridge for stopping DMA transfer when a short packet that includes null data is received while bit 26 (EP[m]_DIR0) of the USB Control Register is | R/W |
|              |                 | 1b (OUT direction).  0: Reserved (not for use)                                                                                                                                                                                                  |     |
|              |                 | Reserved (not for use)     Clear EP[m]_DMA_EN and send DMA completion notice to AHB-EPC bridge                                                                                                                                                  |     |
| b7 to b5     | Reserved        | Should be 0 at writing.                                                                                                                                                                                                                         | R   |
| טו וט טט     | V C 9 C I A C I | Should be o at writing.                                                                                                                                                                                                                         | Λ.  |

Table 10.105 EP[m]\_DMA\_CTRL Register Contents (2/2)

| Bit Position | Bit Name       | Function                                                                                                                                                             | R/W |
|--------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b4           | EP[m]_DMA_EN   | Endpoint[m] DMA enable                                                                                                                                               | R/W |
|              |                | 0: Not use DMA                                                                                                                                                       |     |
|              |                | 1: Use DMA                                                                                                                                                           |     |
|              |                | This bit is cleared to 0b under the following conditions:                                                                                                            |     |
|              |                | A DMA transfer specified by EP[m]DCR2 has completed.                                                                                                                 |     |
|              |                | One DMA packet completion while bits EP[m]_DMACNT of EP[m]_LEN_DCNT is 001h.                                                                                         |     |
|              |                | One DMA packet completion while EP[m]_BURST_SET= 0. (If a last data contains fractional data, this bit is cleared before transferring last data.)                    |     |
|              |                | If a short packet that includes null data is received while EP[m]_STOP_SET=1 and the data has been transferred by DMA.                                               |     |
|              |                | (If EP[m]_STOP_MODE is 1b, it stops when short packet that includes null data is ready to read.)                                                                     |     |
|              |                | This bit is not cleared even if the Endpoint becomes STALL condition due to overrun.                                                                                 |     |
|              |                | If this bit is 1b, PIO access for EP[m] Write and Read Registers is not possible. Similarly, setting bit 7 (EP[m]_DEND) of the EP[m] Control Register is prohibited. |     |
|              |                | Be sure to clear this bit before using PIO access after a DMA transfer or when setting the EP[m]_DEND bit.                                                           |     |
|              |                | Before clearing this bit, stop the DMA master in advance so that no transfer is performed.                                                                           |     |
|              |                | If this bit is cleared during a DMA transfer, the transferred data is not guaranteed.                                                                                |     |
| b3 to b1     | Reserved       | Should be 0 at writing.                                                                                                                                              | R   |
| b0           | EP[m]_DMAMODE0 | DMA mode select                                                                                                                                                      | R/W |
|              |                | 0: Single (Not for use)                                                                                                                                              |     |
|              |                | 1: Demand                                                                                                                                                            |     |

# 10.5.7.19 EP[m]\_PCKT\_ADRS — EP[m] MaxPacket & BaseAddress Register (m = 1..15)

**Address:** 4001 E050h + 20h × (m - 1)



Table 10.106 EP[m]\_PCKT\_ADRS Register Contents

| Bit Position | Bit Name     | Function                                                                                                                       | R/W |
|--------------|--------------|--------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b29   | Reserved     | Should be 0 at writing.                                                                                                        | R   |
| b28 to b16   | EP[m]_BASEAD | Base address RAM mapping for Endpoint[m] This field should be set while bit 31 (EP[m]_EN) of the EP[m] Control Register is 0b. | R/W |
| b15 to b11   | Reserved     | Should be 0 at writing.                                                                                                        | R   |
| b10 to b0    | EP[m]_MPKT   | MaxPacketSize for Endpoint[m].  This field should be set while bit 31 (EP[m]_EN) of the EP[m] Control Register is 0b.          | R/W |

# 10.5.7.20 EP[m]\_LEN\_DCNT — EP[m] Length & DMA Count Register (m = 1..15)

**Address:** 4001 E054h + 20h × (m - 1)

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24         | b23 | b22 | b21  | b20    | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|-------------|-----|-----|------|--------|-----|-----|-----|-----|
|                   | _   | _   | _   | _   | _   | _   | _   |             |     |     | EP[ı | m]_DMA | CNT |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0           | 0   | 0   | 0    | 0      | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8          | b7  | b6  | b5   | b4     | b3  | b2  | b1  | b0  |
|                   | _   | _   | _   | _   | _   |     |     | EP[m]_LDATA |     |     |      |        |     |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0           | 0   | 0   | 0    | 0      | 0   | 0   | 0   | 0   |

### Table 10.107 EP[m]\_LEN\_DCNT Register Contents

| Bit Position | Bit Name     | Function                                                                                                                                                               | R/W |  |  |  |  |  |  |
|--------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|--|--|
| b31 to b25   | Reserved     | Should be 0 at writing.                                                                                                                                                | R/W |  |  |  |  |  |  |
| b24 to b16   | EP[m]_DMACNT | Arbitrary number of DMA transfer can be specified by these bits. Set DMA packet number to these bits. The value is decremented each time of one DMA packet completion. | R/W |  |  |  |  |  |  |
|              |              | Bit 4 (EP[m]_DMA_EN) of the EP[m] DMA Control Register is cleared to 0b at when these bits are decremented to 000h.                                                    |     |  |  |  |  |  |  |
|              |              | To use this function, set bit 9 (EP[m]_BURST_SET) of EP[m] DMA Control Register.                                                                                       |     |  |  |  |  |  |  |
|              |              | This function is disabled when this field is set to 000h.                                                                                                              |     |  |  |  |  |  |  |
|              |              | <b>Caution)</b> Maximum available value is 100h (= 256 packets)  Do not specify the number of transferred bytes.                                                       |     |  |  |  |  |  |  |
| b15 to b11   | Reserved     | Should be 0 at writing.                                                                                                                                                | R   |  |  |  |  |  |  |
| b10 to b0    | EP[m]_LDATA  | Indicates the number of readable bytes stored in the EP[m] Read Register (reception buffer) on the CPU side.                                                           | R   |  |  |  |  |  |  |
|              |              | The value is decremented by reading EP[m] Read Register.                                                                                                               |     |  |  |  |  |  |  |

### 10.5.7.21 EP[m]\_READ — EP[m] Read Register (m = 1..15)

**Address:**  $4001 E058h + 20h \times (m - 1)$ 

| Bit               | b31          | b30          | b29 | b28 | b27 | b26 | b25 | b24 | b23          | b22          | b21 | b20 | b19 | b18 | b17 | b16 |
|-------------------|--------------|--------------|-----|-----|-----|-----|-----|-----|--------------|--------------|-----|-----|-----|-----|-----|-----|
|                   |              | EP[m]_RDATA4 |     |     |     |     |     |     |              | EP[m]_RDATA3 |     |     |     |     |     |     |
| Value after reset | 0            | 0            | 0   | 0   | 0   | 0   | 0   | 0   | 0            | 0            | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit               | b15          | b14          | b13 | b12 | b11 | b10 | b9  | b8  | b7           | b6           | b5  | b4  | b3  | b2  | b1  | b0  |
|                   | EP[m]_RDATA2 |              |     |     |     |     |     |     | EP[m]_RDATA1 |              |     |     |     |     |     |     |
| Value after reset | 0            | 0            | 0   | 0   | 0   | 0   | 0   | 0   | 0            | 0            | 0   | 0   | 0   | 0   | 0   | 0   |

### Table 10.108 EP[m]\_READ Register Contents

| Bit Position | Bit Name     | Function                  | R/W |
|--------------|--------------|---------------------------|-----|
| b31 to b24   | EP[m]_RDATA4 | Endpoint[m] received data | R   |
| b23 to b16   | EP[m]_RDATA3 | Endpoint[m] received data | R   |
| b15 to b8    | EP[m]_RDATA2 | Endpoint[m] received data | R   |
| b7 to b0     | EP[m]_RDATA1 | Endpoint[m] received data | R   |

### 10.5.7.22 EP[m]\_WRITE — EP[m] Write Register (m = 1..15)

Address:  $4001 E05Ch + 20h \times (m - 1)$ 



Table 10.109 EP[m]\_WRITE Register Contents

| Bit Position | Bit Name     | Function                  | R/W |
|--------------|--------------|---------------------------|-----|
| b31 to b24   | EP[m]_WDATA4 | Endpoint[m] transmit data | W   |
| b23 to b16   | EP[m]_WDATA3 | Endpoint[m] transmit data | W   |
| b15 to b8    | EP[m]_WDATA2 | Endpoint[m] transmit data | W   |
| b7 to b0     | EP[m]_WDATA1 | Endpoint[m] transmit data | W   |

# 10.5.8 AHB-EPC Bridge Register Description

### 10.5.8.1 AHBSCTR — AHB Slave Controller Configuration Register

Address: 4001 F000h



Table 10.110 AHBSCTR Register Contents

| Bit Position | Bit Name  | Function                                                                                        | R/W |
|--------------|-----------|-------------------------------------------------------------------------------------------------|-----|
| b31 to b1    | Reserved  | Should be 0 at writing.                                                                         | R/W |
| b0           | WAIT_MODE | Wait behavior control setting for AHB slave 0: Reserved (not for use) 1: Wait control by HREADY | R/W |

# 10.5.8.2 AHBMCTR — AHB Master Controller Configuration Register

Address: 4001 F004h



Table 10.111 AHBMCTR Register Contents

| Bit Position | Bit Name    | Function                                                                                                                                                    | R/W |
|--------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31          | ARBITER_CTR | Select the arbitration type for the Endpoint which uses DMA transfer.  0: Round Robin priority (EP1 → → EP15 → EP1)  1: Fixed priority (EP1 > EP2 > > EP15) | R/W |
| b30 to b13   | Reserved    | Should be 0 at writing.                                                                                                                                     | R   |
| b12          | MCYCLE_RST  | Reserved in this system, should be 0 at writing.                                                                                                            | R/W |
| b11, b10     | Reserved    | Should be 0 at writing.                                                                                                                                     | R   |
| b9, b8       | ENDIAN_CTR  | Select the data conversion type during DMA transfer.  00: Little endian Other: Reserved (not for use)                                                       | R/W |
| b7 to b3     | Reserved    | Keep the initial value                                                                                                                                      | R/W |
| b2           | WBURST_TYPE | Variable-length burst use condition for AHB master write 0: Reserved (not for use) 1: INCR4/8/16 + INCR for 2 to 3 burst                                    | R/W |
| b1, b0       | Reserved    | Should be 0 at writing.                                                                                                                                     | R/W |

# 10.5.8.3 AHBBINT — AHB-EPC Bridge Interrupt Source Register

Address: 4001 F008h



Table 10.112 AHBBINT Register Contents

| Bit Position | Bit Name                | Function                                                                                                                                                | R/W |
|--------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b17   | DMA_ENDINT_EP<br>[15:1] | These bits are set when DMA transfer for corresponding Endpoint is completed This field is cleared by writing 1b.                                       | R/W |
| b16 to b14   | Reserved                | Should be 0 at writing.                                                                                                                                 | R/W |
| b13          | VBUS_INT                | This bit is set when VBUS signal level has changed. This field is cleared by writing 1b.                                                                |     |
| b12 to b7    | Reserved                | Should be 0 at writing.                                                                                                                                 | R/W |
| b6           | MBUS_ERRINT             | This bit is set when the AHB master received error response. This bit is cleared by writing 1b.                                                         |     |
| b5           | Reserved                | Should be 0 at writing.                                                                                                                                 | R/W |
| b4           | SBUS_ERRINT0            | This bit is set when the AHB slave issued error response for over 32 bit access.  This bit is cleared by writing 1b.                                    |     |
| b3 to b0     | ERR_MASTER              | This field stores the master number at error response when SBUS_ERRINT0 is 1b.  This field retains a value until the SBUS_ERRINT0 bit is cleared to 0b. | R   |

### 10.5.8.4 AHBBINTEN — AHB-EPC Bridge Interrupt Enable Register

If each field is disabled, the corresponding interrupt is not asserted even if AHB-EPC Bridge Interrupt Source Register is set.



Table 10.113 AHBBINTEN Register Contents

| Bit Position | Bit Name                  | Function                                                 | R/W |
|--------------|---------------------------|----------------------------------------------------------|-----|
| b31 to b17   | DMA_ENDINTEN_EP<br>[15:1] | Enable for DMA_ENDINT_EP[15:1] of AHBBINT register       | R/W |
|              |                           | 0: Disable                                               |     |
|              |                           | 1: Enable                                                |     |
| b16 to b14   | Reserved                  | Should be 0 at writing.                                  | R/W |
| b13          | VBUS_INTEN                | Enable for bit 13 (VBUS_INT) of the AHBBINT register.    | R/W |
|              |                           | 0: Disable                                               |     |
|              |                           | 1: Enable                                                |     |
| b12 to b7    | Reserved                  | Should be 0 at writing.                                  | R/W |
| b6           | MBUS_ERRINTEN             | Enable for bit 6 (MBUS_ERRINT) of the AHBBINT register.  | R/W |
|              |                           | 0: Disable                                               |     |
|              |                           | 1: Enable                                                |     |
| b5           | Reserved                  | Should be 0 at writing.                                  | R/W |
| b4           | SBUS_ERRINT0EN            | Enable for bit 4 (SBUS_ERRINT0) of the AHBBINT register. | R/W |
|              |                           | 0: Disable                                               |     |
|              |                           | 1: Enable                                                |     |
| b3 to b0     | Reserved                  | Should be 0 at writing.                                  | R   |

# 10.5.8.5 EPCTR — EPC and Transceiver Control Register

Address: 4001 F010h



Table 10.114 EPCTR Register Contents

| Bit Position | Bit Name   | Function                                                                                                                                                                                                                                                  | R/W |
|--------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b13   | Reserved   | Should be 0 at writing.                                                                                                                                                                                                                                   | R   |
| b12          | DIRPD      | If this bit is set to 1b, USB subsystem moves to power-down state.  Bit 8 (DIRPD) of the USBCTR register and DIRPD of CFG_USB in the system controller have same function.  0: Normal operation  1: Direct power-down mode                                | R/W |
| b11 to b9    | Reserved   | Should be 0 at writing.                                                                                                                                                                                                                                   | R   |
| b8           | VBUS_LEVEL | Indicates the status of the VBUS input pin.  0: VBUS = 0  1: VBUS = 1                                                                                                                                                                                     | R   |
| b7, b6       | Reserved   | Should be 0 at writing.                                                                                                                                                                                                                                   | R   |
| b5           | PLL_RESUME | By setting this bit, the clock supply can be resumed, when SIE is in Suspend state and the clock for the function controller is stopped.  Be sure to clear this bit to 0b after the clock supply is resumed.  0: Normal operation  1: Resume clock supply | R/W |
| b4           | PLL_LOCK   | Indicates USBPLL lock status 0: USBPLL has not been locked 1: USBPLL is locked                                                                                                                                                                            | R   |
| b3           | Reserved   | Should be 0 at writing.                                                                                                                                                                                                                                   | R/W |
| b2           | PLL_RST    | Reset of USBPLL The USBPLL is shared between the host and function controllers. Reset to the USBPLL is asserted when both PLL_RST in host and function controllers are 1b.  0: Release USBPLL reset 1: Assert USBPLL reset                                | R/W |
| b1           | Reserved   | Should be 1 at writing.                                                                                                                                                                                                                                   | R/W |
| b0           | EPC_RST    | Reset of EPC block. 0: Release EPC reset 1: Assert EPC reset                                                                                                                                                                                              | R/W |

# 10.5.8.6 USBSSVER — USBf Version Register

Address: 4001 F020h

| Bit               | b31 | b30 | b29 | b28  | b27  | b26 | b25 | b24 | b23 | b22 | b21 | b20  | b19   | b18 | b17 | b16 |
|-------------------|-----|-----|-----|------|------|-----|-----|-----|-----|-----|-----|------|-------|-----|-----|-----|
|                   | -   | _   | _   | _    | _    | _   | _   | _   |     |     |     | AHBE | 3_VER |     |     |     |
| Value after reset | 0   | 0   | 0   | 0    | 0    | 0   | 0   | 0   | 0   | 0   | 0   | 1    | 0     | 1   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12  | b11  | b10 | b9  | b8  | b7  | b6  | b5  | b4   | b3    | b2  | b1  | b0  |
|                   |     |     |     | EPC_ | _VER |     |     |     |     |     |     | SS_  | VER   |     |     |     |
| Value after reset | 0   | 0   | 1   | 0    | 0    | 1   | 0   | 0   | X   | х   | х   | х    | х     | х   | х   | Х   |

Table 10.115 USBSSVER Register Contents

| Bit Position | Bit Name | Function                                       | R/W |
|--------------|----------|------------------------------------------------|-----|
| b31 to b24   | Reserved |                                                | R   |
| b23 to b16   | AHBB_VER | Indicates the AHB bridge version.              | R   |
| b15 to b8    | EPC_VER  | Indicates the EPC version.                     | R   |
| b7 to b0     | SS_VER   | Indicates the USB function controller version. | R   |
|              |          | RZ/N1D: 31h                                    |     |
|              |          | RZ/N1S, RZ/N1L: 41h                            |     |

# 10.5.8.7 USBSSCONF — Endpoint Configuration Register

Address: 4001 F024h



Table 10.116 USBSSCONF Register Contents

| Bit Position | Bit Name      | Function                                                                       | R/W |
|--------------|---------------|--------------------------------------------------------------------------------|-----|
| b31 to b16   | EP_AVAILABLE  | Indicates the implemented Endpoint modules.                                    | R   |
|              |               | Each bit in this field corresponds to Endpoint number.                         |     |
|              |               | 0: Not available                                                               |     |
|              |               | 1: Available                                                                   |     |
| b15 to b0    | DMA_AVAILABLE | Indicates an Endpoint that can be used for DMA transfers.                      | R   |
|              |               | Each bit in this field corresponds to Endpoint number.                         |     |
|              |               | Since Endpoint0 is not available for DMA transfers, bit 0 always indicates 0b. |     |
|              |               | 0: Not Available                                                               |     |
|              |               | 1: Available                                                                   |     |

# 10.5.8.8 EP[m]DCR1 — Endpoint[m] DMA Setting Register1 (m = 1..15)

**Address:** 4001 F110h + 10h × (m - 1)



Table 10.117 EP[m]DCR1 Register Contents

| Bit Position | Bit Name     | Function                                                                                                                                                                       | R/W |
|--------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b24   | Reserved     | Should be 0 at writing.                                                                                                                                                        | R   |
| b23 to b16   | EP[m]_DMACNT | Set the number of packets (not bytes) in DMA transfer.                                                                                                                         | R/W |
|              |              | Set same the value as EP[m]_DMACNT[7:0] of the EP[m] Length & DMA Count Register, except for handling a data packet that cannot be divided by 32 bits.                         |     |
|              |              | However, if the EP[m]_DMACNT[8:0] bits are set to 100h, set this field to 00h.                                                                                                 |     |
|              |              | This field is decremented at every one packet DMA transfer completion.                                                                                                         |     |
|              |              | Caution) Don't change this bit while EP[m]_REQEN is 1b.                                                                                                                        |     |
| b15 to b2    | Reserved     | Should be 0 at writing.                                                                                                                                                        | R   |
| b1           | EP[m]_DIR0   | DMA direction setting                                                                                                                                                          | R/W |
|              |              | Set same the value as EP[m]_DIR0 of the EP[m] Control Register.                                                                                                                |     |
|              |              | 0: IN direction (from AHB to EPC)                                                                                                                                              |     |
|              |              | 1: OUT direction (from EPC to AHB)                                                                                                                                             |     |
|              |              | Caution) Don't change this bit while EP[m]_REQEN is 1b.                                                                                                                        |     |
| b0           | EP[m]_REQEN  | Setting for DMA transfer requests from EPC (Endpoint controller)                                                                                                               | R/W |
|              |              | This bit is cleared to 0b when the number of packets specified by the EP[m]_DMACNT have been transferred or when the EPC receives a short packet and it ends the DMA transfer. |     |
|              |              | 0: Ignore (DMA transfer not available)                                                                                                                                         |     |
|              |              | 1: Permit (DMA transfer is available)                                                                                                                                          |     |

# 10.5.8.9 EP[m]DCR2 — Endpoint[m] DMA Setting Register2 (m = 1..15)

**Address:** 4001 F114h + 10h × (m - 1)



Table 10.118 EP[m]DCR2 Register Contents

| Bit Position | Bit Name    | Function                                                                              | R/W |
|--------------|-------------|---------------------------------------------------------------------------------------|-----|
| b31 to b27   | Reserved    | Should be 0 at writing.                                                               | R   |
| b26 to b16   | EP[m]_LMPKT | Byte length setting of last packet for DMA transfer                                   | R/W |
|              |             | IN transfer (EP[m]_DIR0 of the EP[m]DCR1 Register = 0b)                               |     |
|              |             | Set the number of bytes to be sent by DMA in the last packet.                         |     |
|              |             | DMA transfer completes when the specified number of bytes been transferred.           |     |
|              |             | Since data is transferred in 32-bit unit, the lower 2 bits are ignored.               |     |
|              |             | PIO transfer should be used for 3 bytes or less.                                      |     |
|              |             | <example></example>                                                                   |     |
|              |             | 512 bytes (maximum packet size) → 200h                                                |     |
|              |             | 511 bytes (short packet) → 1FCh                                                       |     |
|              |             | Caution) Don't change this bit while EP[m]_REQEN is 1b.                               |     |
|              |             | OUT transfer (EP[m]_DIR0 of the EP[m]DCR1 Register = 1b)                              |     |
|              |             | Indicates the number of bytes transferred in the last packet by DMA.                  |     |
|              |             | Since data is transferred in 32-bit unit, the lower 2 bits are ignored.               |     |
|              |             | Writing to this field is invalid during OUT transfer.                                 |     |
| b15 to b11   | Reserved    | Should be 0 at writing.                                                               | R   |
| b10 to b0    | EP[m]_MPKT  | Set maximum packet size of Endpoint[m]                                                | R/W |
|              |             | Set same the value as EP[m]_MPKT[10:0] of the EP[m] MaxPacket & BaseAddress Register. |     |
|              |             | Caution) Don't change this bit while EP[m]_REQEN is 1b.                               |     |

# 10.5.8.10 EP[m]TADR — Endpoint[m] DMA Start Address Register (m = 1..15)

**Address:**  $4001 \text{ F} 118\text{h} + 10\text{h} \times (\text{m} - 1)$ 



Table 10.119 EP[m]TADR Register Contents

| Bit Position | Bit Name   | Function                                                                                                           | R/W |
|--------------|------------|--------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b0    | EP[m]_TADR | DMA start address for AHB (System address) Since data is transferred in 32-bit unit, the lower 2 bits are ignored. | R/W |
|              |            | Caution) Don't change this bit while EP[m]_REQEN is 1b.                                                            |     |

## 10.6 Usage Notes

## 10.6.1 Accessing Function Controller Registers

## 10.6.1.1 Notes on Accessing EPC Registers

When accessing EPC registers, make sure the USB\_HCLKF is supplied to the function controller. If not, the operation might deadlock on the AHB bus. Read bit 4 (PLL\_LOCK) of the EPCTR register of AHB-EPC Bridge to check the clock supply status.

Be sure to check the clock supply status in the following cases:

- When accessing an EPC register for the first time after the PLL reset signal is de-asserted
- When the resume signal is de-asserted by using the remote wakeup feature. (See Section 10.6.7.2(2), Power Up (Function Controller) for details.)

## 10.6.1.2 Notes on Accessing a Reserved Area

Address spaces that do not correspond to Endpoint numbers implemented in the system are reserved, so do not access these spaces.

## 10.6.2 Accessing Host Controller Registers

The host controller's registers are accessed via the internal PCI bus. For the AHB bus to perform access properly, therefore, the AHB bus memory space must be correctly mapped to the PCI bus memory space in this subsystem. Note that the PCI has two memory spaces: the PCI configuration space for storing the settings for PCI bus transfer and the base address settings for the PCI memory space; and the PCI memory space for actually transferring data.

Accesses from AHB to the host controller and vice versa are performed via the window area in the AHB-PCI bridge. The relationship between the register areas and each window area is shown in the figure and table below.



Figure 10.3 AHB and PCI Space Mapping Image

Table 10.120 Description of Each Area

| AHI | 3 Area                     | Size                  | Description                                                                                                                                                                                         |
|-----|----------------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (1) | AHBPCI communication       | 1 KB                  | This area stores the registers for specifying the AHB settings and window area base address settings.                                                                                               |
|     | registers                  |                       | This area is also mapped on the PCI memory space, so avoid overlapping other areas when mapping this area.                                                                                          |
| (2) | AHBPCI_WINDOW1 area        | 1 KB                  | The PCI configuration registers are accessed via this area. Whether to access the OHCI/EHCI configuration registers or AHB-PCI bridge registers is specified by using the AHBPCI_WIN1_CTR register. |
| (3) | AHBPCI_WINDOW2 area        | 64 KB                 | The OHCI/EHCI operational registers are accessed via this area.                                                                                                                                     |
| (4) | PCIAHB_WINDOW1             | 256 MB,               | The host controller accesses the work memory on the AHB bus via this area.                                                                                                                          |
|     | area                       | 512 MB,<br>1 GB, 2 GB | The size of this area can be changed by using the USBCTR register.                                                                                                                                  |
| (5) | 5) PCIAHB_WINDOW2 Disable, |                       | The host controller accesses the work memory on the AHB bus via this area.                                                                                                                          |
|     | area                       | 256 MB                | Whether to use this area or not can be specified by using the USBCTR register.                                                                                                                      |

Specify these areas on the PCI memory space so that the area for the AHBPCI communication registers does not overlap the AHBPCI\_WINDOW2 area (OHCI/EHCI operational register area), and the PCIAHB\_WINDOW1 area does not overlap the PCIAHB\_WINDOW2 area.

Although normally the simplest way to perform mapping is to map the AHB memory space to the same addresses as the PCI memory space, if the above areas will overlap on the AHB memory map, it is necessary to specify a base address that prevents overlapping with the PCIAHB\_WINDOW1/2 areas by using a PCI configuration register (the OHCI/EHCI/AHBPCI base address register). This is illustrated in the figure below.



Figure 10.4 AHB and PCI Space Mapping Image (Areas Overlapping)

The relationship between the registers used to map the AHB and PCI spaces and the setting value is shown in the Figure and Table below.



Figure 10.5 AHB and PCI Space Mapping Image (Areas Overlapping)

Table 10.121 Address Setting Register Values

| Regist | ter                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (1)-a  | PCIAHB_WIN1_CTR                 | When the host controller accesses the PCIAHB_WINDOW1 area as a bus master, the AHB bus address is translated to the base address specified in this register.  Generally, specify the area including the work memory used.                                                                                                                                                                                                                                                                                                        |
| (1)-b  | PCIAHB_WIN2_CTR                 | When the host controller accesses the PCIAHB_WINDOW2 area as a bus master, the AHB bus address is translated to the base address specified in this register.  Generally, specify the area including the work memory used.                                                                                                                                                                                                                                                                                                        |
| (2)    | AHBPCI_WIN2_CTR                 | When the AHBPCI_WINDOW2 area is accessed, the PCI bus address is translated to the base address specified in this register.  Generally, specify the same value as that specified for the AHBPCI_WINDOW2 area.  However, make sure that the specified area does not overlap the area including the work memory, which is specified in (1).                                                                                                                                                                                        |
| (3)    | AHBPCI_WIN1_CTR                 | If the base address is specified as 4000_0000h in this register, PCI configuration registers for AHBPCI are accessed.                                                                                                                                                                                                                                                                                                                                                                                                            |
| (4)    | AHBPCI Bridge<br>base address   | Specify the base address of the AHB-PCI bridge in a PCI space. This register is not accessed via the PCI bus, but make sure that the area does not overlap other areas.                                                                                                                                                                                                                                                                                                                                                          |
| (5)-a  | PCIAHB_WIN1<br>base address     | Specify the base address of the PCIAHB_WINDOW1 area in a PCI space.  Generally, specify the same address as that specified in (1)-a. Make sure that the areas specified by (5)-a and (5)-b do not overlap.                                                                                                                                                                                                                                                                                                                       |
| (5)-b  | PCIAHB_WIN2<br>base address     | Specify the base address of the PCIAHB_WINDOW2 area in a PCI space.  Generally, specify the same address as that specified in (1)-a. Make sure that the areas specified by (5)-a and (5)-b do not overlap.                                                                                                                                                                                                                                                                                                                       |
| (6)    | AHBPCI_WIN1_CTR                 | If the base address is specified as 8000_0000h in this register, PCI configuration registers for OHCI/EHCI are accessed.                                                                                                                                                                                                                                                                                                                                                                                                         |
| (7)    | OHCI /EHCI<br>base address      | Specify the base address of the OHCI/EHCI operational registers in a PCI space.  Generally, specify the same address as that specified in (2) for the OHCI operational registers. For EHCI operational registers, specify the address of {address specified in (2) + offset 1000h}.                                                                                                                                                                                                                                              |
| (8)    | OHCI/EHCI operational registers | After the settings of (1) to (7) are specified, the host controller can access data copied to the AHB work RAM, such as descriptors, via the PCI bus.  The following registers are used to specify the work RAM address at which data exists.  OHCI/EHCI Operational Register  HcHCCA register  HcPeriodicCurrentED register  HcControlHeadED register  HcControlCurrentED register  HcBulkHeadED register  HcBulkCurrentED register  HcBulkCurrentED register  HcDoneHead register  HcDoneHead register  ASYNCLISTADDR register |

## 10.6.2.1 Accessing PCI Configuration Registers

PCI configuration space registers are accessed via the AHB-PCI Window 1 area (host controller addresses 10000h to 107FFh: 2 KB space). At this time, be sure to specify appropriate settings for the AHBPCI\_WIN1\_CTR register. The following table shows the AHBPCI\_WIN1\_CTR register setting used to access each PCI configuration space on the OHCI/EHCI and AHB-PCI bridges.

Table 10.122 AHBPCI\_WIN1\_CTR Register Settings

|                         | AHBPCI_WIN1_CTR F      | Register Setting |
|-------------------------|------------------------|------------------|
| Area to Access          | PCIWIN1_BASEADR[31:11] | PCICMD[2:0]      |
| OHCI/EHCI               | Set only bit 31 to 1b. | 101b             |
| PCI configuration space |                        |                  |
| AHB-PCI bridge          | Set only bit 30 to 1b  |                  |
| PCI configuration space |                        |                  |

## 10.6.2.2 Accessing OHCI/EHCI Operational Registers

To access OHCI/EHCI operational registers, OHCI/EHCI PCI configuration space and AHBPCI\_WIN2\_CTR register settings are required, as is the setting of PCI space address mapping. The following shows the required settings.

Table 10.123 Settings Required for Accessing OHCI/EHCI Operational Registers

| Setting bits                                                                                   | Setting                                  |
|------------------------------------------------------------------------------------------------|------------------------------------------|
| Bit 1 (MEMORY_SPACE) of OHCI/EHCI PCI<br>Configuration Space,<br>Offset 04h (Status - Command) | 1b<br>(Enable accessing to memory space) |
| Bits [3:1] (PCICMD[2:0]) of<br>AHBPCI_WIN2_CTR register                                        | 011b<br>(Memory read/write)              |

#### 10.6.3 Reset Control

#### 10.6.3.1 Reset Configuration

USB subsystem is reset by the HRESETn signal. When the HRESETn signal is asserted, all the circuits within the USB subsystem are reset. The reset signal of USB subsystem is an asynchronous reset that is directly connected to the F/F reset signal.

The reset is divided between USB host controller and USB function controller.

The reset signals of USB subsystem are shown in Table below.

Table 10.124 Reset Signals

| Reset Signal           | Supplied From | Description                                                                                                                                          |
|------------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| HRESETn System Control |               | Power-on Reset Signal of the USB subsystem.                                                                                                          |
|                        |               | Resets the entire USB subsystem.                                                                                                                     |
|                        |               | HRESETn is controlled from System Control as software reset.                                                                                         |
| PLL_RST                | Internal      | USBPHY Reset signal.                                                                                                                                 |
|                        |               | The USBPLL is shared between the USB Host and Function Controllers. Do not assert this signal when either USB Host or Function Controller is active. |
| EPC_RST                | Internal      | USB Function Controller (EPC/SIE) Reset Signal                                                                                                       |
| USBH_RST               | Internal      | USB Host Controller Reset Signal                                                                                                                     |

When the HRESETn is asserted, the all internal reset signals are also asserted. The internal USB host controller reset can be operated from the AHB-PCI Bridge register. The internal USB function controller reset can be operated from the AHB-EPC Bridge register. After the HRESETn de-assertion, use the same registers to cancel the reset state. For the reset sequence, refer to **Section 10.6.9.1**, **Reset Sequence**.

## 10.6.3.2 Reset System Diagram

The reset system in USB subsystem is shown below.



Figure 10.6 Reset System Diagram

#### 10.6.4 Interrupts

#### 10.6.4.1 Interrupt Control Registers

#### (1) U2H\_INT Control Register

This is an interrupt generated by the AHB-PCI bridge. Use the AHB-PCI Bridge registers to check the status of, clear, and enable the interrupts.

Table 10.125 U2H\_INT Control Register

| Control                                            | Target Registers        |
|----------------------------------------------------|-------------------------|
| Checking the status of and clearing the interrupts | PCI_INT_STATUS register |
| Enabling the interrupts                            | PCI_INT_ENABLE register |

#### (2) U2H\_OHCI\_INT Control Register

This is an INTA interrupt signal generated by the host controller. Interrupts are controlled basically by using host controller registers, but to assert an interrupt signal, the interrupt must be enabled in the relevant AHB-PCI Bridge register.

Table 10.126 U2H\_OHCI\_INT Control Register

| Control                                            | Target Registers                               |  |  |
|----------------------------------------------------|------------------------------------------------|--|--|
| Checking the status of and clearing the interrupts | HcInterruptStatus register                     |  |  |
| Enabling the interrupts                            | HcInterruptEnable register                     |  |  |
|                                                    | HcInterruptDisable register                    |  |  |
|                                                    | PCI_INT_ENABLE register (bit 16 (USBH_INTAEN)) |  |  |

#### (3) U2H\_EHCI\_INT Control Register

This is an INTB interrupt signal generated by the host controller. Interrupts are controlled basically by using host controller registers, but to assert an interrupt signal, the interrupt must be enabled in the relevant AHB-PCI Bridge register.

Table 10.127 U2H\_EHCI\_INT Control Register

| Control                                            | Target Registers                             |  |
|----------------------------------------------------|----------------------------------------------|--|
| Checking the status of and clearing the interrupts | USBSTS register                              |  |
| Enabling the interrupts                            | USBINTR register                             |  |
|                                                    | PCI_INT_ENABLE register (bit 17 USBH_INTBEN) |  |

#### (4) U2H\_PME\_INT Control Register

This is a PME interrupt signal generated by the host controller. Interrupts are controlled basically by using host controller registers, but to assert an interrupt signal, the interrupt must be enabled in the relevant AHB-PCI Bridge register.

Table 10.128 U2H\_PME\_INT Control Register

| Control                                            | Target Registers                                                                                |  |
|----------------------------------------------------|-------------------------------------------------------------------------------------------------|--|
| Checking the status of and clearing the interrupts | PCI Configuration register for OHCI/EHCI offset 44h                                             |  |
| Enabling the interrupts                            | PCI Configuration register for OHCI/EHCI offset 44h PCI_INT_ENABLE register (bit 19 USBH_PMEEN) |  |



## (5) U2F\_INT Control Register

This register shows the interrupts generated by the AHB-EPC bridge. Use the AHB-EPC bridge registers to check the status of, clear, and enable the interrupts.

Table 10.129 U2F\_INT Control Register

| Control                                            | Target Registers   |
|----------------------------------------------------|--------------------|
| Checking the status of and clearing the interrupts | AHBBINT register   |
| Enabling the interrupts                            | AHBBINTEN register |

## (6) U2F\_EPC\_INT Control Register

This register shows the interrupts generated by the EPC. Use the EPC registers to check the status of, clear, and enable the interrupts.

Table 10.130 U2F\_EPC\_INT Control Register

| Control                                            | Target Registers                    |  |  |
|----------------------------------------------------|-------------------------------------|--|--|
| Checking the status of and clearing the interrupts | USB Interrupt Status register       |  |  |
|                                                    | EP0/EP[m] Status register           |  |  |
| Enabling the interrupts                            | USB Interrupt Enable register       |  |  |
|                                                    | EP0/EP[m] Interrupt Enable register |  |  |

# 10.6.4.2 Interrupt Signal Overview



Figure 10.7 Interrupt Signal Overview

#### 10.6.4.3 Interrupt Signal Clear Time

The AHB-PCI Bridge implements a posted write, therefore, an interrupt generated by the host controller or function controller may not be cleared soon after setting the clear register and same interrupt state may be recognized many times.

The user must take a countermeasure to avoid such false recognition.

For example, access to the host controller or function controller register (b) after accessing to an Interrupt Clear Register (a). The operation of (b) is waited until the operation of (a) is completed. As the result, the interrupt is cleared without fail at the completion of the access of (b).

#### (1) Host Controller

The U2H\_OHCI\_INT, U2H\_EHCI\_INT, and U2H\_PME\_INT may not be cleared soon after setting the clear register.

When USB\_HCLKH = 125 MHz and USB\_PCICLK = 25 MHz, the interrupt is typically cleared in about 360 ns after setting the clear register.

When the host controller is executing a transfer as a master on the internal PCI-bus, it takes about 1.6 us (36 CLK@USB\_PCICLK + 3 CLK@USB\_HCLKH + 2 CLK@12 MHz) at worst to clear the interrupt.

#### (2) Function Controller

When USB\_HCLKF = 125 MHz, the interrupt is typically cleared in about 180 ns after setting the clear register. When the function controller is executing a DMA transfer between AHB-EPC and EPC, it takes about 610 ns  $(35 \text{ CLK}@60 \text{ MHz} + 3 \text{ CLK}@\text{USB}_{\text{HCLKF}})$  at worst to clear the interrupt.

#### 10.6.5 Overcurrent Control and VBUS Control

#### 10.6.5.1 Overcurrent Control

This section describes the behavior of the USB\_OC and USB\_PPON signals used for controlling the external circuit that is used for USB port overcurrent detection and VBUS control.

#### (1) Meanings of USB\_OC and USB\_PPON Signals

The meanings of USB\_OC and USB\_PPON signals are shown in Table below.

The USB\_OC2 and USB\_PPON2 signals perform overcurrent control of the port 2 host only when this subsystem is used as USB interface port 1 host/port 2 host. When used as USB interface port 1 function/port 2 host, because the number of ports used for the host is one only, overcurrent of the port 2 host is controlled by USB\_OC1 and USB\_PPON1 signals.

Table 10.131 USB\_OC and USB\_PPON

| USB Interface               | Pin       | I/O    | Level | Meaning                          |
|-----------------------------|-----------|--------|-------|----------------------------------|
| Port 1 function/port 2 host | USB_OC1   | Input  | 1     | Port 2 overcurrent not detected. |
|                             |           |        | 0     | Port 2 overcurrent detected      |
|                             | USB_OC2   | Input  | PU    |                                  |
|                             | USB_PPON1 | Output | 1     | Power supply to port 2 VBUS ON   |
|                             |           |        | 0     | Power supply to port 2 VBUS OFF  |
|                             | USB_PPON2 | Output | OPEN  |                                  |
| Port 1 host/port 2 host     | USB_OC1   | Input  | 1     | Port 1 overcurrent not detected  |
|                             |           |        | 0     | Port 1 overcurrent detected      |
|                             | USB_OC2   | Input  | 1     | Port 2 overcurrent not detected  |
|                             |           |        | 0     | Port 2 overcurrent detected      |
|                             | USB_PPON1 | Output | 1     | Power supply to port 1 VBUS ON   |
|                             |           |        | 0     | Power supply to port 1 VBUS OFF  |
|                             | USB_PPON2 | Output | 1     | Power supply to port 2 VBUS ON   |
|                             |           |        | 0     | Power supply to port 2 VBUS OFF  |

#### (2) PPON Output Signal Assert/De-assert Conditions

A timing chart showing the conditions under which USB\_OC1 and USB\_PPON1 are asserted and de-asserted is shown in Figure below.



Figure 10.8 USB\_OC1 and USB\_PPON1 Assert, De-assert Timing Chart

The same timing chart applies to when USB\_OC2 and USB\_PPON2 are asserted and de-asserted.

The figure above shows a timing chart for USB interface port 1. When using port 2, specify the same settings for the following port 2 registers:

- HcRhPortStatus2 register
- PORTSC2 register

Even if USB\_OC1/OC2 is de-asserted, USB\_PPON1/PPON2 is not asserted automatically. USB\_PPON1/PPON2 is asserted when the software sets the port power bit after USB\_OC1/OC2 is de-asserted.

#### 10.6.5.2 **VBUS Control**

Depending on the connections with peripheral circuits, it might be possible to stop VBUS to reduce the power consumption when the USB port is not used by connecting the USB\_OC1/PPON1 and USB\_OC2/PPON2 pins to a high-side switch. The relationship between USB\_PPON1/PPON2 and VBUS is as follows:

Table 10.132 Relationship between PPON1/PPON2 and VBUS

| USB Interface               | PPON           | VBUS                 |  |
|-----------------------------|----------------|----------------------|--|
| Port 1 function/port 2 host | USB_PPON1 = 0b | Port 2 VBUS stops    |  |
|                             | USB_PPON1 = 1b | Port 2 VBUS operates |  |
| Port 1 host/port 2 host     | USB_PPON1 = 0b | Port 1 VBUS stops    |  |
|                             | USB_PPON1 = 1b | Port 1 VBUS operates |  |
|                             | USB_PPON2 = 0b | Port 2 VBUS stops    |  |
|                             | USB_PPON2 = 1b | Port 2 VBUS operates |  |

The behavior of USB\_PPON1/PPON2 when USB\_OC1/OC2 is asserted differs depending on the PCI configuration register and OHCI operational register settings. The relationship between the register settings and USB\_PPON1/PPON2 is shown below.

Table 10.133 Relationship between Register Settings and USB\_PPON1/PPON2

| PCI<br>Configuration<br>Register | OHCI Operational Register |            |                                       |       |                                                                            |                                                                                           |                                                                            |  |
|----------------------------------|---------------------------|------------|---------------------------------------|-------|----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--|
| EXT1<br>Register                 | HcRhDe                    | escriptorA | orA Register HcRhDescriptorB Register |       | •                                                                          | PP                                                                                        | ON                                                                         |  |
|                                  | NOCP                      | NPS        | PSM                                   | PPCM  |                                                                            | Output Pin Behavior                                                                       |                                                                            |  |
| PPCNT Bit                        | Bit                       | Bit        | Bit                                   | Bit 1 | Bit 0                                                                      | USB_PPON2                                                                                 | USB_PPON1                                                                  |  |
| 0                                | _                         | _          | _                                     | _     | _                                                                          | Fixed to 1b                                                                               |                                                                            |  |
| _                                | 1                         | _          | _                                     | _     | _                                                                          | Fixed to 1b                                                                               |                                                                            |  |
| _                                | _                         | 1          | _                                     | _     | _                                                                          | Fixed to 1b                                                                               |                                                                            |  |
| 1                                | 0                         | 0          | 0                                     | _     | _                                                                          | USB_PPON1 and USB_PPON2 are de-asserted (1b to 0b) by asserting USB_OC1 or USB_OC2 to 0b. |                                                                            |  |
|                                  | 1                         |            | 1 0                                   |       | 0                                                                          | USB_PPON1 and USB_PPON2 are de-asserted (1b to 0b) by asserting USB_OC1 or USB_OC2 to 0b. |                                                                            |  |
|                                  |                           |            | 0                                     | 1     | USB_PPON2 is de-asserted (1b to 0b) by asserting USB_OC1 or USB_OC2 to 0b. | USB_PPON1 is de-asserted (1b to 0b) by asserting USB_OC1 to 0b.                           |                                                                            |  |
|                                  |                           |            |                                       | 1     | 0                                                                          | USB_PPON2 is de-asserted (1b to 0b) by asserting USB_OC2 to 0b.                           | USB_PPON1 is de-asserted (1b to 0b) by asserting USB_OC1 or USB_OC2 to 0b. |  |
|                                  |                           |            | 1                                     | 1     | USB_PPON2 is de-asserted (1b to 0b) by asserting USB_OC2 to 0b.            | USB_PPON1 is de-asserted (1b to 0b) by asserting USB_OC1 to 0b.                           |                                                                            |  |

Note: If NPS = 1b, the host controller detects an overcurrent. But it does not de-assert USB\_PPON1/PPON2.

## 10.6.5.3 Overcurrent Detection Using PPON



Figure 10.9 Overcurrent Detection Using PPON

## 10.6.5.4 PPON Setting Flow

Shown below is the PPON setting flow in a system where OCI might be active (0b) at system startup.



Figure 10.10 PPON Setting Flow

#### 10.6.6 VBUS Detection

#### 10.6.6.1 External Circuit for VBUS Detection

An external circuit is required to detect VBUS level in USB Function port.

It should convert 5 V to 3 V, prevent chattering and input to USB\_VBUS pin.

#### 10.6.6.2 VBUS Detection Part

VBUS detection is performed by a register in AHB-EPC Bridge. With the EPCTR register bit8 VBUS\_LEVEL, the status of the USB\_VBUS signal can be checked. Also, when the status of the USB\_VBUS signal is changed, AHBBINT register bit 13 VBUS\_INT interrupt can be generated.

In addition, since the VBUS detection circuit in AHB-EPC Bridge is synchronized with the USB\_HCLKPM signal, it is possible to generate an interrupt even when clock supply to the AHB clock (USB\_HCLKF) or the function controller is stopped.



Figure 10.11 VBUS Detection Part Image

#### 10.6.6.3 VBUS Detection Flow



Figure 10.12 VBUS Detection Flow

#### **CAUTIONS**

- 1. If USB is Disconnected in the SUSPEND state (in which clock supply to the function controller is stopped), reset the function controller by the EPCTR Register bit0 EPC\_RST bit.
- The chattering time may be maximum 100 ms or so when an external circuit is not installed.
   Even when an external circuit is installed, time to be taken until USB\_VBUS becomes steady differs depending on the customer's system. So, we recommend that the chattering time be evaluated on the customer's system.

## 10.6.7 Power Management

This chapter describes power management in the host and function controllers and the direct power-down (PLL stop) feature used when a USB port event does not need to be detected.

#### 10.6.7.1 Power Management in the Host Controller

When host operations are paused, the power consumption can be reduced by powering down the host controller and stopping the PCI clock (USB\_PCICLK) in the subsystem. The subsystem contains a USB\_PCICLK mask circuit that can be used to control the PCI clock by using the registers in the AHB-PCI bridge.

#### (1) Power Down (Host Controller)

An example of the procedure used to power down the host controller is shown below.

#### (a) When using OHCI



Figure 10.13 Host Controller Power-Down Flow (When Using OHCI)

#### (b) When using EHCI



Figure 10.14 Host Controller Power-Down Flow (When Using EHCI)

#### (2) Power Up (Host Controller)

An example of the procedure used to power up the host controller is shown below. When restoring power to the host controller after it has been powered down, set the registers using the reverse procedure to the power down procedure.

## (a) When using OHCI



Figure 10.15 Host Controller Power-Up Flow (When Using OHCI)

#### (b) When using EHCI



Figure 10.16 Host Controller Power-Up Flow (When Using EHCI)

#### NOTE

When power-up, please set PERIODIC\_SCHEDULE\_ENABLE bit of the USBCMD register to "1"

## 10.6.7.2 Power Management in the Function Controller

## (1) Power Down (Function Controller)

An example of the procedure used to power down the function controller is shown below.



Figure 10.17 Function Controller Power-Down Flow

## (2) Power Up (Function Controller)

The power can be turned on either by using the resume signal from the corresponding host or by using the remote wakeup feature.

#### (a) RESUME



Figure 10.18 Power Up by Detecting the Resume Signal

#### (b) Remote WakeUp



Figure 10.19 Power Up by Detecting the Resume Signal (Remote WakeUp)

#### 10.6.7.3 Direct Power-Down Feature

When this subsystem is not used in the system, the power consumption can be reduced by stopping PLL by using the direct power-down feature.

## (1) Entering the Direct Power-Down Mode

The following shows how to enter the direct power-down mode. To reduce power consumption, stopping the USB\_PCICLK supply is recommended.



Figure 10.20 Entering the Direct Power-Down Mode

The USB Subsystem has DIRPD input and DIRPD register bits respectively. The relation is described in following figure.



Figure 10.21 USB Subsystem - CFG\_USB Register

## (2) Exiting the Direct Power-Down Mode

The following shows how to exit the direct power-down mode. When doing so, cancel the direct power-down mode when requesting a software reset.



Figure 10.22 Exiting the Direct Power-Down Mode (Host Controller)

#### NOTE

The USB Subsystem has DIRPD input and DIRPD register bits respectively.



Figure 10.23 Exiting the Direct Power-Down Mode (Function Controller)

#### NOTE

The USB Subsystem has DIRPD input and DIRPD register bits respectively.

## 10.6.7.4 Notes on Suspend state transition

When receiving Resume signal or BusReset signal from the USB Host Controller immediately after Suspend state transition, it may not recover from Suspend state.

If it is required to avoid timing conflicts, do as follows.

• Not to stop the clock to USBPHY during Suspend state

Even if Suspend state is detected, do not set 1b to the bit 6 (SUSPEND) of the USB Control Register.

# 10.6.8 USB Function Endpoints Configuration

In this subsystem, the Endpoints are implemented as follows.

Type and Buffer cannot be changed. For Direction and MaxPacketSize, the settings in the table below are recommended.

Table 10.134 Configuration for RZ/N1

| Endpoint | Direction | Туре        | Buffer | MaxPacketSize |
|----------|-----------|-------------|--------|---------------|
| EP0      | IN/OUT    | Control     | Single | 64 Byte       |
| EP1      | IN        | Bulk        | Double | 512 Byte      |
| EP2      | OUT       | Bulk        | Double | 512 Byte      |
| EP3      | IN        | Bulk        | Single | 512 Byte      |
| EP4      | OUT       | Bulk        | Single | 512 Byte      |
| EP5      | IN        | Bulk        | Single | 512 Byte      |
| EP6      | IN        | Interrupt   | Single | 1024 Byte     |
| EP7      | IN        | Interrupt   | Single | 1024 Byte     |
| EP8      | IN        | Interrupt   | Single | 1024 Byte     |
| EP9      | IN        | Interrupt   | Single | 1024 Byte     |
| EP10     | IN        | Isochronous | Double | 1024 Byte     |
| EP11     | OUT       | Isochronous | Double | 1024 Byte     |
| EP12     | IN        | Isochronous | Double | 1024 Byte     |
| EP13     | OUT       | Isochronous | Double | 1024 Byte     |
| EP14     | IN        | Isochronous | Double | 1024 Byte     |
| EP15     | OUT       | Isochronous | Double | 1024 Byte     |

## 10.6.8.1 Specifying the Base Address

To specify which Endpoint buffer is allocated to which RAM area, specify the RAM base address by using the EP[m]\_BASEAD[12:0] bits of the EP[m] MaxPacket & BaseAddress Register. This setting is required for each Endpoint.

For the case shown in table before the table above, the settings are specified for each Endpoint as follows:

- The EP0 buffers are always allocated starting from 000h in the RAM, so no register setting is required. Because EP0 requires 32 words, the EP0 buffers are always allocated from 000h to 01Fh.
- The EP1 buffers are allocated after the EP0 buffer area, to the area starting from 020h.
- Specify the EP1 MaxPacket & BaseAddress Register as follows:
  - EP1\_MPKT[10:0] = 200h (512 bytes) (in HS mode) or 040h (64 bytes) (in FS mode)
  - EP1\_BASEAD[12:0] = 0020h
- The EP2 buffers are allocated after the EP1 buffer area (0020h to 011Fh), to the area starting from 0120h.
- Specify the EP2\_MPKT[10:0] bits in the same way as for EP1.
- Specify the EP3 and subsequent buffer areas in the same way.

The following table lists the EP[m] MaxPacket & BaseAddress Register settings example.

Table 10.135 BaseAddress settings example

|                | EP[m]_BASEAD[12:0] | EP[m]_MPKT[10:0]  | Value Specified for<br>EP[m] MaxPacket & BaseAddress Register |
|----------------|--------------------|-------------------|---------------------------------------------------------------|
| EP0<br>(fixed) | _                  | _                 | _                                                             |
| EP1            | 020h               | 200h(HS)/040h(FS) | 0020_0200h (HS)<br>0020_0040h (FS)                            |
| EP2            | 120h               | 200h(HS)/040h(FS) | 0120_0200h (HS)<br>0120_0040h (FS)                            |
| EP3            | 220h               | 008h              | 0220_0008h                                                    |
| EP4            | 222h               | 200h(HS)/040h(FS) | 0222_0200h (HS)<br>0222_0040h (FS)                            |
| EP5            | 322h               | 200h(HS)/040h(FS) | 0322_0200h (HS)<br>0322_0040h (FS)                            |

## 10.6.9 Operating Procedures

## 10.6.9.1 Reset Sequence



Figure 10.24 Reset Sequence

## 10.6.9.2 Initial Setup Sequence

#### (1) Example of Initial Setup of Host Controller

The following shows an example of implementing the following features:

- Accessing OHCI/EHCI operational registers via the AHB-PCI Window 2 register
- Transferring data from the host controller to the AHB bus



Figure 10.25 Host Controller Initial Setup Sequence (1/2)



Figure 10.25 Host Controller Initial Setup Sequence (2/2)

## (2) Example of Initial Setup of the Function Controller



Figure 10.26 Function Controller Initial Setup Sequence

#### 10.6.9.3 USB Host Transfer Flow

Control the USB host transfer flow according to the following OHCI/EHCI specifications.

- Open Host Controller Interface Specification for USB Rev 1.0a
- Enhanced Host Controller Interface Specification for Universal Serial Bus Revision 1.0

The following describes supplementary information about stopping DMA.

#### (1) Stopping DMA Transfer

The AHB-PCI bridge does not have a feature to enable or disable DMA. The PCI bus cycle in which the host controller activated as a master is output to the AHB bus as is by using DMA.

The host controller performs DMA transfer for the following purposes:

- (a) To write the current frame number to the memory
- (b) To read or write a descriptor and data copied to the memory to perform list processing

#### NOTE

Writing a frame number is automatically performed in each frame cycle if the USB state is "Operational".

To stop a DMA transfer, set the USB to suspend or reset state.

To abort only the list processing in (b), clear the list processing enable bit (BLE, CLE, IE, and PLE in the HcControl register); the list processing stops at the next frame.

#### 10.6.9.4 Function Transfer Overview

## (1) PIO OUT Transfer



Figure 10.27 PIO OUT Transfer Overview

#### (2) PIO IN Transfer



Figure 10.28 PIO IN Transfer Overview

#### (3) DMA OUT Transfer

To perform a DMA transfer, specify the number of transferred packets by using the EP[m]\_DMACNT bit of the EP[m]DCR1 register and EP[m]\_LEN\_DCNT register.

When DMA transfer is performed the number of times specified by the EP[m]\_DMACNT bit of the EP[m]\_LEN\_DCNT register or when a short packet that contains null data is received, the USB function controller stops the DMA transfer and generates the U2F\_INT or U2F\_EPC\_INT interrupt.

A DMA OUT transfer assumes the following conditions:

- The number of packets sent from the corresponding USB host is unknown.

  (The value specified for the EP[m]\_DMACNT bit must be determined according to the user's system.)
- A short packet might be received during a transfer.



Figure 10.29 DMA OUT Transfer Overview (1/3)



Figure 10.29 DMA OUT Transfer Overview (2/3)



Figure 10.29 DMA OUT Transfer Overview (3/3)

#### (4) DMA IN Transfer



Figure 10.30 DMA IN Transfer Overview

## (5) Stopping a DMA Transfer



Figure 10.31 Stopping a DMA Transfer

#### (6) Control Transfer



Figure 10.32 Control Transfer Overview (1/3)



Figure 10.32 Control Transfer Overview (2/3)



Figure 10.32 Control Transfer Overview (3/3)

## (7) Protocol Error NAK Processing

A protocol error NAK is a response returned when an invalid token whose explicit device response is not prescribed in the USB specification is received during a control transfer.

A protocol error NAK is generated in the following cases:

- An IN or OUT token is received before a SETUP token is received. (No setup stage is established.)
- An OUT token is received at a Control Read data stage.
- An IN token is received at a Control Read status stage or an OUT token is received for data PID0.
- An IN token is received at a Control Write status stage or an OUT token is received for data PID0 at the beginning
  of a data stage.
- An OUT token or PING token is received at the Control Write status stage.
- An OUT token is received at a No Data Control status stage.

If a protocol error NAK is returned, bit 16 of the EPO Status register is set and an EPO\_PERR\_NAK\_INT interrupt occurs. If this interrupt is detected, halt the operation at EPO and send a STALL for the subsequent tokens.



Figure 10.33 Protocol Error NAK Processing Overview

#### (8) Processing Specific to each Request

This section describes the standard requests for USB devices, states of the device, and the processes that must be performed by the device.

In the tables that show each request below, the Request Code Field column shows the code included in the standard request. The Action column shows the actions that must be taken by the device in each Default, Address, or Configured state stage. *STALL response* indicates that the device must send a STALL because a request error has occurred. To enable a STALL to be sent, set bit 2 (EP0\_STL) of the EP0 Control register (0028h) to 1b.

The device states are defined in the following table:

Table 10.136 Device States

| Default    | This is the state in which the USB device address is reset to 00h after a USB bus reset is received.                                 |
|------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Address    | This is the state in which the USB device address is set to a value other than 00h.                                                  |
| Configured | This is the state in which the configuration value is set to a value other than 00h, and accessing the relevant Endpoint is enabled. |

#### (a) Clear Feature

Table 10.137 Clear Feature Request

| Request Code Field |          |                             |              |         | Action         |                |                |
|--------------------|----------|-----------------------------|--------------|---------|----------------|----------------|----------------|
| bmRequest -Type    | bRequest | wValue                      | wIndex       | wLength | Default        | Address        | Configured     |
| 00h<br>(Device)    | 01h      | 0001h<br>(Remote<br>Wakeup) | 0000h        | 0000h   | Response (1)*1 | Response (1)*1 | Response (1)*1 |
| 01h<br>(Interface) | 01h      | 0000h                       | 0000h        | 0000h   | STALL response | STALL response | STALL response |
| 02h<br>(Endpoint)  | 01h      | 0000h<br>(Endpoint<br>Halt) | Endpoint No. | 0000h   | Response (2)   | Response (2)   | Response (3)   |

Note 1. The device must send a STALL if it does not support the remote wakeup feature.

Transfer type: No Data Control (SETUP-IN)

<Processing details>

Table 10.138 Clear Feature Request Processing

| Response (1) | Clear the remote wakeup flag.  (The USB function controller does not need to perform special processing. However, if the remote wakeup flag is cleared, the USB function controller can no longer use the remote wakeup feature.)                                                                                                                                                                                                                                                                 |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Response (2) | <ul> <li>If wIndex is 0000h, clear the buffer for Endpoint0. (After setting bit 8 (EP0_BCLR) of the EP0 Control register to 1b, make sure bit 8 (EP0_IN_EMPTY) of the EP0 Status register is 1b.)</li> <li>If wIndex is not 0000h, send a STALL.</li> </ul>                                                                                                                                                                                                                                       |
| Response (3) | <ul> <li>If wIndex is 0000h, clear the buffer for Endpoint0. (Perform the same processing as that of Response (2)).</li> <li>If wIndex indicates the supported Endpoint, clear the transmission/reception data PID, clear the halt status, and clear the buffers for the Endpoint. (Clear the EP[m]_OPIDCLR, EP[m]_IPIDCLR, EP[m]_OSTL, EP[m]_ISTL, and EP[m]_BCLR bits of the EP[m] Control register to 0b.)</li> <li>If wIndex does not indicate a supported Endpoint, send a STALL.</li> </ul> |

# (b) Get Configuration

Table 10.139 Get Configuration Request

| Request Code Field                             |     |     |       |         | Action       |              |              |
|------------------------------------------------|-----|-----|-------|---------|--------------|--------------|--------------|
| bmRequest -Type bRequest wValue wIndex wLength |     |     |       | Default | Address      | Configured   |              |
| 80h                                            | 08h | 00h | 0000h | 0001h   | Response (1) | Response (1) | Response (2) |

Transfer type: Control Read (SETUP-IN-OUT)

<Processing details>

Table 10.140 Get Configuration Request Processing

| Response (1) | Send 00h (1 byte).                              |
|--------------|-------------------------------------------------|
| Response (2) | Send the current configuration number (1 byte). |

#### (c) GET DESCRIPTOR

Table 10.141 Get Descriptor Request

| Request Code Field |          |                                  |                         |                    | Action          |              |              |
|--------------------|----------|----------------------------------|-------------------------|--------------------|-----------------|--------------|--------------|
| bmRequest -Type    | bRequest | wValue                           | wIndex                  | wLength            | Default         | Address      | Configured   |
| 80h                | 06h      | 0100h<br>(Device)                | 0000h                   | Descriptor<br>Size | Response (1)    | Response (1) | Response (1) |
| 80h                | 06h      | 020Xh<br>(Config)                | 0000h                   | Descriptor<br>Size | Response (2)    | Response (2) | Response (2) |
| 80h                | 06h      | 030Xh<br>(String)                | 0000h or<br>Language ID | Descriptor<br>Size | Response (3)    | Response (3) | Response (3) |
| 80h                | 06h      | 0600h<br>(Device<br>Qualifier)   | 0000h                   | Descriptor<br>Size | Response (4)    | Response (4) | Response (4) |
| 80h                | 06h      | 070Xh<br>(Other Speed<br>Config) | 0000h                   | Descriptor<br>Size | Response<br>(5) | Response (5) | Response (5) |

## Transfer type: Control Read (SETUP-IN-OUT)

<Processing details>

Send the type specified by wValue and the index descriptor for the size specified by wLength. The following assumes that the value sent using bMaxPacketSize (0) of the device descriptor is 64.

- If the descriptor size is greater than wLength, send the descriptor for the size specified by wLength, from the beginning of the descriptor.
- If the descriptor size is less than wLength, send a short packet (64 bytes or less of data) at the end of descriptor transmission. At this time, if the descriptor size is a multiple of 64 bytes, send null data at the end.

Table 10.142 Get Descriptor Request Processing

| Response (1) | Send a device descriptor.                                                                                                                                                                                                                   |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Response (2) | Send the configuration descriptor indexed by the lower bits of wValue.  If the configuration descriptor size is less than wLength, send all the interface and Endpoint descriptors contained in the configuration successively.             |
| Response (3) | Send the string descriptor indexed by the lower bits of wValue.                                                                                                                                                                             |
| Response (4) | Send the device qualifier descriptor.                                                                                                                                                                                                       |
| Response (5) | Send the other speed configuration descriptor indexed by the lower bits of wValue.  If the configuration descriptor size is less than wLength, send all the interface and Endpoint descriptors contained in the configuration successively. |

## (d) GET INTERFACE

Table 10.143 Get Interface Request

| Request Code Field |                                                |     |                     |       | Action         |                |              |
|--------------------|------------------------------------------------|-----|---------------------|-------|----------------|----------------|--------------|
| bmRequest -Type    | bmRequest -Type bRequest wValue wIndex wLength |     |                     |       | Default        | Address        | Configured   |
| 81h                | 0Ah                                            | 00h | Interface<br>Number | 0001h | STALL response | STALL response | Response (1) |

Transfer type: Control Read (SETUP-IN-OUT)

<Processing details>

Table 10.144 Get Interface Request Processing

| Response (1) | Send the current alternate setting number for the interface specified by windex. |
|--------------|----------------------------------------------------------------------------------|
|              | If no alternate setting is supported, send a STALL.                              |

## (e) Get Status

Table 10.145 Get Status Request

| Request Code Field |                                                 |     |                 | Action |              |              |              |
|--------------------|-------------------------------------------------|-----|-----------------|--------|--------------|--------------|--------------|
| bmRequest -Type    | mRequest -Type bRequest wValue wIndex wLength [ |     |                 |        | Default      | Address      | Configured   |
| 80h<br>(Device)    | 00h                                             | 00h | 0000h           | 0002h  | Response (1) | Response (1) | Response (1) |
| 81h<br>(Interface) | 00h                                             | 00h | 0000h           | 0002h  | Response (2) | Response (2) | Response (2) |
| 82h<br>(Endpoint)  | 00h                                             | 00h | Endpoint<br>No. | 0002h  | Response (3) | Response (3) | Response (4) |

Transfer type: Control Read (SETUP-IN-OUT)

Table 10.146 Get Status Request Processing

| Response (1) | <ul> <li>Send a return value in which whether self-powered devices are supported is specified for D0 and whether the remote wakeup feature is supported is specified for D1. (For example, if self-powered devices and the remote wakeup feature are not supported, send 0001h.)</li> </ul>   |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Response (2) | Send 0000h or a STALL.                                                                                                                                                                                                                                                                        |
| Response (3) | <ul><li>If wIndex is 0000h, send 0000h.</li><li>If wIndex is not 0000h, send a STALL.</li></ul>                                                                                                                                                                                               |
| Response (4) | <ul> <li>If wIndex is 0000h, send 0000h.</li> <li>If wIndex indicates a supported Endpoint, send a return value in which the halt (STALL) state is specified for D0. (Send 0001h if bit 3 or 2 (EP[m]_ISTL or EP[m]_OSTL) of the EP[m] Control register is 1b. If 0b, send 0000b.)</li> </ul> |
|              | If windex does not indicate a supported Endpoint, send a STALL.                                                                                                                                                                                                                               |

<sup>&</sup>lt;Processing details>

## (f) SET ADDRESS

Table 10.147 Set Address Request

| Request Code Field |          |                   |        |         |                         | Action       |              |
|--------------------|----------|-------------------|--------|---------|-------------------------|--------------|--------------|
| bmRequest -Type    | bRequest | wValue            | wIndex | wLength | Default Address Configu |              |              |
| 00h                | 05h      | Device<br>Address | 0000h  | 0000h   | Response (1)            | Response (1) | Response (1) |

Transfer type: No Data Control (SETUP-IN)

<Processing details>

Table 10.148 Set Address Request Processing

| Response (1) | • If wValue is less than or equal to 127, set the wValue value to the Frame Number & USB Address Register. |
|--------------|------------------------------------------------------------------------------------------------------------|
|              | If wValue is greater than or equal to 128, send a STALL.                                                   |

## (g) Set Configuration

Table 10.149 Set Configuration Request

| Request Code Field                             |     |              |         |         |              | Action       |              |
|------------------------------------------------|-----|--------------|---------|---------|--------------|--------------|--------------|
| bmRequest -Type bRequest wValue wIndex wLength |     |              | Default | Address | Configured   |              |              |
| 00h                                            | 09h | Config Value | 0000h   | 0000h   | Response (1) | Response (2) | Response (3) |

Transfer type: No Data Control (SETUP-IN)

<Processing details>

Table 10.150 Set Configuration Request Processing

| Response (1) | No special processing is required. Send null data at the status stage.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Response (2) | <ul> <li>No special processing is required if wValue is 0. Send null data at the status stage.</li> <li>If the wValue values matches the value of a supported configuration, the transaction transitions to the Configured state. (Set bit 5 (CONF) of the USB Control register to 1b.)</li> <li>If the wValue value does not match the value of a supported configuration, send a STALL.</li> </ul>                                                                                                   |
| Response (3) | <ul> <li>If wValue is 0, the transaction returns to the Address state. (Clear bit 5 (CONF) of the USB Control register to 0b.)</li> <li>No special processing is required if the wValue value matches the current bConfigurationValue value. Send null data at the status stage.</li> <li>If the wValue value matches the value of a supported configuration, change the configuration.</li> <li>If the wValue value does not match the value of the supported configuration, send a STALL.</li> </ul> |

# (h) SET DESCRIPTOR

Table 10.151 Set Descriptor Request

| Request Code Field |          |                    |                            |                    | Action       |              |              |
|--------------------|----------|--------------------|----------------------------|--------------------|--------------|--------------|--------------|
| bmRequest -Type    | bRequest | wValue             | wIndex                     | wLength            | Default      | Address      | Configured   |
| 00h                | 07h      | Descriptor<br>Type | 0000h or<br>Language<br>ID | Descriptor<br>Size | Response (1) | Response (1) | Response (1) |

Transfer type: Control Write (SETUP-OUT-IN)

<Processing details>

Table 10.152 Set Descriptor Request Processing

| Response (1) | If rewriting a descriptor is not enabled, send a STALL.                                                     |
|--------------|-------------------------------------------------------------------------------------------------------------|
|              | If rewriting a descriptor is enabled, read the data and write it to the descriptor again by using software. |
|              | (The USB function controller does not need to perform special processing.)                                  |

## (i) Set Feature

Table 10.153 Set Feature Request

| Request Code Field |          |                             |                  |         | Action                              |                |                |  |
|--------------------|----------|-----------------------------|------------------|---------|-------------------------------------|----------------|----------------|--|
| bmRequest -Type    | bRequest | wValue                      | wIndex           | wLength | Default                             | Address        | Configured     |  |
| 00h                | 03h      | 0001h                       | 0000h            | 0000h   | When Re                             | mote Wakeup is | s supported    |  |
| (Device)           |          | (Remote<br>Wakeup)          |                  |         | Response (1)                        | Response (1)   | Response (1)   |  |
|                    |          |                             |                  |         | When Remote Wakeup is not supported |                |                |  |
|                    |          |                             |                  |         | STALL response                      | STALL response | STALL response |  |
|                    |          | 0002h<br>(TEST<br>MODE)     | Test<br>Selector | 0000h   | Response (2)                        | Response (2)   | Response (2)   |  |
| 01h<br>(Interface) | 03h      | 0000h                       | 0000h            | 0000h   | STALL response                      | STALL response | STALL response |  |
| 02h<br>(Endpoint)  | 03h      | 0000h<br>(Endpoint<br>Halt) | Endpoint<br>No.  | 0000h   | Response (3)                        | Response (3)   | Response (4)   |  |

Transfer type: No Data Control (SETUP-IN)

Table 10.154 Set Feature Request Processing

| Response (1) | Set the remote wakeup flag.     (The USB function controller does not need to perform special processing.)                                                                                                                                                                                                                                                                             |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Response (2) | Write the Test Selector value indicated by wIndex to the USBTESTMODE bit of the USB Control register.                                                                                                                                                                                                                                                                                  |
| Response (3) | <ul> <li>No special processing is required if wlndex is 0000h. Send null data at the status stage.</li> <li>If wlndex is not 0000h, send a STALL.</li> </ul>                                                                                                                                                                                                                           |
| Response (4) | <ul> <li>If wlndex is 0000h, clear the buffer for Endpoint0. (Perform the same processing as that of Response (2)).</li> <li>When wlndex indicates the supported Endpoint, set the target Endpoint to the Halt state. (Set the EP[m]_OSTL and EP[m]_ISTL bit of the EP[m] Control register to 1b.)</li> <li>If wlndex does not indicate a supported Endpoint, send a STALL.</li> </ul> |

<sup>&</sup>lt;Processing details>

## (j) SET INTERFACE

Table 10.155 Set Interface Request

| Request Code Field |          |                      |                     |         |                | Action         |              |
|--------------------|----------|----------------------|---------------------|---------|----------------|----------------|--------------|
| bmRequest -Type    | bRequest | wValue               | wIndex              | wLength | Default        | Address        | Configured   |
| 01h                | 0Bh      | Alternate<br>Setting | Interface<br>Number | 0000h   | STALL response | STALL response | Response (1) |

Transfer type: No Data Control (SETUP-IN)

<Processing details>

Table 10.156 Set Interface Request Processing

| Response (1) | If the alternate setting number specified by wValue differs from the current alternate setting number, change the values of the EP[m] MaxPacket & BaseAddress register etc.     |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | If the alternate setting number specified by wValue is the same as the current alternate setting number, no special processing is required. Send null data at the status stage. |

## (k) Sync Frame

Table 10.157 Sync Frame Request

| Request Code Field  |          |        |        |         | Action         |                |                |
|---------------------|----------|--------|--------|---------|----------------|----------------|----------------|
| bmRequest -<br>Type | bRequest | wValue | wlndex | wLength | Default        | Address        | Configured     |
| 82h                 | 0Ch      | 0000h  | EP No. | 0000h   | STALL response | STALL response | STALL response |

Transfer type: Control Read (SETUP-IN-OUT)

## (9) Descriptors

The types of standard descriptors and setting examples are described below.

#### (a) Device descriptor

Device descriptor is used to send basic information about the device.

Table 10.158 Device Descriptor

| Field              | Offset | Size | Value<br>(Example) | Description                                                                                                   |
|--------------------|--------|------|--------------------|---------------------------------------------------------------------------------------------------------------|
| bLength            | 0      | Byte | 12h                | Specify the descriptor size (18 bytes).                                                                       |
| bDescriptorType    | 1      | Byte | 01h                | For device descriptors, always set this field to 01h.                                                         |
| bcdUSB             | 2      | Word | 0200h              | Specify the USB standard version the device conforms to. 0200h indicates that the device conforms to USB 2.0. |
| bDeviceClass       | 4      | Byte | xxh                | Specify the class the device belongs to.                                                                      |
| bDeviceSubClass    | 5      | Byte | xxh                | Specify the subclass the device belongs to.                                                                   |
| bDeviceProtocol    | 6      | Byte | 00h                | Specify the protocol defined by the class or subclass the device belongs to.                                  |
| bMaxPacketSize0    | 7      | Byte | 40h                | Specify the maximum packet size (64 bytes) to be transferred at Endpoint 0.                                   |
| idVendor           | 8      | Word | xxxxh              | Specify the vendor ID.                                                                                        |
| idProduct          | 10     | Word | xxxxh              | Specify the product ID.                                                                                       |
| bcdDevice          | 12     | Word | 0100h              | Indicates the device version.                                                                                 |
| iManufacturer      | 14     | Byte | 01h                | Specify the index for the string descriptor that describes the manufacturer of the product.                   |
| iProduct           | 15     | Byte | 02h                | Specify the index for the string descriptor that describes the product.                                       |
| iSerialNumber      | 16     | Byte | 03h                | Specify the index for the string descriptor that describes the serial number of the product.                  |
| bNumConfigurations | 17     | Byte | 01h                | Specify the number of supported configurations.                                                               |

## (b) Device qualifier descriptor

Device qualifier descriptor is used to send information about the device descriptor fields whose values change when HS and FS are switched.

Table 10.159 Device Qualifier Descriptor

| Field              | Offset | Size | Value<br>(Example) | Description                                                                                                   |
|--------------------|--------|------|--------------------|---------------------------------------------------------------------------------------------------------------|
| bLength            | 0      | Byte | 0Ah                | Specify the descriptor size (10 bytes)                                                                        |
| bDescriptorType    | 1      | Byte | 06h                | For device qualifier descriptors, always set this field to 06h.                                               |
| bcdUSB             | 2      | Word | 0200h              | Specify the USB standard version the device conforms to. 0200h indicates that the device conforms to USB 2.0. |
| bDeviceClass       | 4      | Byte | xxh                | Specify the class the device belongs to.                                                                      |
| bDeviceSubClass    | 5      | Byte | xxh                | Specify the subclass the device belongs to.                                                                   |
| bDeviceProtocol    | 6      | Byte | 00h                | Specify the protocol defined by the class or subclass the device belongs to.                                  |
| bMaxPacketSize0    | 7      | Byte | 40h                | Specify the maximum packet size (64 bytes) to be transferred at Endpoint 0.                                   |
| bNumConfigurations | 8      | Byte | 01h                | Specify the number of supported configurations.                                                               |
| bReserved          | 9      | Byte | 00h                | Reserved for future use, must be zero.                                                                        |

## (c) Configuration descriptor and Other speed configuration descriptor

Configuration descriptor and Other speed configuration descriptor are used to send information about the configuration of the device. When a device that supports both the fast speed and high speed is operating at either speed, the Other speed configuration descriptor shows the configuration of the device if it operates at the other speed.

These descriptors are generally sent by using a single Get Descriptor Configuration request.

Table 10.160 Configuration Descriptor and Other Speed Configuration Descriptor

| Field               | Offset | Size | Value<br>(Example)      | Description                                                                                                                                                                                                                                                   |
|---------------------|--------|------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bLength             | 0      | Byte | 09h                     | Specify the descriptor size (9 bytes).                                                                                                                                                                                                                        |
| bDescriptorType     | 1      | Byte | 02h<br>07h              | <ul> <li>For configuration descriptors, always set this field to 02h.</li> <li>For other speed configuration descriptors, always set this field to 07h.</li> </ul>                                                                                            |
| wTotalLength        | 2      | Word | 9 +<br>9 × M +<br>7 × N | Specify the size of the descriptor to be transferred.  Specify a total of the following:  Configuration descriptor size (9 bytes)  Interface descriptor size (9 bytes) × number of descriptors M  Endpoint descriptor size (7 bytes) × number of descriptor N |
| bNumInterfaces      | 4      | Byte | 01h                     | Specify the number of interfaces supported by this configuration.                                                                                                                                                                                             |
| bConfigurationValue | 5      | Byte | 01h                     | Specify the configuration number.                                                                                                                                                                                                                             |
| iConfiguration      | 6      | Byte | 00h                     | Specify the index for the string descriptor that describes this configuration.                                                                                                                                                                                |
| bmAttributes        | 7      | Byte | C0h                     | <ul> <li>Bit 7: Always set to 1b.</li> <li>Bit 6: Set to 1b if the device is self-powered.</li> <li>Bit 5: Set to 1b if the device supports the remote wakeup feature.</li> <li>Bits 4 to 0: Always set to 0b.</li> </ul>                                     |
| bMaxPower           | 8      | Byte | 00h                     | Specify the current value required by the device.  Value = current consumption value/2 (mA).                                                                                                                                                                  |

#### (d) Interface descriptor

Interface descriptor is used to send information about the device interface.

Table 10.161 Interface Descriptor

| Field              | Offset | Size | Value<br>(Example) | Description                                                                                                                                                |
|--------------------|--------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bLength            | 0      | Byte | 09h                | Specify the descriptor size (9 bytes)                                                                                                                      |
| bDescriptorType    | 1      | Byte | 04h                | For interface descriptors, always set this field to 04h.                                                                                                   |
| bInterfaceNumber   | 2      | Byte | 00h                | Specify the interface number.                                                                                                                              |
| bAlternateSetting  | 3      | Byte | 01h                | <ul> <li>When using an alternate setting, specify the number for this field.</li> <li>If there is not alternate setting, set this field to 00h.</li> </ul> |
| bNumEndpoints      | 4      | Byte | xxh                | Specify the number of Endpoints other than Endpoint 0 supported by this interface.                                                                         |
| bInterfaceClass    | 5      | Byte | xxh                | Specify the class the interface belongs to.  This is equivalent to bDeviceClass in device descriptors.                                                     |
| bInterfaceSubClass | 6      | Byte | 00h                | Specify the subclass the interface belongs to. This is equivalent to bDeviceSubClass in device descriptors.                                                |
| bInterfaceProtocol | 7      | Byte | xxh                | Specify the protocol defined by the class or subclass the interface belongs to.  This is equivalent to bDeviceProtocol in device descriptors.              |
| iInterface         | 8      | Byte | xxh                | Specify the index for the string descriptor that describes this interface.                                                                                 |

## (e) Endpoint descriptor

Endpoint descriptor is used to send information about the Endpoint used.

Table 10.162 Endpoint Descriptor

| Field            | Offset | Size | Value<br>(Example) | Description                                                                                                                                                                                                                                                                                               |
|------------------|--------|------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bLength          | 0      | Byte | 07h                | Specify the descriptor size (7 bytes)                                                                                                                                                                                                                                                                     |
| bDescriptorType  | 1      | Byte | 05h                | For Endpoint descriptors, always set this field to 05h.                                                                                                                                                                                                                                                   |
| bEndpointAddress | 2      | Byte | xxh                | Specify the Endpoint number and transfer direction.  Bit 7: Transfer direction (0b: OUT, 1b: IN)  Bits 6 to 4: Always set to 000b.  Bits 3 to 0: Endpoint number                                                                                                                                          |
| bmAttributes     | 3      | Byte | xxh                | <ul> <li>Specify the transfer type at the Endpoint.</li> <li>Bits 7 and 6: Always set to 00b.</li> <li>Bits 5 to 2 are fixed to 0000b do not support isochronous transfers.</li> <li>Bits 1 and 0: Set the transfer type.</li> <li>(00b: Control, 01b: Isochronous, 10b: Bulk, 11b: Interrupt)</li> </ul> |
| wMaxPacketSize   | 4      | Word | 0200h              | Specify the maximum packet size to be sent at the Endpoint.  Bits 15 to 11: Always set to 000b.  Bits 10 to 0: Set the maximum packet size.                                                                                                                                                               |
| bInterval        | 6      | Byte | 00h                | <ul> <li>For interrupt transfers, specify the maximum wait time.</li> <li>For bulk and control transfers, specify the maximum NAK ratio.</li> </ul>                                                                                                                                                       |

# (f) String descriptor

String descriptor is used to send the text for description.

Table 10.163 String Descriptor

| Field           | Offset | Size | Value<br>(Example) | Description                                                                                                                                                                        |
|-----------------|--------|------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bLength         | 0      | Byte | xxh                | Specify the descriptor size.                                                                                                                                                       |
|                 |        |      |                    | The size depends on the text to be sent.                                                                                                                                           |
| bDescriptorType | 1      | Byte | 03h                | For string descriptors, always set this field to 03h.                                                                                                                              |
| wLANGID         | 2      | Word | 0409h              | <ul> <li>When windex is 0, specify the language of the string for wLANGID.</li> </ul>                                                                                              |
| bString         |        | Byte | xxh                | <ul> <li>When wIndex is not 0, specify a character string indexed by the<br/>lower bits of the wValue value for bString, by using the language<br/>specified by wIndex.</li> </ul> |

#### (10) EP0 Data Loopback

This section describes how to loop back data at EP0.

Execute data loopback while no other operations are being performed after reset release.



Figure 10.34 EP0 Data Loopback

#### (11) EP[m] Data Loopback

This section describes how to loop back data at EP[m].

Execute data loopback while no other operations are being performed after reset release.



Figure 10.35 EP[m] Data Loopback (1/4)



Figure 10.35 EP[m] Data Loopback (2/4)



Figure 10.35 EP[m] Data Loopback (3/4)



Figure 10.35 EP[m] Data Loopback (4/4)

# Section 11 DMA Controller

Portions Copyright © 2014 Synopsys. Used with permission. All rights reserved. Synopsys & DesignWare are registered trademarks of Synopsys

### 11.1 Overview

RZ/N1 provides two instances of DMA Controller (DMAC1 and DMAC2). Each one is able to service up to 8 independent DMA channels, for data transfers between single source and destination.

- 2 units
  - 8 channels, 16 request sources (request interfaces) for DMAC1
  - 8 channels, 16 request sources (request interfaces) for DMAC2
- Programmable DMA burst size
- Transfer width 8, 16, 32, 64 bits
- Programmable addressing, increment or decrement
- Memory-to-memory, memory-to-peripheral, and peripheral-to-memory transfers
- Internal four-word × 64 bits FIFO per channel
- Multi-block transfers achieved through:
  - Linked Lists (block chaining)
  - Auto-reloading of channel registers
  - Contiguous address between blocks
  - Independent source and destination selection of multi-block transfer method
  - Scatter/Gather



Figure 11.1 DMA Controller Interfaces and Connections

# 11.2 Signal Interfaces

|             | Input  |                                        |
|-------------|--------|----------------------------------------|
| Signal Name | Output | Description                            |
| Clock       |        |                                        |
| DMA[m]_HCLK | Input  | Internal bus clock (AHB)               |
| Interrupt   |        |                                        |
| DMA[m]_Int  | Output | Level sensitive interrupt, Active High |

Note: m = 1 or 2

Index removed style is used in this chapter.

Ex) DMA\_Int

### 11.3 Basic Definitions

The following terms are concise definitions used throughout this chapter.

# ■ Peripheral:

- Area that requires a request interface (DMA request) to the DMAC when executing a DMA transfer.

### ■ Source peripheral:

- Device from which the DMAC reads data (area to read data by DMA request).

### ■ Destination peripheral:

Device to which the DMAC writes the stored data (area to write data by DMA request).

### ■ Memory:

 Source or destination that is always "ready" for a DMA transfer and does not require a request interface to interact with the DMAC.

#### ■ Channel:

- Read/write data path between a source and a destination.
- If the source is peripheral, then a source request interface is assigned to the channel for DMAC transfer from source.
- If the destination is peripheral, then a destination request interface is assigned to the channel for DMAC transfer to destination.
- Request interfaces can be assigned dynamically by programming the channel registers.

### ■ Request interface:

- A set of signals or software registers that controls a transfer request between the DMAC and source/destination peripheral.
- This interface is used to control a DMAC transaction.
- A channel can receive a request from either hardware or software request interface.

### ■ Hardware request interface:

 Hardware signals to control transferring a single or burst transaction between the DMAC and the source/destination peripheral.

### ■ Software request interface:

 Software registers to control transferring a single or burst transaction between the DMAC and the source/destination peripheral. Signals on the peripheral are not used.

### **■** Flow controller:

- Device that determines the DMA block transfer size and terminates it. Peripheral or DMAC can be the flow controller.
- If the peripheral can control the block transfer size, the peripheral will be the flow controller. Otherwise, the DMAC will be the flow controller.



### ■ Flow control mode (CFG[n].FCMODE):

 Special mode that only applies when the destination peripheral is the flow controller. It controls the data prefetching from the source peripheral.

#### **■** Transaction:

- Basic data processing of a DMA transfer per one request.
- There are two types of transactions.

### ■ Single transaction:

− The transaction defined by 1 × CTL[n].SRC\_TR\_WIDTH/DST\_TR\_WIDTH.

#### **■** Burst transaction:

- The transaction with a length of N defined by CTL[n].SRC\_MSIZE/DEST\_MSIZE, and a single transaction × N. If the flow controller is a peripheral, set the length of burst transaction to the same setting as the DMAC.

#### ■ Block:

This is the total amount of data transferred in one DMA execution, and is the same as the block transfer size set by the flow controller. It consists of a series of transactions, and when the transfer of the block size is completed, one DMA is completed. The block transfer size is the total number of single transactions transferred.

#### ■ Multi-block DMA transfer:

 DMA transfer may consist of multiple DMA blocks. Multi-block DMA transfers are supported through block chaining (linked list pointers), auto-reloading channel registers, and contiguous blocks. The source and destination can independently select which method to use.

### ■ Linked lists (block chaining):

Linked list pointer (LLP) points to the location in system memory where the next linked list item (LLI) exists. The
 LLI is a set of registers that describes the next block (block descriptor) and an LLP register. The DMAC fetches
 the LLI at the beginning of every block when block chaining is enabled.

### ■ Auto-reloading:

The DMAC automatically reloads the channel registers to the value when the channel was first enabled at the end
of each block transfer.

### ■ Contiguous blocks:

- Address between successive blocks is selected to be a continuation from the end of the previous block.

#### ■ Scatter:

 Relevant to destination transfers within a block. The destination address is incremented or decremented by a programmed amount when a scatter boundary is reached.

### ■ Gather:

 Relevant to source transfers within a block. The source address is incremented or decremented by a programmed amount when a gather boundary is reached.



### ■ FIFO mode:

Special mode to improve bus utilization. When enabled, the channel waits until the FIFO is less than half full to fetch the data from the source peripheral and waits until the FIFO is greater than or equal to half full to send data to the destination peripheral. Because of this behavior, the channel can transfer the data using bursts, which improve bus utilization ratio. When this mode is not enabled, the channel waits only until the FIFO can transmit or accept a single AHB transfer.

# 11.4 Register Map

# 11.4.1 Register Map of DMAC1

Table 11.1 Register Map of DMAC1

| Address              | Register Symbol       | Register Name                                       |
|----------------------|-----------------------|-----------------------------------------------------|
| 4010 4000h + 58h × n | SAR[n] (n = 07)       | Source Address Register for Channel [n]             |
| 4010 4008h + 58h × n | DAR[n] (n = 07)       | Destination Address Register for Channel [n]        |
| 4010 4010h + 58h × n | LLP[n] (n = 07)       | Linked List Pointer Register for Channel [n]        |
| 4010 4018h + 58h × n | CTL[n] (n = 07)       | Control Register for Channel [n]                    |
| 4010 4020h + 58h × n | SSTAT[n] (n = 07)     | Source Status Register for Channel [n]              |
| 4010 4028h + 58h × n | DSTAT[n] (n = 07)     | Destination Status Register for Channel [n]         |
| 4010 4030h + 58h × n | SSTATAR[n] (n = 07)   | Source Status Address Register for Channel [n]      |
| 4010 4038h + 58h × n | DSTATAR[n] $(n = 07)$ | Destination Status Address Register for Channel [n] |
| 4010 4040h + 58h × n | CFG[n] (n = 07)       | Configuration Register for Channel [n]              |
| 4010 4048h + 58h × n | SGR[n] (n = 07)       | Source Gather Register for Channel [n]              |
| 4010 4050h + 58h × n | DSR[n] (n = 07)       | Destination Scatter Register for Channel [n]        |
| 4010 42C0h           | RawTfr                | Raw Status for IntTfr Interrupt Register            |
| 4010 42C8h           | RawBlock              | Raw Status for IntBlock Interrupt Register          |
| 4010 42D0h           | RawSrcTran            | Raw Status for IntSrcTran Interrupt Register        |
| 4010 42D8h           | RawDstTran            | Raw Status for IntDstTran Interrupt Register        |
| 4010 42E0h           | RawErr                | Raw Status for IntErr Interrupt Register            |
| 4010 42E8h           | StatusTfr             | Status for IntTfr Interrupt Register                |
| 4010 42F0h           | StatusBlock           | Status for IntBlock Interrupt Register              |
| 4010 42F8h           | StatusSrcTran         | Status for IntSrcTran Interrupt Register            |
| 4010 4300h           | StatusDstTran         | Status for IntDstTran Interrupt Register            |
| 4010 4308h           | StatusErr             | Status for IntErr Interrupt Register                |
| 4010 4310h           | MaskTfr               | Mask for IntTfr Interrupt Register                  |
| 4010 4318h           | MaskBlock             | Mask for IntBlock Interrupt Register                |
| 4010 4320h           | MaskSrcTran           | Mask for IntSrcTran Interrupt Register              |
| 4010 4328h           | MaskDstTran           | Mask for IntDstTran Interrupt Register              |
| 4010 4330h           | MaskErr               | Mask for IntErr Interrupt Register                  |
| 4010 4338h           | ClearTfr              | Clear for IntTfr Interrupt Register                 |
| 4010 4340h           | ClearBlock            | Clear for IntBlock Interrupt Register               |
| 4010 4348h           | ClearSrcTran          | Clear for IntSrcTran Interrupt Register             |
| 4010 4350h           | ClearDstTran          | Clear for IntDstTran Interrupt Register             |
| 4010 4358h           | ClearErr              | Clear for IntErr Interrupt Register                 |
| 4010 4360h           | StatusInt             | Combined Interrupt Status Register                  |
| 4010 4368h           | ReqSrcReg             | Source Software Transaction Request Register        |
| 4010 4370h           | ReqDstReg             | Destination Software Transaction Request Register   |
| 4010 4378h           | SglRqSrcReg           | Single Source Transaction Request Register          |
| 4010 4380h           | SglRqDstReg           | Single Destination Transaction Request Register     |
| 4010 4388h           | LstSrcReg             | Last Source Transaction Request Register            |
| 4010 4390h           | LstDstReg             | Last Destination Transaction Request Register       |
| 4010 4398h           | DmaCfgReg             | DMA Configuration Register                          |
| 4010 43A0h           | ChEnReg               | DMA Controller Channel Enable Register              |
| 4010 43A8h           | DmaldReg              | DMA ID Register                                     |
| 4010 43B0h           | DmaTestReg            | DMA Controller Test Register                        |
|                      |                       |                                                     |

# 11.4.2 Register Map of DMAC2

Table 11.2 Register Map of DMAC2

| Table 11.2 Register I | Map of DMAC2          |                                                     |
|-----------------------|-----------------------|-----------------------------------------------------|
| Address               | Register Symbol       | Register Name                                       |
| 4010 5000h + 58h × n  | SAR[n] (n = 07)       | Source Address Register for Channel [n]             |
| 4010 5008h + 58h × n  | DAR[n] (n = 07)       | Destination Address Register for Channel [n]        |
| 4010 5010h + 58h × n  | LLP[n] (n = 07)       | Linked List Pointer Register for Channel [n]        |
| 4010 5018h + 58h × n  | CTL[n] (n = 07)       | Control Register for Channel [n]                    |
| 4010 5020h + 58h × n  | SSTAT[n] (n = 07)     | Source Status Register for Channel [n]              |
| 4010 5028h + 58h × n  | DSTAT[n] (n = 07)     | Destination Status Register for Channel [n]         |
| 4010 5030h + 58h × n  | SSTATAR[n] (n = 07)   | Source Status Address Register for Channel [n]      |
| 4010 5038h + 58h × n  | DSTATAR[n] $(n = 07)$ | Destination Status Address Register for Channel [n] |
| 4010 5040h + 58h × n  | CFG[n] (n = 07)       | Configuration Register for Channel [n]              |
| 4010 5048h + 58h × n  | SGR[n] (n = 07)       | Source Gather Register for Channel [n]              |
| 4010 5050h + 58h × n  | DSR[n] (n = 07)       | Destination Scatter Register for Channel [n]        |
| 4010 52C0h            | RawTfr                | Raw Status for IntTfr Interrupt Register            |
| 4010 52C8h            | RawBlock              | Raw Status for IntBlock Interrupt Register          |
| 4010 52D0h            | RawSrcTran            | Raw Status for IntSrcTran Interrupt Register        |
| 4010 52D8h            | RawDstTran            | Raw Status for IntDstTran Interrupt Register        |
| 4010 52E0h            | RawErr                | Raw Status for IntErr Interrupt Register            |
| 4010 52E8h            | StatusTfr             | Status for IntTfr Interrupt Register                |
| 4010 52F0h            | StatusBlock           | Status for IntBlock Interrupt Register              |
| 4010 52F8h            | StatusSrcTran         | Status for IntSrcTran Interrupt Register            |
| 4010 5300h            | StatusDstTran         | Status for IntDstTran Interrupt Register            |
| 4010 5308h            | StatusErr             | Status for IntErr Interrupt Register                |
| 4010 5310h            | MaskTfr               | Mask for IntTfr Interrupt Register                  |
| 4010 5318h            | MaskBlock             | Mask for IntBlock Interrupt Register                |
| 4010 5320h            | MaskSrcTran           | Mask for IntSrcTran Interrupt Register              |
| 4010 5328h            | MaskDstTran           | Mask for IntDstTran Interrupt Register              |
| 4010 5330h            | MaskErr               | Mask for IntErr Interrupt Register                  |
| 4010 5338h            | ClearTfr              | Clear for IntTfr Interrupt Register                 |
| 4010 5340h            | ClearBlock            | Clear for IntBlock Interrupt Register               |
| 4010 5348h            | ClearSrcTran          | Clear for IntSrcTran Interrupt Register             |
| 4010 5350h            | ClearDstTran          | Clear for IntDstTran Interrupt Register             |
| 4010 5358h            | ClearErr              | Clear for IntErr Interrupt Register                 |
| 4010 5360h            | StatusInt             | Combined Interrupt Status Register                  |
| 4010 5368h            | ReqSrcReg             | Source Software Transaction Request Register        |
| 4010 5370h            | ReqDstReg             | Destination Software Transaction Request Register   |
| 4010 5378h            | SglRqSrcReg           | Single Source Transaction Request Register          |
| 4010 5380h            | SglRqDstReg           | Single Destination Transaction Request Register     |
| 4010 5388h            | LstSrcReg             | Last Source Transaction Request Register            |
| 4010 5390h            | LstDstReg             | Last Destination Transaction Request Register       |
| 4010 5398h            | DmaCfgReg             | DMA Configuration Register                          |
| 4010 53A0h            | ChEnReg               | DMA Controller Channel Enable Register              |
| 4010 53A8h            | DmaldReg              | DMA ID Register                                     |
| 4010 53B0h            | DmaTestReg            | DMA Controller Test Register                        |
|                       |                       |                                                     |

# 11.5 Register Description

# 11.5.1 SAR[n] — Source Address Register for Channel [n] (n = 0..7)

The starting source address is programmed by software before the DMA channel is enabled, or by an LLI update before the start of the DMA transfer. While the DMA transfer is in progress, this register is updated to reflect the source address of the current transfer.





Table 11.3 SAR[n] Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                                                                                                              | R/W |
|--------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b63 to b32   | Reserved |                                                                                                                                                                                                                                                       | R   |
| b31 to b0    | SAR      | Current Source Address of DMA transfer. Updated after each source transfer. The SINC field in the CTL[n] register determines whether the address increments, decrements, or is left unchanged on every source transfer throughout the block transfer. | R/W |

# 11.5.2 DAR[n] — Destination Address Register for Channel [n] (n = 0..7)

The starting destination address is programmed by software before the DMA channel is enabled, or by an LLI update before the start of the DMA transfer. While the DMA transfer is in progress, this register is updated to reflect the destination address of the current transfer.

Address: 4010 4008h + 58h x n (DMAC1) 4010 5008h + 58h x n (DMAC2)



Table 11.4 DAR[n] Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                                                                                                                             | R/W |
|--------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b63 to b32   | Reserved |                                                                                                                                                                                                                                                                      | R   |
| b31 to b0    | DAR      | Current Destination address of DMA transfer. Updated after each destination transfer. The DINC field in the CTL[n] register determines whether the address increments, decrements, or is left unchanged on every destination transfer throughout the block transfer. | R/W |

# 11.5.3 LLP[n] — Linked List Pointer Register for Channel [n] (n = 0..7)

This register has to be programmed to point to the first Linked List Item (LLI) in memory prior to enabling the channel if block chaining is enabled.

Address: 4010 4010h + 58h × n (DMAC1) 4010 5010h + 58h × n (DMAC2)



Table 11.5 LLP[n] Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                                                              | R/W |
|--------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b63 to b32   | Reserved |                                                                                                                                                                                                       | R   |
| b31 to b2    | LOC      | Starting Address In Memory of next LLI if block chaining is enabled. Note that the two LSBs of the starting address are not stored because the address is assumed to be aligned to a 32-bit boundary. | R/W |
|              |          | LLI accesses are always 32-bit accesses aligned to 32-bit boundaries and cannot be changed or programmed to anything other than 32-bit.                                                               |     |
| b1, b0       | Reserved |                                                                                                                                                                                                       | R   |

# 11.5.4 CTL[n] — Control Register for Channel [n] (n = 0..7)

This register contains fields that control the DMA transfer. The CTL[n] register is part of the block descriptor (linked list item—LLI) when block chaining is enabled. It can be varied on a block-by-block basis within a DMA transfer when block chaining is enabled. This register has to be programmed prior to enabling the channel.

Address: 4010 4018h + 58h × n (DMAC1) 4010 5018h + 58h × n (DMAC2)



Table 11.6 CTL[n] Register Contents (1/3)

| Bit Position | Bit Name   | Function                                                                                                                                                                                                                                   | R/W |
|--------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b63 to b45   | Reserved   |                                                                                                                                                                                                                                            | R   |
| b44          | DONE       | Done bit.                                                                                                                                                                                                                                  | R/W |
|              |            | If status write-back is enabled, the upper word of the control register, CTL[n][63:32], is written to the control register location of the Linked List Item (LLI) in system memory at the end of the block transfer with the done bit set. |     |
|              |            | Software can poll the LLI CTL[n].DONE bit to see when a block transfer is complete. The LLI CTL[n].DONE bit should be cleared when the linked lists are set up in memory prior to enabling the channel.                                    |     |
|              |            | LLI accesses are always 32-bit accesses aligned to 32-bit boundaries and cannot be changed or programmed to anything other than 32-bit.                                                                                                    |     |
| b43 to b32   | BLOCK_TS   | Block Transfer Size.                                                                                                                                                                                                                       | R/W |
|              |            | When DMAC is the flow controller, the user writes this field before the channel is enabled in order to indicate the block size. The block transfer size is the total number of single transactions of the source transferred.              |     |
|              |            | Once the transfer starts, it is the number of data read from the source, regardless of what is the flow controller.                                                                                                                        |     |
|              |            | When the source or destination peripheral is assigned as the flow controller, then the maximum block size that can be read back saturates at 4095, but the actual block size can be greater.                                               |     |
| b31 to b29   | Reserved   |                                                                                                                                                                                                                                            | R   |
| b28          | LLP_SRC_EN | Block chaining is enabled on the source side only if the LLP_SRC_EN field is high and LLP[n].LOC is non-zero.                                                                                                                              | R/W |

| Table 44.0 | OTL In1 | D = =:=+== | C        | (0/0) |
|------------|---------|------------|----------|-------|
| Table 11.6 |         | Register   | Contents | (2/3) |

| Bit Position | Bit Name       | Function                                                                                                                                                                                                                                  | R/W |
|--------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b27          | LLP_DST_EN     | Block chaining is enabled on the destination side only if the LLP_DST_EN field is high and LLP[n].LOC is non-zero.                                                                                                                        | R/W |
| b26 to b23   | Reserved       |                                                                                                                                                                                                                                           | R   |
| b22 to b20   | TT_FC          | Transfer Type and Flow Control.                                                                                                                                                                                                           | R/W |
|              |                | Flow Control can be assigned to the DMAC, the source peripheral, or the destination peripheral.                                                                                                                                           |     |
|              |                | 000b: Memory to Memory, DMAC as flow controller                                                                                                                                                                                           |     |
|              |                | 001b: Memory to Peripheral, DMAC as flow controller                                                                                                                                                                                       |     |
|              |                | 010b: Peripheral to Memory, DMAC as flow controller                                                                                                                                                                                       |     |
|              |                | 011b: Reserved                                                                                                                                                                                                                            |     |
|              |                | 100b: Peripheral to Memory, Peripheral as flow controller                                                                                                                                                                                 |     |
|              |                | 101b: Reserved                                                                                                                                                                                                                            |     |
|              |                | 110b: Memory to Peripheral, Peripheral as flow controller                                                                                                                                                                                 |     |
|              |                | 111b: Reserved                                                                                                                                                                                                                            |     |
|              |                | For multi-block transfers using linked list operation, TT_FC must be constant for all blocks of this multi-block transfer.                                                                                                                |     |
| b19          | Reserved       |                                                                                                                                                                                                                                           | R   |
| b18          | DST_SCATTER_EN | Destination scatter enable bit:                                                                                                                                                                                                           | R/W |
|              |                | 0: Scatter disabled                                                                                                                                                                                                                       |     |
|              |                | 1: Scatter enabled                                                                                                                                                                                                                        |     |
|              |                | Scatter on the destination side is applicable only when the CTL[n].DINC bit indicates an incrementing or decrementing address control.                                                                                                    |     |
| b17          | SRC_GATHER_EN  | Source gather enable bit:                                                                                                                                                                                                                 | R/W |
|              |                | 0: Gather disabled                                                                                                                                                                                                                        |     |
|              |                | 1: Gather enabled                                                                                                                                                                                                                         |     |
|              |                | Gather on the source side is applicable only when the CTL[n].SINC bit indicates an incrementing or decrementing address control.                                                                                                          |     |
| b16 to b14   | SRC_MSIZE      | Source Burst Transaction Length.                                                                                                                                                                                                          | R/W |
|              |                | The length of transaction read by one source request. Invalid for "Memory" setting.                                                                                                                                                       |     |
|              |                | 000b: 1                                                                                                                                                                                                                                   |     |
|              |                | 001b: 4                                                                                                                                                                                                                                   |     |
|              |                | 010b: 8                                                                                                                                                                                                                                   |     |
|              |                | 011b: 16                                                                                                                                                                                                                                  |     |
|              |                | 100b: 32                                                                                                                                                                                                                                  |     |
|              |                | 101b: 64                                                                                                                                                                                                                                  |     |
|              |                | 110b: 128                                                                                                                                                                                                                                 |     |
|              |                | 111b: 256                                                                                                                                                                                                                                 |     |
| b13 to b11   | DEST_MSIZE     | Destination Burst Transaction Length.                                                                                                                                                                                                     | R/W |
|              |                | The length of transaction read by one destination request.                                                                                                                                                                                |     |
|              |                | The meaning of the setting is the same as SRC_MSIZE.                                                                                                                                                                                      |     |
|              |                | Invalid for "Memory" setting.                                                                                                                                                                                                             |     |
| b10, b9      | SINC           | Source Address Increment. Indicates whether to increment or decrement the source address on every source transfer. If the device is fetching data from a source peripheral FIFO with a fixed address, then set this field to "No change". | R/W |
|              |                | 00b: Increment                                                                                                                                                                                                                            |     |
|              |                | 01b: Decrement                                                                                                                                                                                                                            |     |
|              |                | 1xb: No change                                                                                                                                                                                                                            |     |
|              |                | <b>Note)</b> Incrementing or decrementing is done for alignment to the next CTL[n].SRC_TR_WIDTH boundary.                                                                                                                                 |     |

Table 11.6 CTL[n] Register Contents (3/3)

| Table 1.10 0.12[in] regions community |              |                                                                                                                                                                                                                                                             |     |
|---------------------------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Bit Position                          | Bit Name     | Function                                                                                                                                                                                                                                                    | R/W |
| b8, b7                                | DINC         | Destination Address Increment. Indicates whether to increment or decrement the destination address on every destination transfer. If your device is writing data to a destination peripheral FIFO with a fixed address, then set this field to "No change". | R/W |
|                                       |              | 00b: Increment                                                                                                                                                                                                                                              |     |
|                                       |              | 01b: Decrement                                                                                                                                                                                                                                              |     |
|                                       |              | 1xb: No change                                                                                                                                                                                                                                              |     |
|                                       |              | <b>Note)</b> Incrementing or decrementing is done for alignment to the next CTL[n].DST_TR_WIDTH boundary.                                                                                                                                                   |     |
| b6 to b4                              | SRC_TR_WIDTH | Source Transfer Width.                                                                                                                                                                                                                                      | R/W |
|                                       |              | 000b: 8 bits                                                                                                                                                                                                                                                |     |
|                                       |              | 001b: 16 bits                                                                                                                                                                                                                                               |     |
|                                       |              | 010b: 32 bits                                                                                                                                                                                                                                               |     |
|                                       |              | 011b: 64 bits                                                                                                                                                                                                                                               |     |
|                                       |              | Other: Reserved                                                                                                                                                                                                                                             |     |
|                                       |              | For a non-memory peripheral, typically the peripheral (source) FIFO width.                                                                                                                                                                                  |     |
| b3 to b1                              | DST_TR_WIDTH | Destination transfer width.                                                                                                                                                                                                                                 | R/W |
|                                       |              | Same as SRC_TR_WIDTH.                                                                                                                                                                                                                                       |     |
|                                       |              | For a non-memory peripheral, typically the peripheral (destination) FIFO width.                                                                                                                                                                             |     |
| b0                                    | INT_EN       | Interrupt Enable Bit.                                                                                                                                                                                                                                       | R/W |
|                                       |              | If set, then all interrupt-generating sources are enabled. Functions as a global mask bit for all interrupts for the channel.                                                                                                                               |     |

# 11.5.5 SSTAT[n] — Source Status Register for Channel [n] (n = 0..7)

This register is a temporary placeholder for the source status information on its way to the SSTAT[n] register location of the LLI. The source status information should be retrieved by software from the SSTAT[n] register location of the LLI, and not by a read of this register over the DMAC slave interface.



Table 11.7 SSTAT[n] Register Contents

Value after reset

0

0

0

0

0

| Bit Position | Bit Name | Function                                                                                                                | R/W |
|--------------|----------|-------------------------------------------------------------------------------------------------------------------------|-----|
| b63 to b32   | Reserved |                                                                                                                         | R   |
| b31 to b0    | SSTAT    | Source status information retrieved by hardware from the address pointed to by the contents of the SSTATAR[n] register. | R/W |

0

0

0

0

0

0

0

0

0

# 11.5.6 DSTAT[n] — Destination Status Register for Channel [n] (n = 0..7)

This register is a temporary placeholder for the destination status information on its way to the DSTAT[n] register location of the LLI. The destination status information should be retrieved by software from the DSTAT[n] register location of the LLI and not by a read of this register over the DMAC slave interface.

Address: 4010 4028h + 58h x n (DMAC1) 4010 5028h + 58h x n (DMAC2)



Table 11.8 DSTAT[n] Register Contents

| Bit Position | Bit Name | Function                                                                                                                     | R/W |
|--------------|----------|------------------------------------------------------------------------------------------------------------------------------|-----|
| b63 to b32   | Reserved |                                                                                                                              | R   |
| b31 to b0    | DSTAT    | Destination status information retrieved by hardware from the address pointed to by the contents of the DSTATAR[n] register. | R/W |

# 11.5.7 SSTATAR[n] — Source Status Address Register for Channel [n] (n = 0..7)

After completion of each block transfer, hardware can retrieve the source status information from the user-defined address to which the contents of the SSTATAR[n] register point. The user can select any location in system memory that would provide a 32-bit value to indicate the status of the source transfer.





Table 11.9 SSTATAR[n] Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                                                                           | R/W |
|--------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b63 to b32   | Reserved |                                                                                                                                                                                                                    | R   |
| b31 to b0    | SSTATAR  | Pointer from where hardware can fetch the source status information, which is registered in the SSTAT[n] register and written out to the SSTAT[n] register location of the LLI before the start of the next block. | R/W |

# 11.5.8 DSTATAR[n] — Destination Status Address Register for Channel [n] (n = 0..7)

After completion of each block transfer, hardware can retrieve the destination status information from the user-defined address to which the contents of the DSTATAR[n] register point. The user can select any location in system memory that would provide a 32-bit value to indicate the status of the destination transfer.

Address: 4010 4038h + 58h × n (DMAC1) 4010 5038h + 58h × n (DMAC2)



Table 11.10 DSTATAR[n] Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                                                                                | R/W |
|--------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b63 to b32   | Reserved |                                                                                                                                                                                                                         | R   |
| b31 to b0    | DSTATAR  | Pointer from where hardware can fetch the destination status information, which is registered in the DSTAT[n] register and written out to the DSTAT[n] register location of the LLI before the start of the next block. | R/W |

# 11.5.9 CFG[n] — Configuration Register for Channel [n] (n = 0..7)

This register contains fields that configure the DMA transfer. The channel configuration register remains fixed for all blocks of a multi-block transfer.

Address: 4010 4040h + 58h × n (DMAC1) 4010 5040h + 58h × n (DMAC2)



Table 11.11 CFG[n] Register Contents (1/3)

| Bit Position | Bit Name  | Function                                                                                                                                                                                                          | R/W |
|--------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b63 to b47   | Reserved  |                                                                                                                                                                                                                   | R   |
| b46 to b43   | DEST_PER  | Assigns a hardware request interface (0 to 15) to the destination of channel [n]. When software request interface is used, this field is ignored.                                                                 |     |
|              |           | The channel can then communicate with the destination peripheral connected to that interface through the assigned hardware request interface.                                                                     |     |
|              |           | For correct DMAC operation, only one peripheral (source or destination) should be assigned to the same request interface.                                                                                         |     |
| b42 to b39   | SRC_PER   | Assigns a hardware request interface (0 to 15) to the source of channel [n]. When software request interface is used, this field is ignored.                                                                      | R/W |
|              |           | The channel can then communicate with the source peripheral connected to that interface through the assigned hardware request interface.                                                                          |     |
|              |           | For correct DMAC operation, only one peripheral (source or destination) should be assigned to the same request interface.                                                                                         |     |
| b38          | SS_UPD_EN | Source Status Update Enable.                                                                                                                                                                                      | R/W |
|              |           | Source status information is fetched only from the location pointed to by the SSTATAR[n] register, stored in the SSTAT[n] register and written out to the SSTAT[n] location of the LLI if SS_UPD_EN is high.      |     |
| b37          | DS_UPD_EN | Destination Status Update Enable.                                                                                                                                                                                 | R/W |
|              |           | Destination status information is fetched only from the location pointed to by the DSTATAR[n] register, stored in the DSTAT[n] register and written out to the DSTAT[n] location of the LLI if DS_UPD_EN is high. |     |
| b36 to b34   | Reserved  | Keep the initial value.                                                                                                                                                                                           | R/W |

Table 11.11 CFG[n] Register Contents (2/3)

| Bit Position         | Bit Name                                                                                                                                                                                                                                                                                          | Function                                                                                                                                                                                                                                                                                                       | R/W  |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| b33                  | FIFO_MODE                                                                                                                                                                                                                                                                                         | FIFO Mode Select.                                                                                                                                                                                                                                                                                              | R/W  |
|                      |                                                                                                                                                                                                                                                                                                   | This mode improves system bus use efficiency.                                                                                                                                                                                                                                                                  |      |
|                      |                                                                                                                                                                                                                                                                                                   | 0: The FIFO accesses the bus if single transfer is possible.                                                                                                                                                                                                                                                   |      |
|                      |                                                                                                                                                                                                                                                                                                   | 1: The FIFO accesses the bus by burst transfers whenever possible. Improves bus use efficiency.                                                                                                                                                                                                                |      |
| b32                  | FCMODE                                                                                                                                                                                                                                                                                            | Flow Control Mode.                                                                                                                                                                                                                                                                                             | R/W  |
|                      |                                                                                                                                                                                                                                                                                                   | Determines when source transaction requests are serviced when the Destination Peripheral is the flow controller.                                                                                                                                                                                               |      |
|                      |                                                                                                                                                                                                                                                                                                   | 0: Source transaction requests are serviced when they occur.                                                                                                                                                                                                                                                   |      |
|                      |                                                                                                                                                                                                                                                                                                   | 1: Source transaction requests are not serviced until a destination transaction<br>request occurs. In this mode, the amount of data transferred from the source is<br>limited so that it is guaranteed to be transferred to the destination prior to block<br>termination by the destination.                  |      |
| b31                  | RELOAD_DST                                                                                                                                                                                                                                                                                        | Automatic Destination Reload.                                                                                                                                                                                                                                                                                  | R/W  |
|                      |                                                                                                                                                                                                                                                                                                   | The DAR[n] register can be automatically reloaded from its initial setting value at the end of every block for multi-block transfers. A new block transfer is then initiated. For conditions under which this occurs, refer to Table 11.46, Programming of Transfer Method and Channel Register Update Method. |      |
| b30                  | RELOAD_SRC                                                                                                                                                                                                                                                                                        | Automatic Source Reload.                                                                                                                                                                                                                                                                                       | R/W  |
|                      | The SAR[n] register can be automatically reloaded from its initial setting value at end of every block for multi-block transfers. A new block transfer is then initiated conditions under which this occurs, refer to Table 11.46, Programming of Transmethod and Channel Register Update Method. |                                                                                                                                                                                                                                                                                                                |      |
| b29 to b20 MAX_ABRST |                                                                                                                                                                                                                                                                                                   | MAX_ABRST Maximum Burst Length.                                                                                                                                                                                                                                                                                |      |
|                      |                                                                                                                                                                                                                                                                                                   | Set the maximum burst length of the channel used for DMA transfers so that the DMAC does not occupy the bus.                                                                                                                                                                                                   |      |
|                      |                                                                                                                                                                                                                                                                                                   | If this field is 0, the DMA transfer of the channel is not limited to the MAX_ABRST.                                                                                                                                                                                                                           |      |
| b19                  | SRC_HS_POL                                                                                                                                                                                                                                                                                        | Source Request Interface Polarity.                                                                                                                                                                                                                                                                             | R/W  |
|                      |                                                                                                                                                                                                                                                                                                   | In this LSI, only active high is valid and keep the initial value.                                                                                                                                                                                                                                             |      |
|                      |                                                                                                                                                                                                                                                                                                   | 0: Active high 1: Active low                                                                                                                                                                                                                                                                                   |      |
| h10                  | DOT HE DOL                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                | R/W  |
| b18                  | DST_HS_POL                                                                                                                                                                                                                                                                                        | Destination Request Interface Polarity.  In this LSI, only active high is valid and keep the initial value.                                                                                                                                                                                                    | K/VV |
|                      |                                                                                                                                                                                                                                                                                                   | 0: Active high                                                                                                                                                                                                                                                                                                 |      |
|                      |                                                                                                                                                                                                                                                                                                   | 1: Active low                                                                                                                                                                                                                                                                                                  |      |
| b17 to b12           | Reserved                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                | R    |
| b11                  | HS_SEL_SRC                                                                                                                                                                                                                                                                                        | Source Software or Hardware Request Interface Select.                                                                                                                                                                                                                                                          | R/W  |
|                      |                                                                                                                                                                                                                                                                                                   | This register selects which of the request interfaces — hardware or software — is active for source requests on this channel.                                                                                                                                                                                  |      |
|                      |                                                                                                                                                                                                                                                                                                   | 0: Hardware request interface. Software-initiated transaction requests are ignored.                                                                                                                                                                                                                            |      |
|                      |                                                                                                                                                                                                                                                                                                   | 1: Software request interface. Hardware-initiated transaction requests are ignored.                                                                                                                                                                                                                            |      |
|                      |                                                                                                                                                                                                                                                                                                   | If the source is "memory" that does not require a request interface, then this bit is ignored.                                                                                                                                                                                                                 |      |
| b10                  | HS_SEL_DST                                                                                                                                                                                                                                                                                        | Destination Software or Hardware Request Interface Select.                                                                                                                                                                                                                                                     | R/W  |
|                      |                                                                                                                                                                                                                                                                                                   | This register selects which of the request interfaces — hardware or software — is active for destination requests on this channel.                                                                                                                                                                             |      |
|                      |                                                                                                                                                                                                                                                                                                   | 0: Hardware request interface. Software-initiated transaction requests are ignored.                                                                                                                                                                                                                            |      |
|                      |                                                                                                                                                                                                                                                                                                   | 1: Software request interface. Hardware-initiated transaction requests are ignored.                                                                                                                                                                                                                            |      |
|                      |                                                                                                                                                                                                                                                                                                   | If the destination is "memory" that does not require a request interface, then this bit is ignored.                                                                                                                                                                                                            |      |
|                      |                                                                                                                                                                                                                                                                                                   | ignorea.                                                                                                                                                                                                                                                                                                       |      |

Table 11.11 CFG[n] Register Contents (3/3)

|              |            | ` ,                                                                                                                                                                                                                       |     |
|--------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Bit Position | Bit Name   | Function                                                                                                                                                                                                                  | R/W |
| b9           | FIFO_EMPTY | Indicates if there is data left in the channel FIFO.                                                                                                                                                                      | R   |
|              |            | Can be used in conjunction with CFG[n].CH_SUSP to disable a channel.                                                                                                                                                      |     |
|              |            | 0: Channel FIFO not empty                                                                                                                                                                                                 |     |
|              |            | 1: Channel FIFO empty                                                                                                                                                                                                     |     |
| b8           | CH_SUSP    | Channel Suspend.                                                                                                                                                                                                          | R/W |
|              |            | Suspends all DMA data transfers from the source until this bit is cleared. There is no guarantee that the current transaction will complete. Can also be used in conjunction with CFG[n].FIFO_EMPTY to disable a channel. |     |
|              |            | 0: Not suspended.                                                                                                                                                                                                         |     |
|              |            | 1: Suspend DMA transfer from the source.                                                                                                                                                                                  |     |
| b7 to b5     | CH_PRIOR   | Channel priority.                                                                                                                                                                                                         | R/W |
|              |            | A priority of 7 is the highest priority, and 0 is the lowest.                                                                                                                                                             |     |
|              |            | Reset value: 0 for Channel0 7 for Channel7                                                                                                                                                                                |     |
|              |            | The highest priority request is always executed. However, if a request of the same priority occurs, the lower numbered channel runs.                                                                                      |     |
| b4 to b0     | Reserved   |                                                                                                                                                                                                                           | R   |
|              |            |                                                                                                                                                                                                                           |     |

# 11.5.10 SGR[n] — Source Gather Register for Channel [n] (n = 0..7)

The Source Gather register contains two fields:

- Source gather count field (SGR[n].SGC) Specifies the number of contiguous source single transactions between gather boundaries.
- Source gather interval field (SGR[n].SGI) Specifies the source address increment/decrement in multiples of CTL[n].SRC\_TR\_WIDTH on a gather boundary when gather mode is enabled for the source transfer.

Address:  $4010 4048h + 58h \times n (DMAC1)$  $4010 5048h + 58h \times n (DMAC2)$ 



Table 11.12 SGR[n] Register Contents

| Bit Position | Bit Name | Function                                                                                    | R/W |
|--------------|----------|---------------------------------------------------------------------------------------------|-----|
| b63 to b32   | Reserved |                                                                                             | R   |
| b31 to b20   | SGC      | Source gather count. Source contiguous transfer count between successive gather boundaries. | R/W |
| b19 to b0    | SGI      | Source gather interval.                                                                     | R/W |

# 11.5.11 DSR[n] — Destination Scatter Register for Channel [n] (n = 0..7)

The Destination Scatter register contains two fields:

- Destination scatter count field (DSR[n].DSC)—Specifies the number of contiguous destination single transactions between scatter boundaries.
- Destination scatter interval field (DSR[n].DSI)—Specifies the destination address increment/decrement in multiples of CTL[n].DST\_TR\_WIDTH on a scatter boundary when scatter mode is enabled for the destination transfer.

Address: 4010 4050h + 58h × n (DMAC1) 4010 5050h + 58h × n (DMAC2)



Table 11.13 DSR[n] Register Contents

| Bit Position | Bit Name | Function                                                                                                | R/W |
|--------------|----------|---------------------------------------------------------------------------------------------------------|-----|
| b63 to b32   | Reserved |                                                                                                         | R   |
| b31 to b20   | DSC      | Destination scatter count. Destination contiguous transfer count between successive scatter boundaries. | R/W |
| b19 to b0    | DSI      | Destination scatter interval.                                                                           | R/W |

# 11.5.12 RawTfr — Raw Status for IntTfr Interrupt Register

This interrupt is generated when the DMA transfer of all blocks is completed. This register has a bit allocated per channel. Each bit in this register is cleared by writing a 1 to the corresponding location in the ClearTfr. Write access is available to this register for software testing purposes only. Under normal operation, writes to this register is not recommended.

Address: 4010 42C0h (DMAC1) 4010 52C0h (DMAC2)



Table 11.14 RawTfr Register Contents

| Bit Position | Bit Name | Function                  | R/W |
|--------------|----------|---------------------------|-----|
| b63 to b8    | Reserved |                           | R   |
| b7 to b0     | RAW      | Raw Interrupt Status      | R/W |
|              |          | 0: No interrupt requested |     |
|              |          | 1: Interrupt requested    |     |

# 11.5.13 RawBlock — Raw Status for IntBlock Interrupt Register

This interrupt is generated on DMA block transfer completion. This register has a bit allocated per channel. Each bit in this register is cleared by writing a 1 to the corresponding location in the ClearBlock. Write access is available to this register for software testing purposes only. Under normal operation, writes to this register is not recommended.

Address: 4010 42C8h (DMAC1) 4010 52C8h (DMAC2)



Table 11.15 RawBlock Register Contents

| Bit Position | Bit Name | Function                  | R/W |
|--------------|----------|---------------------------|-----|
| b63 to b8    | Reserved |                           | R   |
| b7 to b0     | RAW      | Raw Interrupt Status      | R/W |
|              |          | 0: No interrupt requested |     |
|              |          | 1: Interrupt requested    |     |

# 11.5.14 RawSrcTran — Raw Status for IntSrcTran Interrupt Register

This interrupt is generated after completion of the last AHB transfer of the requested single/burst transaction from the request interface on the source side. This register has a bit allocated per channel. Each bit in this register is cleared by writing a 1 to the corresponding location in the ClearSrcTran. Write access is available to this register for software testing purposes only. Under normal operation, writes to this register is not recommended.

Address: 4010 42D0h (DMAC1) 4010 52D0h (DMAC2)



Table 11.16 RawSrcTran Register Contents

| Bit Position | Bit Name | Function                  | R/W |
|--------------|----------|---------------------------|-----|
| b63 to b8    | Reserved |                           | R   |
| b7 to b0     | RAW      | Raw Interrupt Status      | R/W |
|              |          | 0: No interrupt requested |     |
|              |          | 1: Interrupt requested    |     |

# 11.5.15 RawDstTran — Raw Status for IntDstTran Interrupt Register

This interrupt is generated after completion of the last AHB transfer of the requested single/burst transaction from the request interface on the destination side. This register has a bit allocated per channel. Each bit in this register is cleared by writing a 1 to the corresponding location in the ClearDstTran. Write access is available to this register for software testing purposes only. Under normal operation, writes to this register is not recommended.

**Address:** 4010 42D8h (DMAC1) 4010 52D8h (DMAC2)



Table 11.17 RawDstTran Register Contents

| Bit Position | Bit Name | Function                  | R/W |
|--------------|----------|---------------------------|-----|
| b63 to b8    | Reserved |                           | R   |
| b7 to b0     | RAW      | Raw Interrupt Status      | R/W |
|              |          | 0: No interrupt requested |     |
|              |          | 1: Interrupt requested    |     |

# 11.5.16 RawErr — Raw Status for IntErr Interrupt Register

This interrupt is generated when an ERROR response is received from an AHB slave during a DMA transfer. In addition, the DMA transfer is cancelled and the channel is disabled. This register has a bit allocated per channel. Each bit in this register is cleared by writing a 1 to the corresponding location in the ClearErr. Write access is available to this register for software testing purposes only. Under normal operation, writes to this register is not recommended.

Address: 4010 42E0h (DMAC1) 4010 52E0h (DMAC2)



Table 11.18 RawErr Register Contents

| Bit Position | Bit Name | Function                  | R/W |
|--------------|----------|---------------------------|-----|
| b63 to b8    | Reserved |                           | R   |
| b7 to b0     | RAW      | Raw Interrupt Status      | R/W |
|              |          | 0: No interrupt requested |     |
|              |          | 1: Interrupt requested    |     |

# 11.5.17 StatusTfr — Status for IntTfr Interrupt Register

This register has a bit allocated per channel after masking. The content of this register is used to generate the interrupt signals leaving the DMA.

**Address:** 4010 42E8h (DMAC1) 4010 52E8h (DMAC2)



Table 11.19 StatusTfr Register Contents

| Bit Position | Bit Name | Function               | R/W |
|--------------|----------|------------------------|-----|
| b63 to b8    | Reserved |                        | R   |
| b7 to b0     | STATUS   | Interrupt Status       | R   |
|              |          | 0: No Interrupt        |     |
| -            |          | 1: Interrupt generated |     |

# 11.5.18 StatusBlock — Status for IntBlock Interrupt Register

This register has a bit allocated per channel after masking. The content of this register is used to generate the interrupt signals leaving the DMA.

**Address:** 4010 42F0h (DMAC1) 4010 52F0h (DMAC2)



Table 11.20 StatusBlock Register Contents

| Bit Position | Bit Name | Function               | R/W |
|--------------|----------|------------------------|-----|
| b63 to b8    | Reserved |                        | R   |
| b7 to b0     | STATUS   | Interrupt Status       | R   |
|              |          | 0: No Interrupt        |     |
| -            |          | 1: Interrupt generated |     |

# 11.5.19 StatusSrcTran — Status for IntSrcTran Interrupt Register

This register has a bit allocated per channel after masking. The content of this register is used to generate the interrupt signals leaving the DMA.

**Address:** 4010 42F8h (DMAC1) 4010 52F8h (DMAC2)



Table 11.21 StatusSrcTran Register Contents

| Bit Position | Bit Name | Function                         | R/W |
|--------------|----------|----------------------------------|-----|
| b63 to b8    | Reserved |                                  | R   |
| b7 to b0     | STATUS   | Interrupt Status 0: No Interrupt | R   |
|              |          | 1: Interrupt generated           |     |

# 11.5.20 StatusDstTran — Status for IntDstTran Interrupt Register

This register has a bit allocated per channel after masking. The content of this register is used to generate the interrupt signals leaving the DMA.

**Address:** 4010 4300h (DMAC1) 4010 5300h (DMAC2)



Table 11.22 StatusDstTran Register Contents

| Bit Position | Bit Name | Function               | R/W |
|--------------|----------|------------------------|-----|
| b63 to b8    | Reserved |                        | R   |
| b7 to b0     | STATUS   | Interrupt Status       | R   |
|              |          | 0: No Interrupt        |     |
| -            |          | 1: Interrupt generated |     |

# 11.5.21 StatusErr — Status for IntErr Interrupt Register

This register has a bit allocated per channel after masking. The content of this register is used to generate the interrupt signals leaving the DMA.

**Address:** 4010 4308h (DMAC1) 4010 5308h (DMAC2)



Table 11.23 StatusErr Register Contents

| Bit Position | Bit Name | Function               | R/W |
|--------------|----------|------------------------|-----|
| b63 to b8    | Reserved |                        | R   |
| b7 to b0     | STATUS   | Interrupt Status       | R   |
|              |          | 0: No Interrupt        |     |
|              |          | 1: Interrupt generated |     |

# 11.5.22 MaskTfr — Mask for IntTfr Interrupt Register

The content of RawTfr register is masked with the content of the MaskTfr register.

The INT\_MASK[7:0] bits will be written only if the corresponding the INT\_MASK\_WE[7:0] bit is 1. This allows software to set a mask bit without performing a read-modified write operation.

Address: 4010 4310h (DMAC1) 4010 5310h (DMAC2)



Table 11.24 MaskTfr Register Contents

| Bit Position | Bit Name    | Function                    | R/W |
|--------------|-------------|-----------------------------|-----|
| b63 to b16   | Reserved    |                             | R   |
| b15 to b8    | INT_MASK_WE | Interrupt Mask Write-Enable | W   |
|              |             | 0: Write disabled           |     |
|              |             | 1: Write enabled            |     |
| b7 to b0     | INT_MASK    | Interrupt Mask              | R/W |
|              |             | 0: Masked                   |     |
|              |             | 1: Unmasked                 |     |

# 11.5.23 MaskBlock — Mask for IntBlock Interrupt Register

The content of RawBlock register is masked with the content of the MaskBlock register.

The INT\_MASK[7:0] bits will be written only if the corresponding the INT\_MASK\_WE[7:0] bit is 1. This allows software to set a mask bit without performing a read-modified write operation.

Address: 4010 4318h (DMAC1) 4010 5318h (DMAC2)



Table 11.25 MaskBlock Register Contents

| Bit Position | Bit Name    | Function                    | R/W |
|--------------|-------------|-----------------------------|-----|
| b63 to b16   | Reserved    |                             | R   |
| b15 to b8    | INT_MASK_WE | Interrupt Mask Write-Enable | W   |
|              |             | 0: Write disabled           |     |
|              |             | 1: Write enabled            |     |
| b7 to b0     | INT_MASK    | Interrupt Mask              | R/W |
|              |             | 0: Masked                   |     |
|              |             | 1: Unmasked                 |     |

# 11.5.24 MaskSrcTran — Mask for IntSrcTran Interrupt Register

The content of RawSrcTran register is masked with the content of the MaskSrcTran register.

The INT\_MASK[7:0] bits will be written only if the corresponding the INT\_MASK\_WE[7:0] bit is 1. This allows software to set a mask bit without performing a read-modified write operation.

Address: 4010 4320h (DMAC1) 4010 5320h (DMAC2)



Table 11.26 MaskSrcTran Register Contents

| Bit Position | Bit Name    | Function                                                       | R/W |
|--------------|-------------|----------------------------------------------------------------|-----|
| b63 to b16   | Reserved    |                                                                | R   |
| b15 to b8    | INT_MASK_WE | Interrupt Mask Write-Enable 0: Write disabled 1: Write enabled | W   |
| b7 to b0     | INT_MASK    | Interrupt Mask<br>0: Masked<br>1: Unmasked                     | R/W |

# 11.5.25 MaskDstTran — Mask for IntDstTran Interrupt Register

The content of RawDstTran raw is masked with the content of the MaskDstTran register.

The INT\_MASK[7:0] bits will be written only if the corresponding the INT\_MASK\_WE[7:0] bit is 1. This allows software to set a mask bit without performing a read-modified write operation.

Address: 4010 4328h (DMAC1) 4010 5328h (DMAC2)



Table 11.27 MaskDstTran Register Contents

| Bit Position | Bit Name    | Function                    | R/W |
|--------------|-------------|-----------------------------|-----|
| b63 to b16   | Reserved    |                             | R   |
| b15 to b8    | INT_MASK_WE | Interrupt Mask Write-Enable | W   |
|              |             | 0: Write disabled           |     |
|              |             | 1: Write enabled            |     |
| b7 to b0     | INT_MASK    | Interrupt Mask              | R/W |
|              |             | 0: Masked                   |     |
|              |             | 1: Unmasked                 |     |

# 11.5.26 MaskErr — Mask for IntErr Interrupt Register

The content of RawErr register is masked with the content of the MaskErr register.

The INT\_MASK[7:0] bits will be written only if the corresponding the INT\_MASK\_WE[7:0] bit is 1. This allows software to set a mask bit without performing a read-modified write operation.

Address: 4010 4330h (DMAC1) 4010 5330h (DMAC2)



Table 11.28 MaskErr Register Contents

| Bit Position | Bit Name    | Function                    | R/W |
|--------------|-------------|-----------------------------|-----|
| b63 to b16   | Reserved    |                             | R   |
| b15 to b8    | INT_MASK_WE | Interrupt Mask Write-Enable | W   |
|              |             | 0: Write disabled           |     |
|              |             | 1: Write enabled            |     |
| b7 to b0     | INT_MASK    | Interrupt Mask              | R/W |
|              |             | 0: Masked                   |     |
|              |             | 1: Unmasked                 |     |

# 11.5.27 ClearTfr — Clear for IntTfr Interrupt Register

Each bit in the RawTfr and StatusTfr registers is cleared on the same cycle by writing a 1 to the corresponding location in the ClearTfr register. This register has a bit allocated per channel.

This register is not readable.

**Address:** 4010 4338h (DMAC1) 4010 5338h (DMAC2)



Table 11.29 ClearTfr Register Contents

| Bit Position | Bit Name | Function           | R/W |
|--------------|----------|--------------------|-----|
| b63 to b8    | Reserved |                    | R   |
| b7 to b0     | CLEAR    | Interrupt clear.   | W   |
|              |          | 0: No effect       |     |
|              |          | 1: Clear interrupt |     |

# 11.5.28 ClearBlock — Clear for IntBlock Interrupt Register

Each bit in the RawBlock and StatusBlock registers is cleared on the same cycle by writing a 1 to the corresponding location in the ClearBlock register. This register has a bit allocated per channel.

This register is not readable.

**Address:** 4010 4340h (DMAC1) 4010 5340h (DMAC2)



Table 11.30 ClearBlock Register Contents

| Bit Position | Bit Name | Function           | R/W |
|--------------|----------|--------------------|-----|
| b63 to b8    | Reserved |                    | R   |
| b7 to b0     | CLEAR    | Interrupt clear.   | W   |
|              |          | 0: No effect       |     |
|              |          | 1: Clear interrupt |     |

# 11.5.29 ClearSrcTran — Clear for IntSrcTran Interrupt Register

Each bit in the RawSrcTran and StatusSrcTran registers is cleared on the same cycle by writing a 1 to the corresponding location in the ClearSrcTran register. This register has a bit allocated per channel.

This register is not readable.

Address: 4010 4348h (DMAC1) 4010 5348h (DMAC2)



Table 11.31 ClearSrcTran Register Contents

| Bit Position | Bit Name | Function           | R/W |
|--------------|----------|--------------------|-----|
| b63 to b8    | Reserved |                    | R   |
| b7 to b0     | CLEAR    | Interrupt clear.   | W   |
|              |          | 0: No effect       |     |
|              |          | 1: Clear interrupt |     |
|              |          |                    |     |

# 11.5.30 ClearDstTran — Clear for IntDstTran Interrupt Register

Each bit in the RawDstTran and StatusDstTran registers is cleared on the same cycle by writing a 1 to the corresponding location in the ClearDstTran register. This register has a bit allocated per channel.

This register is not readable

**Address:** 4010 4350h (DMAC1) 4010 5350h (DMAC2)



Table 11.32 ClearDstTran Register Contents

| Bit Position | Bit Name | Function           | R/W |
|--------------|----------|--------------------|-----|
| b63 to b8    | Reserved |                    | R   |
| b7 to b0     | CLEAR    | Interrupt clear.   | W   |
|              |          | 0: No effect       |     |
|              |          | 1: Clear interrupt |     |

# 11.5.31 ClearErr — Clear for IntErr Interrupt Register

Each bit in the RawErr and StatusErr registers is cleared on the same cycle by writing a 1 to the corresponding location in the ClearErr register. This register has a bit allocated per channel.

This register is not readable.

**Address:** 4010 4358h (DMAC1) 4010 5358h (DMAC2)



Table 11.33 ClearErr Register Contents

| Bit Name | Function           | R/W                                            |
|----------|--------------------|------------------------------------------------|
| Reserved |                    | R                                              |
| CLEAR    | Interrupt clear.   | W                                              |
|          | 0: No effect       |                                                |
|          | 1: Clear interrupt |                                                |
|          | Reserved           | Reserved  CLEAR Interrupt clear.  0: No effect |

# 11.5.32 StatusInt — Combined Interrupt Status Register

Status for each Interrupt type. The contents of each of the five Status registers — StatusTfr, StatusBlock, StatusSrcTran, StatusDstTran, StatusErr — is ORed to produce a single bit for each interrupt type in the Combined Interrupt Status register (StatusInt).

This register is read-only.

**Address:** 4010 4360h (DMAC1) 4010 5360h (DMAC2)



Table 11.34 StatusInt Register Contents

| Bit Position | Bit Name | Function                                     | R/W |
|--------------|----------|----------------------------------------------|-----|
| b63 to b5    | Reserved |                                              | R   |
| b4           | ERR      | OR of the contents of StatusErr register     | R   |
| b3           | DSTT     | OR of the contents of StatusDstTran register | R   |
| b2           | SRCT     | OR of the contents of StatusSrcTran register | R   |
| b1           | BLOCK    | OR of the contents of StatusBlock register   | R   |
| b0           | TFR      | OR of the contents of StatusTfr register     | R   |

# 11.5.33 ReqSrcReg — Source Software Transaction Request Register

A bit is assigned for each channel in this register. ReqSrcReg[n] is ignored when software request interface is not enabled for the source of channel n. The SRC\_REQ[7:0] bits will be written only if the corresponding the SRC\_REQ\_WE[7:0] bit is 1, and if the channel is enabled in the ChEnReg register. This allows software to set a bit in the ReqSrcReg register without performing a read-modified write operation.

**Address:** 4010 4368h (DMAC1) 4010 5368h (DMAC2)



Table 11.35 ReqSrcReg Register Contents

| Bit Position | Bit Name   | Function                                                     | R/W |
|--------------|------------|--------------------------------------------------------------|-----|
| b63 to b16   | Reserved   |                                                              | R   |
| b15 to b8    | SRC_REQ_WE | Source request Write-Enable                                  | W   |
|              |            | 0: Write disabled                                            |     |
|              |            | 1: Write enabled                                             |     |
| b7 to b0     | SRC_REQ    | Source request                                               | R/W |
|              |            | This bit is cleared after the transaction request completed. |     |
|              |            | <ul> <li>When the DMAC is a flow controller</li> </ul>       |     |
|              |            | Set single or burst setting before software request.         |     |
|              |            | 0: Single transaction                                        |     |
|              |            | 1: Burst transaction                                         |     |

# 11.5.34 ReqDstReg — Destination Software Transaction Request Register

A bit is assigned for each channel in this register. ReqDstReg[n] is ignored when software request interface is not enabled for the source of channel n. The DST\_REQ[7:0] bits will be written only if the corresponding the DST\_REQ\_WE[7:0] bit is 1, and if the channel is enabled in the ChEnReg register.

**Address:** 4010 4370h (DMAC1) 4010 5370h (DMAC2)



Table 11.36 ReqDstReg Register Contents

| Bit Position | Bit Name   | Function                                                     | R/W |
|--------------|------------|--------------------------------------------------------------|-----|
| b63 to b16   | Reserved   |                                                              | R   |
| b15 to b8    | DST_REQ_WE | Destination request Write-Enable                             | W   |
|              |            | 0: Write disabled                                            |     |
|              |            | 1: Write enabled                                             |     |
| b7 to b0     | DST_REQ    | Destination request                                          | R/W |
|              |            | This bit is cleared after the transaction request completed. |     |
|              |            | <ul> <li>When the DMAC is a flow controller</li> </ul>       |     |
|              |            | Set single or burst setting before software request.         |     |
|              |            | 0: Single transaction                                        |     |
|              |            | 1: Burst transaction                                         |     |

# 11.5.35 SglRqSrcReg — Single Source Transaction Request Register

A bit is assigned for each channel in this register. SglRqSrcReg[n] is ignored when software request interface is not enabled for the source of channel n. The SRC\_SGLREQ[7:0] bits will be written only if the corresponding the SRC\_SGLREQ\_WE[7:0] bit is 1, and if the channel is enabled in the ChEnReg register.

Address: 4010 4378h (DMAC1) 4010 5378h (DMAC2)



Table 11.37 SglRqSrcReg Register Contents

| Bit Position | Bit Name      | Function                                                                                                                                                                                                                                                                                                              | R/W |
|--------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b63 to b16   | Reserved      |                                                                                                                                                                                                                                                                                                                       | R   |
| b15 to b8    | SRC_SGLREQ_WE | Source single or burst request Write-Enable 0: Write disabled 1: Write enabled                                                                                                                                                                                                                                        | W   |
| b7 to b0     | SRC_SGLREQ    | Source single or burst request  • When the DMAC is a flow controller  Transaction request  0: Transaction is not requested  1: Transaction is requested  This bit is cleared after the transaction request completed.  Set transaction setting (single or burst) to the Source Software Transaction Request Register. | R/W |

Address:

4010 4380h (DMAC1)

DST\_SGLREQ\_WE

0

0

0

0

DST SGLREQ

0

0

0

0

0

# 11.5.36 SglRqDstReg — Single Destination Transaction Request Register

A bit is assigned for each channel in this register. SglRqDstReg[n] is ignored when software request interface is not enabled for the destination of channel n. The DST\_SGLREQ[7:0] bits will be written only if the corresponding the DST\_SGLREQ\_WE[7:0] bit is 1, and if the channel is enabled in the ChEnReg register.

4010 5380h (DMAC2) b60 b55 b52 Bit b63 b62 b61 b59 b58 b57 b56 b54 b53 b51 b50 b49 b48 Х Χ Χ Х Χ Х Χ Х Χ Χ Χ Χ Х Value after reset Bit b47 b46 b45 b44 b43 b42 b41 b40 b39 b38 b37 b36 b35 b34 b33 b32 Χ Χ Χ Х Χ Χ Х Χ Χ Value after reset Bit b30 b29 b26 b25 b24 b16 Value after reset Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Χ Bit b15 b14 b13 b12 b11 b10 b9 b7 b6 b3 b0

Table 11.38 SglRqDstReg Register Contents

0

Value after reset

0

| Bit Position | Bit Name      | Function                                                                                                                                                                                                                                                                                                                      | R/W |
|--------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b63 to b16   | Reserved      |                                                                                                                                                                                                                                                                                                                               | R   |
| b15 to b8    | DST_SGLREQ_WE | Destination single or burst request Write-Enable 0: Write disabled 1: Write enabled                                                                                                                                                                                                                                           | W   |
| b7 to b0     | DST_SGLREQ    | Destination single or burst request  When the DMAC is a flow controller  Transaction request  O: Transaction is not requested  1: Transaction is requested  This bit is cleared after the transaction request completed.  Set transaction setting (single or burst) to the Destination Software Transaction Request Register. | R/W |

0

0

0

0

# 11.5.37 LstSrcReg — Last Source Transaction Request Register

A bit is assigned for each channel in this register. LstSrcReg[n] is ignored when software request interface is not enabled for the source of channel n, or when the source of channel n is not a flow controller. The LSTSRC[7:0] bits will be written only if the corresponding the LSTSRC\_WE[7:0] bit is 1, and if the channel is enabled in the ChEnReg register.

**Address:** 4010 4388h (DMAC1) 4010 5388h (DMAC2)



Table 11.39 LstSrcReg Register Contents

| Bit Position | Bit Name  | Function                                                                                                        | R/W |
|--------------|-----------|-----------------------------------------------------------------------------------------------------------------|-----|
| b63 to b16   | Reserved  |                                                                                                                 | R   |
| b15 to b8    | LSTSRC_WE | TSRC_WE Source last transaction request Write-Enable  0: Write disabled  1: Write enabled                       |     |
| b7 to b0     | LSTSRC    | Source last transaction request  0: Not last transaction in current block  1: Last transaction in current block | R/W |

# 11.5.38 LstDstReg — Last Destination Transaction Request Register

A bit is assigned for each channel in this register. LstDstReg[n] is ignored when software request interface is not enabled for the destination of channel n or when the destination of channel n is not a flow controller. The LSTDST[7:0] bits will be written only if the corresponding the LSTDST\_WE[7:0] bit is 1, and if the channel is enabled in the ChEnReg register.

**Address:** 4010 4390h (DMAC1) 4010 5390h (DMAC2)



Table 11.40 LstDstReg Register Contents

| Bit Position | Bit Name                                                                                         | Function                                                                                                             | R/W |
|--------------|--------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|-----|
| b63 to b16   | Reserved                                                                                         |                                                                                                                      | R   |
| b15 to b8    | LSTDST_WE Destination last transaction request Write-Enable  0: Write disabled  1: Write enabled |                                                                                                                      | W   |
| b7 to b0     | LSTDST                                                                                           | Destination last transaction request  0: Not last transaction in current block  1: Last transaction in current block | R/W |

# 11.5.39 DmaCfgReg — DMA Configuration Register

This register is used to enable the DMAC, which must be done before any channel activity can begin. If this bit is cleared while any channel is still active, then DmaCfgReg.DMA\_EN still returns 1 to indicate that there are channels still active until hardware has terminated all activity on all channels, at which point the DmaCfgReg.DMA\_EN bit returns 0.

Address: 4010 4398h (DMAC1) 4010 5398h (DMAC2)



Table 11.41 DmaCfgReg Register Contents

| Bit Position | Bit Name | Function         | R/W |
|--------------|----------|------------------|-----|
| b63 to b1    | Reserved |                  | R   |
| b0           | DMA_EN   | DMAC Enable bit. | R/W |
|              |          | 0: DMAC Disabled |     |
|              |          | 1: DMAC Enabled. |     |

# 11.5.40 ChEnReg — DMA Controller Channel Enable Register

This is the DMAC Channel Enable Register. If software needs to set up a new channel, then it can read this register in order to find out which channels are currently inactive; it can then enable an inactive channel with the required priority. The CH\_EN[7:0] bits will be written only if the corresponding the CH\_EN\_WE[7:0] is 1. A channel CH\_EN bit is cleared to 0 when the DmaCfgReg.DMA\_EN is 0. When the DmaCfgReg.DMA\_EN is 0, then a write to the ChEnReg register is ignored and a read will always read back 0.

**Address:** 4010 43A0h (DMAC1) 4010 53A0h (DMAC2)



Table 11.42 ChEnReg Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                                                                                                                                                                                                                                                                             | R/W |
|--------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b63 to b16   | Reserved |                                                                                                                                                                                                                                                                                                                                                                                                                      | R   |
| b15 to b8    | CH_EN_WE | Channel enable Write-Enable 0: Write disabled 1: Write enabled                                                                                                                                                                                                                                                                                                                                                       | W   |
| b7 to b0     | CH_EN    | Enables/Disables the channel. Setting this bit enables a channel; clearing this bit disables the channel.  0: Disable the Channel  1: Enable the Channel  This bit is automatically cleared by hardware to disable the channel after the last AHB transfer of the DMA transfer to the destination has completed. Software can therefore poll this bit to determine when this channel is free for a new DMA transfer. | R/W |

# 11.5.41 DmaldReg — DMA ID Register

A 32-bit value that is hardwired and read back by a read to the DMAC ID Register.

**Address:** 4010 43A8h (DMAC1) 4010 53A8h (DMAC2)



Table 11.43 DmaldReg Register Contents

| Bit Position | Bit Name | Function                | R/W |
|--------------|----------|-------------------------|-----|
| b63 to b32   | Reserved |                         | R   |
| b31 to b0    | DMA_ID   | DMA ID register         | R   |
|              |          | $DMAC1 \rightarrow 0x1$ |     |
|              |          | $DMAC2 \to 0x2$         |     |

# 11.5.42 DmaTestReg — DMA Controller Test Register

This register is used to put the AHB slave interface into test mode, during which the readback value of the writable registers match the value written, assuming the DMA configuration has not optimized the same registers.

**Address:** 4010 43B0h (DMAC1) 4010 53B0h (DMAC2)



Table 11.44 DmaTestReg Register Contents

| Bit Position | Bit Name    | Function                                                                                                                                                                                                                       | R/W |
|--------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b63 to b1    | Reserved    |                                                                                                                                                                                                                                | R   |
| b0           | TEST_SLV_IF | Puts the AHB slave interface into test mode. In this mode, the readback value of the writable registers always matches the value written. This bit does not allow writing to read-only registers.  0: Normal mode 1: Test mode | R/W |

# 11.6 Operation

#### 11.6.1 DMA Transfer Mode

This chapter describes the functional details of DMA coupling between DMAC and peripherals:

The following peripheral modules are available as request interface (DMA request). A DMA transfer transaction is performed once by the source or destination request interface. Since "memory" does not require the request interface, enabling the channel will process the DMA transfer immediately.

- UARTs
- SPIs
- MSEBI Master
- Timer block
- ADC
- ETHERCAT
- SERCOSIII
- GMAC1

The main DMA features used are:

- DMAC or Peripheral flow controller
- Peripheral to Memory and Memory to Peripheral
- Single and burst transaction management
- Handshaking by DMAC signals (Peripheral or DMAC flow controller mode)

#### CAUTION

If the channel is disabled by software during the DMA transfer process, the data is not guaranteed. And, if a transfer is processing, it will not be disabled immediately, so check with the ChEnReg.CH\_EN bit.

#### 11.6.1.1 Flow Controller and Transfer Type

The device that controls the block transfer size is known as the flow controller. Either the DMAC, the source peripheral, or the destination peripheral must be assigned as the flow controller.

• If the peripheral (source of the request interface) cannot control the block transfer size, then the DMAC should be programmed as the flow controller. The block size should be programmed into the DMAC:CTL[n].BLOCK\_TS field.

This mode is used by following peripherals:

- Timer blocks
- ADC
- ETHERCAT
- SERCOSIII
- GMAC1
- If the peripheral (source of the request interface) can control the block transfer size, either the source or destination peripheral must be the flow controller. The block size should be programmed into following fields:

UART:DEST\_BLOCK\_SIZE/UART:SRC\_BLOCK\_SIZE SPI:DEST\_BLOCK\_SIZE/SPI:SRC\_BLOCK\_SIZE MSEBI:DEST\_BLOCK\_SIZE/MSEBI:SRC\_BLOCK\_SIZE

This mode is used by following peripherals:

- UARTs
- SPIs
- MSEBI Master

The DMAC:CTL[n].TT\_FC field indicates the transfer type and flow controller for that channel. The table below lists valid transfer types and flow controller combinations.

Table 11.45 DMA Transfer Type and Flow Control Combinations

| Transfer Type (TT_FC) Flow Controller |            | Peripheral hardware request interface                            |
|---------------------------------------|------------|------------------------------------------------------------------|
| Memory to Memory                      | DMAC       | None                                                             |
| Memory to Peripheral                  | DMAC       | Destination DMA request (TIMER, ADC, ETHERCAT, SERCOSIII, GMAC1) |
| Peripheral to Memory                  | DMAC       | Source DMA request (TIMER, ADC, ETHERCAT, SERCOSIII, GMAC1)      |
| Memory to Peripheral                  | Peripheral | Destination DMA request (UART, SPI, MSEBI)                       |
| Peripheral to Memory Peripheral       |            | Source DMA request (UART, SPI, MSEBI)                            |

When using the request interface (DMA request), specify "Peripheral" as the transfer type. When you do not use the request interface, specify "Memory" as the transfer type.

#### **CAUTION**

Please refer to Bus Connection Map in Section 2, Network-On-Chip for DMAC configurable transfers.

#### 11.6.1.2 Block Chaining Using Linked Lists

The DMA transfer can be executed by the DMAC register setting or linked lists.

The DMA transfer by linked lists reprograms the channel registers prior to the start of each block by fetching the block descriptor for that block from system memory. This is known as an LLI update.

DMAC block chaining uses a Linked List Pointer register (LLP[n]) that stores the address in memory of the next linked list item. Each LLI contains the corresponding block descriptors:

- 1. **SAR**[n]
- 2. DAR[n]
- 3. LLP[n]
- 4. CTL[n]
- 5. SSTAT[n]
- 6. DSTAT[n]

To set up block chaining, you program a sequence of Linked Lists in memory.

LLI accesses are always 32-bit accesses aligned to 32-bit boundaries.

The SAR[n], DAR[n], LLP[n], and CTL[n] registers are fetched from system memory on an LLI update. The updated contents of the CTL[n], SSTAT[n], and DSTAT[n] registers are written back to memory on block completion. Following Figure shows how you use chained linked lists in memory to define multi-block transfers using block chaining.



Figure 11.2 Multi-Block Transfer Using Linked Lists

#### NOTE

In this chapter, the SAR[n], DAR[n], LLP[n], CTL[n], SSTAT[n], and DSTAT[n] uses the following notation to distinguish those from the corresponding DMAC registers.

LLI.SAR[n], LLI.DAR[n], LLI.LLP[n], LLI.CTL[n], LLI.SSTAT[n], and LLI.DSTAT[n].

Table 11.46 Programming of Transfer Method and Channel Register Update Method

|     | Transfer Method                                             | LLP.LOC<br>= 0 | LLP_SRC<br>_EN<br>(CTL[n]) | RELOAD<br>_SRC<br>(CFG[n]) | LLP_DST<br>_EN<br>(CTL[n]) | RELOAD<br>_DST<br>(CFG[n]) | CTL[n], LLP[n] Update Method                            | SAR[n]<br>Update<br>Method | DAR[n]<br>Update<br>Method | Write<br>Back |
|-----|-------------------------------------------------------------|----------------|----------------------------|----------------------------|----------------------------|----------------------------|---------------------------------------------------------|----------------------------|----------------------------|---------------|
| 1.  | Single-block or last transfer of multi-block.               | Yes            | 0                          | 0                          | 0                          | 0                          | None, user reprograms                                   | None<br>(single)           | None<br>(single)           | No            |
| 2.  | Auto-reload multi-block<br>transfer with contiguous<br>SAR  | Yes            | 0                          | 0                          | 0                          | 1                          | CTL[n], LLP[n] are reloaded from initial values.        | Contiguous                 | Auto-Reload                | No            |
| 3.  | Auto-reload multi-block transfer with contiguous DAR.       | Yes            | 0                          | 1                          | 0                          | 0                          | CTL[n], LLP[n] are reloaded from initial values         | Auto-Reload                | Contiguous                 | No            |
| 4.  | Auto-reload multi-block transfer                            | Yes            | 0                          | 1                          | 0                          | 1                          | CTL[n], LLP[n] are reloaded from initial values         | Auto-Reload                | Auto-Reload                | No            |
| 5.  | Single-block or last transfer of multi-block.               | No             | 0                          | 0                          | 0                          | 0                          | None, user reprograms                                   | None<br>(single)           | None<br>(single)           | Yes           |
| 6.  | Linked list multi-block<br>transfer with contiguous<br>SAR  | No             | 0                          | 0                          | 1                          | 0                          | CTL[n], LLP[n]<br>loaded from next<br>Linked List item. | Contiguous                 | Linked List                | Yes           |
| 7.  | Linked list multi-block<br>transfer with auto-reload<br>SAR | No             | 0                          | 1                          | 1                          | 0                          | CTL[n], LLP[n]<br>loaded from next<br>Linked List item. | Auto-Reload                | Linked List                | Yes           |
| 8.  | Linked list multi-block<br>transfer with contiguous<br>DAR  | No             | 1                          | 0                          | 0                          | 0                          | CTL[n], LLP[n]<br>loaded from next<br>Linked List item. | Linked List                | Contiguous                 | Yes           |
| 9.  | Linked list multi-block<br>transfer with auto-reload<br>DAR | No             | 1                          | 0                          | 0                          | 1                          | CTL[n], LLP[n]<br>loaded from next<br>Linked List item. | Linked List                | Auto-Reload                | Yes           |
| 10. | Linked list multi-block transfer                            | No             | 1                          | 0                          | 1                          | 0                          | CTL[n], LLP[n]<br>loaded from next<br>Linked List item. | Linked List                | Linked List                | Yes           |

Transfer Method 6 to 10 of above table shows the required values of LLP[n], CTL[n], and CFG[n] for multi-block DMA transfers using block chaining.

#### NOTE

For Transfer Method 6 to 10, the LLI.CTL[n], LLI.LLP[n], LLI.SAR[n], and LLI.DAR[n] register locations of the LLI are always affected at the start of every block transfer. The LLI.LLP[n] and LLI.CTL[n] locations are always used to reprogram the DMAC LLP[n] and CTL[n] registers. However, the LLI.SAR[n]/LLI.DAR[n] is used to update the DMAC SAR[n]/DAR[n] only when using a linked list.



Figure 11.3 Mapping of Block Descriptor (LLI) in Memory to Channel Registers

#### (1) Auto-Reloading of Channel Registers

During auto-reloading, the channel registers are reloaded with their initial values at the completion of each block and the new values used for the new block. Depending on Transfer Method, some or all of the SAR[n], DAR[n], and CTL[n] channel registers are reloaded from their initial value at the start of a block transfer.

#### (2) Contiguous Address Between Blocks

In this case, the address between successive blocks is selected as a continuation from the end of the previous block.

Without automatic reloading and updating from the linked list, successive source or destination addresses will be set according to CTL [n].SINC/CTL [n].DINC.

For source address: CTL[n].LLP\_SRC\_EN = 0 and CFG[n].RELOAD\_SRC = 0

For destination address: CTL[n].LLP\_DST\_EN = 0 and CFG[n].RELOAD\_DST = 0

# (3) Suspension of Transfers Between Blocks

For Transfer Method 6, 8 and 10 of **Table 11.46**, the DMA transfer does not stall between block transfers. For example, at the end-of-block N, the DMAC automatically proceeds to block N + 1.

For Transfer Method 2, 3, 4, 7 and 9 of **Table 11.46** (SAR[n] and/or DAR[n] auto-reloaded between block transfers), the DMA transfer automatically stalls after the end-of-block interrupt is asserted.

At the end of every block transfer, an end-of-block interrupt is asserted if:

- 1. Interrupts are enabled,  $CTL[n].INT\_EN = 1$ .
- 2. The channel block interrupt is unmasked,  $MaskBlock.INT\_MASK[n] = 1$ .

The DMAC does not proceed to the next block transfer until a write to the ClearBlock[n] register, done by software to clear the channel block-complete interrupt, is detected by hardware.

#### (4) Ending Multi-Block Transfers

All multi-block transfers must end as shown in either Transfer Method 1 or 5 of **Table 11.46**. At the end of every block transfer, the DMAC samples the Transfer Method, and if the DMAC is in the Transfer Method 1 or 5 state, then the previous block transferred was the last block and the DMA transfer is terminated.

When to use automatic reload with Transfer Method 2, 3 and 4 of **Table 11.46** (LLP[n].LOC = 0 and CFG[n].RELOAD\_SRC and/or CFG[n].RELOAD\_DST is set), automatic reload must be disabled before the last block transfer. When the end-of-block interrupt of the previous block of the last block is generated, CFG [n].RELOAD\_SRC and CFG [n].RELOAD\_DST should be programmed to 0 to hold the block transfer. This puts the DMAC into the Transfer Method 1 state.

For Transfer Method 6, 8 and 10 of **Table 11.46** (both CFG[n].RELOAD\_SRC and CFG[n].RELOAD\_DST cleared), the user must set up the last block descriptor in memory so that both LLI.CTL[n].LLP\_SRC\_EN and LLI.CTL[n].LLP\_DST\_EN are 0.

The sampling of the LLP[n].LOC takes place exclusively at the beginning of the transfer when the channel is enabled. This determines whether writeback is enabled throughout the complete transfer, and changing the value in subsequent blocks does not have any effect.

#### 11.6.1.3 Basic Interface Definitions

The following equations below, refer to the decoded values of the parameters.

For example:

CTL[n].SRC\_MSIZE: Burst Transaction Length 1–256 CTL[n].SRC\_TR\_WIDTH: Transfer Width 8/16/32/64 bits

 PERIPHERAL:SRC\_BURST\_SIZE, refers PERIPHERAL register SRC\_BURST\_SIZE (Initialization required only for peripheral flow controller like UART, SPI, MSEBI)

The following definitions are used in this chapter:

• Source single transaction size in bytes

```
(1) src_single_size_bytes = DMAC:CTL[n].SRC_TR_WIDTH/8
```

• Source burst transaction size in bytes

```
(2) src_burst_size_bytes = DMAC:CTL[n].SRC_MSIZE × src_single_size_bytes = PERIPHERAL:SRC_BURST_SIZE × src_single_size_bytes
```

• Destination single transaction size in bytes

```
(3) dst_single_size_bytes = DMAC:CTL[n].DST_TR_WIDTH/8
```

• Destination burst transaction size in bytes

```
(4) dst_burst_size_bytes = DMAC:CTL[n].DEST_MSIZE × dst_single_size_bytes = PERIPHERAL:DEST_BURST_SIZE × dst_single_size_bytes
```

• Burst size in bytes:

With the DMAC as the flow controller

 The length of a DMA burst transaction is programmed into the DMAC:CTL[n].SRC\_MSIZE/DMAC:CTL[n].DEST\_MSIZE.

With the Peripheral as the flow controller

- The length of a DMA burst transaction is programmed into the DMAC:CTL[n].SRC\_MSIZE/DMAC:CTL[n].DEST\_MSIZE.
- The length of a Peripheral burst transaction is programmed into the
   PERIPHERAL:DEST\_BURST\_SIZE/PERIPHERAL:SRC\_BURST\_SIZE field of each peripheral used.
- The peripheral registers are
   UART:DEST\_BURST\_SIZE/UART:SRC\_BURST\_SIZE,
   SPI:DEST\_BURST\_SIZE/SPI:SRC\_BURST\_SIZE,
   MSEBI:DEST\_BURST\_SIZE/MSEBI:SRC\_BURST\_SIZE.

#### • Block size in bytes:

With the DMAC as the flow controller:

 The processor programs the DMAC with the number of data items (block size) of source transfer width (DMAC:CTL[n].SRC\_TR\_WIDTH) to be transferred by the DMAC in a block transfer, this is programmed into the DMAC:CTL[n].BLOCK\_TS field.

Therefore, the total number of bytes to be transferred in a block is:

```
(5a) blk_size_bytes_dma = DMAC:CTL[n].BLOCK_TS × src_single_size_bytes
```

With the Peripheral as the flow controller:

 The block size registers of the peripheral are UART:DEST\_BLOCK\_SIZE/UART:SRC\_BLOCK\_SIZE, SPI:DEST\_BLOCK\_SIZE/SPI:SRC\_BLOCK\_SIZE, MSEBI:DEST\_BLOCK\_SIZE/MSEBI:SRC\_BLOCK\_SIZE.

Therefore, the total number of bytes to be transferred in a block is:

When source peripheral is the flow controller:

```
(5b) blk_size_bytes_dma = PERIPHERAL:SRC_BLOCK_SIZE × src_single_size_bytes
```

When destination peripheral is the flow controller:

```
(5b) blk_size_bytes_dma = PERIPHERAL:DEST_BLOCK_SIZE × dst_single_size_bytes
```

- Block of DMA data.
  - The amount of which is the block transfer size and is determined by the flow controller. For transfers between the
     DMAC and memory or peripheral, a block is broken directly into a sequence of bursts and single transactions.
- Transaction

Length of a transaction is programmed into the DMAC:CTL[n].SRC\_MSIZE/DMAC:CTL[n].DEST\_MSIZE and also in the PERIPHERAL:DEST\_BURST\_SIZE/PERIPHERAL:SRC\_BURST\_SIZE (Peripheral flow controller only). The burst transaction is converted into a sequence of bursts and single AHB transfers.

DMAC executes each burst transfer no longer than the maximum burst size set (SRC\_MSIZE/DEST\_MSIZE and MAX\_ABRST). The burst transaction length is under program control. Normally, set an appropriate value according to the DMAC FIFO size and the FIFO watermark level of the peripheral to be transferred.

#### **CAUTION**

For peripheral flow controller, the burst size transaction must have the same values on DMAC and Peripherals (UART, SPI or MSEBI only).

### 11.6.1.4 Transaction Examples

#### (1) DMA in Burst Transaction Mode Only

The device that controls the block transfer size is known as the flow controller.

- If the flow controller is DMAC, the block transfer size should be programmed into the DMAC:CTL[n].BLOCK\_TS field. If the flow controller is peripheral, it should be programmed into the PERIPHERAL:SRC\_BLOCK\_SIZE/PERIPHERAL:DST\_BLOCK\_SIZE.
- The DMAC:CTL[n].TT\_FC field indicates the transfer type and flow controller for that channel. **Table 11.45** lists valid transfer types and flow controller combinations.

As an example, when the DMAC is the flow controller, the DMAC tries to transfer the data using burst transactions and, when possible, fill or empty the channel FIFO in single bursts, as shown below.

A total of 48 bytes are transferred in the block; that is, blk\_size\_bytes\_dma = 48. As shown below, this block transfer consists of three bursts of length 4 from the source, interleaved with three bursts, again of length 4, to the destination.



Figure 11.4 Burst DMA Transaction

#### (2) DMA in Burst and Single Transaction Mode at the Same Time

There are cases where a DMA block transfer cannot be completed using only burst transactions. Typically this occurs when the block size is not a multiple of the burst transaction length.

In these cases, the transfer uses burst transactions up to the point where the amount of data left to complete the block is less than the amount of data in a burst transaction. At this point, the Peripheral (UART, SPI or MSEBI) controls DMA and completes the block transfer using single transaction request.

The Peripheral asserts the single transaction request to indicate to the DMAC that there is enough data or space to complete a single transaction from or to the source/destination peripheral.

The Single Transaction Region is the time interval where the Peripheral (UART, SPI or MSEBI) uses single transactions to complete the block transfer, burst transactions are exclusively used outside this region.

The precise definition of when this region is entered:

- The source peripheral enters the Single Transaction Region when the number of bytes left to complete in the source block transfer is less than src\_burst\_size\_bytes.
  - If blk\_size\_bytes\_dma/src\_burst\_size\_bytes = integer
     then the source never enters this region, and the source block uses only burst transactions.
- The destination peripheral enters the Single Transaction Region when the number of bytes left to complete in the destination block transfer is less than dst\_burst\_size\_bytes.
  - If blk\_size\_bytes\_dma/dst\_burst\_size\_bytes = integer
     then the destination never enters this region, and the destination block uses only burst transactions.

The example below demonstrates how a block from the source can be completed using a series of single transactions. It also demonstrates how the watermark level that triggers a burst request in the source peripheral.

Consider the case where the watermark level that triggers a source burst request in the source peripheral is equal to DMAC:CTL[n].SRC\_MSIZE = PERIPHERAL:SRC\_BURST\_SIZE = 8, that is, eight entries or more need to be in the source peripheral FIFO in order to trigger a burst request. The figure shows how this block transfer is broken into burst and single transactions.

When the amount of data left to transfer to complete the source block is less than src\_burst\_size\_bytes, the source Peripheral (UART, SPI, MSEBI), knowing the block transfer size, requests single transactions regardless the watermark level. This region, where the amount of data left to transfer in the source block is less than src\_burst\_size\_bytes, is known as the Single Transaction Region.

In the Single Transaction Region, the source Peripheral requests single transaction to the DMAC until the source block transfer has completed.

In this example, the source Peripheral completes the source block transfer using four single transactions to the DMAC.





Figure 11.5 Burst and Single DMA Transaction

# 11.6.1.5 DMAC Programing Example

The flow diagram shows an overview of DMA programming example.



Figure 11.6 Flowchart for DMA Programming Example

# 11.6.2 DMA Request Allocation

Each DMAC1 and DMAC2 provides 16 peripheral hardware request interface. There are 64 DMA request in the system. To connect total 32 hardware request interface to 64 DMA request, the additional multiplexers exist. It is managed by dedicated CFG\_DMAMUX registers in System Controller. The table below describes the details.

Table 11.47 DMA Multiplexing Channel Request Signals

| Hardware Request Interface | Peripheral DMA Request                                                       |                               |  |  |
|----------------------------|------------------------------------------------------------------------------|-------------------------------|--|--|
| DMAC1                      | CFG_DMAMUX[15:0] in System Controller, dedicated multiplexing bit to manage  |                               |  |  |
| Register bit:              | 1'b1:                                                                        | 1'b0:                         |  |  |
| Request interface0         | UART4 RX                                                                     | CAT_SYNC0 or SERCOS3_Int[0]*1 |  |  |
| Request interface1         | UART4 TX                                                                     | CAT_SYNC1 or SERCOS3_Int[1]*1 |  |  |
| Request interface2         | UART5 RX                                                                     | MAC_PPS[0]*1                  |  |  |
| Request interface3         | UART5 TX                                                                     | MAC_PPS[1]*1                  |  |  |
| Request interface4         | UART6 RX                                                                     | MAC_TRIG[1]*1                 |  |  |
| Request interface5         | UART6 TX                                                                     | S3_CONCLK*1                   |  |  |
| Request interface6         | UART7 RX                                                                     | S3_DIVCLK*1                   |  |  |
| Request interface7         | UART7 TX                                                                     | TIMER1_SubTimer6              |  |  |
| Request interface8         | SPI1 RX                                                                      | CAT_SYNC0 or SERCOS3_Int[0]*1 |  |  |
| Request interface9         | SPI1 TX                                                                      | CAT_SYNC1 or SERCOS3_Int[1]*1 |  |  |
| Request interface10        | SPI2 RX                                                                      | MAC_PPS[0]*1                  |  |  |
| Request interface11        | SPI2 TX                                                                      | MAC_PPS[1]*1                  |  |  |
| Request interface12        | SPI3 RX                                                                      | MAC_TRIG[1]*1                 |  |  |
| Request interface13        | SPI3 TX                                                                      | S3_CONCLK*1                   |  |  |
| Request interface14        | SPI4 RX                                                                      | S3_DIVCLK*1                   |  |  |
| Request interface15        | SPI4 TX                                                                      | TIMER1_SubTimer7              |  |  |
| DMAC2                      | CFG_DMAMUX[31:16] in System Controller, dedicated multiplexing bit to manage |                               |  |  |
| Register bit:              | 1'b1:                                                                        | 1'b0:                         |  |  |
| Request interface0         | SPI5 RX                                                                      | CAT_SYNC0 or SERCOS3_Int[0]*1 |  |  |
| Request interface1         | SPI5 TX                                                                      | CAT_SYNC1 or SERCOS3_Int[1]*1 |  |  |
| Request interface2         | SPI6 RX                                                                      | MAC_PPS[0]*1                  |  |  |
| Request interface3         | SPI6 TX                                                                      | MAC_PPS[1]*1                  |  |  |
| Request interface4         | UART8 RX                                                                     | MAC_TRIG[1]*1                 |  |  |
| Request interface5         | UART8 TX                                                                     | S3_CONCLK*1                   |  |  |
| Request interface6         | Not used                                                                     | S3_DIVCLK*1                   |  |  |
| Request interface7         | Not used                                                                     | TIMER2_SubTimer6              |  |  |
| Request interface8         | Not used                                                                     | CAT_SYNC0 or SERCOS3_Int[0]*1 |  |  |
| Request interface9         | Not used                                                                     | CAT_SYNC1 or SERCOS3_Int[1]*1 |  |  |
| Request interface10        | MSEBIM0 (RX on CS0_N)                                                        | MAC_PPS[0]*1                  |  |  |
| Request interface11        | MSEBIM1 (TX on CS0_N)                                                        | MAC_PPS[1]*1                  |  |  |
| Request interface12        | MSEBIM2 (RX on CS1_N)                                                        | MAC_TRIG[1]*1                 |  |  |
| Request interface13        | MSEBIM3 (TX on CS1_N)                                                        | S3_CONCLK*1                   |  |  |
| Request interface14        | ADC ch0                                                                      | S3_DIVCLK*1                   |  |  |
| Request interface15        | ADC ch1                                                                      | TIMER2_SubTimer7              |  |  |

Note 1. CAT\_SYNC0 or SERCOS3\_Int[0] is selected by DMACTRL in Ethernet Accessory registers.

CAT\_SYNC1 or SERCOS3\_Int[1] is selected by DMACTRL in Ethernet Accessory registers.

7 DMA requests from Ethernet Peripherals are assigned to the request interface 4 times, only one request should be used at the same time.

# 11.6.3 Illegal Register Access

An illegal access can be any of the following:

- A write to the SAR[n], DAR[n], LLP[n], CTL[n], SSTAT[n], DSTAT[n], SSTATAR[n], DSTATAR[n], SGR[n] or DSR[n] registers occur when the channel is enabled.
- A read from the ClearBlock, ClearDstTran, ClearErr, ClearSrcTran, ClearTfr is attempted.
- A write to the StatusBlock, StatusDstTran, StatusErr, StatusSrcTran, StatusTfr is attempted.
- A write to the StatusInt register is attempted.
- A write to the DmaIdReg register is attempted.

An illegal access (read/write) returns an error response on AHB bus.

# Section 12 RTC

# 12.1 Overview

The RTC keeps track of the real time of day. It also functions as an alarm and a calendar. The time is displayed in 24-hour format, and time/calendar values are stored in binary-coded decimal format.



Figure 12.1 RTC Interfaces and Connections

- Time-of-day clock in 24-hour mode
- Calendar
- Alarm capability
- Interrupt capability
  - 1second
  - Fixed interval
  - Alarm
- XTAL 32 kHz
- Separate and isolated power supply for backup mode
  - Self-isolation mode, which allows RTC to work even if power is not supplied to the rest of the device.
  - RTC is reset to the default value when it detects a backup voltage failure

# 12.2 Signal Interfaces

|                           | Input     |                                                             |
|---------------------------|-----------|-------------------------------------------------------------|
| Signal Name               | Output    | Description                                                 |
| RTC_PCLK                  | Input net | Clock for RTC APB interface and NoC interconnect            |
| Reset                     |           |                                                             |
| RSTN_FW_RTC Software rese |           | Software reset to the interconnect for RTC                  |
| RST_RTC                   | Input     | Active high reset to RTC module                             |
| Interrupt                 |           |                                                             |
| RTCATINTAL_Int Output     |           | Alarm interrupt, level sensitive, Active High <sup>⋆1</sup> |
| RTCATINTR_Int             | Output    | Fixed interval interrupt, level sensitive, Active High*1    |
| RTCATINT1S_Int            | Output    | 1second interrupt, level sensitive, Active High*1           |
| External Signal           |           |                                                             |
| RTC_PWRGOOD input         |           | RTC backup mode control (dedicated pin)                     |

Note: RTC\_PCLK, RSTN\_FW\_RTC and RST\_RTC are controlled by PWRCTRL\_RTC register of System Control.

Note 1. Interrupt output for one clock of 32k clock

# 12.3 Register Map

Table 12.1 Register Map of RTC

| Address    | Register Symbol | Register Name                       |
|------------|-----------------|-------------------------------------|
| 4000 6000h | RTCA0CTL0       | RTC Control Register 0              |
| 4000 6004h | RTCA0CTL1       | RTC Control Register 1              |
| 4000 6008h | RTCA0CTL2       | RTC Control Register 2              |
| 4000 600Ch | RTCA0SUBC       | RTC Sub Count Register              |
| 4000 6010h | RTCA0SRBU       | RTC Sub Count Register Read Buffer  |
| 4000 6014h | RTCA0SEC        | RTC Sec Count Buffer Register       |
| 4000 6018h | RTCA0MIN        | RTC Min Count Buffer Register       |
| 4000 601Ch | RTCA0HOUR       | RTC Hour Count Buffer Register      |
| 4000 6020h | RTCA0WEEK       | RTC Week Count Buffer Register      |
| 4000 6024h | RTCA0DAY        | RTC Day Count Buffer Register       |
| 4000 6028h | RTCA0MONTH      | RTC Month Count Buffer Register     |
| 4000 602Ch | RTCA0YEAR       | RTC Year Count Buffer Register      |
| 4000 6030h | RTCA0TIME       | RTC Time Set Register               |
| 4000 6034h | RTCA0CAL        | RTC Calendar Set Register           |
| 4000 6038h | RTCA0SUBU       | RTC Clock Error Correction Register |
| 4000 603Ch | RTCA0SCMP       | RTC Sub Count Compare Register      |
| 4000 6040h | RTCA0ALM        | RTC Alarm Min Set Register          |
| 4000 6044h | RTCA0ALH        | RTC Alarm Hour Set Register         |
| 4000 6048h | RTCA0ALW        | RTC Alarm Week Set Register         |
| 4000 604Ch | RTCA0SECC       | RTC Second Count Register           |
| 4000 6050h | RTCA0MINC       | RTC Minute Count Register           |
| 4000 6054h | RTCA0HOURC      | RTC Hour Count Register             |
| 4000 6058h | RTCA0WEEKC      | RTC Week Count Register             |
| 4000 605Ch | RTCA0DAYC       | RTC Day Count Register              |
| 4000 6060h | RTCA0MONC       | RTC Month Count Register            |
| 4000 6064h | RTCA0YEARC      | RTC Year Count Register             |
| 4000 6068h | RTCA0TIMEC      | RTC Time Count Register             |
| 4000 606Ch | RTCA0CALC       | RTC calendar Count Register         |
| 4000 6070h | RTCA0TCR        | RTC Test Register                   |

# 12.4 Register Description

# 12.4.1 RTCA0CTL0 — RTC Control Register 0

Address: 4000 6000h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23         | b22           | b21           | b20           | b19 | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-------------|---------------|---------------|---------------|-----|-----|-----|-----|
|                   | _   | _   | _   | _   | _   | _   | _   | _   | _           | _             | _             | _             | _   | _   | _   | _   |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0           | 0             | 0             | 0             | 0   | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7          | b6            | b5            | b4            | b3  | b2  | b1  | b0  |
|                   | _   | _   | _   | _   | _   | _   | _   | _   | RTCA0<br>CE | RTCA0<br>CEST | RTCA0<br>AMPM | RTCA0<br>SLSB | _   | -   | _   | _   |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0           | 0             | 0             | 0             | 0   | 0   | 0   | 0   |

Table 12.2 RTCA0CTL0 Register Contents

| Bit Position | Bit Name  | Function                                                                                                                                                  | R/W |
|--------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b8    | Reserved  |                                                                                                                                                           | R   |
| b7           | RTCA0CE   | RTC Controller enable bit                                                                                                                                 | R/W |
|              |           | 0: Clock counter operation stop                                                                                                                           |     |
|              |           | 1: Clock counter operation enable. The clock counter counts up.                                                                                           |     |
|              |           | Setting this bit to "0" initializes the internal circuit of RTC Controller other than the control registers*1.                                            |     |
|              |           | Moreover, interrupts (RTCATINTR_Int, RTCATINT1S_Int and RTCATINTAL_Int) are cleared.                                                                      |     |
| b6           | RTCA0CEST | RTC Controller enable status                                                                                                                              | R   |
|              |           | 0: Clock counter operation stopped status                                                                                                                 |     |
|              |           | 1: Clock counter operation enabled status (The clock counter counts up.)                                                                                  |     |
| b5           | RTCA0AMPM | RTCA0HOUR, RTCA0ALH display format selection bit                                                                                                          | R/W |
|              |           | 0: 12 hour display                                                                                                                                        |     |
|              |           | 1: 24 hour display                                                                                                                                        |     |
| b4           | RTCA0SLSB | RTCA0SUBU and RTCA0SCMP enable/disable setting                                                                                                            | R/W |
|              |           | 0: RTCA0SUBU setting enabled RTCA0SCMP setting disabled                                                                                                   |     |
|              |           | 1: RTCA0SUBU setting disabled RTCA0SCMP setting enabled                                                                                                   |     |
|              |           | When this bit is set to "0", RTC Controller operates on the assumption that a 32.768 kHz clock is input to 32k clock.                                     |     |
|              |           | At this time, the error of the input clock can be corrected in the range of 32.76180000 kHz to 32.77420000 kHz using the RTCA0SUBU register.              |     |
|              |           | When this bit is set to "1", refer to the RTCA0SCMP register description.                                                                                 |     |
|              |           | Caution) When setting this bit, be sure to follow the flow described in Section 12.5.1.1, Initial Setting.                                                |     |
|              |           | It is prohibited to change the setting of this bit while the clock counter operation is enabled (RTCA0CE = 1).                                            |     |
|              |           | If the setting of this bit is changed during clock counter operation, the                                                                                 |     |
|              |           | operation of RTC Controller cannot be guaranteed.  When changing the setting of this bit, first perform initialization according to                       |     |
|              |           | Section 12.5.1.5, Initialization of RTC While Clock Counter Operation is<br>Enabled, and then perform the setting of this bit again according to the flow |     |
|              |           | described in Section 12.5.1.1, Initial Setting.                                                                                                           |     |
| b3 to b0     | Reserved  |                                                                                                                                                           | R   |

Note 1. Status flags RTCA0WST, RTCA0RSST, RTCA0WSST, and RTCA0WUST, which cannot be written by the user, are cleared.

## 12.4.2 RTCA0CTL1 — RTC Control Register 1

Address: 4000 6004h



Table 12.3 RTCA0CTL1 Register Contents

| Bit Position | Bit Name  | Function                                                                                                                                    | R/W |
|--------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b6    | Reserved  |                                                                                                                                             | R   |
| b5           | Reserved  | Should be 0.                                                                                                                                | R/W |
| b4           | RTCA0ALME | Alarm interrupt (RTCATINTAL_Int) output enable bit.                                                                                         | R/W |
|              |           | 0: Disable                                                                                                                                  |     |
|              |           | 1: Enable                                                                                                                                   |     |
| b3           | RTCA01SE  | 1 second interrupt (RTCATINT1S_Int) output enable bit                                                                                       | R/W |
|              |           | 0: Stops interrupt output at every 1 second                                                                                                 |     |
|              |           | 1: Enables interrupt output at every 1 second                                                                                               |     |
| b2 to b0     | RTCA0CT   | Fixed interval interrupt (RTCATINTR_Int) output setting bit                                                                                 | R/W |
|              |           | RTCA0CT[2]/RTCA0CT[1]/RTCA0CT[0]                                                                                                            |     |
|              |           | 000b: Fixed interval interrupt output stop                                                                                                  |     |
|              |           | 001b: Interrupt once every 0.25 seconds (in synchronization with second count-up)                                                           |     |
|              |           | 010b: Interrupt once every 0.5 seconds (in synchronization with second count-up)                                                            |     |
|              |           | 011b: Interrupt once every 1 second (in synchronization with second count-up)                                                               |     |
|              |           | 100b: Interrupt once every 1 minute (every 1 minute 00 seconds)                                                                             |     |
|              |           | 101b: Interrupt once every 1 hour (every 1 hour 00 minutes 00 seconds)                                                                      |     |
|              |           | 110b: Interrupt once every 1 day (every 1 day 00 hours 00 minutes 00 seconds)                                                               |     |
|              |           | 111b: Interrupt once every 1 month (every 1 month first day 00 hours 00 minutes 00 seconds a.m.)                                            |     |
|              |           | Refer to Section 12.5.1.8, Changing the Setting of Fixed Interval Interrupt During Clock Counter Operation for changing this field setting. |     |

# 12.4.3 RTCA0CTL2 — RTC Control Register 2

Address: 4000 6008h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21           | b20           | b19 | b18           | b17          | b16           |
|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---------------|---------------|-----|---------------|--------------|---------------|
|                   | _   | ı   | ı   | ı   | ı   | ı   | _   | _   | _   | _   | _             | _             | ı   | ı             | _            | _             |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0             | 0             | 0   | 0             | 0            | 0             |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5            | b4            | b3  | b2            | b1           | b0            |
|                   | _   | -   | -   | -   | -   | -   | _   | _   | _   | _   | RTCA0<br>WUST | RTCA0<br>WSST |     | RTCA0<br>RSUB | RTCA0<br>WST | RTCA0<br>WAIT |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0             | 0             | 0   | 0             | 0            | 0             |

Table 12.4 RTCA0CTL2 Register Contents (1/2)

| D'' D '''    |           | egister Contents (1/2)                                                                                                                                                                                                                                                                               | D.4. |
|--------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| Bit Position | Bit Name  | Function                                                                                                                                                                                                                                                                                             | R/W  |
| o31 to b6    | Reserved  |                                                                                                                                                                                                                                                                                                      | R    |
| 5            | RTCA0WUST | RTCA0SUBU write status                                                                                                                                                                                                                                                                               | R    |
|              |           | 0: RTCA0SUBU write completed                                                                                                                                                                                                                                                                         |      |
|              |           | 1: RTCA0SUBU write in progress                                                                                                                                                                                                                                                                       |      |
|              |           | This bit is set (to "1") when RTCA0SUBU is written to while the clock counter operation is enabled (RTCA0CE = 1).                                                                                                                                                                                    |      |
|              |           | It is then cleared (to "0") upon completion of RTCA0SUBU write (RTCA0SUBC overflow).                                                                                                                                                                                                                 |      |
|              |           | Caution) Do not write to RTCA0SUBU while the value of this bit is "1" because write<br>to RTCA0SUBU is in progress.                                                                                                                                                                                  |      |
| o4           | RTCA0WSST | RTCA0SCMP write status                                                                                                                                                                                                                                                                               | R    |
|              |           | 0: RTCA0SCMP write completed                                                                                                                                                                                                                                                                         |      |
|              |           | 1: RTCA0SCMP write in progress                                                                                                                                                                                                                                                                       |      |
|              |           | This bit is set (to "1") when RTCA0SCMP is written to while the clock counter operation is enabled (RTCA0CE = 1).                                                                                                                                                                                    |      |
|              |           | It is then cleared (to "0") upon completion of RTCA0SCMP write (RTCA0SUBC overflow).                                                                                                                                                                                                                 |      |
|              |           | <b>Caution)</b> Do not write to RTCA0SCMP while the value of this bit is "1" because write to RTCA0SCMP is in progress.                                                                                                                                                                              |      |
| <br>o3       | RTCA0RSST | RTCA0SRBU transfer status                                                                                                                                                                                                                                                                            | R    |
|              |           | 0: RTCA0SRBU data hold status                                                                                                                                                                                                                                                                        |      |
|              |           | 1: Transfer of the value of RTCA0SUBC to RTCA0SRBU completed                                                                                                                                                                                                                                         |      |
|              |           | When "1" has been written to RTCA0RSUB, the value of this bit becomes "1" when the value of RTCA0SUBC is loaded to RTCA0SRBU.                                                                                                                                                                        |      |
|              |           | Before reading RTCA0SRBU during clock counter operation (RTCA0CE = 1), check that the value of this register is "1".                                                                                                                                                                                 |      |
| o2           | RTCA0RSUB | RTCA0SUBC data transfer control                                                                                                                                                                                                                                                                      | R/W  |
|              |           | 0: RTCA0SRBU data hold                                                                                                                                                                                                                                                                               |      |
|              |           | 1: Transfer of value of RTCA0SUBC to RTCA0SRBU                                                                                                                                                                                                                                                       |      |
|              |           | This is a control bit for transferring the value of RTCA0SUBC of RTCA0SRBU. Use it when reading the value of RTCA0SRBU while the clock counter operation is enabled (RTCA0CE = 1). When "1" is written to this bit, the value of RTCA0SUBC is loaded to RTCA0SRBU in synchronization with 32k clock. |      |
|              |           | For the usage method, refer to <b>Section 12.5.1.4</b> , <b>Reading RTCA0SRBU While Clock Counter Operation is Enabled</b> (RTCA0CE = 1).                                                                                                                                                            |      |

Table 12.4 RTCA0CTL2 Register Contents (2/2)

| Bit Position | Bit Name  | Function                                                                                                                                                                                                                                        | R/W |
|--------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b1           | RTCA0WST  | RTC Controller counter wait status                                                                                                                                                                                                              | R   |
|              |           | 0: Count-up status of RTCA0SECC, RTCA0MINC, RTCA0HOURC, RTCA0WEEKC, RTCA0DAYC, RTCA0MONC, RTCA0YEARC                                                                                                                                            |     |
|              |           | <ol> <li>Count-up stopped status of RTCA0SECC, RTCA0MINC, RTCA0HOURC,<br/>RTCA0WEEKC, RTCA0DAYC, RTCA0MONC, RTCA0YEARC. (Count-up<br/>operation of second, minute, hour, week, day, month, and year count registers is<br/>stopped.)</li> </ol> |     |
|              |           | When "1" has been written to RTCA0WAIT, the value of this bit becomes "1" when the count-up operation of RTCA0SEC, RTCA0MIN, RTCA0HOUR, RTCA0WEEK, RTCA0DAY, RTCA0MONTH, RTCA0YEAR has stopped completely.                                      |     |
|              |           | Before reading and writing clock counters (RTCA0SEC, RTCA0MIN, RTCA0HOUR, RTCA0WEEK, RTCA0DAY, RTCA0MONTH, RTCA0YEAR) during clock counter operation (RTCA0CE = 1), check that the value of this register is "1".                               |     |
|              |           | Also, when write to a clock counter (RTCA0SEC, RTCA0MIN, RTCA0HOUR, RTCA0WEEK, RTCA0DAY, RTCA0MONTH, RTCA0YEAR) has occurred, the value written to RTCA0WAIT is reflected only once the write operation has been completed (status hold).       |     |
| b0           | RTCA0WAIT | RTC Controller counter wait control                                                                                                                                                                                                             | R/W |
|              |           | 0: Counter operation                                                                                                                                                                                                                            |     |
|              |           | <ol> <li>Count-up operation of RTCA0SEC, RTCA0MIN, RTCA0HOUR, RTCA0WEEK,<br/>RTCA0DAY, RTCA0MONTH, RTCA0YEAR is stopped. (Count-up operation of<br/>second, minute, hour, week, day, month, and year count registers is stopped.)</li> </ol>    |     |
|              |           | This bit controls the count-up operation of the counters. Be sure to write "1" to this bit when reading and writing counter values while the clock counter operation is enabled (RTCA0CE = 1).                                                  |     |
|              |           | When the value of this bit is "1", upon occurrence of RTCA0SUBC overflow, the overflow information is held internally, and after "0" has been written to this bit, RTCA0SEC is counted up.                                                      |     |
|              |           | However, when the value of the second counter is written while RTCA0WAIT = 1, the overflow information that was held is discarded.                                                                                                              |     |

## 12.4.4 RTCA0SUBC — RTC Sub Count Register

Address: 4000 600Ch

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24  | b23  | b22 | b21 | b20 | b19  | b18  | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|------|------|-----|-----|-----|------|------|-----|-----|
|                   | _   | _   | _   | _   | _   | _   | _   | _    | _    | _   |     |     | RTCA | SUBC |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0    | 0   | 0   | 0   | 0    | 0    | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8   | b7   | b6  | b5  | b4  | b3   | b2   | b1  | b0  |
|                   |     |     |     |     |     |     |     | RTCA | SUBC |     |     |     |      |      |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0    | 0   | 0   | 0   | 0    | 0    | 0   | 0   |

Table 12.5 RTCA0SUBC Register Contents

| Bit Position | Bit Name  | Function                                         | R/W |
|--------------|-----------|--------------------------------------------------|-----|
| b31 to b22   | Reserved  |                                                  | R   |
| b21 to b0    | RTCA0SUBC | Register that counts the 1 second reference time | R   |

This register is cleared when reset or upon write to the RTCA0SEC (RTC Sec Count Buffer register) or RTCA0TIME (RTC Time Set register), and arbitrary values cannot be written to this register. Count-up occurs upon clock input when the clock counter operation is enabled (RTCA0CE = 1).

When this register is read while the clock counter operation is enabled (RTCA0CE = 1), the register value, which changes in synchronization with 32k clock, is read asynchronously, so that the read value is not guaranteed.

To check the value of this register while the clock counter operation is enabled (RTCA0CE = 1), use the RTCA0SRBU register.

The count-up operation of this register functions according to the setting of RTCA0SLSB as follows.

#### <RTCA0SLSB = 0>

When the clock error correction function is not used, count-up operation starts from 0h, and when 7FFFh is reached, an overflow signal is output to RTCA0SEC (Second Count Buffer register), and this register is cleared.

When clock error correction is performed, overflow occurs in the range of 7F83h to 807Bh due to the setting of RTCA0SUBU.

The setting of RTCA0SCMP (Sub Count Compare register) is ignored.

#### <RTCA0SLSB = 1>

The count-up operation starts from 0h, and upon matching the value set to RTCA0SCMP, an overflow signal is output to RTCA0SEC (Second Count Buffer register), and this register is cleared.

The setting of RTCA0SUBU (Clock Error Correction) is ignored.

[Example] Operation using 32 kHz clock

"32000 - 1 = 31999 (decimal code) = 7CFFh" is set to RTCA0SCMP.

Counting up is performed each time a 32 kHz clock is input, taking on values from 0h to 7CFFh.

1 second is counted when the value changes from 7CFFh to 0h.

## 12.4.5 RTCA0SRBU — RTC Sub Count Register Read Buffer

Address: 4000 6010h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24  | b23  | b22 | b21 | b20 | b19  | b18  | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|------|------|-----|-----|-----|------|------|-----|-----|
|                   | _   | _   | _   | _   | _   | _   | _   | _    | _    | _   |     |     | RTCA | SRBU |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0    | 0   | 0   | 0   | 0    | 0    | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8   | b7   | b6  | b5  | b4  | b3   | b2   | b1  | b0  |
|                   |     |     |     |     |     |     |     | RTCA | SRBU |     |     |     |      |      |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0    | 0   | 0   | 0   | 0    | 0    | 0   | 0   |

Table 12.6 RTCA0SRBU Register Contents

| Table 12.0   | INTOAGGINDO IN | egister contents                                                                                                                                                                                                                                                                 |     |
|--------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Bit Position | Bit Name       | Function                                                                                                                                                                                                                                                                         | R/W |
| b31 to b22   | Reserved       |                                                                                                                                                                                                                                                                                  | R   |
| b21 to b0    | RTCA0SRBU      | Read buffer register of RTCA0SUBC.                                                                                                                                                                                                                                               | R   |
|              |                | This register is cleared when reset, at which time arbitrary values cannot be written. When "1" is written to the RTCA0RSUB bit while the clock counter operation is enabled (RTCA0CE = 1), the value of RTCA0SUBC is loaded to this register in synchronization with 32k clock. |     |
|              |                | Caution) Be sure to perform RTCA0SRBU read according to the flow described in<br>Section 12.5.1.4, Reading RTCA0SRBU While Clock Counter Operation<br>is Enabled.                                                                                                                | 1   |

# 12.4.6 RTCA0SEC — RTC Sec Count Buffer Register

Address: 4000 6014h



Table 12.7 RTCA0SEC Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                                                                                  | R/W |
|--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b7    | Reserved |                                                                                                                                                                                                                           | R   |
| b6 to b0     | RTCA0SEC | Buffer register to read/write RTC Second Count register (RTCA0SECC).  This register is used when Second Count register is read and written. When setting this register, must set a decimal value of 00 to 59 in BCD code. | R/W |

# 12.4.7 RTCA0MIN — RTC Min Count Buffer Register

Address: 4000 6018h



Table 12.8 RTCA0MIN Register Contents

| Bit Position | Bit Name | Function                                                                                                                                            | R/W |
|--------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b7    | Reserved |                                                                                                                                                     | R   |
| b6 to b0     | RTCA0MIN | Buffer register to read/write RTC Minute Count register (RTCA0MINC).                                                                                | R/W |
|              |          | This register is used when Minute Count register is read and written. When setting this register, must set a decimal value of 00 to 59 in BCD code. |     |

#### 12.4.8 RTCA0HOUR — RTC Hour Count Buffer Register

Address: 4000 601Ch



**Table 12.9** RTCA0HOUR Register Contents

| Bit Position | Bit Name  | Function                                                            | R/W |
|--------------|-----------|---------------------------------------------------------------------|-----|
| b31 to b6    | Reserved  |                                                                     | R   |
| b5 to b0     | RTCA0HOUR | Buffer register to read/write RTC Hour Count register (RTCA0HOURC). | R/W |

Buffer register to read/write RTC Hour Count register (RTCA0HOURC).

This register is used when Hour Count register is read and written. When setting this register, must set a decimal value of 01 to 12 or 21 to 32 when RTCA0AMPM = 0, or a decimal value of 0 to 23 when RTCA0AMPM = 1, in BCD code in both cases.

Display of RTCA0HOUR is 12-hour display when the RTCA0AMPM bit is set to "0", and 24-hour display when it is "1". In the case of 12-hour display, am/pm is indicated by the 5th bit of RTCA0HOUR. During am, RTCA0HOUR[5] = 0, and during pm, RTCA0HOUR[5] = 1.

| 12-hour d | lisplay              |  |
|-----------|----------------------|--|
| Time      | RTCA0HOUR<br>Display |  |
| 0 am      | 12h                  |  |
| 1 am      | 01h                  |  |
|           |                      |  |
| 9 am      | 09h                  |  |
| 10 am     | 10h                  |  |
| 11 am     | 11h                  |  |
| 0 pm      | 32h                  |  |
| 1 pm      | 21h                  |  |
|           |                      |  |
| 9 pm      | 29h                  |  |
| 10 pm     | 30h                  |  |
| 11 pm     | 31h                  |  |
|           | ·                    |  |

| 24-hour | display              |
|---------|----------------------|
| Time    | RTCA0HOUR<br>Display |
| 0       | 00h                  |
| 1       | 01h                  |
|         |                      |
| 9       | 09h                  |
| 10      | 10h                  |
| 11      | 11h                  |
| 12      | 12h                  |
| 13      | 13h                  |
|         |                      |
| 21      | 21h                  |
| 22      | 22h                  |
| 23      | 23h                  |
|         | _                    |

## 12.4.9 RTCA0WEEK — RTC Week Count Buffer Register

Address: 4000 6020h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19 | b18       | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----------|-----|-----|
|                   | _   | _   | _   | _   | _   | _   | _   | _   | _   | _   | _   | _   | _   | _         | _   | _   |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0         | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3  | b2        | b1  | b0  |
|                   | _   |     | _   | _   | _   | _   | -   | _   | -   | -   | -   | -   | -   | RTCA0WEEK |     | EK  |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0         | 0   | 0   |

Table 12.10 RTCA0WEEK Register Contents

| Bit Position | Bit Name  | Function                                                                                                                                                                                                                                                                                                                                                                                                                               | R/W |
|--------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b3    | Reserved  |                                                                                                                                                                                                                                                                                                                                                                                                                                        | R   |
| b2 to b0     | RTCA0WEEK | Buffer register to read/write RTC Week Count register (RTCA0WEEKC).  This register is used when Week Count register is read and written. When setting this register, must set a decimal value of 00 to 06 in BCD code. There is no particular correspondence between the value of RTCA0WEEK and the day of the week. Set the correspondence according to the application to be used.  [Example]  0 → Sunday, 1 → Monday,, 6 → Saturday | R/W |

# 12.4.10 RTCA0DAY — RTC Day Count Buffer Register

**Address:** 4000 6024h



Table 12.11 RTCA0DAY Register Contents

| Bit Position | Bit Name | Function                                                                                                                                         | R/W |
|--------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b6    | Reserved |                                                                                                                                                  | R   |
| b5 to b0     | RTCA0DAY | Buffer register to read/write RTC Day Count register (RTCA0DAYC).                                                                                | R/W |
|              |          | This register is used when Day Count register is read and written. When setting this register, must set a decimal value of 01 to 31 in BCD code. |     |
|              |          | <ul> <li>01 to 31 (January, March, May, July, August, October, December)</li> </ul>                                                              |     |
|              |          | <ul> <li>01 to 30 (April, June, September, November)</li> </ul>                                                                                  |     |
|              |          | • 01 to 29 (February, leap year)                                                                                                                 |     |
|              |          | • 01 to 28 (February, non-leap year)                                                                                                             |     |

## 12.4.11 RTCA0MONTH — RTC Month Count Buffer Register

Address: 4000 6028h



Table 12.12 RTCA0MONTH Register Contents

| Bit Position | Bit Name   | Function                                                                                                                                                                                                                | R/W |
|--------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b5    | Reserved   |                                                                                                                                                                                                                         | R   |
| b4 to b0     | RTCA0MONTH | Buffer register to read/write RTC Month Count register (RTCA0MONC).  This register is used when Month Count register is read and written. When setting this register, must set a decimal value of 01 to 12 in BCD code. | R/W |

# 12.4.12 RTCA0YEAR — RTC Year Count Buffer Register

Address: 4000 602Ch



Table 12.13 RTCA0YEAR Register Contents

| Bit Position | Bit Name  | Function                                                                                                                                                                                                               | R/W |
|--------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b8    | Reserved  |                                                                                                                                                                                                                        | R   |
| b7 to b0     | RTCA0YEAR | Buffer register to read/write RTC Year Count register (RTCA0YEARC).  This register is used when Year Count register is read and written. When setting this register, must set a decimal value of 00 to 99 in BCD code. | R/W |

## 12.4.13 RTCA0TIME — RTC Time Set Register

RTCA0TIME is a register for accessing the RTCA0HOUR, RTCA0MIN, and RTCA0SEC registers simultaneously. By using this register, the RTCA0HOUR, RTCA0MIN, and RTCA0SEC registers can be read or written simultaneously.



Table 12.14 RTCA0TIME Register Contents

| Bit Position | Bit Name  | Function                    | R/W |
|--------------|-----------|-----------------------------|-----|
| b31 to b24   | Reserved  |                             | R   |
| b23 to b16   | RTCA0HOUR | Refer to RTCA0HOUR register | R/W |
| b15 to b8    | RTCA0MIN  | Refer to RTCA0MIN register  | R/W |
| b7 to b0     | RTCA0SEC  | Refer to RTCA0SEC register  | R/W |

## 12.4.14 RTCA0CAL — RTC Calendar Set Register

RTCA0CAL is a register for accessing the RTCA0YEAR, RTCA0MONTH, RTCA0DAY, and RTCA0WEEK registers simultaneously. By using this register, the RTCA0YEAR, RTCA0MONTH, RTCA0DAY, and RTCA0WEEK registers can be read or written simultaneously.



Table 12.15 RTCA0CAL Register Contents

| Bit Position | Bit Name   | Function                     | R/W |
|--------------|------------|------------------------------|-----|
| b31 to b24   | RTCA0YEAR  | Refer to RTCA0YEAR register  | R/W |
| b23 to b16   | RTCA0MONTH | Refer to RTCA0MONTH register | R/W |
| b15 to b8    | RTCA0DAY   | Refer to RTCA0DAY register   | R/W |
| b7 to b0     | RTCA0WEEK  | Refer to RTCA0WEEK register  | R/W |

## 12.4.15 RTCA0SUBU — RTC Clock Error Correction Register

Address: 4000 6038h



Table 12.16 RTCA0SUBU Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                                  | R/W |
|--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b8    | Reserved |                                                                                                                                                                           | R   |
| b7           | RTCA0DEV | Setting of clock error correction timing                                                                                                                                  | R/W |
|              |          | <ol><li>Clock error correction when RTCA0SEC (second counter) is 00, 20, and 40<br/>seconds</li></ol>                                                                     |     |
|              |          | 1: Clock error correction when RTCA0SEC (second counter) is 00 seconds                                                                                                    |     |
| b6           | RTCA0F6  | Clock error correction value Bit6                                                                                                                                         | R/W |
|              |          | 0: Count value of RTCA0SUBC is incremented (+ correction) by the amount set with RTCA0F5 to 0.  Increment value calculation formula: (RTCA0F[5:0] setting value − 1 ) × 2 |     |
|              |          | 1: Count value of RTCA0SUBC is decremented (- correction) by the amount set with RTCA0F5 to 0.  Decrement value calculation formula: (Inverted data of setting value of   |     |
|              |          | RTCA0F[5:0] + 1) × 2                                                                                                                                                      |     |
| b5           | RTCA0F5  | Clock error correction value Bit5                                                                                                                                         | R/W |
| b4           | RTCA0F4  | Clock error correction value Bit4                                                                                                                                         | R/W |
| b3           | RTCA0F3  | Clock error correction value Bit3                                                                                                                                         | R/W |
| b2           | RTCA0F2  | Clock error correction value Bit2                                                                                                                                         | R/W |
| b1           | RTCA0F1  | Clock error correction value Bit1                                                                                                                                         | R/W |
| b0           | RTCA0F0  | Clock error correction value Bit0                                                                                                                                         | R/W |

# 12.4.16 RTCA0SCMP — RTC Sub Count Compare Register

Address: 4000 603Ch

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24  | b23  | b22 | b21 | b20 | b19  | b18  | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|------|------|-----|-----|-----|------|------|-----|-----|
|                   |     |     |     |     |     |     |     |      |      |     |     |     |      |      |     |     |
|                   | _   | _   | _   | _   | _   | _   | _   | _    | _    | _   |     |     | RTCA | SCMP |     |     |
|                   |     |     |     |     |     |     |     |      |      |     |     |     |      |      |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0    | 0   | 0   | 0   | 0    | 0    | 0   | 0   |
|                   |     |     |     |     |     |     |     |      |      |     |     |     |      |      |     |     |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8   | b7   | b6  | b5  | b4  | b3   | b2   | b1  | b0  |
|                   |     |     |     |     |     |     |     |      |      |     |     |     |      |      |     |     |
|                   |     |     |     |     |     |     |     | RTCA | SCMP |     |     |     |      |      |     |     |
|                   |     |     |     |     |     |     |     |      |      |     |     |     |      |      |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0    | 0    | 0   | 0   | 0   | 0    | 0    | 0   | 0   |

Table 12.17 RTCA0SCMP Register Contents

| Bit Position | Bit Name  | Function                                                                                                                                                                                                                  | R/W |
|--------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b22   | Reserved  |                                                                                                                                                                                                                           | R   |
| b21 to b0    | RTCA0SCMP | Register that sets the compare value of RTCA0SUBC (sub-counter).                                                                                                                                                          | R/W |
|              |           | The setting of this register is effective when RTCA0SLSB = 1.                                                                                                                                                             |     |
|              |           | When RTCA0SLSB = 1 is set, RTCA0SUBC starts counting up from 0, and when the value set to this register is matched, an overflow signal is output to RTCA0SEC (Second Count Buffer register), and the register is cleared. |     |
|              |           | Set the value for this register according to the frequency of the selected input clock.                                                                                                                                   |     |
|              |           | Accurate one second counting can be performed to 32k clock through the value set to this register.                                                                                                                        |     |
|              |           | [Example]                                                                                                                                                                                                                 |     |
|              |           | When input clock = 32 kHz                                                                                                                                                                                                 |     |
|              |           | Setting of 32,000 (decimal) - 1 = 31,999 (decimal) = 7CFFh (hexadecimal) to RTCA0SCMP                                                                                                                                     |     |
|              |           | When performing write to this register during clock counter operation (RTCA0CE = 1), be sure to check that RTCA0WSST = 0.                                                                                                 |     |
|              |           | When writing to this register during clock counter operation (RTCA0CE = 1), write ends at the timing of RTCA0SUBC overflow.                                                                                               |     |
|              |           | Caution) When RTCA0SLSB is set to "1", be sure to set a value of 31999 or higher (32 kHz or higher) to this register. When RTCA0SLSB is set to "1", the operation of RTC Controller cannot be                             |     |

guaranteed if a value of 31998 or lower has been set to this register.

Be sure to perform RTCA0SCMP write according to the flows described in Section 12.5.1.1, Initial Setting and Section 12.5.1.7, Writing to

RTCA0SCMP During Clock Counter Operation.

## 12.4.17 RTCA0ALM — RTC Alarm Min Set Register

Address: 4000 6040h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20 | b19    | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|--------|-----|-----|-----|
|                   | _   | _   | _   | _   | -   | _   | _   | _   | _   | _   | _   | _   | _      | _   | _   | _   |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4  | b3     | b2  | b1  | b0  |
|                   | _   | _   | _   | _   | _   | _   | _   | _   | _   |     |     | R   | TCA0AL | M   |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0      | 0   | 0   | 0   |

Table 12.18 RTCA0ALM Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                                                          | R/W |
|--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b7    | Reserved |                                                                                                                                                                                                   | R   |
| b6 to b0     | RTCA0ALM | RTCA0ALM is a register that performs the minute setting for the alarm interrupt. Set a decimal value of 00 to 59 in BCD code. (Alarm detection is not performed if an out-of-range value is set.) | R/W |

# 12.4.18 RTCA0ALH — RTC Alarm Hour Set Register

Address: 4000 6044h



Table 12.19 RTCA0ALH Register Contents

| Bit Position | Bit Name | Function                                                                                                                                                                                                                                                                                                  | R/W |
|--------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b6    | Reserved |                                                                                                                                                                                                                                                                                                           | R   |
| b5 to b0     | RTCA0ALH | RTCA0ALH is a register that performs the hour setting for the alarm interrupt.  When RTCA0AMPM = 0, set a decimal value of 01 to 12 or 21 to 32, and when RTCA0AMPM = 1, set a decimal value of 00 to 23, in BCD code in both cases.  (Alarm detection is not performed if an out-of-range value is set.) | R/W |

## 12.4.19 RTCA0ALW — RTC Alarm Week Set Register

This register enables the alarm corresponding to RTCA0WEEK value.

#### [Example]

If RTCA0WEEK = 0 is Sunday, RTCA0ALW0 bit functions as Sunday alarm. If RTCA0WEEK = 6 is Saturday, RTCA0ALW6 bit functions as Saturday alarm.



Table 12.20 RTCA0ALW Register Contents

| Bit Position | Bit Name  | Function                                      | R/W |
|--------------|-----------|-----------------------------------------------|-----|
| b31 to b7    | Reserved  |                                               | R   |
| b6           | RTCA0ALW6 | Alarm interrupt day of the week setting bit 6 | R/W |
|              |           | 0: Disable alarm                              |     |
|              |           | 1: Enable alarm                               |     |
| b5           | RTCA0ALW5 | Alarm interrupt day of the week setting bit 5 | R/W |
|              |           | 0: Disable alarm                              |     |
|              |           | 1: Enable alarm                               |     |
| b4           | RTCA0ALW4 | Alarm interrupt day of the week setting bit 4 | R/W |
|              |           | 0: Disable alarm                              |     |
|              |           | 1: Enable alarm                               |     |
| b3           | RTCA0ALW3 | Alarm interrupt day of the week setting bit 3 | R/W |
|              |           | 0: Disable alarm                              |     |
|              |           | 1: Enable alarm                               |     |
| b2           | RTCA0ALW2 | Alarm interrupt day of the week setting bit 2 | R/W |
|              |           | 0: Disable alarm                              |     |
|              |           | 1: Enable alarm                               |     |
| b1           | RTCA0ALW1 | Alarm interrupt day of the week setting bit 1 | R/W |
|              |           | 0: Disable alarm                              |     |
|              |           | 1: Enable alarm                               |     |
| b0           | RTCA0ALW0 | Alarm interrupt day of the week setting bit 0 | R/W |
|              |           | 0: Disable alarm                              |     |
|              |           | 1: Enable alarm                               |     |

## 12.4.20 RTCA0SECC — RTC Second Count Register

Address: 4000 604Ch



Table 12.21 RTCA0SECC Register Contents

| Bit Position | Bit Name  | Function                                                                                                                                                    | R/W |
|--------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b7    | Reserved  |                                                                                                                                                             | R   |
| b6 to b0     | RTCA0SECC | Counts Up the Seconds  This register counts from 00 to 59, and when its value changes from 59 to 00 in BCD code, an overflow signal is output to RTCA0MINC. | R   |

# 12.4.21 RTCA0MINC — RTC Minute Count Register

**Address:** 4000 6050h



Table 12.22 RTCA0MINC Register Contents

| Bit Position | Bit Name  | Function                                                                                                                                                     | R/W |
|--------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b7    | Reserved  |                                                                                                                                                              | R   |
| b6 to b0     | RTCA0MINC | Counts Up the Minutes  This register counts from 00 to 59, and when its value changes from 59 to 00 in BCD code, an overflow signal is output to RTCA0HOURC. | R   |

## 12.4.22 RTCA0HOURC — RTC Hour Count Register

Address: 4000 6054h



Table 12.23 RTCA0HOURC Register Contents

| Bit Position | Bit Name   | Function                                                                                                                                                                                                                              | R/W |
|--------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b6    | Reserved   |                                                                                                                                                                                                                                       | R   |
| b5 to b0     | RTCA0HOURC | Counts Up the Hours This register counts from 00 to 23, or 01 to 12, or 21 to 32 in BCD code depending on the setting of RTCA0AMPM, and when its value changes from 23 to 00, an overflow signal is output to RTCA0DAY and RTCA0WEEK. | R   |

# 12.4.23 RTCA0WEEKC — RTC Week Count Register

Address: 4000 6058h



Table 12.24 RTCA0WEEKC Register Contents

| Bit Position | Bit Name   | Function                                                                                                                                      | R/W |
|--------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b3    | Reserved   |                                                                                                                                               | R   |
| b2 to b0     | RTCA0WEEKC | Counts Up the Weeks This register counts up upon occurrence of RTCA0HOURC overflow when the clock counter operation is enabled (RTCA0CE = 1). | R   |

## 12.4.24 RTCA0DAYC — RTC Day Count Register

Address: 4000 605Ch



Table 12.25 RTCA0DAYC Register Contents

| Bit Position | Bit Name  | Name Function                                                                                                                                                                        |   |  |  |  |  |  |
|--------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--|--|--|--|--|
| b31 to b6    | Reserved  |                                                                                                                                                                                      | R |  |  |  |  |  |
| b5 to b0     | RTCA0DAYC | Counts Up the Days  This register counts up upon occurrence of RTCA0HOURC overflow when the clock                                                                                    | R |  |  |  |  |  |
|              |           | counter operation is enabled (RTCA0CE = 1). This register counts according to the value of RTCA0MONC, and upon occurrence of an overflow, an overflow signal is output to RTCA0MONC. |   |  |  |  |  |  |

# 12.4.25 RTCA0MONC — RTC Month Count Register

**Address:** 4000 6060h



Table 12.26 RTCA0MONC Register Contents

| Bit Position | Bit Name  | Function                                                                                                                                                                                                                                                        | R/W |
|--------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b5    | Reserved  |                                                                                                                                                                                                                                                                 | R   |
| b4 to b0     | RTCA0MONC | Counts Up the Months                                                                                                                                                                                                                                            | R   |
|              |           | This register counts up upon occurrence of RTCA0DAYC overflow while the clock counter operation is enabled (RTCA0CE = 1). This register counts from 01 to 12 in BCD code, and when its value changes from 12 to 01, an overflow signal is output to RTCA0YEARC. |     |

## 12.4.26 RTCA0YEARC — RTC Year Count Register

Address: 4000 6064h

| Bit               | b31 | b30 | b29 | b28 | b27 | b26 | b25 | b24 | b23 | b22 | b21 | b20   | b19   | b18 | b17 | b16 |
|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-------|-------|-----|-----|-----|
|                   | _   | _   | _   | _   | _   | _   | _   | _   | _   | _   | _   | _     | _     | _   | _   | _   |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0     | 0   | 0   | 0   |
| Bit               | b15 | b14 | b13 | b12 | b11 | b10 | b9  | b8  | b7  | b6  | b5  | b4    | b3    | b2  | b1  | b0  |
|                   | _   | _   | _   | _   | _   | _   | _   | _   |     |     |     | RTCA0 | YEARC |     |     |     |
| Value after reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0     | 0   | 0   | 0   |

Table 12.27 RTCA0YEARC Register Contents

| Bit Position | Bit Name   | Function                                                                                                                                                                                      | R/W |
|--------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| b31 to b8    | Reserved   |                                                                                                                                                                                               | R   |
| b7 to b0     | RTCA0YEARC | Counts Up the Years This register counts up upon occurrence of RTCA0MONC overflow while the clock counter operation is enabled (RTCA0CE = 1). This register counts from 00 to 99 in BCD code. | R   |

## 12.4.27 RTCA0TIMEC — RTC Time Count Register

This register is for reading the RTCA0HOURC, RTCA0MINC, and RTCA0SECC registers simultaneously.

**Address:** 4000 6068h



Table 12.28 RTCA0TIMEC Register Contents

| Bit Position | Bit Name   | Function                     | R/W |
|--------------|------------|------------------------------|-----|
| b31 to b24   | Reserved   |                              | R   |
| b23 to b16   | RTCA0HOURC | Refer to RTCA0HOURC register | R   |
| b15 to b8    | RTCA0MINC  | Refer to RTCA0MINC register  | R   |
| b7 to b0     | RTCA0SECC  | Refer to RTCA0SECC register  | R   |

## 12.4.28 RTCA0CALC — RTC Calendar Count Register

This register is for reading the RTCA0YEARC, RTCA0MONC, RTCA0DAYC, and RTCA0WEEKC simultaneously.

Address: 4000 606Ch



Table 12.29 RTCA0CALC Register Contents

| Bit Position | Bit Name   | Function                     | R/W |
|--------------|------------|------------------------------|-----|
| b31 to b24   | RTCA0YEARC | Refer to RTCA0YEARC register | R   |
| b23 to b16   | RTCA0MONC  | Refer to RTCA0MONC register  | R   |
| b15 to b8    | RTCA0DAYC  | Refer to RTCA0DAYC register  | R   |
| b7 to b0     | RTCA0WEEKC | Refer to RTCA0WEEKC register | R   |

## 12.4.29 RTCA0TCR — RTC Test Register

Not available in this LSI.

Address: 4000 6070h



Table 12.30 RTCA0TCR Register Contents

| Bit Position | Bit Name | Function                                            | R/W |
|--------------|----------|-----------------------------------------------------|-----|
| b31 to b16   | Reserved |                                                     | R   |
| b15          | RTCA0OSE | 0: Disable interrupt substitution latch.            | R/W |
|              |          | 1: Enable interrupt substitution latch.             |     |
| b14 to b4    | Reserved |                                                     | R   |
| b3           | RTCA0OS3 | Value of RTCATINTAL_Int substitution latch.         |     |
| b2           | RTCA0OS2 | Value of RTCATINT1S_Int substitution latch.         |     |
| b1           | RTCA0OS1 | RTCA0OS1 Value of RTCATINTR_Int substitution latch. |     |
| b0           | Reserved | Should be 0.                                        | R/W |

## 12.5 Operation

## 12.5.1 Programming RTC

#### 12.5.1.1 Initial Setting

Perform initial setting of RTC according to the following flow.



Figure 12.2 Setting RTC When Clock Counter is Disabled

The internal clock counter operates in synchronization with 32k clock, and two 32k clocks are required until completion of the above-described initial value setting procedure. Therefore, RTC\_PCLK must be continuously supplied until completion of the initial value setting procedure. Therefore, to stop RTC\_PCLK supply after the initial value setting procedure, check first that RTCA0CEST = 1 (clock counter operation enabled status).

## 12.5.1.2 Writing to Clock Counters While Clock Counter Operation is Enabled

Be sure to write to the RTCA0SEC, RTCA0MIN, RTCA0HOUR, RTCA0WEEK, RTCA0DAY, RTCA0MONTH and RTCA0YEAR counters while the clock counter operation is enabled (RTCA0CE = 1) according to the following flow



Figure 12.3 Setting RTC When Clock Counter Is Enabled

It is prohibited to write two or more times to the same register in the above-described flow. For example, it is prohibited to write twice to the second counter. End the programming flow within 1 second.

When RTCA0WAIT = 1 is set, the operation of RTCA0SEC (second counter buffer) stops. If RTCA0SUBC overflow occurs while RTCA0WAIT = 1, one overflow is held internally. However, if overflow occurs two or more times, the overflow count cannot be held.

The internal clock counter operates in synchronization with 32k clock. Two 32k clock cycles are required until completion of the above-described initial value setting procedure. Therefore, RTC\_PCLK must be continuously supplied until completion of the initial value setting procedure.

To stop RTC\_PCLK supply after the initial value setting procedure, check first that RTCA0WST = 0 (clock counter count-up status).

#### 12.5.1.3 Reading Clock Counters While Clock Counter Operation is Enabled

There are two methods to read clock counters while clock counter operation is enabled (RTCA0CE = 1):

#### (1) Using Count Buffer Registers

This is how to read clock counter value by using bu using buffer registers. The value of clock count registers are transferred to count buffer registers by writing 1 in RTCA0WAIT. The count buffer registers are read after that. In this method, program wait\*1 occurs from setting RTCA0WAIT=1 to completion of data transfer.

#### (2) Reading Count Registers

This is how to read clock counter immediately. RTCA0SECC (see count register) is read twice in the beginning and the end. This is because it confirms whether overflow of sub-counter does not happen while counter is read. After that, the first read value is compared with the second read value. If the first read value is same as the second read value, it is judged that overflow of sub-counter didn't occur while counter read flow. If the first read value is not same as the second read value, it is judged that overflow\*2 of sub-counter occurred while counter read flow, and It begins to read clock counter again.

The merit and demerit of the two methods are mentioned in the next table.

|     |                              | Merit                                                                                                                        | Demerit                                                                                            |
|-----|------------------------------|------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|
| (1) | Using count buffer registers | It is unnecessary to read clock counter several times like the method of (2), because clock counters are read synchronously. | Program wait*1 occurs from setting RTCA0WAIT = 1 to completion of data transfer                    |
| (2) | Reading count registers      | Program wait doesn't occur.                                                                                                  | When the reading of counter and overflow of RTCA0SUBC competed, read clock counters several times. |

- Note 1. The maximum of program wait is 3 clock cycles of RTC PCLK + 2 clock cycles of 32k clock.
- **Note 2.** When reading of counter and overflow of sub-counter competed with each other, it has the possibility that unknown value is read.



# Reading clock counters while clock counter operation is enabled (RTCA0CE = 1) (using count buffer registers)



Figure 12.4 Reading RTC Using the Buffer Registers

End this flow within 1 second.

When RTCA0WAIT = 1 is set, the operation of RTCA0SEC (second counter buffer) stops. If RTCA0SUBC overflow occurs while RTCA0WAIT = 1, one overflow is held internally. However, if overflow occurs two or more times, the overflow count cannot be held.

# Reading clock counters while clock counter operation is enabled (RTCA0CE = 1) (reading count registers)



Figure 12.5 Reading RTC Using the Counting Registers

End this flow within 1 second.

When it isn't finished within one second, read clock counter value can't be assured.

## 12.5.1.4 Reading RTCA0SRBU While Clock Counter Operation is Enabled

Be sure to read RTCA0SRBU while the clock counter operation is enabled (RTCA0CE = 1) according to the following flow.



Figure 12.6 Reading RTCA0SRBU

## 12.5.1.5 Initialization of RTC While Clock Counter Operation is Enabled

Be sure to perform initialization of RTC controller while the clock counter operation is enabled (RTCA0CE = 1) according to the following flow. To restart the RTC controller operation at the end of the flow, implement the flow described in **Section 12.5.1.1**, **Initial Setting**.



Figure 12.7 Initialization of RTC While Clock Counter Operation is Enabled

## 12.5.1.6 Writing to RTCA0SUBU Clock Counter Operation

Be sure to write to RTCA0SUBU while the clock counter operation is enabled (RTCA0CE = 1) according to the flow described below.



Figure 12.8 Writing to RTCA0SUBU

RTCA0WUST is set to "1" when RTCA0SUBU is written to while the clock counter operation is enabled (RTCA0CE = 1), and upon completion of RTCA0SUBU write (RTCA0SUBC overflow), it is cleared to "0". Because RTCA0WUST displays "1" for up to 1 second for this reason, caution is required when polling RTCA0WUST.

## 12.5.1.7 Writing to RTCA0SCMP During Clock Counter Operation

Be sure to write to RTCA0SCMP while the clock counter operation is enabled (RTCA0CE = 1) according to the flow described below.



Figure 12.9 Writing to RTCA0SCMP

RTCA0WSST is set to "1" when RTCA0SCMP is written to while the clock counter operation is enabled (RTCA0CE = 1), and upon completion of RTCA0SCMP write (RTCA0SUBC overflow), it is cleared to "0". Because RTCA0WSST displays "1" for up to 1 second for this reason, caution is required when polling RTCA0WSST.

## 12.5.1.8 Changing the Setting of Fixed Interval Interrupt During Clock Counter Operation

Be sure to change the fixed interval interrupt setting while the clock counter operation is enabled (RTCA0CE = 1) according to the following flow.



Figure 12.10 Setting of Fixed Interval Interrupt During Clock Counter Operation

## 12.5.1.9 Changing Alarm Setting During Clock Counter Operation

Be sure to change the alarm interrupt setting while the clock counter operation is enabled (RTCA0CE = 1) according to the following flow.



Figure 12.11 Changing the Alarm Setting During Clock Counter Operation

## 12.5.2 RTC Backup Mode

Power supply of RTC domain is separated from other domain. It can keep counting RTC controller while rest of domain is not powered.

RTC\_PWRGOOD pin should be controlled properly when it enters or exits backup mode. Refer to power up/down sequence in Electrical Characteristics.

LVD reset circuits in RTC domain detects a low voltage, the circuit asserts reset and reset RTC controller. The circuit also works during cold power up of system as well.

#### **CAUTION**

PWRCTRL\_OPPDIV of System Control register values should be changed to initial value in case of entering RTC backup mode.

#### 12.5.3 Clock Error Correction

The clock error correction function of RTC controller is a function that corrects the oscillation frequency error of the connected resonator.

The correction value of RTCA0SUBC is determined by the RTCA0F6-RTCA0F0 bits of the RTCA0SUBU register. Whether RTCA0SUBC is incremented or decremented is decided by bit RTCA0F6, and the value is decided by bits RTCA0F5 to RTCA0F0.

- If RTCA0F6 = 0, the count value of RTCA0SUBC is incremented by the amount set with RTCA0F5 to RTCA0F0. Increment value calculation formula: (Setting value of RTCA0F5 to RTCA0F0 1) × 2
- If RTCA0F6 = 1, the count value of RTCA0SUBC is decremented by the amount set with RTCA0F5 to RTCA0F0.

  Decrement value calculation formula: (Inverted data of setting value of RTCA0F5 to RTCA0F0 + 1) × 2

#### [Example]

```
(1) Setting of RTCA0F6 = 0, RTCA0F5 to RTCA0F0 = 15h (15h - 1) × 2 = 40
Increment count value of RTCA0SUBC by 40
Count value of RTCA0SUBC = 32768 + 40 = 32808
(2) Setting of RTCA0F6 = 1, RTCA0F5 to RTCA0F0 = 15h Inverted data of "15h" = 2Ah (2Ah + 1) × 2 = 86
Count value of RTCA0SUBC decremented by 86
Count value of RTCA0SUBC = 32768 - 86 = 32682
```

Bit RTCA0DEV determines the timing at which the setting of RTCA0F6 to RTCA0F0 above becomes effective. The value set with RTCA0F6 to RTCA0F0 is not reflected to the count value of RTCA0SUBC every time, but it is reflected to the count value of RTCA0SUBC when RTCA0SEC = 00, 20, 40 seconds if RTCA0DEV = 0, and when RTCA0SEC = 00 seconds if RTCA0DEV = 1.

#### [Example]

• Setting of 0010101b to RTCA0F6 to RTCA0F0

When RTCA0DEV = 0, the count value of RTCA0SUBC is 32808 at 00, 20, and 40 seconds.

At all other times, the count value is 32768.

When RTCA0DEV = 1, the count value of RTCA0SUBC is 32808 at 00 seconds.

At all other times, the count value is 32768.

• Correcting the count value of RTCA0SUBC every 20 seconds and 60 seconds instead of every second in this manner is so to allow adjustment to the deviation width of the resonator. The frequency range of the resonator that can actually be corrected is as follows.

```
When RTCA0DEV = 0
32.76180000 to 32.77420000 kHz
When RTCA0DEV = 1
32.76593333 to 32.77006667 kHz
```

The correctable frequency range when RTCA0DEV = 0 is three times as wide as that when RTCA0DEV = 1. However, three times higher accuracy can be set for RTCA0DEV = 1.

The setting values of bits RTCA0DEV and RTCA0F6 through RTCA0F0, as well as the frequencies that can be corrected at this time, are listed on the next page.

# [Correctable Frequency Range when RTCA0DEV = 0]

| RTCA0F6 | RTCA0F5 to 0 | RTCA0SUBC Correction Value                   | Connected Clock Frequency     |
|---------|--------------|----------------------------------------------|-------------------------------|
| 0       | 000000b      | No correction                                | _                             |
| 0       | 000001b      | No correction                                | _                             |
| 0       | 000010b      | Once every 20 s, RTCA0SUBC count value + 2   | 32.76810000 kHz               |
| 0       | 000011b      | Once every 20 s, RTCA0SUBC count value + 4   | 32.76820000 kHz               |
| 0       | 000100b      | Once every 20 s, RTCA0SUBC count value + 6   | 32.76830000 kHz               |
|         |              |                                              |                               |
| 0       | 111011b      | Once every 20 s, RTCA0SUBC count value + 120 | 32.77400000 kHz               |
| 0       | 111110b      | Once every 20 s, RTCA0SUBC count value + 122 | 32.77410000 kHz               |
| 0       | 111111b      | Once every 20 s, RTCA0SUBC count value + 124 | 32.77420000 kHz (upper limit) |
| 1       | 000000b      | No correction                                | _                             |
| 1       | 000001b      | No correction                                | _                             |
| 1       | 000010b      | Once every 20 s, RTCA0SUBC count value - 124 | 32.76180000 kHz (lower limit) |
| 1       | 000011b      | Once every 20 s, RTCA0SUBC count value - 122 | 32.76190000 kHz               |
| 1       | 000100b      | Once every 20 s, RTCA0SUBC count value - 120 | 32.76200000 kHz               |
|         |              |                                              |                               |
| 1       | 111011b      | Once every 20 s, RTCA0SUBC count value - 6   | 32.76770000 kHz               |
| 1       | 111110b      | Once every 20 s, RTCA0SUBC count value - 4   | 32.76780000 kHz               |
| 1       | 111111b      | Once every 20 s, RTCA0SUBC count value - 2   | 32.76790000 kHz               |

## [Correctable frequency range when RTCA0DEV = 1]

| RTCA0F6 | RTCA0F5 to 0 | RTCA0SUBC Correction Value                   | Connected Clock Frequency     |
|---------|--------------|----------------------------------------------|-------------------------------|
| 0       | 000000b      | No correction                                | <del>-</del>                  |
| 0       | 000001b      | No correction                                | _                             |
| 0       | 000010b      | Once every 60 s, RTCA0SUBC count value + 2   | 32.76803333 kHz               |
| 0       | 000011b      | Once every 60 s, RTCA0SUBC count value + 4   | 32.76806667 kHz               |
| 0       | 000100b      | Once every 60 s, RTCA0SUBC count value + 6   | 32.76810000 kHz               |
|         |              |                                              |                               |
| 0       | 111011b      | Once every 60 s, RTCA0SUBC count value + 120 | 32.77000000 kHz               |
| 0       | 111110b      | Once every 60 s, RTCA0SUBC count value + 122 | 32.77003333 kHz               |
| 0       | 111111b      | Once every 60 s, RTCA0SUBC count value + 124 | 32.77006667 kHz (upper limit) |
| 1       | 000000b      | No correction                                | _                             |
| 1       | 000001b      | No correction                                | _                             |
| 1       | 000010b      | Once every 60 s, RTCA0SUBC count value - 124 | 32.76593333 kHz (lower limit) |
| 1       | 000011b      | Once every 60 s, RTCA0SUBC count value - 122 | 32.76596667 kHz               |
| 1       | 000100b      | Once every 60 s, RTCA0SUBC count value - 120 | 32.76600000 kHz               |
|         |              |                                              |                               |
| 1       | 111011b      | Once every 60 s, RTCA0SUBC count value - 6   | 32.76790000 kHz               |
| 1       | 111110b      | Once every 60 s, RTCA0SUBC count value - 4   | 32.76793333 kHz               |
| 1       | 111111b      | Once every 60 s, RTCA0SUBC count value - 2   | 32.76796667 kHz               |

# Section 13 Watchdog

#### 13.1 Overview

The watchdog timer is based on a free running 12-bit decrementing counter with reload register: when the counter reaches 000h, the output can be used to activate a system reset or as an interrupt.



Figure 13.1 Watchdog Interfaces and Connections

The watchdog timers consist of the following:

- Free running 12-bit decrementing counters with reload register.
- Counters are retriggered by the CPUs (CA7 processor0, CA7 processor1, CM3)
- Clock source is the clock divided by a prescaler (2 or 2<sup>14</sup>)
- Output can be used to activate a system reset with the setting of RSTEN register in System Controller or can be used as an interrupt
- Stop of watchdog effect while CPU is being stopped by debugger (e.g. by breakpoint execution)

# 13.2 Signal Interfaces

|                      | Input  |                                           |
|----------------------|--------|-------------------------------------------|
| Signal Name          | Output | Description                               |
| Clock                |        |                                           |
| WDOGA7_PCLK          | Input  | Internal bus clock (APB), no clock gating |
| WDOGM3_PCLK          |        | Half frequency of NoC clock.              |
| Interrupt            |        |                                           |
| WDT_CA7_p0_reset_Int | Output | Pulse interrupt, Active High              |
| WDT_CA7_p1_reset_Int |        |                                           |
| WDT_CM3_reset_Int    |        |                                           |

# 13.3 Register Map

# 13.3.1 Register Map CA7 Processor0 Watchdog

Table 13.1 Register Map of CA7 Processor0 Watchdog

| Address    | Register Symbol | Register Name                  |
|------------|-----------------|--------------------------------|
| 4000 8000h | CTRL_RETRIGGER  | Control and Retrigger Register |

# 13.3.2 Register Map CA7 Processsor1 Watchdog

Table 13.2 Register Map of CA7 Processor1 Watchdog

| Address    | Register Symbol | Register Name                  |
|------------|-----------------|--------------------------------|
| 4000 9000h | CTRL_RETRIGGER  | Control and Retrigger Register |

## 13.3.3 Register Map CM3 Watchdog

Table 13.3 Register Map of CM3 Watchdog

| Address    | Register Symbol | Register Name                  |
|------------|-----------------|--------------------------------|
| 4000 A000h | CTRL_RETRIGGER  | Control and Retrigger Register |

# 13.4 Register Description

#### 13.4.1 CTRL\_RETRIGGER — Control and Retrigger Register

This register can be set only once. After setting of the value, only retrigger is possible. Write this register with any value to retrigger counter reload with the value of WDRV.

Address: 4000 8000h (CA7 Processor0 Watchdog)

4000 9000h (CA7 Processor1 Watchdog)

4000 A000h (CM3 Watchdog)



Table 13.4 CTRL\_RETRIGGER Register Contents

| Bit Position | Bit Name | Function                                                           | R/W |
|--------------|----------|--------------------------------------------------------------------|-----|
| b31 to b16   | Reserved |                                                                    | R   |
| b15, b14     | WDSI     | Watchdog timer secure ID                                           | W   |
|              |          | 0x2: Allowed to write access to the lower 14 bits of this register |     |
| b13          | WDE      | Watchdog timer enable flag                                         | R/W |
|              |          | 0: Watchdog disabled                                               |     |
|              |          | 1: Enable Watchdog                                                 |     |
| b12          | PSF      | Prescaler factor                                                   | R/W |
|              |          | 0: Prescaler is set to subdivide clock by 2                        |     |
|              |          | 1: Prescaler is set to subdivide clock by 2 <sup>14</sup>          |     |
| b11 to b0    | WDRV     | Watchdog timer reload value                                        | R/W |
|              |          | WDRV = ((fpclk × WDInterval) / PSF) - 1                            |     |
|              |          | fpclk: Half frequency of NoC clock [Hz]                            |     |
|              |          | WDInterval: Interval time [s]                                      |     |
|              |          | PSF: 2 <sup>14</sup> or 2 (depends on PSF bit)                     |     |

# 13.5 Operation

The reload value is loaded to the counter register each time the watchdog timer is retriggered by write with any value to CTRL\_RETRIGGER register. The counter can be triggered by one of the internal CPU. If the counter register reaches 000h, the configurable output is activated as a system reset or an interrupt.

The watchdog timer interval is determined by the pre-scale factor and the value in the reload register. The pre-scale factor and reload value can be written just once. To protect unintentional write access, 3'b101 must be written to bit 15 to bit 13 together with the pre-scale factor and the reload value.

# Section 14 Mailbox (IPCM)

#### 14.1 Overview

The IPCM provides 3 mailboxes with control logic and interrupts generation to support inter-processor communication between Cortex-A7 and Cortex-M3. The IPCM has three interrupt output connected to every interrupt controller in the system, enabling any core to send a message to any other core; each mailbox contains seven data registers to hold the message.

- 3 mailboxes, each comprising seven 32-bit data registers to store the message.
- 3 sets of read-only interrupt status registers, one for each interrupt



Figure 14.1 IPCM Interfaces and Connections

# 14.2 Signal Interfaces

| Signal Name | Input<br>Output | Description                               |  |  |
|-------------|-----------------|-------------------------------------------|--|--|
| Clock       | Clock           |                                           |  |  |
| MBOX_HCLK   | Input           | Internal bus clock (AHB), no clock gating |  |  |
| Interrupt   |                 |                                           |  |  |
| IPCM_Int[n] | Output          | Level sensitive interrupt, Active High    |  |  |

**Note:** n = 0..2

# 14.3 Register Map

Table 14.1 IPCM Register Map

| Address                       | Register Symbol                | Register Name                          |
|-------------------------------|--------------------------------|----------------------------------------|
| 4000 B000h + 40h × n          | IPCM[n]SOURCE (n = 02)         | Mailbox[n] Source Register             |
| 4000 B004h + 40h × n          | IPCM[n]DSET (n = 02)           | Mailbox[n] Destination Set Register    |
| 4000 B008h + 40h × n          | IPCM[n]DCLEAR (n = 02)         | Mailbox[n] Destination Clear Register  |
| 4000 B00Ch + 40h × n          | IPCM[n]DSTATUS (n = 02)        | Mailbox[n] Destination Status Register |
| 4000 B010h + 40h × n          | IPCM[n]MODE (n = 02)           | Mailbox[n] Mode Register               |
| 4000 B014h + 40h × n          | IPCM[n]MSET (n = 02)           | Mailbox[n] Mask Set Register           |
| 4000 B018h + 40h × n          | IPCM[n]MCLEAR (n = 02)         | Mailbox[n] Mask Clear Register         |
| 4000 B01Ch + 40h × n          | IPCM[n]MSTATUS (n = 02)        | Mailbox[n] Mask Status Register        |
| 4000 B020h + 40h × n          | IPCM[n]SEND (n = 02)           | Mailbox[n] Send Register               |
| 4000 B024h + 40h × n + 4h × k | IPCM[n]DR[k] (n = 02) (k = 06) | Mailbox[n] Data Register [k]           |
| 4000 B800h + 8h × n           | IPCMMIS[n] (n=02)              | Masked Interrupt[n] Status Register    |
| 4000 B804h + 8h × n           | IPCMRIS[n] (n=02)              | Raw Interrupt[n] Status Register       |
| 4000 B900h                    | IPCMCFGSTAT                    | Configuration Status Register          |
| 4000 BF00h                    | IPCMTCR                        | Integration Test Control Register      |
| 4000 BF04h                    | IPCMTOR                        | Integration Test Output Register       |

# 14.4 Register Description

## 14.4.1 IPCM[n]SOURCE — Mailbox[n] Source Register (n = 0..2)

The read/write IPCM[n]SOURCE Register defines which core the message came from. The register is programmed with the Channel ID to identify which interrupt line to send the acknowledge interrupt through bit-wise encoding and can only be programmed to this value from 0x00000000. When the register is programmed, it must be cleared to 0x00000000 before it can be reprogrammed. The software must ensure that IPCM[n]SOURCE is only programmed to a one-hot encoded value.



Table 14.2 IPCM[n]SOURCE Register Contents

| Bit Position | Bit Name | Function                                                                                                   | R/W |
|--------------|----------|------------------------------------------------------------------------------------------------------------|-----|
| b31 to b3    | Reserved |                                                                                                            | R   |
| b2 to b0     | SRC_SET  | Used to define which core is the source and which interrupt line is asserted for the acknowledge interrupt | R/W |

## 14.4.2 IPCM[n]DSET — Mailbox[n] Destination Set Register (n = 0..2)

The write-only IPCM[n]DSET Register sets bits in virtual Mailbox Destination Register. Virtual Mailbox Destination Register indicates the destination core and is reflected in the Mailbox Destination Status Register. It can only be written to after the Mailbox Source Register is defined.



Table 14.3 IPCM[n]DSET Register Contents

| Bit Position | Bit Name | Function                                                                               | R/W |
|--------------|----------|----------------------------------------------------------------------------------------|-----|
| b31 to b3    | Reserved |                                                                                        | R   |
| b2 to b0     | DEST_SET | Used to set bits in the IPCM[n]DSTATUS Register by writing 1 to the corresponding bit. | W   |

## 14.4.3 IPCM[n]DCLEAR — Mailbox[n] Destination Clear Register (n = 0..2)

The write-only IPCM[n]DCLEAR Register clears bits in virtual Mailbox Destination Register. Virtual Mailbox Destination Register indicates the destination core and is reflected in the Mailbox Destination Status Register. It can only be written to after the Mailbox Source Register is defined.



Table 14.4 IPCM[n]DCLEAR Register Contents

| Bit Position | Bit Name | Function                                                                                      | R/W |
|--------------|----------|-----------------------------------------------------------------------------------------------|-----|
| b31 to b3    | Reserved |                                                                                               | R   |
| b2 to b0     | DEST_CLR | Used to clear bits in the Mailbox Destination Register by writing 1 to the corresponding bit. | W   |

#### 14.4.4 IPCM[n]DSTATUS — Mailbox[n] Destination Status Register (n = 0..2)

The read-only IPCM[n]DSTATUS Register contains the current status of virtual Mailbox Destination Register. When set, the Mailbox Destination Registers determine which cores to send the message to through bit-wise encoding using the Channel ID for each core. For cores that use multiple Channel IDs, only a single Channel ID is used per message. The Mailbox Destination Registers are cleared in Auto Acknowledge Mode by destination cores to clear the mailbox interrupts to each core. When not in Auto Acknowledge mode, the Mailbox Destination Registers are only cleared by the source core when the mailbox is being reassigned. The Mailbox Destination Registers are cleared automatically by the mailbox regardless of which mode it is in when the Mailbox Source Register is cleared.



Table 14.5 IPCM[n]DSTATUS Register Contents

| Bit Position | Bit Name  | Function                                                                                                        | R/W |
|--------------|-----------|-----------------------------------------------------------------------------------------------------------------|-----|
| b31 to b3    | Reserved  |                                                                                                                 | R   |
| b2 to b0     | DEST_STAT | Gives the status of the Mailbox Destination Register. Defines which interrupt output to assert for the message. | R   |

#### 14.4.5 IPCM[n]MODE — Mailbox[n] Mode Register (n = 0..2)

The read/write IPCM[n]MODE Register defines how the mailbox is used. The register can only be written to when the mailbox is assigned, indicated by a bit in the Mailbox Source Register being set.

Address: 4000 B010h + 40h × n Bit b31 b30 b29 b28 b26 b25 b24 b23 b22 b21 b20 b19 b18 b17 b16 b27 0 Value after reset 0 0 0 0 0 0 0 0 0 0 0 0 Bit b15 b13 b12 b10 b7 b6 b3 b0 b14 b11 h9 b8 b5 b4 b2 b1 AUTO AUTO LINK ACK Value after reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Table 14.6 IPCM[n]MODE Register Contents

| Bit Position | Bit Name  | Function                        | R/W |
|--------------|-----------|---------------------------------|-----|
| b31 to b2    | Reserved  |                                 | R   |
| b1           | AUTO_LINK | Set to enable Auto Link.        | R/W |
| b0           | AUTO_ACK  | Set to enable Auto Acknowledge. | R/W |

#### 14.4.6 IPCM[n]MSET — Mailbox[n] Mask Set Register (n = 0..2)

The write-only IPCM[n]MSET Register sets bits in virtual Mailbox Mask Register. Virtual Mailbox Mask Register indicates the mask state and is reflected in the Mailbox Mask Status Register. It can only be written to after the Mailbox Source Register is defined.

Address: 4000 B014h + 40h × n Bit b31 b30 h29 b28 h27 b26 b25 h24 b23 h22 b21 h20 b19 b18 b17 b16 0 0 0 0 0 0 0 0 0 0 Value after reset 0 0 0 0 0 0 Bit b15 b14 b13 b12 b11 b10 b9 b8 b7 b6 b5 b4 b3 b2 b1 b0 MASK\_SET 0 0 0 0 Value after reset

Table 14.7 IPCM[n]MSET Register Contents

| Bit Position | Bit Name | Function                                                                             | R/W |
|--------------|----------|--------------------------------------------------------------------------------------|-----|
| b31 to b3    | Reserved |                                                                                      | R   |
| b2 to b0     | MASK_SET | Used to set bits in the Mailbox Mask Register by writing 1 to the corresponding bit. | W   |

#### 14.4.7 IPCM[n]MCLEAR — Mailbox[n] Mask Clear Register (n = 0..2)

The write-only IPCM[n]MCLEAR Register clears bits in virtual Mailbox Mask Register. Virtual Mailbox Mask Register indicates the mask state and is reflected in the Mailbox Mask Status Register. It can only be written to after the Mailbox Source Register is defined.



Table 14.8 IPCM[n]MCLEAR Register Contents

| Bit Position | Bit Name | Function                                                                               | R/W |
|--------------|----------|----------------------------------------------------------------------------------------|-----|
| b31 to b3    | Reserved |                                                                                        | R   |
| b2 to b0     | MASK_CLR | Used to clear bits in the Mailbox Mask Register by writing 1 to the corresponding bit. | W   |

#### 14.4.8 IPCM[n]MSTATUS — Mailbox[n] Mask Status Register (n = 0..2)

The read-only IPCM[n]MSTATUS Register contains the current status of virtual Mailbox Mask Register. Each core is assigned its own bit. When set, the Mailbox Mask Registers enable the interrupts to each core through bit-wise encoding for each of the Channel IDs. These bits reset to 0, disabling the interrupts. When cleared, the Mailbox Mask Registers disable the interrupts, enabling the cores to use polling rather than interrupts for messaging. The Mailbox Mask Registers are all cleared when the Mailbox Source Register is cleared.



Table 14.9 IPCM[n]MSTATUS Register Contents

| Bit Name  | Function                                            | R/W                                                                                                                                            |
|-----------|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Reserved  |                                                     | R                                                                                                                                              |
| MASK_STAT | Gives the status of the Mailbox Mask Register       | R                                                                                                                                              |
|           | For each bit position:                              |                                                                                                                                                |
|           | 0: Mailbox interrupt disabled, polling used instead |                                                                                                                                                |
|           | 1: Mailbox interrupt enabled                        |                                                                                                                                                |
|           | Reserved                                            | Reserved  MASK_STAT  Gives the status of the Mailbox Mask Register For each bit position:  0: Mailbox interrupt disabled, polling used instead |

#### 14.4.9 IPCM[n]SEND — Mailbox[n] Send Register (n = 0..2)

The read/write IPCM[n]SEND Register sends the message to either the source or destination cores. The Mailbox Send Register bits can only be written to after the Mailbox Source Register is defined:

- setting bit 0 generates an interrupt to the destination core(s)
- setting bit 1 generates an interrupt to the source core.

In Auto Acknowledge mode, when the Mailbox Destination Status Register changes from being non-zero to zero and the Mailbox Send Register currently contains 2'b01, the mailbox automatically changes the register to 2'b10, triggering the Auto Acknowledge interrupt back to the source core.

The Mailbox Send Registers are cleared when the Mailbox Source Register is cleared.



Table 14.10 IPCM[n]SEND Register Contents

| Bit Position | Bit Name | Function                                   | R/W |
|--------------|----------|--------------------------------------------|-----|
| b31 to b2    | Reserved |                                            | R   |
| b1, b0       | SEND     | Send message:                              | R/W |
|              |          | 2'b00: Inactive                            |     |
|              |          | 2'b01: Send message to destination core(s) |     |
|              |          | 2'b10: Send message to source core         |     |
|              |          | 2'b11: Invalid, unpredictable behavior     |     |

#### 14.4.10 IPCM[n]DR[k] — Mailbox[n] Data Register [k] (n = 0..2) (k = 0..6)

The read/write IPCM[n]DR[k] Register holds the message. The Mailbox Data Registers can only be written to after the Mailbox Source Register is defined and are cleared when the Mailbox Source Register is cleared.



| Bit Position | Bit Name | Function     | R/W |
|--------------|----------|--------------|-----|
| b31 to b0    | DATA     | Message data | R/W |

#### 14.4.11 IPCMMIS[n] — Masked Interrupt[n] Status Register (n = 0..2)

The read-only IPCMMIS[n] Register contains the current mailbox status for every interrupt identified by the address encoding. This enables each core to read a single register to determine which mailbox caused the interrupt.



| Bit Position | Bit Name      | Function                | R/W |
|--------------|---------------|-------------------------|-----|
| b31 to b3    | Reserved      |                         | R   |
| b2 to b0     | MASK_INT_STAT | Masked interrupt status | R   |
|              |               | For each bit position:  |     |
|              |               | 0: No Interrupt         |     |
|              |               | 1: Interrupt generated  |     |

#### 14.4.12 IPCMRIS[n] — Raw Interrupt[n] Status Register (n = 0..2)

The read-only IPCMRIS[n] Register indicates the unmasked interrupt status of each mailbox for each core.

**Address:** 4000 B804h + 8h × n



| Bit Position | Bit Name     | Function                  | R/W |
|--------------|--------------|---------------------------|-----|
| b31 to b3    | Reserved     |                           | R   |
| b2 to b0     | RAW_INT_STAT | Raw interrupt status      | R   |
|              |              | For each bit position:    |     |
|              |              | 0: No interrupt requested |     |
|              |              | 1: Interrupt requested    |     |

#### 14.4.13 IPCMCFGSTAT — Configuration Status Register

The read-only IPCMCFGSTAT Register indicates the hardware configuration options chosen for implementation of the IPCM.

Address: 4000 B900h



Table 14.14 IPCMCFGSTAT Register Contents

| Bit Position | Bit Name   | Function                 | R/W |
|--------------|------------|--------------------------|-----|
| b31 to b22   | Reserved   |                          | R   |
| b21 to b16   | MAILBOXES  | Number of Mailboxes      | R   |
| b15, b14     | Reserved   |                          | R   |
| b13 to b8    | INTERRUPTS | Number of Interrupts     | R   |
| b7 to b3     | Reserved   |                          | R   |
| b2 to b0     | DATA_WORDS | Number of data registers | R   |

Address:

#### 14.4.14 IPCMTCR — Integration Test Control Register

4000 BF00h

The read/write IPCMTCR Register controls the IPCM integration test mode. When ITEN = 1, the IPCM is placed in integration test mode.

b26 Bit b31 b30 b29 b28 b27 b25 b24 b23 b22 b21 b20 b19 b18 b17 b16 0 0 0 0 0 Value after reset 0 0 0 0 0 0 0 0 Bit b15 b14 b13 b12 b11 b10 b9 b7 b6 b3 b0 b8 b5 b4 b2 b1 ITEN Value after reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Table 14.15 IPCMTCR Register Contents

| Bit Position | Bit Name | Function                          | R/W |
|--------------|----------|-----------------------------------|-----|
| b31 to b1    | Reserved |                                   | R   |
| b0           | ITEN     | Integration test enable:          | R/W |
|              |          | 0: Integration test mode disabled |     |
|              |          | 1: Integration test mode enabled  |     |

#### 14.4.15 IPCMTOR — Integration Test Output Register

4000 BF04h

The read/write IPCMTOR Register enables the output port signals of the IPCM to be driven directly rather than from their normal internal logic source when in integration test mode, that is, when ITEN = 1 in the IPCMTCR Register.

Bit b31 b30 b29 b28 b27 b26 b25 b24 b23 b22 b21 b20 b19 b18 b17 b16 Value after reset 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 b15 b13 b12 b10 b6 Bit b14 b11 b9 b8 b7 b5 b4 b3 b2 b1 b0 INTTEST 0 0 0 Value after reset 0 0 0 0 0 0 0 0 0 0 0 0

Address:

| Bit Position | Bit Name | Function             | R/W |
|--------------|----------|----------------------|-----|
| b31 to b3    | Reserved |                      | R   |
| b2 to b0     | INTTEST  | IPCM_Int[2:0] output | R/W |

## 14.5 Operation

The IPCM generates interrupts under software control. These interrupts normally have data associated with them and can be directed to one or more interrupt outputs. Each interrupt output corresponds directly to a bit in every Mailbox Source, Mailbox Destination, and Mailbox Mask Register in every mailbox in the IPCM. Mailbox Destination and Mailbox Mask Registers are virtual. These registers therefore control which interrupt lines are asserted when messages are sent and acknowledged.

#### 14.5.1 Channel ID

The Channel ID is defined as the one-hot encoded value that corresponds to a specific interrupt output from the IPCM. In the current configuration, the IPCM has 3 interrupt outputs with 3 corresponding Channel IDs. The Channel ID programs the Mailbox Source, Mailbox Destination, and Mailbox Mask Registers.

The following table shows the mapping of Channel ID to Interrupt output.

Table 14.17 Channel ID to Interrupt Output

| Channel ID | Interrupt Output |
|------------|------------------|
| 0x0000001  | IPCM_Int[0]      |
| 0x00000002 | IPCM_Int[1]      |
| 0x00000004 | IPCM_Int[2]      |

#### 14.5.2 Defining Source Core

A core must obtain a mailbox to send a message. To do this the core writes one of its Channel IDs to the Mailbox Source Register and then reads the Mailbox Source Register back again to check whether the write was successful. The Mailbox Source Register must only contain a one-hot encoded value, that is, a single Channel ID. The software must ensure that only a one-hot encoded number is written to the Mailbox Source Register. You can only clear the Mailbox Source Register after it is programmed. Any writes other than 0x000000000 are ignored. This mechanism guarantees that only a single core has control of the mailbox at any one time.

A core gives up a mailbox, when it is no longer required, by clearing the Mailbox Source Register. Clearing the Mailbox Source Register also clears all the other registers in the mailbox. This guarantees that a mailbox is always cleared when it is newly allocated.

#### 14.5.3 Defining Destination Core

The Mailbox Destination Register has separate Set and Clear write locations to enable you to set individual bits in the Mailbox Destination Register without using read-modify-write transfers. You can set a single bit in the Mailbox Destination Register by writing that bit to the Destination Set Register. This causes the hardware to OR that bit with the current Mailbox Destination Register value. Similarly, you can clear a single bit in the Mailbox Destination Register by writing that bit to the Destination Clear Register.

When the source core defines the mode of a mailbox, it defines which other cores are to receive the message by programming the OR of all the Channel IDs into the Mailbox Destination Register. If a core has more than one Channel ID only one is used per message. You can only write to the Mailbox Destination Register after the Mailbox Source Register is defined.

#### 14.5.4 Using the Mailbox Mask Register

The Mailbox Mask Register uses separate Set and Clear registers for modification similar to the Mailbox Destination Register. The Mailbox Mask Register enables the interrupt outputs. To enable interrupts for a particular mailbox, a core writes its Channel ID to the Mask Set location. The interrupt for that mailbox can be masked out by writing the same Channel ID to the Mask Clear location. You can only write to the Mailbox Mask Register locations after the Mailbox Source Register is defined.

#### 14.5.5 Using the Mailbox Send Register

A message is sent by setting bit 0 of the Mailbox Send Register. This triggers the interrupt to the destination core. Clearing this bit clears the interrupt to the destination core. The acknowledge message is sent to the source core by setting bit 1 of the Mailbox Send Register. Clearing this bit clears the interrupt to the source core. You can use one write to clear bit 0 and set bit 1 in the Mailbox Send Register, although this is not mandatory. You cannot set bit 1 then clear bit 0 because 2'b11 is an invalid value for the Mailbox Send Register. The Mailbox Send Register can only be written to after the Mailbox Source Register is defined.

#### 14.5.6 Mailbox Data Registers

The Mailbox Data Registers are general-purpose 32-bit registers that contain the message and can only be written to after the Mailbox Source Register is defined. The Mailbox Data Registers are normally written to before sending the message.

#### 14.5.7 Setting Mode

The Mailbox Mode Register controls how the acknowledge interrupt is sent back to the source core, and whether the current mailbox is linked to the next mailbox in the IPCM. The Mailbox Mode Register has two bits and you can only write to it after the Mailbox Source Register is defined.

#### **Auto Acknowledge**

In Auto Acknowledge mode, an acknowledge interrupt is automatically sent to the source core after the final destination core has cleared its interrupt. Destination cores must clear their interrupts by writing their Channel ID value to the Destination Clear location. This clears their Channel ID from the Mailbox Destination Register. When the Mailbox Destination Register finally reaches zero, indicating that all destination cores have cleared their interrupts, the mailbox automatically detects this, clears bit 0 and sets bit 1 of the Mailbox Send Register. The source core then receives the acknowledge interrupt. The data associated with an Auto Acknowledge is the same as that for the original message.

When Auto Acknowledge mode is disabled, the acknowledge interrupt is optional. The destination core must clear its interrupt by clearing bit 0 of the Mailbox Send Register. Only when the destination core sets bit 1 of the Mailbox Send Register does the source core obtain its acknowledge interrupt, indicating that the destination core has finished with the message. You can only disable Auto Acknowledge mode when there is only one destination core, where there is also a possibility of updating the message for the acknowledge.

#### **Auto Link**

Auto Link provides a mechanism to link mailboxes together so that when a message is acknowledged in one mailbox, the next message is sent from the linked mailbox instead of interrupting the source core. When Auto Link is enabled, the destination core clears bit 0 and sets bit 1 of the Mailbox Send Register in the usual way, but the acknowledge interrupt to the source core is masked out and Mailbox Send Register bit 0 is set in the next mailbox, sending that message.

In this mode, a source core can allocate multiple mailboxes to itself, link them together by setting the Auto Link bits and preload messages in all the mailboxes. When the first message is sent, it is not acknowledged until all the messages



have been sent. There is no restriction on the destinations of these messages or whether Auto Acknowledge is enabled when Auto Link is used. When Auto Link is disabled, the source core is interrupted if an acknowledge interrupt is sent that has no effect on any other mailbox.

#### 14.5.8 Interrupts and Status Registers

When a core receives an IPCM interrupt, it determines which mailbox triggered it by reading the Masked Interrupt Status Register related to that interrupt line. Each Masked Interrupt Status Register contains 3 bits, each bit referring to a single mailbox.

If a core is using a mailbox in polled mode, it can use the Raw Interrupt Status Register to indicate which mailbox requires attention.

Each mailbox can generate up to 3 interrupts, one for each Channel ID. The number of interrupts defines the number of bits in the Mailbox Source Register, Mailbox Destination Register, and Mailbox Mask Register. In Figure Mailbox Interrupt mapping, the IPCM has 3 interrupt outputs. Mailbox0 generates bit 0 of the IPCMMIS0-2 buses, while Mailbox2 generates bit 2 of the IPCMMIS0-2 buses.



Figure 14.2 Mailbox Interrupt Mapping

Multiple mailboxes are grouped together as shown in the figure above to form the 3-bit IPCM interrupt bus, IPCM\_Int[2:0]. All the interrupt bits from each mailbox relating to a single Channel ID are grouped together to form the masked interrupt status buses, IPCMMIS0[2:0] to IPCMMIS2[2:0]. The bits within these buses are then ORed together to form the IPCM interrupt bus, IPCM\_Int[2:0].

Below figure shows how each mailbox status is generated.



Figure 14.3 Interrupt Status of Mailbox[k], Interrupt[n]

#### 14.5.9 Configuration Status Register

The selected configuration options (3 mailbox, 7 data registers per mailbox, 3 interrupts) define the read-only Configuration Status Register, enabling software to determine the IPCM configuration by reading this register. This enables a generic IPCM software driver to determine how to use each IPCM instance within a system.

#### 14.5.10 Usage Constraints

There are several valid use models for a mailbox and some constraints under which they can be used. Messages can be sent to:

#### • Multiple cores

If a message is sent to multiple cores, it must use the Auto Acknowledge feature and data must not be modified for the acknowledge. Destination cores must clear their interrupts by writing their Channel ID to the Destination Clear Register.

#### • Single core

If there is only a single destination core, the Auto Acknowledge mode is optional. If it disables the Auto Acknowledge mode, the acknowledge is optional, although an acknowledge normally happens, and the Mailbox Data Register can optionally be updated. When Auto Acknowledge is disabled, the destination core must clear its interrupt by clearing bit 0 of the Mailbox Send Register. It can only use the Auto Link feature when there is an acknowledge.

It can use the Auto Link feature with either:

- Auto Acknowledge enabled
   The mailbox automatically sets the acknowledge when the final destination core clears its interrupt.
- Auto Acknowledge disabled
   The destination core must send the acknowledge.

# **REVISION HISTORY**

# RZ/N1D Group, RZ/N1S Group, RZ/N1L Group User's Manual: System Control and Peripheral

|      |              |          | Description                                                                                                                                                                                 |
|------|--------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rev. | Date         | Page     | Summary                                                                                                                                                                                     |
| 0.50 | Jun 30, 2017 | _        | First Edition issued                                                                                                                                                                        |
| 0.80 | Oct 31, 2017 | 26 to 28 | Section 1, all chapter title, corrected                                                                                                                                                     |
|      |              | 28       | 1.2.2, CM_FCLK: no clock gating, deleted. CM3_STCLK: no clock gating, added. NMI_CORTEXM3: active high, added                                                                               |
|      | -            | 28       | 1.2.3, description, modified                                                                                                                                                                |
|      | -            | 30, 31   | 2.2, Table 2.1 to 2.3, corrected and modified                                                                                                                                               |
|      |              | 35       | 3.4.3, Table 3.5: b19 to b16 of Reserved, R → R/W, corrected                                                                                                                                |
|      |              | 54       | 5.1, Figure 5.1, revised                                                                                                                                                                    |
|      |              | 57       | 5.2.3, Figure 5.5, modified                                                                                                                                                                 |
|      |              | 60       | 6.1, description, modified                                                                                                                                                                  |
|      |              | 62       | 6.2, DDR_HCLK: no clock gating, added                                                                                                                                                       |
|      |              | 219      | 7.4.1, CMD_SEQ → cmd_seq, corrected                                                                                                                                                         |
|      |              | 222      | 7.4.3, MEMx_ST → MEM[n]_ST, corrected                                                                                                                                                       |
|      |              | 251      | 7.4.34, lun_sel → mlun_sel, corrected                                                                                                                                                       |
|      |              | 273      | 7.5.3, corrected (DEL0 → DELAY0, DEL1 → DELAY1)                                                                                                                                             |
|      |              | 299      | 7.6, corrected (ADDRx_AUTO_INCR $\rightarrow$ ADDR[n]_AUTO_INCR, DEVn_PTR $\rightarrow$ DEV[n]_PTR, DEVn_SIZE $\rightarrow$ DEV[n]_SIZE)                                                    |
|      |              | 300      | 7.6, Figure 7.31, corrected (DEV_PTRx $\rightarrow$ DEV[n]_PTR, DEV_SIZEx $\rightarrow$ DEV[n]_SIZE)                                                                                        |
|      | -            | 301      | 7.6.1, corrected (MEMx_WP $\rightarrow$ MEM[n]_WP, MEMx_ST $\rightarrow$ MEM[n]_ST)                                                                                                         |
|      |              | 302      | 7.6.2, $MEMx\_ST \rightarrow MEM[n]\_ST$ , corrected                                                                                                                                        |
|      |              | 303      | 7.6.3, corrected (MEMx_WP $\rightarrow$ MEM[n]_WP, MEMx_ST $\rightarrow$ MEM[n]_ST)                                                                                                         |
|      |              | 305      | 7.6.4 (6), corrected (MEMx_WP $\rightarrow$ MEM[n]_WP, the 0 address register $\rightarrow$ the address register 0)                                                                         |
|      |              | 308      | 7.6.6, Figure 7.38: figure title, corrected                                                                                                                                                 |
|      |              | 313      | 7.6.9, corrected (ecc $\rightarrow$ ECC, MEMx_WP $\rightarrow$ MEM[n]_WP). Figure 7.43, corrected (write COMMAND 0x3000002A $\rightarrow$ write COMMAND 0x0010800C).                        |
|      |              | 317      | 7.8.1, corrected (ADDRx_COL $\rightarrow$ ADDR[n]_COL, ADDRx_ROW $\rightarrow$ ADDR[n]_ROW)                                                                                                 |
|      |              | 319      | 7.8.4, newly added                                                                                                                                                                          |
|      |              | 323, 325 | 8.4.1, Table 8.3: mstr_baud_div_fld: 1/2 (mstr_baud_div_fld = 0000b) is not available, corrected. b2, b1: SPI clock → QUAD_CLK, revised. enb_qspi_fld: spi_enable → QSPI Enable, corrected. |
|      |              | 334      | 8.4.12, Table 8.14: description of Function, modifed                                                                                                                                        |
|      |              | 353      | 8.6.1, SPI clock → QUAD_CLK, revised                                                                                                                                                        |
|      |              | 396      | 9.4.26, b7 to b0: $R \rightarrow R/W$ , modified                                                                                                                                            |
|      |              | 401      | 9.4.30, Table 9.32: Bit Position: $b5 \rightarrow b6$ , $b5$ , corrected                                                                                                                    |
|      |              | 420      | 10.2, Description, modified                                                                                                                                                                 |
|      |              | 421      | 10.3, PLL USB → USDBPLL, USB_CFG → CFG_USB, revised                                                                                                                                         |
|      |              | 491      | 10.5.5.6, Table 10.75: PCI_WIN1_BASEADR: PCI_AHB_WIN_SIZE → PCI_AHB_WIN1_SIZE, corrected                                                                                                    |
|      |              | 494      | 10.5.6.1, Table 10.79: PCI_WIN1_BASEADR: PCI_AHB_WIN_SIZE → PCI_AHB_WIN1_SIZE, corrected                                                                                                    |
|      |              | 495      | 10.5.6.2, Table 10.80: PCI_AHB_WIN2_SIZE → PCI_AHB_WIN2_EN, corrected                                                                                                                       |
|      |              | 503      | 10.5.6.8, Table 10.86: PCICLK_MASK: description of Function, modified                                                                                                                       |
|      |              | 505      | 10.5.7.1, chapter title, currected                                                                                                                                                          |

|      |              |                                                | Description                                                                                                                                                                 |
|------|--------------|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rev. | Date         | Page                                           | Summary                                                                                                                                                                     |
| 0.80 | Oct 31, 2017 | 507                                            | 10.5.7.2, Table 10.89: USB address register → Frame Number & USB Address Register, corrected                                                                                |
|      |              | 523                                            | 10.5.7.15, Table 10.102: EP[m]_ONAK: EP0 read register → EP[m] Read Register                                                                                                |
|      |              | 529                                            | 10.5.7.18, Table 10.105: EP[m]_DEND_SET and EP[m]_BURST_SET: description, revised                                                                                           |
|      |              | 540                                            | 10.5.8.8, Table 10.117: EP[m] length & DMA counter register → EP[m] Length & DMA Count Register, corrected                                                                  |
|      |              | 541                                            | 10.5.8.9, Address: 4001 F104h + 10h × (m - 1) $\rightarrow$ 4001 F114h + 10h × (m - 1), corrected                                                                           |
|      |              | 542                                            | 10.5.8.10, Address: 4001 F108h + 10h × (m - 1) $\rightarrow$ 4001 F118h + 10h × (m - 1), corrected. Table 10.118: EP[m]DCR1.EP[m]_REQEN $\rightarrow$ EP[m]_REQEN, revised. |
|      |              | 548                                            | 10.6.2, Table 10.121: (6): 800_0000h → 8000_0000h, corrected                                                                                                                |
|      |              | 549                                            | 10.6.2.1, changed chapter number (10.6.3 $\rightarrow$ 10.6.2.1, 10.6.4 $\rightarrow$ 10.6.2.2)                                                                             |
|      |              | 549                                            | 10.6.2.1, Table10.122, corrected                                                                                                                                            |
|      |              | 553                                            | 10.6.4.1(6), Table 10.130: EP0/EPn → EP0/EP[m], corrected                                                                                                                   |
|      |              | 556                                            | 10.6.5.1(2), OCI1/OCI2 → USB_OCI1/OCI2, corrected                                                                                                                           |
|      |              | 557                                            | 10.6.5.2, corrected (OCI1/PPON1 → USB_OCI1/PPON1, OCI2/PPON2 → USB_OCI2/PPON2, PPON1/PPON2 → USB_PPON1/PPON2, PPON1 → USB_PPON1, PPON2 → USB_PPON2)                         |
|      |              | 557                                            | 10.6.5.2, Table 10.133: the right end of header line: PPON2 → USB_PPON1, corrected. description of PPON Output Pin behavior, modified.                                      |
|      |              | 559                                            | 10.6.5.4, Figure 10.10, revised                                                                                                                                             |
|      |              | 560                                            | 10.6.6.1, description, modified                                                                                                                                             |
|      |              | 561                                            | 10.6.6.3, Figure 10.12: USB Contzrol Register Setting → USB Control Register Setting, corrected                                                                             |
|      |              | 563 to 566                                     | 10.6.7.1, Figure 10.13, 10.14, 10.15 and 10.16: PCLK → USB_PCICLK, corrected                                                                                                |
|      |              | 567 to 569                                     | 10.6.7.2, Figure 10.17, 10.18 and 10.19, revised                                                                                                                            |
|      |              | 570, 572, 573                                  | 10.6.7.3, Figure 10.20, 10.22 and 10.23: USB macro → USB subsystem, corrected                                                                                               |
|      |              | 573                                            | 10.6.7.3, NOTE, USB macro → USB subsystem, corrected                                                                                                                        |
|      |              | 575                                            | 10.6.8.1, corrected (EPn_BASEAD → EP[m]_BASEAD, EPn max packet & base address register → EP[m] MaxPacket & BaseAddress Register, EPn_MPKT → EP[m]_MPKT)                     |
|      |              | 576                                            | 10.6.9.1, Figure 10.24, revised                                                                                                                                             |
|      |              | 577, 578                                       | 10.6.9.2(1), Figure 10.25, revised. 10.6.9.2(1), Figure 10.25: figure title, corrected.                                                                                     |
|      |              | 579                                            | 10.6.9.2(2), Figure 10.26: EPn → EP[m], corrected                                                                                                                           |
|      |              | 581                                            | 10.6.9.4(1), Figure 10.27: corrected (EPn → EP[m], Data Lenght → Data Length)                                                                                               |
|      |              | 582                                            | 10.6.9.4(2), Figure 10.28: EPn → EP[m], corrected                                                                                                                           |
|      |              | 582, 583, 593,<br>596, 599, 600,<br>605 to 608 | 10.6.9.4, EPn $\rightarrow$ EP[m], corrected                                                                                                                                |
|      |              | 583                                            | 10.6.9.4(3), corrected (EPn length & DMA count register → EP[m]_LEN_DCNT register, USB_INTF0 → U2F_INT, USB_INTF1 → U2F_EPC_INT)                                            |
|      |              | 584 to 586                                     | 10.6.9.4(3), Figure 10.29, corrected (EPn → EP[m], EPn_Burst_Set → EP[m]_BURST_SET, Behaviour when ENDB_EPn asserted → EP[m]_DEND auto set enable)                          |
|      |              | 587                                            | 10.6.9.4(4), Figure 10.30, corrected (EPn → EP[m], EPn_Burst_Set → EP[m]_BURST_SET, Behaviour when ENDB_EPn asserted → EP[m]_DEND auto set enable)                          |
|      |              | 588                                            | 10.6.9.4(5), Figure 10.31: EPn → EP[m], corrected                                                                                                                           |
|      |              | 589                                            | 10.6.9.4(6), Figure 10.32: EPn → EP[m], corrected                                                                                                                           |
|      |              | 594                                            | 10.6.9.4(8)(b), Table 10.139: the lower right corner: (1) $\rightarrow$ (2), corrected                                                                                      |
|      |              | 604                                            | 10.6.9.4(10), Figure 10.34, revised                                                                                                                                         |



|      |              |                                 | Description                                                                                                                                                                                     |
|------|--------------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rev. | Date         | Page                            | Summary                                                                                                                                                                                         |
| 0.80 | Oct 31, 2017 | 605 to 608                      | 10.6.9.4(11), Figure 10.35, corrected (EPn $\rightarrow$ EP[m], TEPn Write Register $\rightarrow$ EP[m] Write Register, ENDB_EPn auto transmit enable $\rightarrow$ EP[m]_DEND auto set enable) |
|      |              | 617                             | 11.4.4, Table 11.6: SRC_MSIZE and DEST_MSIZE, description, modified                                                                                                                             |
|      |              | 651                             | 11.4.35, SglReqSrcReg → SglRqSrcReg, corrected                                                                                                                                                  |
|      |              | 651                             | 11.4.35, Table 11.37: SRC_SGLREQ_WE: Single write enable → Source single request Write-Enable, revised                                                                                          |
|      |              | 652                             | 11.4.36, SglReqDstReg → SglRqDstReg, corrected                                                                                                                                                  |
|      |              | 652                             | 11.4.36, Table 11.38: DST_SGLREQ_WE: Destination write enable → Destination single or burst request Write-Enable, revised                                                                       |
|      |              | 671                             | 11.5.2, Table11.47, corrected                                                                                                                                                                   |
|      |              | 672                             | 11.5.3, chapter title, corrected                                                                                                                                                                |
|      |              | 680                             | 12.4.4, Table 12.5, corrected                                                                                                                                                                   |
|      |              | 681                             | 12.4.6 to 12.4.12, Table 12.7 to 12.13: description of Function, modified                                                                                                                       |
|      |              | 686                             | 12.4.14, chapter title, corrected                                                                                                                                                               |
|      |              | 688                             | 12.4.16, chapter title, corrected                                                                                                                                                               |
|      |              | 688                             | 12.4.16, Table 12.17, corrected (second count register → Second Count Buffer register)                                                                                                          |
|      |              | 708                             | 12.5.3, description, modified                                                                                                                                                                   |
|      |              | 712                             | 13.4.1, Value after reset, corrected                                                                                                                                                            |
|      |              | 714                             | Section 14, chapter title, modified                                                                                                                                                             |
|      |              | 716 to 719,<br>721 to 722       | 14.4.1 to 14.4.8, 14.4.11 and 14.4.12, bit assignment, corrected                                                                                                                                |
|      |              | 722                             | 14.4.13, Value after reset, corrected (0x00020301 → 0x00030307)                                                                                                                                 |
|      |              | 722                             | 14.4.13, Table 14.14: description of Function, modified                                                                                                                                         |
|      |              | 723                             | 14.4.15, bit assignment, corrected                                                                                                                                                              |
|      |              | 726                             | 14.5.8, Figure 14.2, corrected                                                                                                                                                                  |
|      |              | 727                             | 14.5.8, Figure 14.3, added                                                                                                                                                                      |
| 0.90 | Dec 28, 2017 | all                             | All sections, corrected English spelling and syntax errors                                                                                                                                      |
|      |              | 26, 28, 54                      | Section 1 and 5, add trademarks                                                                                                                                                                 |
|      |              | 26, 28, 54, 56 to<br>59         | Section 1 and 5, ARM → Arm, changed                                                                                                                                                             |
|      |              | 26 to 27                        | 1.1, description, revised                                                                                                                                                                       |
|      |              | 26                              | 1.1.1, Cortex-A7 URL, changed                                                                                                                                                                   |
|      |              | 28                              | 1.2.1, description, revised. 1.2.1, Cortex-M3 URL, changed.                                                                                                                                     |
|      |              | 29                              | 2.2, description, revised                                                                                                                                                                       |
|      |              | 32                              | 3.2, R-IN Accessory register → R-IN Engine Accessory register, corrected                                                                                                                        |
|      |              | 37                              | 3.4.5, Table 3.7: Function, revised                                                                                                                                                             |
|      |              | 43                              | 3.6.4, CAUTION, modified. 3.6.5, description, revised.                                                                                                                                          |
|      |              | 48                              | 4.4.5, Table 4.7: Function, revised                                                                                                                                                             |
|      |              | 53                              | 4.6.4, CAUTION, modified. 4.6.5, description, revised.                                                                                                                                          |
|      |              | 59                              | 5.3.3, description, modified                                                                                                                                                                    |
|      |              | 68                              | 6.4.1.3, Table 6.5: Function of ASYNC_CDC_STAGES, revised                                                                                                                                       |
|      |              | 85                              | 6.4.1.32, Table 6.34: Function of MRW_STATUS, revised                                                                                                                                           |
|      |              | 101, 172, 196,<br>198, 201, 202 | 6.4.1.57, 6.5.1.3, 6.5.6.3(1), 6.5.6.5, 6.5.6.7, and 6.5.6.9, user word $\rightarrow$ 64-bit-defined-word, changed                                                                              |
|      |              | 121 to 123                      | 6.4.1.89 to 6.4.1.91, Function of *_FIFO_TYPE_REG, modified                                                                                                                                     |
|      |              | 158                             | 6.4.2.1, Table 6.143: Function of MASKSDLOFS, modified                                                                                                                                          |
|      |              | 159                             | 6.4.2.2, Table 6.144: Function of ASDLLOCK and MDLLOCK, revised                                                                                                                                 |



|      |              |                 | Description                                                                                                                                                                                   |
|------|--------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rev. | Date         | Page            | Summary                                                                                                                                                                                       |
| 0.90 | Dec 28, 2017 | 159             | 6.4.2.2, Table 6.144: Function of DDMODE, modified                                                                                                                                            |
|      |              | 160             | 6.4.2.2, Table 6.144: Function of MFSL and MDLLSTBY, modified                                                                                                                                 |
|      |              | 161             | 6.4.2.3, Table 6.145: Function of ZQCALFREQ and ZQCALMODE, modified.                                                                                                                          |
|      |              | 162             | 6.4.2.4, Table 6.146: Function of CAPHASE and FIFORPINIT, modified                                                                                                                            |
|      |              | 164             | 6.4.2.5, Table 6.147: Function, modified                                                                                                                                                      |
|      |              | 166             | 6.4.2.7, Table 6.149: Function, revised                                                                                                                                                       |
|      |              | 167             | 6.4.2.8, Table 6.150: Function, Hi-Z → Floating, DQSB → DDR_DQS_N, MRESETB → DDR_RESET_N, MCKE → DDR_CLKEN, MODT → DDR_ODT, changed.                                                          |
|      |              | 168             | 6.4.2.9, Table 6.151: Function of WLVEND and WLSTR, revised                                                                                                                                   |
|      |              | 168             | 6.4.2.9, Table 6.151: Function of WL2OFS and WL1OFS, modified (deleted "The setting that is smaller than the minimum SDLY delay will be a minimum delay.") and corrected (condition of [6]=1) |
|      |              | 169             | 6.4.2.10. Table 6.152: Function of DQCAL2OFS and DQCAL1OFS, revised                                                                                                                           |
|      |              | 185             | 6.5.2,9, chapter title, changed. 6.5.2,9, description, modified                                                                                                                               |
|      |              | 186, 187        | 6.5.3, description, modified                                                                                                                                                                  |
|      |              | 188             | 6.5.4, chapter title, changed                                                                                                                                                                 |
|      |              | 196             | 6.5.6.3 (1), description, modified                                                                                                                                                            |
|      |              | 204             | 6.5.7.1 (2), CAUTION, corrected (deleted DDR1)                                                                                                                                                |
|      |              | 205             | 6.5.7.1 (4), CAUTION, corrected (deleted DDR1)                                                                                                                                                |
|      |              | 206             | 6.5.7.2 (1), CAUTION, corrected (deleted DDR1)                                                                                                                                                |
|      |              | 212             | 6.6.2 (2), Request idle state for AXI interconnection and wait for acknowledge, modified (deleted "{wait} PWRSTAT_DDRC.MIRACK_A = 1")                                                         |
|      |              | 213             | 6.6.2 (2), Request active state for AXI interconnection and wait for acknowledge, modified (DDRC.MIRACK $\rightarrow$ DDRC.MISTAT_A)                                                          |
|      |              | 213             | 6.6.2 (3), ZQCALCTRL register setting, modified                                                                                                                                               |
|      |              | 213             | 6.6.2 (3), Enable output for CKE, ODT and RESET $\rightarrow$ Enable output for DDR_CLKEN, DDR_ODT and DDR_RESET_N, changed                                                                   |
|      |              | 213             | 6.6.2 (3), Configuration for ZQ calibration, modified                                                                                                                                         |
|      |              | 214             | 6.6.2 (3), Wait more than 200us, or wait until MDLL locked and initial ZQ calibration completed → Wait more than 200us, or wait until MDLL locked and ZQ calibration completed, changed       |
|      |              | 221             | 7.4.3, Table 7.4: Function of datasize_error_st, revised                                                                                                                                      |
|      |              | 227             | 7.4.7, Table 7.8: Function of err_threshold, revised                                                                                                                                          |
|      |              | 236             | 7.4.21, Table 7.22: Function of dma_burst, modifed                                                                                                                                            |
|      |              | 240 to 245, 253 | 7.4.25 to 7.4.30 and 7.4.39, description, revised                                                                                                                                             |
|      |              | 258             | 7.5.1, description, modifed                                                                                                                                                                   |
|      |              | 260             | 7.5.2.2, Table 7.45: colum of COL_A0, corrected                                                                                                                                               |
|      |              | 275             | 7.5.4.1, Table 7.46: SYNCH_RESET and LUN_RESET, deleted                                                                                                                                       |
|      |              | 275             | 7.5.4.1, Table 7.46: VOLUME_SELECT → VOLUME SELECT, corrected                                                                                                                                 |
|      |              | 277             | 7.5.4, LUN RESET Command and SYNCH RESET Command sub-section, deleted                                                                                                                         |
|      |              | 285             | 7.5.4.22, description, modified                                                                                                                                                               |
|      |              | 317             | 7.8.3 and 7.8.4, description, revised                                                                                                                                                         |
|      |              | 318             | 8.1, description, modified                                                                                                                                                                    |
|      |              | 321             | 8.4.1, Table 8.3 (1/3): Function of mstr_baud_div_fld and enter_xip_mode_imm_fld, revised                                                                                                     |
|      |              | 322             | 8.4.1, Table 8.3 (2/3): Function of enter_xip_mode_fld and enb_dir_acc_ctlr_fld, revised                                                                                                      |
|      |              | 323             | 8.4.1, Table 8.3 (3/3): Function of enb_qspi_fld, revised                                                                                                                                     |
|      |              | 324             | 8.4.2, Table 8.4: Function of addr_xfer_type_std_mode_fld, revised                                                                                                                            |
|      |              | 326             | 8.4.4, Table 8.6: Function, revised                                                                                                                                                           |



|      |              |            | Description                                                                                                                           |
|------|--------------|------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Rev. | Date         | Page       | Summary                                                                                                                               |
| 0.90 | Dec 28, 2017 | 330        | 8.4.9 and 8.4.10, Function of level_fld, revised                                                                                      |
|      | ·            | 333, 334   | 8.4.13, Table 8.15: Function of b11 to b8 and b1, revised                                                                             |
|      |              | 335        | 8.4.14, Table 8.16: Function of b11 to b8, revised                                                                                    |
|      |              | 336        | 8.4.16, Table 8.18: Function, revised                                                                                                 |
|      |              | 338        | 8.4.18, Table 8.20: Function of cmd opcode fld, revised                                                                               |
|      |              | 340        | 8.4.20, Table 8.22: Function, revised                                                                                                 |
|      |              | 342        | 8.4.24, Table 8.26: Function, revised                                                                                                 |
|      | <br>         | 344        | 8.5.1.2, A block can be between 1 and 65K bytes → A block can be between 1 and 64K bytes, corrected                                   |
|      | Ī            | 345        | 8.5.3 and 8.5.4, description, modified                                                                                                |
|      | Ī            | 346        | 8.5.6, description, modified                                                                                                          |
|      | Ī            | 347        | 8.5.7, description, modified                                                                                                          |
|      | Ī            | 348        | 8.5.8, description, revised                                                                                                           |
|      | Ī            | 349        | 8.5.9, description, revised                                                                                                           |
|      | <u> </u>     | 350        | 8.5.9.1 (9), description, modified                                                                                                    |
|      | Ī            | 351, 352   | 8.6 (including sub-section), description, modified and corrected                                                                      |
|      | Ī            | 354        | 8.6.5 (including sub-section), description, modified and revised                                                                      |
|      |              | 355        | 8.6.7, description, revised                                                                                                           |
|      | <u> </u>     | 356        | 9.1, description, modified                                                                                                            |
|      | Ī            | 374        | 9.4.12, Table 9.14: Function of hostctrl1_extdatawidth, revised                                                                       |
|      |              | 408        | 9.5.1, Table 9.42: ARM processor → CPU, changed                                                                                       |
|      |              | 415        | 10.1, descripton, revised                                                                                                             |
|      |              | 419        | 10.3, description, revised                                                                                                            |
|      |              | 432        | 10.5.1.6, Table 10.14: Function of b6 to b0, revised                                                                                  |
|      |              | 445        | 10.5.1.22, Table 10.30: Function of R_PRSW_SPR, modified                                                                              |
|      |              | 453        | 10.5.2.6, Table 10.36: HCHALTED, corrected                                                                                            |
|      |              | 460        | 10.5.2.13, Table 10.43: Function of PP, modified                                                                                      |
|      |              | 461        | 10.5.2.13, Table 10.43: Function of FORCE_PORT_RESUME                                                                                 |
|      |              | 472        | 10.5.3.13, Table 10.56: Function of b18 to b16, corrected                                                                             |
|      |              | 488 to 490 | 10.5.5.5 to 10.5.5.7, Function of TYPE, revised                                                                                       |
|      |              | 498        | 10.5.6.6, Table 10.84: Function of RESERR_INT, modified                                                                               |
|      |              | 503        | 10.5.7.1, Table 10.88: Function of FORCEFS, modified                                                                                  |
|      |              | 520        | 10.5.7.15, Table 10.102: Function of EP[m]_AUTO, Ex2) 32 bit CPU MaxPacketSize = 512 → Ex2) 32 bit CPU MaxPacketSize = 511, corrected |
|      |              | 533        | 10.5.8.2, Table 10.111: Function of ARBITER_CTR, corrected                                                                            |
|      |              | 543        | 10.6.2, Tabe 10.120: (1), Description, corrected (window area burst address → window area base address)                               |
|      |              | 568        | 10.6.7.3 (1), description, modified                                                                                                   |
|      |              | 568        | 10.6.7.3 (1), Figure 10.20, revised                                                                                                   |
|      |              | 570, 571   | 10.6.7.3 (2), NOTE, modified. Figure 10.22 and 10.23, revised                                                                         |
|      |              | 580        | 10.6.9.4 (2), moved Example 1 and 2 to under Note 1 of Figure 10.28                                                                   |
|      |              | 599        | 10.6.9.4 (9) (a), Table 10.158: bcdUSB, Description, revised. 10.6.9.4 (9) (b), Table 10.159: bcdUSB, Description, revised            |
|      |              | 607        | 11.1, Unidirectional transfer supported, deleted                                                                                      |
|      |              | 614        | 11.4.4, Table 11.6: Function of BLOCK_TS, modified                                                                                    |
|      |              | 622        | 11.4.9, Table 11.11: Function of MAX_ABRST, modified                                                                                  |



|      |              |        | Description                                                                                                                         |
|------|--------------|--------|-------------------------------------------------------------------------------------------------------------------------------------|
| Rev. | Date         | Page   | Summary                                                                                                                             |
| 0.90 | Dec 28, 2017 | 646    | 11.4.32, description, corrected (Combined Status register → Combined Interrupt Status register)                                     |
|      |              | 658    | 11.5.1.1, description, revised (following functions → following peripherals)                                                        |
|      |              | 672    | 12.2, chapter title, changed (Module Interface Signals → Signal Interfaces)                                                         |
|      |              | 674    | 12.4.1, Table 12.2: Function of RTCA0CE, revised                                                                                    |
|      |              | 675    | 12.4.2, Table 12.3: Function, revised                                                                                               |
|      |              | 678    | 12.4.4, Table 12.5: Function of RTCA0SUBC, RTCA0PE → RTCA0CE, corrected                                                             |
|      |              | 679    | 12.4.5, Table 12.6: Function of RTCA0SRBU, CAUTION, corrected                                                                       |
|      |              | 685    | 12.4.15, Table 12.16: Function of RTCA0DEV, revised                                                                                 |
|      |              | 692    | 12.4.27, description, RTCA0TIME → RTCA0TIMEC, corrected                                                                             |
|      |              | 693    | 12.4.28, description, RTCA0CAL → RTCA0CALC, corrected                                                                               |
|      |              | 695    | 12.5.1.2, RTCA0SEC (second counter) → RTCA0SEC (second counter buffer), corrected                                                   |
|      |              | 697    | 12.5.1.3, RTCA0SEC (second counter) → RTCA0SEC (second counter buffer), corrected                                                   |
|      |              | 708    | 13.1, software reset → system reset, corrected                                                                                      |
|      |              | 710    | 13.4.1, Table 13.4: Function of WDSI, revised                                                                                       |
|      |              | 711    | 13.5, description. revised                                                                                                          |
| 0.95 | Oct 19, 2018 | _      | All sections, spelling, syntax errors and appearances are corrected, and expressions are modified properly                          |
|      |              | 4      | How to Use This Manual, 1. Objective and Target Users, Documents related to RZ/N1 (R18DS0026 → R01DS0323), table modified           |
|      |              | 6      | How to Use This Manual, 3. List of Abbreviations and Acronyms, INTC, OTP, description modified                                      |
|      |              | 26     | 1.1.1 Overview, Figure 1.1 Arm Cortex-A7 Core Interfaces and Connections (16K → 16KB), figure modified                              |
|      |              | 26, 27 | 1.1.1 Overview (add: Generic timer, add: Configuration Base Address Register (CBAR) value, others), description modified            |
|      |              | 27     | 1.1.2 Usage Notes, description modified                                                                                             |
|      |              | 28     | 1.2.1 Overview, description modified                                                                                                |
|      |              | 28     | 1.2.3.1 Restriction, expression modified                                                                                            |
|      |              | 29     | 2.2 Features, description modified                                                                                                  |
|      |              | 30     | 2.2 Features, Table 2.1 RZ/N1D Bus Connection Map, Note1,2, description added                                                       |
|      |              | 31     | 2.2 Features, Table 2.2 RZ/N1S Bus Connection Map, Note1,2, description added                                                       |
|      |              | 32     | 2.2 Features, Table 2.3 RZ/N1L Bus Connection Map, Note1,2, description added                                                       |
|      |              | _      | Overall of Section 3 2MB SRAM (1-bit/2-bit → single/double), term modified                                                          |
|      |              | 33     | 3.2 Signal Interfaces, RINBUS_HCLK (N/A → Input), description modified                                                              |
|      |              | 43     | 3.6.2 ECC Decoder Config Register (RAMEDC) (or → and), description modified                                                         |
|      |              | 44     | 3.6.5 Double Bit ECC Error Address Register (RAMDBEAD), description modified                                                        |
|      |              | _      | Overall of Section 4 4MB SRAM (1-bit/2-bit → single/double), term modified                                                          |
|      |              | 53     | 4.6.2 SRAM 4MB ECC Decoder Config Register (SR4EDC) (or → and), description modified                                                |
|      |              | 54     | 4.6.5 SRAM 4MB Double Bit ECC Error Address Register (SR4DBEAD), description modified                                               |
|      |              | 59     | 5.3.1 RZ/N1 Reset Signals, description modified                                                                                     |
|      |              | 59     | 5.3.2 Debugger Reset Signals, description modified                                                                                  |
|      |              | 68     | 6.4.1.1 DDR_CTL_00 — DDR-Controller Status & Control 00, DRAM_CLASS, description added                                              |
|      |              | 69     | 6.4.1.2 DDR_CTL_01 — DDR-Controller Status & Control 01, Value after reset, modified 6,4,1,37, 6.4.1.138 Same as 6.4.1.2 DDR_CTL_01 |



|      |              |      | Description                                                                                                                                                                                                                            |
|------|--------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rev. | Date         | Page | Summary                                                                                                                                                                                                                                |
| 0.95 | Oct 19, 2018 | 74   | 6.4.1.12 DDR_CTL_11 — DDR-Controller Status & Control 11, CASLAT_LIN, description modified                                                                                                                                             |
|      |              | 83   | 6.4.1.27 DDR_CTL_26 — DDR-Controller Status & Control 26, LOWPOWER_REFRESH_ENABLE, description modified                                                                                                                                |
|      |              | 84   | 6.4.1.28 DDR_CTL_27 — DDR-Controller Status & Control 27, LP_STATE, description modified                                                                                                                                               |
|      |              | 85   | 6.4.1.30 DDR_CTL_29 — DDR-Controller Status & Control 29, expression modified                                                                                                                                                          |
|      |              | 95   | 6.4.1.49 DDR_CTL_48 — DDR-Controller Status & Control 48, ROW_DIFF, BANK_DIFF, description added                                                                                                                                       |
|      |              | 96   | 6.4.1.50 DDR_CTL_49 — DDR-Controller Status & Control 49, COL_DIFF, description modified                                                                                                                                               |
|      |              | 102  | 6.4.1.57 DDR_CTL_56 — DDR-Controller Status & Control 56, INT_STATUS (MC → memory controller), expression modified 6.4.1.72, 6.4.1.117, 6.4.1.133134 Same as 6.4.1.57 DDR_CTL_56                                                       |
|      |              | 103  | 6.4.1.58 DDR_CTL_57 — DDR-Controller Status & Control 57, INT_ACK (mask → bit), description modified                                                                                                                                   |
|      |              | 110  | 6.4.1.69 DDR_CTL_68 — DDR-Controller Status & Control 68, OCD_ADJUST_PUP_CS_0, OCD_ADJUST_PDN_CS_0, description modified                                                                                                               |
|      |              | 130  | 6.4.1.102 DDR_CTL_[k] — Port0 Range[n] Protect Setting Register2 (n = 014) (k = 220 + n × 2), Bit name(AXI0_RANGE_PROT_BITS[n+1] → AXI0_RANGE_PROT_BITS_[n+1]), modified 6.4.1.105, 6.4.1.108, 6.4.1.111 Same as 6.4.1.102 DDR_CTL_[k] |
|      |              | 140  | 6.4.1.112 DDR_CTL_346 — Port3 Range15 Protect Setting Register2, AXI3_RANGE_WID_CHECK_BITS_ID_LOOKUP_15, AXI3_RANGE_RID_CHECK_BITS_ID_LOOKUP_15 ([n] → 15), modified                                                                   |
|      |              | 143  | 6.4.1.116 DDR_CTL_350 — DDR-Controller Status & Control 350, DLL_RST_ADJ_DLY, DLL_RST_DELAY, description modified                                                                                                                      |
|      |              | 156  | 6.4.1.138 DDR_CTL_372 — DDR-Controller Status & Control 372, OPTIMAL_RMODW_EN, description modified                                                                                                                                    |
|      |              | 171  | 6.5.1 Address Mapping, description deleted                                                                                                                                                                                             |
|      |              | 171  | 6.5.1.1 DDR SDRAM Address Mapping Options, description modified                                                                                                                                                                        |
|      |              | 173  | 6.5.1.3 Memory Mapping to Address Space, description modified                                                                                                                                                                          |
|      |              | 173  | 6.5.1.3 Memory Mapping to Address Space, CAUTION (address 0x2, the Datapath bits must be defined as 3'b010 $\rightarrow$ address 0x1, the Datapath bits must be defined as 1'b1), value modified                                       |
|      |              | 176  | 6.5.2.4 Understanding Port Bandwidth (DDR Controller initialization $\rightarrow$ DDR Controller), description modified                                                                                                                |
|      |              | 185  | 6.5.2.8 Arbitration Examples, Table 6.157 Priority Round-Robin with Bandwidth Consideration, table axis (Arbitration Winner → Bandwidth Held Off?), description modified                                                               |
|      |              | 187  | 6.5.3 Port Protection Option (AXI0_RANGE $\rightarrow$ AXIY_RANGE), description modified                                                                                                                                               |
|      |              | 190  | 6.5.4.1 Rules of the Placement Algorithm, Table 6.159 Simple Command Queue Example, title modified                                                                                                                                     |
|      |              | 190  | 6.5.4.1 Rules of the Placement Algorithm PQ, term deleted                                                                                                                                                                              |
|      |              | 197  | 6.5.6.3 ECC Control (a 2 bit parameter $\rightarrow$ a parameter), description modified                                                                                                                                                |
|      |              | 198  | 6.5.6.4 Syndromes, caution added                                                                                                                                                                                                       |
|      |              | 200  | 6.5.6.5 Command Processing when ECC is Enabled, Table 6.162 ECC Functionality on Various Transaction Types (2/2), Masked Write, description modified                                                                                   |
|      |              | 205  | 6.5.7.1 Low Power States, (1) Active Power-Down, (3) Pre-Charge Power-Down, description modified                                                                                                                                       |
|      |              | 207  | 6.5.7.2 Management of the Low Power Control Module, Table 6.164 Low Power State Management, Automatic (No $\rightarrow$ Yes), table modified                                                                                           |
|      |              | 209  | 6.5.7.3 Software Programmable Interface, (2) Software Programmable Interface Commands, reference modified                                                                                                                              |



|      |              |      | Description                                                                                                                                                                |     |                                                                                                                                                                                               |
|------|--------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rev. | Date         | Page | Summary                                                                                                                                                                    |     |                                                                                                                                                                                               |
| 0.95 | Oct 19, 2018 | 209  | 6.5.7.3 Software Programmable Interface, (2) Software Programmable Interface Commands (bit → bit (LP_CMD[4:2])), description modified                                      |     |                                                                                                                                                                                               |
|      |              | 211  | 6.5.7.4 Automatic Interface, (1) Automatic Entry, CAUTION (four power → power), description modified                                                                       |     |                                                                                                                                                                                               |
|      |              | 211  | 6.5.7.4 Automatic Interface, (4) Refresh Masking, description deleted                                                                                                      |     |                                                                                                                                                                                               |
|      |              | 215  | 7.1 Overview, Figure 7.1 NAND Flash Controller Interfaces and Connections (FNAND_RYBY_N → FNAND_RY/BY_N), figure modified                                                  |     |                                                                                                                                                                                               |
|      |              | 220  | 7.4.2 CONTROL — CONTROL Register, int_en (Global Interrupt → Interrupt), expression modified                                                                               |     |                                                                                                                                                                                               |
|      |              | 226  | 7.4.6 INT_STATUS — INT_STATUS Register ('1' value or the rising edge $\rightarrow$ '1' value), description modified                                                        |     |                                                                                                                                                                                               |
|      |              | 227  | 7.4.7 ECC_CTRL — ECC Control Register (present → available), description modified                                                                                          |     |                                                                                                                                                                                               |
|      |              | 232  | 7.4.14 PROTECT — Protect Register, description deleted                                                                                                                     |     |                                                                                                                                                                                               |
|      |              | 233  | 7.4.15 FIFO_DATA — FIFO Data Register (external CPU → CPU), description modified                                                                                           |     |                                                                                                                                                                                               |
|      |              | 235  | 7.4.20 DMA_CNT — DMA Counter Register, cnt_init (FFFF_FFFDh → FFFF_FFFCh), value modified                                                                                  |     |                                                                                                                                                                                               |
|      |              | 242  | 7.4.27 TIME_SEQ_1 — Command Sequence Timing Register 1, trr, twb, description modified                                                                                     |     |                                                                                                                                                                                               |
|      |              | 244  | 7.4.29 TIME_GEN_SEQ_1 — Generic Command Sequence Register 1, t0_d7, t0_d6, t0_d5, t0_d4 (commands → address, others), description modified                                 |     |                                                                                                                                                                                               |
|      |              | 245  | 7.4.30 TIME_GEN_SEQ_2 — Generic Command Sequence Register 2, t0_d11, t0_d10, t0_d9, t0_d8, description modified                                                            |     |                                                                                                                                                                                               |
|      |              | 248  | 7.4.33 GEN_SEQ_CTRL — Generic Sequence Register (delay → DELAY, others), description modified                                                                              |     |                                                                                                                                                                                               |
|      |              | 250  | 7.4.34 MLUN — LUN Configuration Register, mlun_sel, description modified                                                                                                   |     |                                                                                                                                                                                               |
|      |              | 257  | 7.4.42 PARAM_REG — PARAMETER Register, toggle_mode_implement (toggle work mode → toggle mode), description modified                                                        |     |                                                                                                                                                                                               |
|      |              | 275  | 7.5.4.1 Instruction Set, Table 7.46 Instruction Set (1/2), Instruction (PROGRAM PAGE IMD → PROGRAM PAGE IMMEDIATE, PROGRAM PAGE DEL → PROGRAM PAGE DELAYED), term modified |     |                                                                                                                                                                                               |
|      |              | 276  | 7.5.4.3 RESET Command, description deleted                                                                                                                                 |     |                                                                                                                                                                                               |
|      |              | 277  | 7.5.4.4 READ ID Command, description deleted                                                                                                                               |     |                                                                                                                                                                                               |
|      |              | 278  | 7.5.4.7 GET FEATURES Command, description deleted                                                                                                                          |     |                                                                                                                                                                                               |
|      |              | 281  | 7.5.4.13 LUN STATUS Command (SELECT LUN WITH STATUS $\rightarrow$ LUN STATUS), term modified                                                                               |     |                                                                                                                                                                                               |
|      |              |      |                                                                                                                                                                            | 286 | 7.5.4.25 PROGRAM PAGE IMMEDIATE Command (Then five address cycles containing the column address and row address → Then three address cycles containing the row address), description modified |
|      |              | 286  | 7.5.4.25 PROGRAM PAGE IMMEDIATE Command, Table 7.69 PROGRAM PAGE IMMEDIATE Instruction Encoding (PROGRAM PAGE IMD → PROGRAM PAGE IMMEDIATE), title modified                |     |                                                                                                                                                                                               |
|      |              | 287  | 7.5.4.26 PROGRAM PAGE DELAYED Command (The PROGRAM PAGE DELAY instruction uses the SEQ_12 → The PROGRAM PAGE DELAYED instruction uses the SEQ_23), description modified    |     |                                                                                                                                                                                               |
|      |              | 287  | 7.5.4.26 PROGRAM PAGE DELAYED Command, Table 7.70 PROGRAM PAGE DELAYED Instruction Encoding (DELAY → DELAYED), title modified                                              |     |                                                                                                                                                                                               |
|      |              | 293  | 7.5.4.41 PAGE READ OTP Command (SEQ_9 → SEQ_10), description modified                                                                                                      |     |                                                                                                                                                                                               |
|      |              | 294  | 7.5.5 Multi LUN Work Mode (LUN_ $\rightarrow$ MLUN _, LUN STATUS 0 $\rightarrow$ LUN_STATUS_0), expression modified                                                        |     |                                                                                                                                                                                               |
|      |              | 297  | 7.6 Setup and Configuration (Global Interrupt → Interrupt, others), description modified                                                                                   |     |                                                                                                                                                                                               |
|      |              | 301  | 7.6.3 Send Data to NAND Flash via Master Interface (Using DMA) (global interrupt → interrupt), description modified                                                        |     |                                                                                                                                                                                               |

|      |              |            | Description                                                                                                                                                                                                                |
|------|--------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rev. | Date         | Page       | Summary                                                                                                                                                                                                                    |
| 0.95 | Oct 19, 2018 | 303        | 7.6.4 Fast Writing and Reading of Several Pages from the Memory Using DMA (global interrupt → interrupt, (10): section 8 → section 7, (18): CHCHE SEQUENTIAL → CHCHE, (19): section 18 → section 16), description modified |
|      |              | 316        | 7.8.2 Protect Register (PROTECT), description deleted                                                                                                                                                                      |
|      |              | 318        | 8.1 Overview (Transmit and receive FIFOs are 16 bytes), description added                                                                                                                                                  |
|      |              | 323        | 8.4.1 config_reg — QSPI Configuration Register, sel_clk_phase_fld, sel_clk_pol_fld, description modified                                                                                                                   |
|      |              | 324        | 8.4.2 dev_instr_rd_config_reg — Device Read Instruction Configuration Register, Function (Standard SPI → SPI), description modified                                                                                        |
|      |              | 325        | 8.4.3 dev_instr_wr_config_reg — Device Write Instruction Configuration Register, Function (Standard SPI → SPI), description modified                                                                                       |
|      |              | 328        | 8.4.6 dev_size_config_reg — Device Size Configuration Register, Function, description added                                                                                                                                |
|      |              | 335        | 8.4.14 irq_mask_reg — Interrupt Mask Register, Function (add: mask), description modified                                                                                                                                  |
|      |              | 338        | 8.4.18 flash_cmd_ctrl_reg — Flash Command Control Register, cmd_opcode_fld, description modified                                                                                                                           |
|      |              | 348        | 8.5.7 Selecting the Flash Instruction Type, Table 8.29 Number of Lanes for WRITE Instructions Supported by the N25Q128 Device, note added                                                                                  |
|      |              | 349        | 8.5.9.1 Example of an 8 byte Read Transfer, (8) (26 cycles → 16 cycles), description modified                                                                                                                              |
|      |              | 352        | 8.6.2 Configuring the QuadSPI Controller for optimal use, (6) (d_nss field → d_nss_fld), description modified                                                                                                              |
|      |              | 353        | 8.6.4 Using SPI Legacy Mode (RX-FIFO are of limited depth → RX-FIFO are of limited depth (8 bytes) in legacy mode), description added                                                                                      |
|      |              | 354        | 8.6.5.3 Exiting XIP mode (enb_dir_acc_ctlr_fld → enter_xip_mode_fld), description modified                                                                                                                                 |
|      |              | 371 to 373 | 9.4.11 reg_presentstate — Present State Register, Function, description added                                                                                                                                              |
|      |              | 374        | 9.4.12 reg_hostcontrol1 — Host Control 1 Register, hostctrl1_cdsigselect (detection → selection), description modified                                                                                                     |
|      |              | 376        | 9.4.13 reg_powercontrol — Power Control Register, emmc_hwreset, description modified                                                                                                                                       |
|      |              | 383        | 9.4.18 reg_softwarereset — Software Reset Register, description added                                                                                                                                                      |
|      |              | 383        | 9.4.18 reg_softwarereset — Software Reset Register, swreset_for_all, description modified                                                                                                                                  |
|      |              | 384        | 9.4.19 reg_normalintrsts — Normal Interrupt Status Register (normalintrsts_cardintsts, normalintrsts_cardremsts), description modified                                                                                     |
|      |              | 388        | 9.4.20 reg_errorintrsts — Error Interrupt Status Register, errorintrsts_cmdcrcerror (CRT → CRC), description modified                                                                                                      |
|      |              | 391        | 9.4.23 reg_normalintrsigena — Normal Interrupt Signal Enable Register (sample → same), description modified                                                                                                                |
|      |              | 392        | 9.4.24 reg_errorintrsigena — Error Interrupt Signal Enable Register (sample → same), description modified                                                                                                                  |
|      |              | 395        | 9.4.27 reg_capabilities — Capabilities Register, Value after reset, modified                                                                                                                                               |
|      |              | 395        | 9.4.27 reg_capabilities — Capabilities Register (corecfg_1p8voltsupport, corecfg_3p0voltsupport), description modified                                                                                                     |
|      |              | 398        | 9.4.29 reg_maxcurrentcap — Maximum Current Capabilities Register, Function, description modified                                                                                                                           |
|      |              | 402        | 9.4.33 reg_admasysaddr0 — ADMA System Address Register Low, adma_sysaddress0 (lower → system address), description modified                                                                                                |
|      |              | 409        | 9.5.2 DMA Transaction, Figure 9.3 Data Transfer Using DAT Line Sequence (Using DMA) (8: Complete → Clear), figure modified                                                                                                 |
|      |              | 410        | 9.5.2 DMA Transaction, Table 9.43 DMA Transaction, 11 (Step(4) → Step(14)), description modified                                                                                                                           |

|      |              |            | Description                                                                                                                                                                                         |  |     |
|------|--------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|-----|
| Rev. | Date         | Page       | Summary                                                                                                                                                                                             |  |     |
| 0.95 | Oct 19, 2018 | 410        | 9.5.2 DMA Transaction, DMA Transaction Sequence (512 $\rightarrow$ 512 bytes ), description modified                                                                                                |  |     |
|      |              | _          | Overall of Section 10 USB 2.0 HS Host/Function Controller (USBh/USBf) (OCI $\rightarrow$ USB_OC, PPON $\rightarrow$ USB_PPON), term modified                                                        |  |     |
|      |              | 415        | 10.1 Overview, description modified                                                                                                                                                                 |  |     |
|      |              | 419        | 10.3 USBPLL Features, description modified                                                                                                                                                          |  |     |
|      |              | 445        | 10.5.1.22 HCRHPORTSTATUS1/ HCRHPORTSTATUS2 - HcRhPortStatus1/ HcRhPortStatus2 Register, R_PPSW_SPP (turn off → turn on), description modified                                                       |  |     |
|      |              | 452        | 10.5.2.5 USBCMD — USBCMD Register, PERIODIC_SCHEDULE_ENABLE, description modified                                                                                                                   |  |     |
|      |              | 455        | 10.5.2.7 USBINTR — USBINTR Register, Function, description modified                                                                                                                                 |  |     |
|      |              | 512        | 10.5.7.9 EP0_CONTROL — EP0 Control Register, EP0_STL (set to 1b $\rightarrow$ cleared to 0b), description modified                                                                                  |  |     |
|      |              | 519        | 10.5.7.15 EP[m]_CONTROL — EP[m] Control Register (m = 115), Bit (b1: RESERVED $\rightarrow$ –), expression modified                                                                                 |  |     |
|      |              | 521        | 10.5.7.15 EP[m]_CONTROL — EP[m] Control Register (m = 115), EP[m]_ISTL (Return → Not Return), description modified                                                                                  |  |     |
|      |              | 522 to 524 | 10.5.7.16 EP[m]_STATUS — EP[m] Status Register (m = 115) (EP[m]_ISO_PIDERR, EP[m]_OUT_NAK_ERR_INT, EP[m]_IN_NAK_ERR_INT, EP[m]_IN_INT), description modified                                        |  |     |
|      |              | 554        | 10.6.5.1 Overcurrent Control, Figure 10.8 USB_OC1 and USB_PPON1 Assert, De-assert Timing Chart (SPP $\rightarrow$ R_PPS_W_SPP, SGP $\rightarrow$ R_LPSC_W_SGP), figure modified                     |  |     |
|      |              | 555        | 10.6.5.2 VBUS Control, Table 10.133 Relationship between Register Settings and USB_PPON1/PPON2, table modified                                                                                      |  |     |
|      |              | 556        | 10.6.5.3 Overcurrent Detection Using PPON, Figure 10.9 Overcurrent Detection Using PPON (POCI → R_POCIW_CSS, SPP → R_PPSW_SPP), figure modified                                                     |  |     |
|      |              | 557        | 10.6.5.4 PPON Setting Flow, Figure 10.10 PPON Setting Flow (SPP $\rightarrow$ R_PPS_W_SPP), figure modified                                                                                         |  |     |
|      |              | 559        | 10.6.6.3 VBUS Detection Flow, Figure 10.12 VBUS Detection Flow(NOCP $\rightarrow$ VBUS_INT), figure modified                                                                                        |  |     |
|      |              | 561        | 10.6.7.1 Power Management in the Host Controller, (1), Figure 10.13 Host Controller Power-Down Flow (When Using OHCI) (PS → R_PSSW_SPS, SRWE → R_DRWEW_SRWE), figure modified                       |  |     |
|      |              | 564        | 10.6.7.1 Power Management in the Host Controller, (2), Figure 10.16 Host Controller Power-Up Flow (When Using EHCI) (1. Connect/Disconnect: PORTSC1 Register), figure modified                      |  |     |
|      |              |            |                                                                                                                                                                                                     |  | 567 |
|      |              | 568        | 10.6.7.3 Direct Power-Down Feature, (1), Figure 10.20 Entering the Direct Power-Down Mode (EPCRST → EPC_RST), figure modified                                                                       |  |     |
|      |              | 571        | 10.6.7.3 Direct Power-Down Feature, (2), Figure 10.23 Exiting the Direct Power-Down Mode (Function Controller) (bit8 DIRPD=0b or → bit8 DIRPD=0b), figure modified                                  |  |     |
|      |              | 573        | 10.6.8.1 Specifying the Base Address (or the case shown in the table before the table above $\rightarrow$ example), description modified                                                            |  |     |
|      |              | 573        | 10.6.8.1 Specifying the Base Address, Table 10.135 BaseAddress settings example, title modified                                                                                                     |  |     |
|      |              | 574        | 10.6.9.1 Reset Sequence, Figure 10.24 Reset Sequence (PLL reset is (description): AHB reset → Release USB reset) , figure modified                                                                  |  |     |
|      |              | 575        | 10.6.9.2 Initial Setup Sequence, (1), Figure 10.25 Host Controller Initial Setup Sequence (1/2) (PREFETCH_EN $\rightarrow$ PREFETCH, PCI_ARBITERCTR $\rightarrow$ PCI_ARBITER_CTR), figure modified |  |     |
|      |              | 576        | 10.6.9.2 Initial Setup Sequence, (1), Figure 10.25 Host Controller Initial Setup Sequence (2/2) (PCIAHB_WIN1_CTR → AHBPCI_WIN1_CTR, others), figure modified                                        |  |     |



|      |              |            | Description                                                                                                                                                                                                            |
|------|--------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rev. | Date         | Page       | Summary                                                                                                                                                                                                                |
| 0.95 | Oct 19, 2018 | 577        | 10.6.9.2 Initial Setup Sequence, (2), Figure 10.26 Function Controller Initial Setup Sequence (PCI Configuration Registers for OHCI/EHCI initial setting → EPC initial setting), figure modified                       |
|      |              | 582        | 10.6.9.4 Function Transfer Overview, (3), Figure 10.29 DMA OUT Transfer Overview (1/3) (EP[m] Status → EP[m] Length & DMA Count, EP[m] Length & DMA Count → EP[m] Status), figure modified                             |
|      |              | 584        | 10.6.9.4 Function Transfer Overview, (3), Figure 10.29 DMA OUT Transfer Overview (3/3) (Clear this interrupt (write 0b) → (Clear this interrupt (write 1b)), figure modified                                           |
|      |              | 585        | 10.6.9.4 Function Transfer Overview, (4), Figure 10.30 DMA IN Transfer Overview (EP[m]_OUT_END_INT → EP[m]_IN_END_INT), figure modified                                                                                |
|      |              | 587        | 10.6.9.4 Function Transfer Overview, (6), Figure 10.32 Control Transfer Overview (1/3) (SETUP_INT → EP0_STALL_INT), figure modified                                                                                    |
|      |              | 588        | 10.6.9.4 Function Transfer Overview, (6), Figure 10.32 Control Transfer Overview (2/3) (Routine for the Request → Specific Routine for the Request), figure modified                                                   |
|      |              | 589        | 10.6.9.4 Function Transfer Overview, (6), Figure 10.32 Control Transfer Overview (3/3) (Routine for the Request → Request data transfer), figure modified                                                              |
|      |              | 598        | 10.6.9.4 Function Transfer Overview, (8), Table 10.156 Set Interface Request Processing (BaseAddress register → BaseAddress register etc.), description modified                                                       |
|      |              | 599        | 10.6.9.4 Function Transfer Overview, (9), Table 10.158 Device Descriptor (bMaxPacktetSize0 → bMaxPacketSize0), term modified                                                                                           |
|      |              | 599        | 10.6.9.4 Function Transfer Overview, (9), Table 10.159 Device Qualifier Descriptor (bMaxPacktetSize0→ bMaxPacketSize0, others), description modified                                                                   |
|      |              | 600        | 10.6.9.4 Function Transfer Overview, (9), Table 10.160 Configuration Descriptor and Other Speed Configuration Descriptor (bNumInterface $\rightarrow$ bNumInterfaces, MaxPower $\rightarrow$ bMaxPower), term modified |
|      |              | 603        | 10.6.9.4 Function Transfer Overview, (11) (EP1 $\rightarrow$ EP[m]), description modified                                                                                                                              |
|      |              | 604        | 10.6.9.4 Function Transfer Overview, (11), Figure 10.35 EP[m] Data Loopback (2/4) (EP[m]REQEN → EP[m]_REQEN, others), figure modified                                                                                  |
|      |              | _          | Overall of Section 11 DMA Controller (handshaking $\rightarrow$ request, handshaking $\rightarrow$ request interface), term modified                                                                                   |
|      |              | 607        | 11.1 Overview (sources → sources (request interfaces)), description added                                                                                                                                              |
|      |              | 609 to 611 | 11.3 Basic Definitions, subsection added                                                                                                                                                                               |
|      |              | 624, 625   | 11.5.9 CFG[n] — Configuration Register for Channel [n] (n = 07), DEST_PER, SS_UPD_EN, RELOAD_DST, RELOAD_SRC, SRC_HS_POL, DST_HS_POL, description modified                                                             |
|      |              | 633        | 11.5.16 RawErr — Raw Status for IntErr Interrupt Register (slave on the HRESP bus → slave), description modified                                                                                                       |
|      |              | 649        | 11.5.32 StatusInt — Combined Interrupt Status Register, DSTT ( StatusDst → StatusDstTran), term modified                                                                                                               |
|      |              | 657        | 11.5.40 ChEnReg — DMA Controller Channel Enable Register, CH_EN, description added                                                                                                                                     |
|      |              | 660        | 11.6.1 DMA Transfer Mode, description modified                                                                                                                                                                         |
|      |              | 661        | 11.6.1.1 Flow Controller and Transfer Type, Table 11.45 DMA Transfer Type and Flow Control Combination, description modified                                                                                           |
|      |              | 661        | 11.6.1.1 Flow Controller and Transfer Type, caution added                                                                                                                                                              |
|      |              | 666        | 11.6.1.3 Basic Interface Definitions, Transactions (decodes to $32 \rightarrow$ is decoded to $32$ ), description modified                                                                                             |
|      |              | 669        | 11.6.1.4 Transaction Examples, Figure 11.4 Burst DMA Transaction (AMBA bursts from $\rightarrow$ bursts from), figure modified                                                                                         |
|      |              | 670        | 11.6.1.4 Transaction Examples, (2) DMA in Burst and Single Transaction Mode at the Same Time (blk_size_bytes → blk_size_bytes_dma), description modified                                                               |
|      |              | 671        | 11.6.1.4 Transaction Examples, (2), Figure 11.5 Burst and Single DMA Transaction (AMBA bursts from → bursts from), figure modified                                                                                     |



|      |              |            | Description                                                                                                                                          |
|------|--------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rev. | Date         | Page       | Summary                                                                                                                                              |
| 0.95 | Oct 19, 2018 | 672        | 11.6.2 DMA Request Allocation (DMA Channel Allocation → DMA Request Allocation), title modified                                                      |
|      |              | 672        | 11.6.2 DMA Request Allocation, description modified                                                                                                  |
|      |              | 672        | 11.6.2 DMA Request Allocation, Table 11.47 DMA Multiplexing Channel Request Signals (Request ch → Request interface, others), description modified   |
|      |              | 672        | 11.6.2 DMA Request Allocation, Table 11.47 DMA Multiplexing Channel Request Signals, Note1, description modified                                     |
|      |              | 675        | 12.2 Signal Interfaces, Note1, description added                                                                                                     |
|      |              | 694        | 12.4.24 RTCA0DAYC — RTC Day Count Register, RTCA0DAYC, description modified                                                                          |
|      |              | 696        | 12.4.28 RTCA0CALC — RTC Calendar Count Register, description modified                                                                                |
|      |              | 696        | 12.4.29 RTCA0TCR — RTC Test Register, description added                                                                                              |
|      |              | 702        | 12.5.1.4 Reading RTCA0SRBU While Clock Counter Operation is Enabled, Figure 12.6 Reading RTCA0SRBU (Read RTCA0SUB → Read RTCA0RSUB), figure modified |
|      |              | 704        | 12.5.1.6 Writing to RTCA0SUBU Clock Counter Operation, Figure 12.8 Writing to RTCA0SUBU (RTCA0SRBU → RTCA0SUBU), title modified                      |
|      |              | 708        | 12.5.2 RTC Backup Mode, CAUTION (PWRCTRL_OPPDIV → PWRCTRL_OPPDIV of System Control), description modified                                            |
|      |              | 711        | 13.1 Overview, description modified                                                                                                                  |
|      |              | 713        | 13.4.1 CTRL_RETRIGGER — Control and Retrigger Register, description added                                                                            |
|      |              | 713        | 13.4.1 CTRL_RETRIGGER — Control and Retrigger Register, Value after reset, modified                                                                  |
|      |              | 713        | 13.4.1 CTRL_RETRIGGER — Control and Retrigger Register, WDRV, description modified                                                                   |
|      |              | 714        | 13.5 Operation, description modified                                                                                                                 |
|      |              | 714        | 13.6 Usage Notes, subsection deleted                                                                                                                 |
|      |              | 727        | 14.5.8 Interrupts and Status Registers (up to 32 bits $\rightarrow$ 3 bits), description modified                                                    |
| 1.00 | Mar 29, 2019 | _          | All sections, spelling, syntax errors and appearances are corrected, and expressions are modified properly                                           |
|      |              | 27         | 1.1.1 Overview, TrustZone, description added                                                                                                         |
|      |              | 28         | 1.2.1 Overview, MPU, description added                                                                                                               |
|      |              | 33         | 3.1 Overview, Table 3.1 2MB SRAM Summary, description deleted                                                                                        |
|      |              | 33         | 3.2 Signal Interfaces, ECC_2MB_Int, description modified                                                                                             |
|      |              | 35 to 39   | 3.4.2 RAMEDC — RAM_SYS ECC Decoder Config Register, As same, 3.4.34, description modified                                                            |
|      |              | 43         | 3.5.4 Self-Testing of the ECC Circuit, Figure 3.2 Example of ECC Error-Injection Setting Procedure, description modified                             |
|      |              |            | Overall of Section 4 4MB SRAM, (way → area), term modified                                                                                           |
|      |              | 47         | 4.1 Overview, Table 4.1 4MB SRAM Summary, description deleted                                                                                        |
|      |              | 47         | 4.2 Signal Interfaces, ECC_4MB_Int, description modified                                                                                             |
|      |              | 48 to 50   | 4.4.2 SR4EDC — SRAM 4MB ECC Decoder Config Register, As same, 4.4.34, description modified                                                           |
|      |              | 53         | 4.5.4 Self-Testing of the ECC Circuit, description modified                                                                                          |
|      |              | 53         | 4.5.4 Self-Testing of the ECC Circuit, Figure 4.2 Example of ECC Error-Injection Setting Procedure, description modified                             |
|      |              | 65         | 6.2 Signal Interfaces, DDR_ADDR, description modified                                                                                                |
|      |              | 100 to 146 | 6.4.1.53 DDR_CTL_52 — DDR-Controller Status & Control 52, As same, 6.4.1.5455, 6.4.1.58, 6.4.1.65, 6.4.1.115116, description modified                |
|      |              | 104        | 6.4.1.57 DDR_CTL_56 — DDR-Controller Status & Control 56, INT_STATUS, description modified                                                           |
|      |              | 105        | 6.4.1.59 DDR_CTL_58 — DDR-Controller Status & Control 58, INT_MASK, description modified                                                             |

|      |              |            | Description                                                                                                                              |
|------|--------------|------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Rev. | Date         | Page       | Summary                                                                                                                                  |
| 1.00 | Mar 29, 2019 | 112 to 158 | 6.4.1.69 DDR_CTL_68 — DDR-Controller Status & Control 68, As same, 6.4.1.7088, 6.4.1.124137, description modified                        |
|      |              | 163        | 6.4.2.2 DLLCTRL — MDLL Control Register, MDLLOCK, description modified                                                                   |
|      |              | 165        | 6.4.2.3 ZQCALCTRL — ZQ Calibration Control Register, Value after reset, value modified                                                   |
|      |              | 173        | 6.4.2.10 DQCALOFS1 — DQS Offset Setting, B2RSSAT, B1RSSAT, description modified                                                          |
|      |              | 224        | 7.4.3 STATUS — STATUS Register, Value after reset, value modified                                                                        |
|      |              | 226        | 7.4.4 STATUS_MASK — STATUS_MASK Register, error_mask, state_mask, description modified                                                   |
|      |              | 233 to 256 | 7.4.10 ADDR0_COL — Column Address 0 Register, As same, 7.4.1114, 7.4.25, 7.4.2730, 7.4.33, 7.4.39, description modified                  |
|      |              | 238        | 7.4.19 DMA_ADDR — DMA Address Register, description modified                                                                             |
|      |              | 241        | 7.4.23 MEM_CTRL — Memory Devices Control Register, mem3_wp, mem2_wp, mem1_wp, mem0_wp, description modified                              |
|      |              | 245        | 7.4.27 TIME_SEQ_1 — Command Sequence Timing Register 1, tww, description modified                                                        |
|      |              | 250        | 7.4.32 FIFO_STATE — FIFO Status Register, description modified                                                                           |
|      |              | 263        | 7.5.2.2 Command Sequence Encoding, Table 7.45 Command Sequence Encoding, SEQ_20, value modified                                          |
|      |              | 270        | 7.5.2.18 Sequence SEQ_15, description modified                                                                                           |
|      |              | 272        | 7.5.2.24 Sequence SEQ_22, description modified                                                                                           |
|      |              | 273        | 7.5.2.28 Sequence SEQ_26, description deleted                                                                                            |
|      |              | 288        | 7.5.4.22 QUEUE PAGE READ Command, Table 7.66 QUEUE PAGE READ Instruction Encoding, description modified                                  |
|      |              | 297        | 7.5.5 Multi LUN Work Mode, description modified                                                                                          |
|      |              | 302        | 7.6.1 Send Data to NAND Flash via Slave Interface, description modified                                                                  |
|      |              | 304        | 7.6.3 Send Data to NAND Flash via Master Interface (Using DMA), description modified                                                     |
|      |              | 306        | 7.6.4 Fast Writing and Reading of Several Pages from the Memory Using DMA, description modified                                          |
|      |              | 308        | 7.6.5 Writing of Data into Two NAND Flash Memory Devices, Figure 7.35 Writing Data into Two NAND Flash Memory Devices 1, figure modified |
|      |              | 310        | 7.6.7 Writing Data into Four NAND Flash Memory Devices, Figure 7.38 Writing Data into Four NAND Flash Memory Devices 1, figure modified  |
|      |              | 312        | 7.6.8 Reading Data from Four NAND Flash Memory Devices, Figure 7.40 Reading Data from Four NAND Flash Memory Devices 1, figure modified  |
|      |              | 314        | 7.6.9 Writing Partial Pages, description modified                                                                                        |
|      |              | 318        | 7.8.1 ADDR[n]_COL and ADDR[n]_ROW Registers, Table 7.87 Address Cycles, expression modified                                              |
|      |              | 321        | 8.1 Overview, description modified                                                                                                       |
|      |              | 322        | 8.2 Signal interfaces, caution added                                                                                                     |
|      |              | 325 to 326 | 8.4.1 config_reg — QSPI Configuration Register, description modified                                                                     |
|      |              | 328        | 8.4.2 dev_instr_rd_config_reg — Device Read Instruction Configuration Register, rd_opcode_non_xip_fld, term modified                     |
|      |              | 329        | 8.4.3 dev_instr_wr_config_reg — Device Write Instruction Configuration Register, wel_dis_fld, description modified                       |
|      |              | 332        | 8.4.6 dev_size_config_reg — Device Size Configuration Register, bytes_per_device_page_fld, description deleted                           |
|      |              | 332        | 8.4.6 dev_size_config_reg — Device Size Configuration Register, num_addr_bytes_fld, description modified                                 |
|      |              | 335        | 8.4.11 write_completion_ctrl_reg — Write Completion Control Register, disable_polling_fld, description modified                          |
|      |              | 338        | 8.4.13 irq_status_reg — Interrupt Status Register, illegal_access_det_fld, prot_wr_attempt_fld, description modified                     |



|      |              |            | Description                                                                                                                                        |
|------|--------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Rev. | Date         | Page       | Summary                                                                                                                                            |
| 1.00 | Mar 29, 2019 | 342 to 343 | 8.4.18 flash_cmd_ctrl_reg — Flash Command Control Register, description modified                                                                   |
|      |              | 349        | 8.5.4 Servicing a STIG request, description modified                                                                                               |
|      |              | 350        | 8.5.6 SPI Command Translation, term modified                                                                                                       |
|      | <br>         | 351        | 8.5.7 Selecting the Flash Instruction Type, Table 8.28 Number of Lanes for READ Instructions Supported by the N25Q128 Device, expression modified  |
|      |              | 352        | 8.5.7 Selecting the Flash Instruction Type, Table 8.29 Number of Lanes for WRITE Instructions Supported by the N25Q128 Device, expression modified |
|      |              | 358        | 8.6.5 Entering and Exiting NoCMD mode, description modified                                                                                        |
|      |              | 375 to 376 | 9.4.11 reg_presentstate — Present State Register, description modified                                                                             |
|      |              | 384        | 9.4.16 reg_clockcontrol — Clock Control Register, clkctrl_sdclkfreqsel, description modified                                                       |
|      | -            | 386        | 9.4.17 reg_timeoutcontrol — Timeout Control Register, timeout_ctrvalue, description modified                                                       |
|      |              | 388        | 9.4.19 reg_normalintrsts — Normal Interrupt Status Register, description modified                                                                  |
|      |              | 391 to 392 | 9.4.20 reg_errorintrsts — Error Interrupt Status Register, description modified                                                                    |
|      |              | 393        | 9.4.21 reg_normalintrstsena — Normal Interrupt Status Enable Register, description modified                                                        |
|      |              | 394        | 9.4.22 reg_errorintrstsena — Error Interrupt Status Enable Register, description modified                                                          |
|      |              | 395        | 9.4.23 reg_normalintrsigena — Normal Interrupt Signal Enable Register, description modified                                                        |
|      |              | 396        | 9.4.24 reg_errorintrsigena — Error Interrupt Signal Enable Register, description modified                                                          |
|      |              | 400        | 9.4.27 reg_capabilities — Capabilities Register, corecfg_maxblklength, corecfg_baseclkfreq, corecfg_timeoutclkunit, description modified           |
|      |              | 403        | 9.4.30 reg_ForceEventforAUTOCMDErrorStatus — Force Event for Auto CMD Error Status Register, description modified                                  |
|      |              | 404        | 9.4.31 reg_forceeventforerrintsts — Force Event for Error Interrupt Status Register, description modified                                          |
|      |              | 411        | 9.5.1 Non-DMA Transaction, Figure 9.2 Data Transfer Using DAT Line Sequence (Not Using DMA), description modified                                  |
|      |              | 413        | 9.5.2 DMA Transaction, Figure 9.3 Data Transfer Using DAT Line Sequence (Using DMA), description modified                                          |
|      |              | 415        | 9.5.3 ADMA Transactions, Figure 9.4 ADMA Transaction Flow, description modified                                                                    |
|      |              | 417        | 9.5.4.1 Synchronous Abort, Figure 9.5 Synchronous Abort, description modified                                                                      |
|      |              | 433 to 434 | 10.5.1.4 HCINTERRUPTSTATUS — HcInterruptStatus Register, description modified                                                                      |
|      |              | 435        | 10.5.1.5 HCINTERRUPTENABLE — HcInterruptEnable Register, description modified                                                                      |
|      |              | 436        | 10.5.1.6 HCINTERRUPTDISABLE — HcInterruptDisable Register, description modified                                                                    |
|      |              | 442        | 10.5.1.15 HCFMREMAINING — Hc Frame Remaining Register, FRT, expression modified                                                                    |
|      |              | 444        | 10.5.1.19 HCRHDESCRIPTORA — HcRhDescriptorA Register, PSM, description modified                                                                    |
|      |              | 446 to 447 | 10.5.1.21 HCRHSTATUS — HcRhStatus Register, R_LPSCW_SGP, R_LPSW_CGP, description modified                                                          |
|      |              | 449        | 10.5.1.22 HCRHPORTSTATUS1/ HCRHPORTSTATUS2 — HcRhPortStatus1/HcRhPortStatus2 Register, R_POCIW_CSS, description deleted                            |
|      |              | 458        | 10.5.2.6 USBSTS — USBSTS Register, USBINT, description modified                                                                                    |
|      |              | 464 to 465 | 10.5.2.13 PORTSC1/PORTSC2 — PORTSC1/PORTSC2 Register, description modified                                                                         |
|      |              | 487        | 10.5.4.14 EXT2 — EXT2 Register (EHCI), description added                                                                                           |
|      |              | 506        | 10.5.6.9 PCI_ARBITER_CTR — PCI Arbiter Control Register, PCIBP_MODE, PCIREQ1, PCIREQ0, expression modified                                         |
|      |              | 507        | 10.5.7.1 USB_CONTROL — USB Control Register, USBTESTMODE, description modified                                                                     |
|      |              | 514        | 10.5.7.8 USB_INT_ENA — USB Interrupt Enable Register, description added                                                                            |
|      | [            | 515 to 516 | 10.5.7.9 EP0_CONTROL — EP0 Control Register, description modified                                                                                  |



|      |              |            | Description                                                                                                                       |
|------|--------------|------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Rev. | Date         | Page       | Summary                                                                                                                           |
| 1.00 | Mar 29, 2019 | 517 to 518 | 10.5.7.10 EP0_STATUS — EP0 Status Register, description modified                                                                  |
|      | -            | 520 to 521 | 10.5.7.11 EP0_INT_ENA — EP0 Interrupt Enable Register, description modified                                                       |
|      | -            | 525 to 526 | 10.5.7.15 EP[m]_CONTROL — EP[m] Control Register (m = 115), description modified                                                  |
|      |              | 527, 529   | 10.5.7.16 EP[m]_STATUS — EP[m] Status Register (m = 115), description modified                                                    |
|      |              | 531        | 10.5.7.17 EP[m]_INT_ENA — EP[m] Interrupt Enable Register (m = 115), description modified                                         |
|      |              | 540        | 10.5.8.4 AHBBINTEN — AHB-EPC Bridge Interrupt Enable Register, description modified                                               |
|      |              | 553        | 10.6.3.1 Reset Configuration, description modified                                                                                |
|      |              | 557 to 558 | 10.6.4.3 Interrupt Signal Clear Time, value modified                                                                              |
|      |              | 561        | 10.6.5.2 VBUS Control, Table 10.133 Relationship between Register Settings and USB_PPON1/PPON2, expression modified               |
|      |              | 562        | 10.6.5.3 Overcurrent Detection Using PPON, Figure 10.9 Overcurrent Detection Using PPON, figure modified                          |
|      |              | 563        | 10.6.5.4 PPON Setting Flow, Figure 10.10 PPON Setting Flow, figure modified                                                       |
|      |              | 565        | 10.6.6.3 VBUS Detection Flow, Figure 10.12 VBUS Detection Flow, figure modified                                                   |
|      |              | 567        | 10.6.7.1 Power Management in the Host Controller, Figure 10.13 Host Controller Power-Down Flow (When Using OHCI), figure modified |
|      |              | 568        | 10.6.7.1 Power Management in the Host Controller, Figure 10.14 Host Controller Power-Down Flow (When Using EHCI), figure modified |
|      |              | 569        | 10.6.7.1 Power Management in the Host Controller, Figure 10.15 Host Controller Power-Up Flow (When Using OHCI), figure modified   |
|      |              | 570        | 10.6.7.1 Power Management in the Host Controller, Figure 10.16 Host Controller Power-Up Flow (When Using EHCI), figure modified   |
|      |              | 578        | 10.6.7.4 Notes on Suspend state transition, subsection added                                                                      |
|      |              | 582        | 10.6.9.2 Initial Setup Sequence, Figure 10.25 Host Controller Initial Setup Sequence (1/2), figure modified                       |
|      |              | 584        | 10.6.9.2 Initial Setup Sequence, Figure 10.26 Function Controller Initial Setup Sequence, figure modified                         |
|      |              | 590        | 10.6.9.4 Function Transfer Overview, Figure 10.29 DMA OUT Transfer Overview (2/3), figure modified                                |
|      |              | 592        | 10.6.9.4 Function Transfer Overview, Figure 10.30 DMA IN Transfer Overview, figure modified                                       |
|      |              | 593        | 10.6.9.4 Function Transfer Overview, Figure 10.31 Stopping a DMA Transfer, figure modified                                        |
|      |              | 597        | 10.6.9.4 Function Transfer Overview, Figure 10.33 Protocol Error NAK Processing Overview, figure modified                         |
|      |              | 602        | 10.6.9.4 Function Transfer Overview, (g) Set Configuration, Table 10.149, title modified                                          |
|      |              | 605        | 10.6.9.4 Function Transfer Overview, (k) Sync Frame, Table 10.157, title modified                                                 |
|      |              | 612        | 10.6.9.4 Function Transfer Overview, Figure 10.35 EP[m] Data Loopback (3/4), figure modified                                      |
|      |              | 615        | 11.2 Signal Interfaces, DMA[m]_HCLK, expression modified                                                                          |
|      |              | 631        | 11.5.9 CFG[n] — Configuration Register for Channel [n] (n = 07), description modified                                             |
|      |              | 635 to 639 | 11.5.12 RawTfr — Raw Status for IntTfr Interrupt Register, As same, 11.5.1316, description modified                               |
|      |              | 640 to 644 | 11.5.17 StatusTfr — Status for IntTfr Interrupt Register Register, As same, 11.5.1821, description modified                       |
|      |              | 656        | 11.5.33 ReqSrcReg — Source Software Transaction Request Register, SRC_REQ, description modified                                   |
|      |              | 657        | 11.5.34 ReqDstReg — Destination Software Transaction Request Register, DST_REQ, description modified                              |



|      |              |            | Description                                                                                                                                                    |
|------|--------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Rev. | Date         | Page       | Summary                                                                                                                                                        |
| 1.00 | Mar 29, 2019 | 658        | 11.5.35 SglRqSrcReg — Single Source Transaction Request Register, SRC_SGLREQ_WE, SRC_SGLREQ, description modified                                              |
|      |              | 659        | 11.5.36 SglRqDstReg — Single Destination Transaction Request Register, DST_SGLREQ, description modified                                                        |
|      |              | 663        | 11.5.40 ChEnReg — DMA Controller Channel Enable Register, CH_EN_WE, description modified                                                                       |
|      |              | 674        | 11.6.1.4 Transaction Examples, (1) DMA in Burst Transaction Mode Only, description modified                                                                    |
|      |              | 680        | 12.1 Overview, Figure 12.1 RTC Interfaces and Connections, figure modified                                                                                     |
|      |              | 681        | 12.2 Signal Interfaces, term modified                                                                                                                          |
|      |              | 691        | 12.4.9 RTCA0WEEK — RTC Week Count Buffer Register, description modified                                                                                        |
|      |              | 695        | 12.4.16 RTCA0SCMP — RTC Sub Count Compare Register, RTCA0SCMP, description modified                                                                            |
|      |              | 697        | 12.4.19 RTCA0ALW — RTC Alarm Week Set Register, description modified                                                                                           |
|      |              | 706        | 12.5.1.3 Reading Clock Counters While Clock Counter Operation is Enabled, description deleted                                                                  |
|      |              | 708        | 12.5.1.4 Reading RTCA0SRBU While Clock Counter Operation is Enabled, Figure 12.6 Reading RTCA0SRBU, figure modified                                            |
|      |              | 721        | 14.1 Overview, description modified                                                                                                                            |
|      |              | 721        | 14.2 Signal Interfaces, IPCM_Int[n], expression modified                                                                                                       |
|      |              | 724        | 14.4.2 IPCM[n]DSET — Mailbox[n] Destination Set Register (n = 02), description modified                                                                        |
|      |              | 725        | 14.4.3 IPCM[n]DCLEAR — Mailbox[n] Destination Clear Register (n = 02), description modified                                                                    |
|      |              | 726        | 14.4.4 IPCM[n]DSTATUS — Mailbox[n] Destination Status Register (n = 02), description modified                                                                  |
|      |              | 727 to 728 | 14.4.6 IPCM[n]MSET — Mailbox[n] Mask Set Register (n = 02), As same, 14.4.68, description modified                                                             |
|      |              | 730        | 14.4.11 IPCMMIS[n] — Masked Interrupt[n] Status Register (n = 02), MASK_INT_STAT, description modified                                                         |
|      |              | 731        | 14.4.12 IPCMRIS[n] — Raw Interrupt[n] Status Register (n = 02), RAW_INT_STAT, description modified                                                             |
|      |              | 733        | 14.5 Operation, description modified                                                                                                                           |
| 1.10 | Jun 30, 2020 | _          | All sections, spelling, syntax errors and appearances are corrected, and expressions are modified properly                                                     |
|      |              | 91         | 6.4.1.37 DDR_CTL_36 — DDR-Controller Status & Control 36, ECC_EN, description added                                                                            |
|      |              | 102        | 6.4.1.55 DDR_CTL_54 — DDR-Controller Status & Control 54, REDUC, description added                                                                             |
|      |              | 200        | 6.5.6.3 ECC Control, description added                                                                                                                         |
|      |              | 321        | 8.1 Overview, description added                                                                                                                                |
|      |              | 325        | 8.4.1 config_reg — QSPI Configuration Register, enable_ahb_decoder_fld, description modified                                                                   |
|      |              | 326        | 8.4.1 config_reg — QSPI Configuration Register, periph_cs_lines_fld, periph_sel_dec_fld, enb_legacy_ip_mode_fld, description modified                          |
|      |              | 328        | 8.4.2 dev_instr_rd_config_reg — Device Read Instruction Configuration Register, data_xfer_type_ext_mode_fld, addr_xfer_type_std_mode_fld, expression modified  |
|      |              | 329        | 8.4.3 dev_instr_wr_config_reg — Device Write Instruction Configuration Register, data_xfer_type_ext_mode_fld, addr_xfer_type_std_mode_fld, expression modified |
|      |              | 330        | 8.4.4 dev_delay_reg — QSPI Device Delay Register, d_nss_fld, description modified                                                                              |
|      |              | 332        | 8.4.6 dev_size_config_reg — Device Size Configuration Register, mem_size_on_cs3_fld, description modified                                                      |
|      |              | 335        | 8.4.11 write_completion_ctrl_reg — Write Completion Control Register, poll_rep_delay_fld, expression modified                                                  |



|      |              |      | Description                                                                                                                   |
|------|--------------|------|-------------------------------------------------------------------------------------------------------------------------------|
| Rev. | Date         | Page | Summary                                                                                                                       |
| 1.10 | Jun 30, 2020 | 336  | 8.4.12 no_of_polls_bef_exp_reg — Polling Expiration Register, no_of_polls_bef_exp_fld, expression modified                    |
|      |              | 348  | 8.5.1.1 Remapping the AHB address, description modified                                                                       |
|      |              | 349  | 8.5.2 Direct Access Controller (DAC), description modified                                                                    |
|      |              | 357  | 8.6.4 Using SPI Legacy Mode, expression modified                                                                              |
|      |              | 358  | 8.6.5.2 Exiting NoCMD mode, description modified                                                                              |
|      |              | 359  | 8.6.6 Remapping AHB addresses, description deleted                                                                            |
|      |              | 359  | 8.7 Usage Notes, description added                                                                                            |
|      |              | 380  | 9.4.13 reg_powercontrol — Power Control Register, pwrctrl_sdbuspower, description added                                       |
|      |              | 384  | 9.4.16 reg_clockcontrol — Clock Control Register, clkctrl_sdclkena, description added                                         |
|      |              | 399  | 9.4.27 reg_capabilities — Capabilities Register, corecfg_slottype, description modified                                       |
|      |              | 579  | 10.6.8 USB Function Endpoints Configuration, description added                                                                |
|      |              | 614  | 11.1 Overview, description modified                                                                                           |
|      |              | 616  | 11.3 Basic Definitions, Peripheral:, description added                                                                        |
|      |              | 616  | 11.3 Basic Definitions, Channel:, Flow controller:, description modified                                                      |
|      |              | 617  | 11.3 Basic Definitions, Transaction:, Single transaction:, Burst transaction:, description modified                           |
|      |              | 617  | 11.3 Basic Definitions, Block:, description added                                                                             |
|      | -            | 624  | 11.5.4 CTL[n] — Control Register for Channel [n] (n = 07), BLOCK_TS, description modified                                     |
|      |              | 625  | 11.5.4 CTL[n] — Control Register for Channel [n] (n = 07), TT_FC, SRC_MSIZE, DEST_MSIZE, description modified                 |
|      |              | 632  | 11.5.9 CFG[n] — Configuration Register for Channel [n] (n = 07), FIFO_MODE, FCMODE, MAX_ABRST, description modified           |
|      |              | 633  | 11.5.9 CFG[n] — Configuration Register for Channel [n] (n = 07), FIFO_EMPTY, CH_SUSP, CH_PRIOR, description modified          |
|      |              | 634  | 11.5.10 SGR[n] — Source Gather Register for Channel [n] (n = 07), expression modified                                         |
|      |              | 635  | 11.5.11 DSR[n] — Destination Scatter Register for Channel [n] (n = 07), expression modified                                   |
|      |              | 657  | 11.5.33 ReqSrcReg — Source Software Transaction Request Register, SRC_REQ, description modified                               |
|      |              | 658  | 11.5.34 ReqDstReg — Destination Software Transaction Request Register, DST_REQ, description modified                          |
|      |              | 667  | 11.6.1 DMA Transfer Mode, description modified                                                                                |
|      |              | 668  | 11.6.1.1 Flow Controller and Transfer Type, description modified                                                              |
|      |              | 668  | 11.6.1.1 Flow Controller and Transfer Type, Table 11.45 DMA Transfer Type and Flow Control Combinations, description modified |
|      |              | 669  | 11.6.1.2 Block Chaining Using Linked Lists, description added                                                                 |
|      |              | 671  | 11.6.1.2 Block Chaining Using Linked Lists, (2) Contiguous Address Between Blocks, description modified                       |
|      |              | 671  | 11.6.1.2 Block Chaining Using Linked Lists, (3) Suspension of Transfers Between Blocks, description modified                  |
|      |              | 672  | 11.6.1.2 Block Chaining Using Linked Lists, (4) Ending Multi-Block Transfers, description modified                            |
|      |              | 673  | 11.6.1.3 Basic Interface Definitions, description modified                                                                    |
|      |              | 674  | 11.6.1.3 Basic Interface Definitions, Transaction, description modified                                                       |
|      |              | 675  | 11.6.1.4 Transaction Examples, (1) DMA in Burst Transaction Mode Only, description modified                                   |



|      |              | Description |                                                                                                                                                |
|------|--------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Rev. | Date         | Page        | Summary                                                                                                                                        |
| 1.10 | Jun 30, 2020 | 678         | 11.6.1.4 Transaction Examples, Figure 11.5 Burst and Single DMA Transaction, figure modified                                                   |
|      |              | 679         | 11.6.1.5 DMAC Programing Example, subsection added                                                                                             |
| 1.20 | Dec 29, 2021 | _           | All sections, spelling, syntax errors and appearances are corrected, and expressions are modified properly                                     |
|      |              | 74          | 6.4.1.9 DDR_CTL_08 — DDR-Controller Status & Control 08, TRST_PWRON, expression modified                                                       |
|      |              | 78          | 6.4.1.17 DDR_CTL_16 — DDR-Controller Status & Control 16, TCKESR, TCKE, expression modified                                                    |
|      |              | 84          | 6.4.1.26 DDR_CTL_25 — DDR-Controller Status & Control 25, CKE_DELAY, expression modified                                                       |
|      |              | 85          | 6.4.1.27 DDR_CTL_26 — DDR-Controller Status & Control 26, CKSRX, CKSRE, expression modified                                                    |
|      |              | 87          | 6.4.1.29 DDR_CTL_28 — DDR-Controller Status & Control 28, LP_AUTO_PD_IDLE, expression modified                                                 |
|      |              | 98          | 6.4.1.50 DDR_CTL_49 — DDR-Controller Status & Control 49, COMMAND_AGE_COUNT, AGE_COUNT, expression modified                                    |
|      |              | 108         | 6.4.1.64 DDR_CTL_63 — DDR-Controller Status & Control 63, TODTH_WR, TODTL_2CMD, expression modified                                            |
|      |              | 109         | 6.4.1.65 DDR_CTL_64 — DDR-Controller Status & Control 64, RD_TO_ODTH, WR_TO_ODTH, TODTH_RD, expression modified                                |
|      |              | 110         | 6.4.1.67 DDR_CTL_66 — DDR-Controller Status & Control 66, W2W_DIFFCS_DLY, W2R_DIFFCS_DLY, R2W_DIFFCS_DLY, R2R_DIFFCS_DLY, expression modified  |
|      |              | 111         | 6.4.1.68 DDR_CTL_67 — DDR-Controller Status & Control 67, W2W_SAMECS_DLY, W2R_SAMECS_DLY, R2W_SAMECS_DLY, R2R_SAMECS_DLY, expression modified  |
|      |              | 151         | 6.4.1.123 DDR_CTL_357 — DDR-Controller Status & Control 357, TDFI_DRAM_CLK_DISABLE, TDFI_CTRL_DELAY, WRLAT_ADJ, RDLAT_ADJ, expression modified |
|      |              | 172         | 6.4.2.9 WLCTRL1 — Write Leveling Control Register 1, WL2OFS, WL1OFS, description modified                                                      |
|      |              | 173         | 6.4.2.10 DQCALOFS1 — DQS Offset Setting, DQCAL2OFS, DQCAL1OFS, description modified                                                            |
|      |              | 616         | 11.3 Basic Definitions, description added                                                                                                      |
|      |              | 632         | 11.5.9 CFG[n] — Configuration Register for Channel [n] (n = 07), HS_SEL_SRC, HS_SEL_DST, description modified                                  |
|      |              | 636         | 11.5.12 RawTfr — Raw Status for IntTfr Interrupt Register, description modified                                                                |
|      |              | 637         | 11.5.13 RawBlock — Raw Status for IntBlock Interrupt Reg, description modified                                                                 |
|      |              | 668         | 11.6.1.1 Flow Controller and Transfer Type, description modified                                                                               |
|      |              | 668         | 11.6.1.1 Flow Controller and Transfer Type, Table 11.45 DMA Transfer Type and Flow Control Combinations, description modified                  |

RZ/N1D Group, RZ/N1S Group, RZ/N1L Group User's Manual: System Control and Peripheral

Publication Date: Rev.0.50 Jun 30, 2017

Rev.1.20 Dec 29, 2021

Published by: Renesas Electronics Corporation

RZ/N1D Group, RZ/N1S Group, RZ/N1L Group

