

# USB 2.0 Hi-Speed Graphics Controller with VGA, HDMI/DVI, and Digital RGB Interfaces

**UFX6000** 

## **PRODUCT FEATURES**

#### Databook

### **Highlights**

- Single-Chip Hi-Speed USB 2.0 Graphics Adapter
- USB 2.0 Device Controller with Integrated USB 2.0 PHY
- Highly Efficient Compression Algorithm
- HDMI/DVI Display Connectivity via Integrated HDMI/DVI Controller/PHY
- VGA Display Connectivity via Integrated Video DAC
- Support for External Display Interface IC's via Digital RGB Interface
- High Performance DDR2 SDRAM Controller with Integrated DDR2 PHY

#### **Target Applications**

- USB to Video Adapters
- Docking Stations, USB Port Replicators
- Thin Clients
- USB Monitors and Projectors
- Embedded Systems

#### **Features**

- USB 2.0 Device Controller
  - Fully compliant with Universal Serial Bus Specification Revision 2.0
  - Operates in HS (480 Mbps) mode
  - Supports Control, Bulk-Out, and Interrupt-In endpoints
  - Supports vendor specific commands
  - Integrated USB 2.0 PHY
  - Integrated USB termination pull-up/pull-down resistors
  - Short circuit protection of USB differential signals

- Graphics Subsystem
  - Integrated HDMI/DVI Controller and PHY
    - Complies with DVI specification v1.0
    - Complies with HDMI specification v1.3
    - S/PDIF and I<sup>2</sup>S inputs for HDMI audio (2-channel uncompressed PCM)
    - Master I<sup>2</sup>C interface for DDC connection
  - Integrated Triple 10-bit Video DAC with VGA output
  - Digital RGB Interface
    - 12/15-bit double data rate digital RGB
      24-bit single data rate digital RGB
  - Supports up to 2048x1152 (QWXGA) with 32-bit color
  - 8-bit and 16-bit color support
  - Supports display cloning and extending
  - Standard and wide screen aspect ratios
  - Complies with VESA auto display identification
  - Gamma correction
  - Color Look-Up Table (CLUT)
  - Triple-buffered animations
  - Graphics Engine
    - Optimized algorithms for static and dynamic content
  - I<sup>2</sup>C controller
- DDR2 SDRAM Controller
  - 16-bit data bus, 13-bit address bus
  - JEDEC DDR2 compliant (JESD79-2E)
  - Integrated DDR2 SDRAM PHY
- Power
  - Reduced power operating modes
  - Supports bus-powered and self-powered operation
- Miscellaneous Features
  - Optional EEPROM controller
  - IEEE 1149.1 (JTAG) boundary scan TAP controller
- Software
  - Microsoft Windows® XP/Vista/7 drivers
- Packaging & Environmental
  - 225-ball LFBGA, lead-free RoHS compliant package
  - Commercial temperature range (0°C to +70°C)



#### Order Number:

UFX6000-VE FOR 225-BALL LFBGA Pb-FREE ROHS COMPLIANT PACKAGE (0 TO +70°C TEMP RANGE)

This product meets the halogen maximum concentration values per IEC61249-2-21 For RoHS compliance and environmental information, please visit www.smsc.com/rohs



80 ARKAY DRIVE, HAUPPAUGE, NY 11788 (631) 435-6000, FAX (631) 273-3123

#### Copyright © 2013 SMSC or its subsidiaries. All rights reserved.

Circuit diagrams and other information relating to SMSC products are included as a means of illustrating typical applications. Consequently, complete information sufficient for construction purposes is not necessarily given. Although the information has been checked and is believed to be accurate, no responsibility is assumed for inaccuracies. SMSC reserves the right to make changes to specifications and product descriptions at any time without notice. Contact your local SMSC sales office to obtain the latest specifications before placing your product order. The provision of this information does not convey to the purchaser of the described semiconductor devices any licenses under any patent rights or other intellectual property rights of SMSC or others. All sales are expressly conditional on your agreement to the terms and conditions of the most recently dated version of SMSC's standard Terms of Sale Agreement dated before the date of your order (the "Terms of Sale Agreement"). The product may contain design defects or errors known as anomalies which may cause the product's functions to deviate from published specifications. Anomaly sheets are available upon request. SMSC products are not designed, intended, authorized or warranted for use in any life support or other application where product failure could cause or contribute to personal injury or severe property damage. Any and all such uses without prior written approval of an Officer of SMSC and further testing and/or modification will be fully at the risk of the customer. Copies of this document or other SMSC literature, as well as the Terms of Sale Agreement, may be obtained by visiting SMSC's website at http://www.smsc.com. SMSC is a registered trademark of Standard Microsystems Corporation ("SMSC"). Product names and company names are the trademarks of their respective holders.

SMSC DISCLAIMS AND EXCLUDES ANY AND ALL WARRANTIES, INCLUDING WITHOUT LIMITATION ANY AND ALL IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE, AND AGAINST INFRINGEMENT AND THE LIKE, AND ANY AND ALL WARRANTIES ARISING FROM ANY COURSE OF DEALING OR USAGE OF TRADE. IN NO EVENT SHALL SMSC BE LIABLE FOR ANY DIRECT, INCIDENTAL, INDIRECT, SPECIAL, PUNITIVE, OR CONSEQUENTIAL DAMAGES; OR FOR LOST DATA, PROFITS, SAVINGS OR REVENUES OF ANY KIND; REGARDLESS OF THE FORM OF ACTION, WHETHER BASED ON CONTRACT; TORT; NEGLIGENCE OF SMSC OR OTHERS; STRICT LIABILITY; BREACH OF WARRANTY; OR OTHERWISE; WHETHER OR NOT ANY REMEDY OF BUYER IS HELD TO HAVE FAILED OF ITS ESSENTIAL PURPOSE, AND WHETHER OR NOT SMSC HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.



# **Table of Contents**

| -          | oter 1 General Terms and Conventions                        |    |
|------------|-------------------------------------------------------------|----|
| 1.1        | General Terms                                               |    |
| 1.2        | Register Nomenclature                                       | 16 |
| Char       | oter 2 Overview                                             |    |
| 2.1        | USB Controllers and PHYs                                    | 17 |
| 2.2        | Graphics Engine (GPH)                                       |    |
| 2.2        | DDR2 Controller and PHY                                     |    |
| 2.3<br>2.4 |                                                             |    |
|            | Display Controller (DISP)                                   |    |
| 2.5        |                                                             |    |
| 2.6        | System PLL (SYS)                                            |    |
| 2.7        | Video DAC (DAC)                                             |    |
| 2.8        | Audio Controller (AUDIO)                                    |    |
| 2.9        | HDMI/DVI Controller                                         |    |
| 2.10       | I2C                                                         |    |
| 2.11       | EEPROM                                                      |    |
| 2.12       | TAP Controller                                              | 21 |
| 2.13       | Performance                                                 | 21 |
| 2.14       | System Memory Map                                           | 22 |
|            |                                                             |    |
|            | oter 3 Pin Description and Configuration                    |    |
| 3.1        | Pin Assignments                                             |    |
| 3.2        | Buffer Types                                                | 43 |
|            |                                                             |    |
| Char       | oter 4 USB Controller                                       |    |
| 4.1        | Overview                                                    | 44 |
| 4.2        | USB Control Endpoint.                                       | 44 |
|            | 4.2.1 USB Vendor Commands                                   | 44 |
| 4.3        | USB Bulk Out Endpoint                                       | 46 |
| 4.4        | USB Interrupt Endpoint.                                     | 47 |
| 4.5        | USB Descriptors                                             |    |
|            | 4.5.1 USB Descriptors - UFX6000                             |    |
| 4.6        | Control and Status Registers                                |    |
|            | 4.6.1 USB Configuration Register (USB_CFG)                  |    |
|            | 4.6.2 USB Interrupt Endpoint Status Register (USB_INT_STS). |    |
|            | 4.6.3 USB Interrupt Endpoint Control Register (USB INT_CTL) |    |
|            |                                                             |    |
| Char       | oter 5 Clocks and Power Management                          |    |
| 5.1        | Overview                                                    | 63 |
| 5.2        | Power States                                                |    |
| 0.2        | 5.2.1 Power State Definitions                               |    |
|            | 5.2.2 VBUS Detection.                                       |    |
|            |                                                             |    |
| - 0        | 5.2.3 Power State Mapping Tables                            |    |
| 5.3        |                                                             |    |
| 5.4        | Pixel and System PLLs.                                      |    |
|            | 5.4.1 Overview                                              |    |
|            | 5.4.2 PLL Programming                                       |    |
|            | 5.4.3 PLL Programming Examples                              |    |
|            | 5.4.4 DDR2 Clock Frequency Considerations                   |    |
| 5.5        | USB Suspend                                                 | 70 |
| 5.6        | USB Resume                                                  | 73 |



| 5.7                     | LPM Su  | Jpport                                                         | ŀ |
|-------------------------|---------|----------------------------------------------------------------|---|
| 5.8                     |         |                                                                |   |
| 5.9                     |         | and Status Registers                                           |   |
|                         | 5.9.1   | Pixel Clock PLL Control Register (PIX_PLL_CTL)                 | 3 |
|                         | 5.9.2   | Pixel Clock PLL Stage 0 Configuration Register (PIX_PLL0_CFG)  | 3 |
|                         | 5.9.3   | Pixel Clock PLL Stage 1 Configuration Register (PIX_PLL1_CFG)  | ) |
|                         | 5.9.4   | System Clock PLL Control Register (SYS_PLL_CTL)                |   |
|                         | 5.9.5   | System Clock PLL Stage 0 Configuration Register (SYS_PLL0_CFG) |   |
|                         | 5.9.6   | System Clock PLL Stage 1 Configuration Register (SYS_PLL1_CFG) |   |
|                         | 5.9.7   | CPM Control Register (CPM_CTL)                                 |   |
|                         | 0.0.1   |                                                                | - |
| Cha                     |         | Reset Generator                                                |   |
| 6.1                     | Descrip | tion                                                           | 5 |
| Cha                     | pter 7  | Memory Controller                                              |   |
| 7.1                     |         | ew                                                             | , |
| 7.2                     |         | tion of Controller Functions                                   |   |
|                         | 7.2.1   | Address Mapper                                                 |   |
|                         | 7.2.2   | ODT Controls                                                   |   |
|                         | 7.2.3   | Refresh Controls                                               |   |
|                         | 7.2.4   | DLL Calibration                                                |   |
|                         | 7.2.5   | Power Saving Features                                          |   |
|                         | 7.2.6   | DRAM Initialization Sequence                                   |   |
| 7.3                     |         | Controller Configuration                                       |   |
| 1.0                     | 7.3.1   | Auto Initialization                                            |   |
|                         | 7.3.2   | Configuration Example                                          |   |
| 7.4                     |         | ng Modes                                                       |   |
| <i>י</i> . <del>-</del> | 7.4.1   | Moving To Power Down                                           |   |
|                         | 7.4.2   | Moving To Self Refresh                                         |   |
|                         | 7.4.3   | List of Dynamic Registers                                      |   |
|                         | 7.4.4   | Refresh Related Signals                                        |   |
|                         | 7.4.4   | Changing Clock Frequencies                                     |   |
| 7 5                     |         |                                                                |   |
| 7.5                     |         | and Status Registers                                           |   |
|                         | 7.5.1   | DDR2 Dynamic Register (DDR_DYN_REG)                            |   |
|                         | 7.5.2   | DDR2 Bank/CS Address Mapping Register (DDR_AD_MAP_BA_CS)       |   |
|                         | 7.5.3   | DDR2 Column Address Mapping Register (DDR_AD_MAP_COL)          |   |
|                         | 7.5.4   | DDR2 Row Address Mapping Register (DDR_AD_MAP_ROW)             |   |
|                         | 7.5.5   | DDR2 Timing Register 0 (DDR_TIMING_0) 107                      |   |
|                         | 7.5.6   | DDR2 Timing Register 1 (DDR_TIMING_1) 108                      |   |
|                         | 7.5.7   | DDR2 Timing Register 2 (DDR_TIMING_2) 109                      |   |
|                         | 7.5.8   | DDR2 Timing Register 3 (DDR_TIMING_3) 110                      |   |
|                         | 7.5.9   | DDR2 Timing Register 4 (DDR_TIMING_4)                          |   |
|                         | 7.5.10  | DDR2 Refresh Register (DDR_REFRESH)                            |   |
|                         | 7.5.11  | DDR2 Control Register 0 (DDR_CONTROL_0)                        |   |
|                         | 7.5.12  | DDR2 Control Register 1 (DDR_CONTROL_1)                        |   |
|                         | 7.5.13  | DDR2 Control Register 2 (DDR_CONTROL_2) 116                    |   |
|                         | 7.5.14  | DDR2 Control Register 3 (DDR_CONTROL_3) 117                    |   |
|                         | 7.5.15  | DDR2 Control Register 4 (DDR_CONTROL_4) 118                    |   |
|                         | 7.5.16  | DDR2 Control Register 5 (DDR_CONTROL_5) 119                    |   |
|                         | 7.5.17  | DDR2 Control Register 6 (DDR_CONTROL_6) 120                    |   |
|                         | 7.5.18  | DDR2 Control Register 7 (DDR_CONTROL_7) 121                    |   |
|                         | 7.5.19  | DDR2 Control Register 8 (DDR_CONTROL_8) 122                    |   |
|                         | 7.5.20  | DDR2 Control Register 9 (DDR_CONTROL_9) 123                    |   |
|                         | 7.5.21  | DDR2 Control Register 10 (DDR_CONTROL_10) 124                  |   |
|                         | 7.5.22  | DDR2 Control Register 11 (DDR_CONTROL_11) 125                  | 5 |



| 7.5.23 | DDR2 Control Register 12 (DDR_CONTROL_12)    | . 126 |
|--------|----------------------------------------------|-------|
| 7.5.24 | DDR2 Control Register 13 (DDR_CONTROL_13)    | . 127 |
| 7.5.25 | DDR2 PHY Control Register 0 (DDR_PHY_CTL_0)  | . 128 |
| 7.5.26 | DDR2 PHY Control Register 1 (DDR_PHY_CTL_1). | . 130 |
| 7.5.27 | DDR2 PHY Debug Register 0 (DDR_PHY_DEBUG_0)  | . 131 |
| 7.5.28 | DDR2 PHY Debug Register 1 (DDR_PHY_DEBUG_1)  | . 132 |
| 7.5.29 | DDR2 PHY Debug Register 2 (DDR_PHY_DEBUG_2)  | . 133 |
| 7.5.30 | DDR2 PHY Debug Register 3 (DDR_PHY_DEBUG_3)  | . 134 |
| 7.5.31 | DDR2 PHY Debug Register 4 (DDR_PHY_DEBUG_4)  | . 135 |
| 7.5.32 | DDR2 PHY Debug Register 5 (DDR_PHY_DEBUG_5)  | . 136 |
| 7.5.33 | DDR2 PHY Debug Register 6 (DDR_PHY_DEBUG_6)  | . 137 |
| 7.5.34 | DDR2 PHY Debug Register 7 (DDR_PHY_DEBUG_7)  | . 138 |
| 7.5.35 | DDR2 PHY Debug Register 8 (DDR_PHY_DEBUG_8)  | . 139 |
|        |                                              |       |

## Chapter 8 EEPROM

| 8.1 | Descripti | on                                                      | 140 |
|-----|-----------|---------------------------------------------------------|-----|
|     |           | Command Register Format                                 |     |
|     | 8.1.2     | Data Register Format                                    | 141 |
| 8.2 | EEPRON    | / Format                                                | 141 |
| 8.3 | EEPRON    | / Defaults                                              | 146 |
| 8.4 | Customiz  | zed Operation Without EEPROM                            | 147 |
|     | 8.4.1     | Initialization of SCSR Elements in Lieu of EEPROM Load  | 147 |
|     | 8.4.2     | Attribute Register Initialization                       | 147 |
|     | 8.4.3     | Descriptor RAM Initialization                           | 148 |
|     | 8.4.4     | Enable Descriptor RAM and Attribute Registers as Source | 150 |
|     | 8.4.5     | Inhibit Reset of Select SCSR Elements.                  | 150 |
| 8.5 | Control a | Ind Status Registers                                    | 151 |
|     | 8.5.1     | EEPROM Command Register (E2P_CMD).                      | 152 |
|     | 8.5.2     | EEPROM Data Register (E2P_DATA)                         | 155 |

# Chapter 9 HDMI

| 9.1 | Overview | 156 |
|-----|----------|-----|
|-----|----------|-----|

## **Chapter 10 Display Controller**

| 10.1 | Introduct | ion                                                       |
|------|-----------|-----------------------------------------------------------|
| 10.2 | Block Dia | agram                                                     |
| 10.3 | Configur  | ation                                                     |
|      | 10.3.1    | Controller Reset / Enable / Status                        |
|      | 10.3.2    | Horizontal and Vertical Timing Configuration              |
|      | 10.3.3    | Display Blanking                                          |
|      | 10.3.4    | Display Frame Buffer Processing                           |
|      | 10.3.5    | Display Data Interpretation                               |
|      | 10.3.6    | Display Cursor                                            |
|      | 10.3.7    | Combining Cursor and Display Frame Data                   |
|      | 10.3.8    | Color Lookup/Gamma Correction Via The Color Lookup Table  |
|      | 10.3.9    | Border and Blanking Insert, Color Lookup/Gamma Correction |
|      | 10.3.10   | Interface Control                                         |
| 10.4 | Display ( | Controller Programming Outline                            |
|      | 10.4.1    | Initialization                                            |
|      | 10.4.2    | System Operation                                          |
| 10.5 | Control a | and Status Registers                                      |
|      | 10.5.1    | Display Control Register (DISPLAY_CTRL) 172               |
|      | 10.5.2    | Display Status Register (DISPLAY_STATUS)                  |
|      | 10.5.3    | Display Horizontal Size Register (DISPLAY_H_SIZE) 176     |
|      | 10.5.4    | Display Horizontal Blank Register (DISPLAY_H_BLANK)       |



| 10.5.5  | Display Horizontal Sync Register (DISPLAY_H_SYNC) 178                      |
|---------|----------------------------------------------------------------------------|
| 10.5.6  | Display Vertical Size Register (DISPLAY_V_SIZE)                            |
| 10.5.7  | Display Vertical Blank Register (DISPLAY_V_BLANK)                          |
| 10.5.8  | Display Vertical Sync Register (DISPLAY_V_SYNC)                            |
| 10.5.9  | Display Frame Buffer Base Address Register (DISPLAY_FRAME_BASE_ADDR) 182   |
| 10.5.10 | Display Border Color Register (DISPLAY_BORDER_COLOR)                       |
| 10.5.11 | Display Frame Buffer Length Register (DISPLAY_FRAME_LEN)                   |
| 10.5.12 | Display Frame Base Address Changed Count Register                          |
|         | (DISPLAY_FRAME_BASE_ADDR_CHANGED_CNT)185                                   |
| 10.5.13 | Display Interface Control 0 Register (DISPLAY_INTERFACE_CTRL_0) 186        |
| 10.5.14 | Display Interface Control 1 Register (DISPLAY_INTERFACE_CTRL_1) 187        |
| 10.5.15 | Display Interface Control 2 Register (DISPLAY_INTERFACE_CTRL_2) 188        |
| 10.5.16 | Display Cursor Control Register (DISPLAY_CURSOR_CTRL)                      |
| 10.5.17 | Display Cursor Status Register (DISPLAY_CURSOR_STATUS) 192                 |
| 10.5.18 | Display Cursor Base Address Register (DISPLAY_CURSOR_BASE_ADDR) 193        |
| 10.5.19 | Display Cursor Current Base Address Register                               |
|         | (DISPLAY_CURSOR_CUR_BASE_ADDR)194                                          |
| 10.5.20 |                                                                            |
| 10.5.21 | Display Cursor Current Position Register (DISPLAY_CURSOR_CUR_POSITION) 196 |
| 10.5.22 | Display Cursor Color 0 Register (DISPLAY_CURSOR_COLOR_0) 197               |
| 10.5.23 | Display Cursor Current Color 0 Register (DISPLAY_CURSOR_CUR_COLOR_0) 198   |
| 10.5.24 | Display Cursor Color 1 Register (DISPLAY_CURSOR_COLOR_1) 199               |
| 10.5.25 | Display Cursor Current Color 1 Register (DISPLAY_CURSOR_CUR_COLOR_1) 200   |
| 10.5.26 | Display Cursor Color 2 Register (DISPLAY_CURSOR_COLOR_2) 201               |
| 10.5.27 | Display Cursor Current Color 2 Register (DISPLAY_CURSOR_CUR_COLOR_2) 202   |
| 10.5.28 | Display Cursor Color 3 Register (DISPLAY_CURSOR_COLOR_3) 203               |
| 10.5.29 | Display Cursor Current Color 3 Register (DISPLAY_CURSOR_CUR_COLOR_3) 204   |
| 10.5.30 | Display Color Lookup Table (DISPLAY_CLUT)                                  |

### **Chapter 11 Graphics Engine**

| 11.1 | Overviev  | V                                   | 206 |
|------|-----------|-------------------------------------|-----|
| 11.2 | FIFO (FC  | CT) Interface                       | 207 |
| 11.3 | Commar    | nd Parser                           | 207 |
|      | 11.3.1    | Error Checking and Handling         | 207 |
|      | 11.3.2    | Aborting Command                    | 208 |
|      | 11.3.3    | Graphics Engine Commands.           | 208 |
|      | 11.3.4    | Command Parser Implemented Commands | 208 |
| 11.4 | Direct R/ | AM Write Co-processor               | 210 |
|      | 11.4.1    | Error Checking and Handling         | 211 |
|      | 11.4.2    | Aborting Command                    | 211 |
| 11.5 | BLT Co-   | processor                           | 211 |
|      | 11.5.1    | Error Checking and Handling         | 216 |
|      | 11.5.2    | Aborting Command                    |     |
|      | 11.5.3    | Writing to Display Frame Buffer.    | 217 |
|      | 11.5.4    | DRAW_FILLED_RECTANGLE               | 217 |
|      | 11.5.5    | DRAW_RAW_RECTANGLE                  | 217 |
|      | 11.5.6    | ROP_RECTANGLE                       | 218 |
|      | 11.5.7    | ROP_RAW_RECTANGLE                   | 219 |
| 11.6 | JPEG Co   | p-processor                         | 220 |
|      | 11.6.1    | Error Checking and Handling         | 223 |
|      | 11.6.2    | Aborting Command                    | 223 |
|      | 11.6.3    | Block Diagram                       | 223 |
|      | 11.6.4    | FCT Reader / FIFO                   | 224 |
|      | 11.6.5    | Command Reader                      | 224 |
|      | 11.6.6    | Data Feeder                         | 224 |



|       | 11.6.7     | JPEG Decoder                                                         | . 224 |
|-------|------------|----------------------------------------------------------------------|-------|
|       | 11.6.8     | YCbCr Interpolation and Conversion.                                  | . 225 |
| 11.7  | Hextile C  | Co-processor                                                         | . 225 |
|       | 11.7.1     | Error Checking and Handling                                          | . 226 |
|       | 11.7.2     | Aborting Command                                                     | . 227 |
|       | 11.7.3     | Block Diagram                                                        | . 227 |
|       | 11.7.4     | FCT Reader / FIFO                                                    | . 228 |
|       | 11.7.5     | Hextile Stream Processor                                             | . 228 |
| 11.8  | JPEG-LS    | S Co-processor                                                       |       |
|       | 11.8.1     | Error Checking and Handling                                          | . 231 |
|       | 11.8.2     | Aborting Command                                                     | . 231 |
|       | 11.8.3     | Block Diagram                                                        | . 232 |
|       | 11.8.4     | Command Reading                                                      | . 232 |
|       | 11.8.5     | Data Feeding                                                         | . 232 |
|       | 11.8.6     | Header Processing                                                    | . 232 |
|       | 11.8.7     | Data Segment Decoder                                                 | . 233 |
|       | 11.8.8     | Writing to Display Frame Buffer.                                     | . 234 |
| 11.9  | General    | Error Checking and Handling                                          | . 234 |
| 11.10 | Pixel Re   | triever                                                              | . 234 |
|       | 11.10.1    | Pixel Retrieving                                                     | . 234 |
|       | 11.10.2    | Pixel Reading                                                        | . 234 |
|       | 11.10.3    | Pixel Color Data.                                                    | . 234 |
|       | 11.10.4    | Error Checking and Handling                                          | . 234 |
| 11.11 | Pixel to ( | QWORD Converter                                                      | . 235 |
|       | 11.11.1    | Memory Address                                                       | . 235 |
|       | 11.11.2    | Pixel Color Data.                                                    | . 235 |
| 11.12 | Control a  | and Status Registers                                                 | . 235 |
|       | 11.12.1    | Graphic Engine Control Register (GE_CTRL)                            | . 236 |
|       | 11.12.2    | Graphic Engine Command Status Register (GE_CMD_STATUS)               | 237   |
|       | 11.12.3    | Graphic Engine Command Info Register (GE_CMD_INFO)                   |       |
|       | 11.12.4    | Graphic Engine Command Length Register (GE_CMD_LEN)                  |       |
|       | 11.12.5    | Graphic Engine Command Offset Register (GE_CMD_OFFSET)               |       |
|       | 11.12.6    | Graphic Engine Previous Command Info Register (GE_PREV_CMD_INFO)     |       |
|       | 11.12.7    |                                                                      |       |
|       | 11.12.8    | Graphic Engine Previous Command Offset Register (GE_PREV_CMD_OFFSET) |       |
|       |            | Graphic Engine Chroma Key High Register (GE_CHROMA_KEY_HIGH)         |       |
|       | 11.12.10   | ) Graphic Engine Chroma Key Low Register (GE_CHROMA_KEY_LOW)         | . 246 |
| 11.13 | Error Re   | covery                                                               | . 247 |
|       | 11.13.1    | USB 3-Strike Error Recovery.                                         | . 247 |

## **Chapter 12 I2C Controller**

| 12.1 | I2C Cont | troller Overview                                                     | 249 |
|------|----------|----------------------------------------------------------------------|-----|
| 12.2 | I2C Sub- | Modules                                                              | 250 |
|      | 12.2.1   | Control Block                                                        | 250 |
|      | 12.2.2   | Interrupt Controller                                                 | 250 |
|      | 12.2.3   | I2C Mode Logic                                                       | 251 |
|      | 12.2.4   | I2C Data Control Logic                                               | 251 |
|      | 12.2.5   | Clock Generator                                                      | 251 |
| 12.3 | I2C Tern | ninology                                                             | 251 |
|      | 12.3.1   | I2C Bus Terms.                                                       |     |
|      | 12.3.2   | I2C Bus Transfer Terms                                               | 252 |
| 12.4 | I2C Ope  | ration                                                               | 252 |
|      | 12.4.1   | Slave Mode Operation                                                 | 252 |
|      | 12.4.2   | Master Mode Operation                                                | 254 |
|      | 12.4.3   | Prioritizing Slave-Transmit Operation Over Master-Receiver Operation | 255 |



|      | 12.4.4  | Disabling the I2C Controller.                          |     |
|------|---------|--------------------------------------------------------|-----|
|      | 12.4.5  | I2CSCL Frequency Configuration                         |     |
|      | 12.4.6  |                                                        |     |
| 12.5 | -       |                                                        |     |
|      | 12.5.1  | Control Register (I2C_CONTROL)                         |     |
|      | 12.5.2  | Target Address Register (I2C_TAR)                      |     |
|      | 12.5.3  | Slave Address Register (I2C_SAR).                      |     |
|      | 12.5.4  | Rx/Tx Data Buffer and Command Register (I2C_DATA_CMD)  |     |
|      | 12.5.5  | SCL Clock High Count Register (I2C_SCL_HCNT)           |     |
|      | 12.5.6  | SCL Clock Low Count Register (I2C_SCL_LCNT)            |     |
|      | 12.5.7  | Masked Interrupt Status Register (I2C_MIS).            |     |
|      | 12.5.8  | Interrupt Mask Register (I2C_INTR_MASK)                |     |
|      | 12.5.9  | Raw Interrupt Status Register (I2C_RIS).               |     |
|      | 12.5.10 | Receive FIFO Threshold Register (I2C_RX_TL).           |     |
|      | 12.5.11 | Transmit FIFO Threshold Register (I2C_TX_TL)           |     |
|      | 12.5.12 |                                                        |     |
|      | 12.5.13 |                                                        |     |
|      | 12.5.14 |                                                        |     |
|      | 12.5.15 |                                                        |     |
|      | 12.5.16 |                                                        |     |
|      | 12.5.17 |                                                        |     |
|      | 12.5.18 | Clear RX_DONE Interrupt Register (I2C_CLR_RX_DONE)     |     |
|      | 12.5.19 | Clear ACTIVITY Interrupt Register (I2C_CLR_ACTIVITY)   |     |
|      | 12.5.20 | Clear STOP_DET Interrupt Register (I2C_CLR_STOP_DET)   | 281 |
|      | 12.5.21 | Clear START_DET Interrupt Register (I2C_CLR_START_DET) |     |
|      | 12.5.22 | Clear GEN_CALL Interrupt Register (I2C_CLR_GEN_CALL).  | 283 |
|      | 12.5.23 | I2C Enable Register (I2C_ENABLE)                       | 284 |
|      | 12.5.24 | Status Register (I2C_STATUS)                           |     |
|      | 12.5.25 | Transmit FIFO Level Register (I2C_TXFLR)               | 287 |
|      | 12.5.26 |                                                        | 288 |
|      | 12.5.27 | Transmit Abort Source Register (I2C_TX_ABRT_SRC)       | 289 |
|      | 12.5.28 | SDA Setup Register (I2C_SDA_SETUP)                     | 291 |
|      | 12.5.29 | ACK General Call Register (I2C_ACK_GEN_CALL).          | 292 |
|      | 12.5.30 | Enable Status Register (I2C_ENABLE_STATUS).            | 293 |
|      | 12.5.31 |                                                        |     |
|      | 12.5.32 | I2C Pin Control Register (I2C_PIN).                    | 296 |
|      | 12.5.33 | Sequential Data 0 Register (I2C_SEQ_DATA_0)            | 297 |
|      | 12.5.34 | Sequential Data 1 Register (I2C_SEQ_DATA_1)            | 298 |
|      | 12.5.35 | Sequential Data 2 Register (I2C_SEQ_DATA_2)            | 299 |
|      | 12.5.36 | Sequential Data 3 Register (I2C_SEQ_DATA_3)            | 300 |
|      | 12.5.37 | Sequential Data 4 Register (I2C_SEQ_DATA_4)            | 301 |
|      | 12.5.38 | Sequential Data 5 Register (I2C_SEQ_DATA_5)            | 302 |
|      | 12.5.39 | Sequential Data 6 Register (I2C_SEQ_DATA_6)            | 303 |
|      | 12.5.40 | Sequential Data 7 Register (I2C_SEQ_DATA_7)            | 304 |
|      | 12.5.41 | Sequential Data 8 Register (I2C_SEQ_DATA_8)            | 305 |
|      | 12.5.42 | Sequential Data 9 Register (I2C_SEQ_DATA_9)            | 306 |
|      | 12.5.43 | Sequential Data 10 Register (I2C_SEQ_DATA_10)          |     |
|      | 12.5.44 | Sequential Data 11 Register (I2C_SEQ_DATA_11)          |     |
|      | 12.5.45 | Sequential Data 12 Register (I2C_SEQ_DATA_12)          |     |
|      | 12.5.46 | Sequential Data 13 Register (I2C_SEQ_DATA_13)          |     |
|      | 12.5.47 | Sequential Data 14 Register (I2C_SEQ_DATA_14)          |     |
|      | 12.5.48 | Sequential Data 15 Register (I2C_SEQ_DATA_15)          | 312 |

# Chapter 13 System Control

| 13.1 | Overview | 13 |
|------|----------|----|
|      |          |    |



| 13.2 | I2C Selection |                                                     |       |
|------|---------------|-----------------------------------------------------|-------|
| 13.3 | Control a     | and Status Registers                                | . 314 |
|      | 13.3.1        | Device ID (ID_REV).                                 | . 315 |
|      | 13.3.2        | FPGA (FPGA_REV)                                     | . 316 |
|      | 13.3.3        | Hardware Configuration Register (HW_CFG)            | . 317 |
|      | 13.3.4        | I2C Interface Selection Register (I2C_SEL)          | . 319 |
| Chap | oter 14 N     | Aiscellaneous                                       |       |
| 14.1 | Overview      | Ν                                                   | . 320 |
| 14.2 | LED Cor       | nfiguration                                         | . 320 |
| 14.3 | Audio Co      |                                                     | . 324 |
|      | 14.3.1        | I2S Audio                                           | . 324 |
|      | 14.3.2        | SDPIF Audio                                         | . 324 |
| 14.4 | Control a     | and Status Registers                                | . 325 |
|      | 14.4.1        | Data Port Select Register (DP_SEL)                  | . 326 |
|      | 14.4.2        | Data Port Command Register (DP_CMD)                 | . 328 |
|      | 14.4.3        | Data Port Address Register (DP_ADDR)                | . 329 |
|      | 14.4.4        | Data Port Data 0 Register (DP_DATA0)                | . 330 |
|      | 14.4.5        | Data Port Data 1 Register (DP_DATA1)                | . 331 |
|      | 14.4.6        | FIFO Status Register (FIFO_STATUS)                  | . 332 |
|      | 14.4.7        | Video DAC Configuration Register (VDAC_CFG)         |       |
|      | 14.4.8        | RGB Configuration Register (RGB_CFG)                | . 334 |
|      | 14.4.9        | External Reset Configuration Register (EXT_RST_CFG) |       |
|      | 14.4.10       | Audio Configuration Register (AUDIO_CFG)            | . 336 |
|      | 14.4.11       | Audio Frequency 0 Register (AUDIO_FREQ0)            | . 337 |
|      | 14.4.12       | Audio Frequency 1 Register (AUDIO_FREQ1)            | . 338 |
|      | 14.4.13       | HDMI Configuration Register (HDMI_CFG).             | . 339 |
|      | 14.4.14       |                                                     |       |
|      | 14.4.15       | LED Configuration Register 1 (LED_CFG1)             | . 341 |
|      | 14.4.16       | LED Configuration Register 2 (LED_CFG2)             | . 342 |
|      | 14.4.17       | GPIO Enable Register (GPIO_ENABLE).                 | . 343 |
|      | 14.4.18       | GPIO Buffer Type Register (GPIO_BUF)                | . 344 |
|      | 14.4.19       | GPIO Direction Register (GPIO_DIR)                  | . 345 |
|      | 14.4.20       | GPIO Data Register (GPIO_DATA).                     |       |
|      | 14.4.21       | BOS Attributes Register (BOS_ATTR)                  | . 347 |
|      | 14.4.22       |                                                     |       |
|      | 14.4.23       | FS Attributes Register (FS_ATTR)                    | . 349 |
|      | 14.4.24       | String Attributes Register 0 (STRNG_ATTR0)          | . 350 |
|      | 14.4.25       | String Attributes Register 1 (STRNG_ATTR1)          | . 351 |

## **Chapter 15 Operational Characteristics**

| Operatin | g Conditions**                                                                                                               | 352                                                                                         |
|----------|------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|
| Package  | Thermal Specifications                                                                                                       | 353                                                                                         |
| Current  | Consumption                                                                                                                  | 353                                                                                         |
| 15.4.1   | SUSPEND Power State                                                                                                          | 353                                                                                         |
| 15.4.2   | Operational                                                                                                                  | 354                                                                                         |
|          |                                                                                                                              |                                                                                             |
| AC Spec  | sifications                                                                                                                  | 356                                                                                         |
| 15.6.1   | Power Sequence Timing                                                                                                        | 357                                                                                         |
| 15.6.2   | Power-On Reset Timing                                                                                                        | 358                                                                                         |
| 15.6.3   | Reset Timing                                                                                                                 |                                                                                             |
| 15.6.4   | Video DAC Timing                                                                                                             | 359                                                                                         |
| 15.6.5   | Digital RGB Timing                                                                                                           | 360                                                                                         |
| 15.6.6   | EEPROM Timing                                                                                                                | 362                                                                                         |
|          | Operatin<br>Package<br>Current (<br>15.4.1<br>15.4.2<br>DC Spec<br>AC Spec<br>15.6.1<br>15.6.2<br>15.6.3<br>15.6.4<br>15.6.5 | 15.6.2Power-On Reset Timing15.6.3Reset Timing15.6.4Video DAC Timing15.6.5Digital RGB Timing |



| 15.7 | 15.6.7 JTAG Timing |  |
|------|--------------------|--|
|      |                    |  |

## **Chapter 17 Power Connections**

Chapter 18 Databook Revision History



# **List Of Tables**

| Table 1.1  | Register Bit Types                                          |   | 16 |
|------------|-------------------------------------------------------------|---|----|
| Table 2.1  | Graphics Engine Commands.                                   |   | 18 |
| Table 2.2  | Graphics Engine Compression Algorithms                      |   | 19 |
| Table 2.3  | UFX6000 Memory Map                                          |   |    |
|            | USB Pins                                                    |   |    |
|            | Digital RGB Pins                                            |   |    |
|            | RGB / DDR Mode Mapping Table                                |   |    |
|            | VDAC Pins.                                                  |   |    |
|            | DDR2 Memory Pins.                                           |   |    |
|            | HDMI Pins                                                   |   |    |
|            | EEPROM Pins                                                 |   |    |
|            | JTAG Pins                                                   |   |    |
|            | Miscellaneous Pins                                          |   |    |
|            | I/O Power Pins, Core Power Pins, and Ground Pins.           |   |    |
|            |                                                             |   |    |
|            | No-Connect Pins                                             |   |    |
|            | UFX6000 Bond Options                                        |   |    |
|            | 225-LFBGA Package Pin Assignments                           |   |    |
|            | Buffer Types                                                |   |    |
|            | Format of Register Write Setup Stage                        |   |    |
|            | Format of Register Write Data Stage.                        |   |    |
|            | Format of Register Read Setup Stage.                        |   |    |
|            | Format of Register Read Data Stage                          |   |    |
| Table 4.5  | Format of Register Read Setup Stage.                        | ' | 45 |
| Table 4.6  | Format of Get Statistics Setup Stage                        | ' | 46 |
| Table 4.7  | Format of Get Statistics Data Stage                         | ' | 46 |
| Table 4.8  | Interrupt Packet Format.                                    | ' | 47 |
| Table 4.9  | Device Descriptor                                           |   | 48 |
|            | Configuration Descriptor                                    |   |    |
|            | Interface Descriptor 0                                      |   |    |
|            | Endpoint 1 Descriptor                                       |   |    |
|            | Endpoint 2 Descriptor                                       |   |    |
|            | Other Speed Configuration Descriptor.                       |   |    |
|            | Device Qualifier Descriptor                                 |   |    |
|            | Binary Device Object Store Descriptor                       |   |    |
|            | USB 2.0 Extension Descriptor                                |   |    |
|            | LANGID String Descriptor                                    |   |    |
|            | String Descriptor (Indices 1-5).                            |   |    |
|            | USB Control and Status Register Map                         |   |    |
|            |                                                             |   |    |
|            | Power States                                                |   |    |
| Table 5.2  | Functionality to Power State Mapping - UFX6000              |   |    |
| Table 5.3  | Clocks                                                      |   |    |
|            | PLL Frequency Configurations                                |   |    |
|            | LPM States                                                  |   |    |
|            | LFPS States.                                                |   |    |
| Table 5.7  | Clocks and Power Management Control and Status Register Map |   |    |
| Table 6.1  | Chip Level Resets                                           |   | 85 |
| Table 7.1  | Sample Programming Values for DDR2                          |   |    |
| Table 7.2  | Memory Controller Control and Status Register Map           |   |    |
| Table 8.1  | EEPROM Format                                               |   |    |
| Table 8.2  | Configuration Flags 0                                       | 1 | 45 |
|            | EEPROM Defaults                                             |   |    |
|            | USB Control and Status Register Map                         |   |    |
| Table 10.1 | Display Cursor Status/Control Register Pairs                | 1 | 63 |





| Table 10.2 Display Controller Control and Status Register Map                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | . 171 |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Table 10.3 Cursor Modes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | . 191 |
| Table 11.1 Graphics Engine Control and Status Register Map                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | . 235 |
| Table 12.1 Clearing Method of I2C Interrupts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | . 257 |
| Table 12.2 I2C Register Map.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | . 257 |
| Table 13.1 System Control Register Map                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | . 314 |
| Table 14.1 Miscellaneous Control and Status Register Map.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | . 325 |
| Table 14.2 Data Port Select Mapping Table                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | . 327 |
| Table 15.1 Package Thermal Parameters    Image: Comparison of the table of ta | . 353 |
| Table 15.2 SUSPEND Supply Current                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |
| Table 15.3 Typical High-Speed Operational Supply Current (mA)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | . 354 |
| Table 15.4 I/O Buffer Characteristics.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | . 355 |
| Table 15.5 Video DAC - DC Characteristics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | . 356 |
| Table 15.6 Power-On Timing Values                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | . 357 |
| Table 15.7 nRESET Power-On Timing Values                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | . 358 |
| Table 15.8 nRESET Timing Values                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | . 359 |
| Table 15.9 Video DAC - AC Characteristics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | . 359 |
| Table 15.10Digital RGB Timing Values - DDR Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | . 360 |
| Table 15.11Digital RGB Timing Values - SDR Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | . 361 |
| Table 15.12EEPROM Timing Values                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | . 362 |
| Table 15.13JTAG Timing Values.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | . 363 |
| Table 15.14 Crystal Specifications                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | . 364 |
| Table 16.1 UFX6000 225-LFBGA Package Parameters                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | . 366 |
| Table 18.1 Customer Revision History                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | . 368 |



# List of Figures

| Figure 2.1  | UFX6000 System Diagram                          | . 17 |
|-------------|-------------------------------------------------|------|
| Figure 3.1  | Pin Assignments (TOP VIEW)                      | . 23 |
| Figure 5.1  | Power States                                    | . 64 |
| Figure 5.2  | VBUS Detection                                  | . 64 |
| Figure 5.3  | USB Suspend Sequence                            | . 70 |
| Figure 5.4  | Auto Suspend Actions                            | . 72 |
| Figure 5.5  | USB Resume Sequence                             |      |
| Figure 7.1  | ODT Write Timing Diagram                        |      |
| Figure 7.2  | ODT Read Timing Diagram                         |      |
| Figure 8.1  | EEPROM Access Flow Diagram                      | 141  |
| Figure 8.2  | Descriptor RAM Example                          |      |
| Figure 10.1 | Display Controller Block Diagram                | 157  |
| Figure 10.2 | Horizontal Timing                               | 158  |
| Figure 10.3 | Vertical Timing                                 | 158  |
|             | Combined Vertical and Horizontal Timing         |      |
| Figure 10.5 | Quad Word to Pixel Mapping 24 bbp               | 162  |
| Figure 10.6 | Quad Word to Pixel Mapping 16 bbp               | 162  |
| Figure 10.7 | Quad Word to Pixel Mapping 8 bbp                | 163  |
|             | Graphics Engine Block Diagram                   |      |
| Figure 11.2 | Command Parser Wait for Event Logic             | 209  |
| Figure 11.1 | JPEG Co-processor Block Diagram                 | 224  |
|             | Hextile Co-processor Block Diagram              |      |
| Figure 11.3 | JPEG-LS Co-processor Block Diagram              | 232  |
| Figure 12.1 | I2C Block Diagram                               | 250  |
|             | I2C Interface Selection.                        |      |
|             | LED Initial State Determination                 |      |
| Figure 14.2 | LED State Transitions                           | 322  |
|             | Power-On Timing                                 |      |
|             | nRESET Power-On Timing                          |      |
|             | nRESET Timing                                   |      |
|             | Digital RGB Timing - DDR Mode                   |      |
|             | Digital RGB Timing - SDR Mode                   |      |
| Figure 15.4 | EEPROM Timing                                   | 362  |
|             | JTAG Timing                                     |      |
|             | UFX6000 225-LFBGA Package Definition            |      |
|             | UFX6000 225-LFBGA Package Ball Detail           |      |
| 0           | UFX6000 225-LFBGA Recommended PCB Land Pattern. |      |
| Figure 17.1 | Power Connections                               | 367  |



# **Chapter 1 General Terms and Conventions**

# 1.1 General Terms

Below is a list of the general terms used in this document:

| ВҮТЕ                       | 8-bits                                                                                                                                                                                                                                                   |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AL                         | Posted CAS Additive Latency - Allows READ or WRITE commands to be issued prior to $t_{RCD(min)}$ with the requirement that AL <= $t_{RCD(min)}$ . The READ or WRITE command is held for the time of AL before it is issued internally to the DDR2 SDRAM. |
| BL                         | Burst Length - Maximum number of column locations that can be accessed with a given WRITE or READ command.                                                                                                                                               |
| CL                         | CAS Latency - Delay, in clocks cycles, of registering the READ command by the DDR device to the availability of the first bit of the READ DATA.                                                                                                          |
| CSR                        | Control and Status Registers                                                                                                                                                                                                                             |
| CWL                        | CAS Write Latency - Delay, in clock cycles, of registering the WRITE command by the DDR device to the registering of the first bit of Write Data.                                                                                                        |
| DDC                        | Display Data Channel                                                                                                                                                                                                                                     |
| DDRC                       | Double Data Rate Controller                                                                                                                                                                                                                              |
| DISP                       | Display Controller Module                                                                                                                                                                                                                                |
| DTS                        | Digital Theater Sound                                                                                                                                                                                                                                    |
| DTS-HD                     | Digital Theater Sound High Definition                                                                                                                                                                                                                    |
| DVI                        | Digital Visual Interface                                                                                                                                                                                                                                 |
| DWORD                      | 32-bits                                                                                                                                                                                                                                                  |
| EDID                       | Extended Display Identification Data                                                                                                                                                                                                                     |
| FIFO                       | First In First Out buffer                                                                                                                                                                                                                                |
| FSM                        | Finite State Machine                                                                                                                                                                                                                                     |
| GPIO                       | General Purpose I/O                                                                                                                                                                                                                                      |
| HDCP                       | High-bandwidth Digital Content Protection                                                                                                                                                                                                                |
| HDMI                       | High-Definition Multimedia Interface                                                                                                                                                                                                                     |
| HOST                       | External system (Includes processor, application software, etc.)                                                                                                                                                                                         |
| 12C                        | Philips Inter-Integrated Circuit (I <sup>2</sup> C) bus                                                                                                                                                                                                  |
| 12S                        | Integrated Interchip Sound bus                                                                                                                                                                                                                           |
| Level-Triggered Sticky Bit | This type of status bit is set whenever the condition that it represents is asserted. The bit remains set until the condition is no longer true, and the status bit is cleared by writing a zero.                                                        |
| LFSR                       | Linear Feedback Shift Register                                                                                                                                                                                                                           |
| LPM                        | Link Power Management                                                                                                                                                                                                                                    |



| N/A      | Not Applicable                                                                                                                                                                                                                                                               |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ODT      | On Die Termination                                                                                                                                                                                                                                                           |
| Packet   | In the context of this document a packet refers to transfers on the USB interface.                                                                                                                                                                                           |
| POR      | Power on Reset.                                                                                                                                                                                                                                                              |
| RESERVED | Refers to a reserved bit field or address. Unless otherwise noted, reserved bits must always be zero for write operations. Unless otherwise noted, values are not guaranteed when reading reserved bits. Unless otherwise noted, do not read or write to reserved addresses. |
| RL       | Read Latency - The sum of CL and AL.                                                                                                                                                                                                                                         |
| S/PDIF   | Sony Philips Digital Interface                                                                                                                                                                                                                                               |
| SCSR     | System Control and Status Registers                                                                                                                                                                                                                                          |
| URX      | USB Bulk Out Packet Receiver.                                                                                                                                                                                                                                                |
| USB      | Universal Serial Bus                                                                                                                                                                                                                                                         |
| UTX      | USB Bulk In Packet Transmitter.                                                                                                                                                                                                                                              |
| WL       | Write Latency - The sum of CWL and AL.                                                                                                                                                                                                                                       |
| WORD     | 16-bits                                                                                                                                                                                                                                                                      |
| ZLP      | Zero Length USB Packet                                                                                                                                                                                                                                                       |
|          |                                                                                                                                                                                                                                                                              |



# 1.2 Register Nomenclature

Table 1.1 describes the register bit attributes used throughout this document.

### Table 1.1 Register Bit Types

| REGISTER BIT TYPE<br>NOTATION | REGISTER BIT DESCRIPTION                                                                                                                                                                                                                                                                                                                                                       |
|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| R                             | Read: A register or bit with this attribute can be read.                                                                                                                                                                                                                                                                                                                       |
| W                             | Write: A register or bit with this attribute can be written.                                                                                                                                                                                                                                                                                                                   |
| RO                            | Read only: Read only. Writes have no effect.                                                                                                                                                                                                                                                                                                                                   |
| RS                            | Read to Set: This bit is set on read.                                                                                                                                                                                                                                                                                                                                          |
| WO                            | Write only: If a register or bit is write-only, reads will return unspecified data.                                                                                                                                                                                                                                                                                            |
| WC                            | Write One to Clear: writing a one clears the value. Writing a zero has no effect.                                                                                                                                                                                                                                                                                              |
| WAC                           | Write Anything to Clear: writing anything clears the value.                                                                                                                                                                                                                                                                                                                    |
| RC                            | Read to Clear: Contents is cleared after the read. Writes have no effect.                                                                                                                                                                                                                                                                                                      |
| LL                            | Latch Low: Clear on read of register.                                                                                                                                                                                                                                                                                                                                          |
| LH                            | Latch High: Clear on read of register.                                                                                                                                                                                                                                                                                                                                         |
| SC                            | <b>Self-Clearing:</b> Contents is self-cleared after the being set. Writes of zero have no effect. Contents can be read.                                                                                                                                                                                                                                                       |
| RO/LH                         | <b>Read Only, Latch High:</b> This mode is used by the Ethernet PHY registers. Bits with this attribute will stay high until the bit is read. After it a read, the bit will remain high, but will change to low if the condition that caused the bit to go high is removed. If the bit has not been read the bit will remain high regardless of if its cause has been removed. |
| NASR                          | <b>Not Affected by Software Reset.</b> The state of NASR bits does not change on assertion of a software reset.                                                                                                                                                                                                                                                                |
| RESERVED                      | <b>Reserved Field:</b> Reserved fields must be written with zeros to ensure future compatibility. The value of reserved bits is not guaranteed on a read.                                                                                                                                                                                                                      |



# **Chapter 2 Overview**

The UFX6000 is a high performance USB 2.0 graphics adapter with multiple graphics interfaces. The device is an ideal solution for extending a PC workspace to an additional monitor without the need for an additional internal graphics card. With applications ranging from docking stations, USB port replicators, USB monitors/projectors and embedded systems, the UFX6000 is targeted as a high performance, low cost USB-to-graphics solution.

The UFX6000 contains an integrated USB 2.0 Device Controller, USB 2.0 PHY, USB 2.0 Bulk-Out Endpoint, USB 2.0 Control Endpoint, USB 2.0 Interrupt-In Endpoint, DDR2 SDRAM Controller/PHY, Graphics Engine, HDMI/DVI Controller/PHY, Video DAC, TAP Controller, EEPROM Controller, and I<sup>2</sup>C Controller.

The internal USB Device Controller and USB PHY are compliant with the USB 2.0 Specification. The device implements Control, Interrupt-In, and Bulk-out USB Endpoints. The device accepts graphics data via the USB Bulk-Out Pipe. If the graphics data is compressed, it is decompressed via the Graphics Engine. The graphics data is then written into a frame buffer, located in the DDR2 SDRAM.

The frame buffer is retrieved from the DDR2 SDRAM by the Display Controller. The Display Controller processes the frame and transmits it to one of the supported display interfaces: HDMI/DVI, Video DAC(VGA), or the Digital RGB video interface.

An internal EEPROM controller exists to load the USB descriptors and other configuration information. The I<sup>2</sup>C controller is used to implement the management interface for the HDMI/DVI and Video DAC interfaces. The integrated IEEE 1149.1 compliant TAP controller provides boundary scan via JTAG.



Figure 2.1 UFX6000 System Diagram

# 2.1 USB Controllers and PHYs

The device receives video data and is configured by the host CPU through the USB interface. The USB interface features a USB 2.0 device controller (UDC) and PHY that are compliant with the USB 2.0 standard.

The UDC contains a USB low-level protocol interpreter that control the USB bus protocol, packet generation/extraction, PID/Device ID parsing, and CRC coding/decoding with autonomous error handling. The UDC allows the device to operate in USB 1.1 or 2.0 compliant modes. TheUDC implements three USB endpoints: Bulk-Out (URX), Control (CTL), and Interrupt-In (INT). The received



data is packed into 32-bit words which are passed to one of the supported endpoints via UDC's respective native interface.

The UDC 2.0 interfaces to the USB 2.0 PHY via a 8-bit 60 MHz UTMI compliant interface.

The USB 2.0 PHY includes a common block. The enabled common block has the additional responsibility for generating the bulk of the system clocks. In USB 2.0 mode, system clocks are typically a multiple of 60 MHz.

The common block uses a crystal oscillator which accepts a 25 MHz crystal. The oscillator can also accept a single-ended clock input.

The Bulk-Out endpoint is implemented by the URX module. This module is responsible for receiving compressed or uncompressed graphics data and drawing commands from the host.

The URX interfaces with the FIFO Controller (FCT). The FCT manages a 18 KB FIFO. The FIFO uses a store and forward architecture and supports flushing out errored Bulk-Out frames when the URX requests a rewind. In USB 2.0 mode, the USB 2.0 URX interfaces with the FCT via a 64-bit 60 MHz bus.

The FCT also serves as a mechanism to cross clock domains in USB 2.0 mode, bridging the 60 MHz clock domain where the USB logic primarily operates on 167 MHz domain. The Control module (CTL) manages traffic to/from the control endpoint that is not handled by the UDC. The CTL is responsible for handling select USB standard commands and all vendor specific commands (e.g., CSR reads and writes). The CTL also provides a direct path to the DDR2 SDRAM.

# 2.2 Graphics Engine (GPH)

The Graphics Engine module (GPH) receives a stream of commands, along with parameters and data, over the USB Bulk-Out endpoint. It executes the commands and writes the results into the display frame buffer in SDRAM via a DMA engine. The various commands range from simple memory write accesses to various decompression algorithms. The GPH supports the following commands.

| COMMAND NAME          | DESCRIPTION                                                                                                                                                                                                  |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DRAW_FILLED_RECTANGLE | This command writes a rectangle of single solid color into the frame buffer.                                                                                                                                 |
| DRAW_RAW_RECTANGLE    | This command writes a rectangle into the frame buffer. The contents of the rectangle are specified in the command.                                                                                           |
| ROP_RECTANGLE         | This command reads a source rectangle from the frame buffer, optionally performs a logic operation with the color specified in the command, and writes the rectangle into the display frame buffer.          |
|                       | The location of the source and destination rectangles can be the same, overlapping or independent areas.                                                                                                     |
| ROP_RAW_RECTANGLE     | This command reads a source rectangle from the frame buffer, optionally performs a logic operation with the raw pixel data specified in the command, and writes the rectangle into the display frame buffer. |
|                       | The location of the source and destination rectangles can be the same, overlapping or independent areas.                                                                                                     |
| DIRECT_RAM_WRITE      | This command writes the data in the command's payload into the frame buffer.                                                                                                                                 |
| WRITE_CSR             | This command allows write access to the device's control and status registers.                                                                                                                               |
| NOP                   | This command is used to wait state the graphics engine.                                                                                                                                                      |
| WAIT_FOR_EVENT        | This command instructs the GPH to pause until the event specified occurs (forced blanking status, base page pending, etc.)                                                                                   |

| Table 2.1 | Graphics | Engine | Commands |
|-----------|----------|--------|----------|
|-----------|----------|--------|----------|



| DECOMP_HEXTILE | This commands performs hextile decompression on the data in the command's payload. It is ideal for font based applications (PDF, Word processing, etc.)                                          |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DECOMP_JPEG    | This commands performs lossy JPEG decompression on the data in the command's payload. This is algorithm is ideal for video.                                                                      |
| DECOMP_JPEG_LS | This commands performs JPEG-LS decompression on the data in the command's payload. This algorithm is ideal for still images and computer generated graphics (Powerpoint, pictures, gaming, etc.) |
| PAD            | This command is used to align subsequent commands to any DWORD boundary, if needed by the driver. Other than ones complement and sequence number checking, this command has no other affect.     |
| BYPASS_JPEG    | This command is used to accept raw video in YCrCb format and color space convert it into RGB.                                                                                                    |

#### Table 2.1 Graphics Engine Commands (continued)

The device is coupled with a host PC which generates the graphics commands. These commands have been optimized for minimal CPU utilization, resulting in minimal negative impact on the user experience when the USB-to-video functionality is enabled. Optimization is particularly relevant for the decompression commands, as many popular compression algorithms are highly CPU intensive. The JPEG-D, JPEG-LS, and Hextile compression algorithms represent a reasonable trade-off between CPU load and compression performance. The expected compression ratios for the supported algorithms are detailed below.

| ALGORITHM  | APPROXIMATE<br>COMPRESSION RATIO |
|------------|----------------------------------|
| Hextile    | 8:1 to 15:1                      |
| JPEG Lossy | 15:1 to 20:1                     |
| JPEG-LS    | 2:1                              |

#### Table 2.2 Graphics Engine Compression Algorithms

In order to implement the commands, the GPH includes several memories, the largest being 8 KB. The 8KB memory size, which can store 2048 pixels, was selected to enable the GPH to buffer an entire row of the frame buffer. This functionality is needed to execute rectangle copy commands such as ROP\_RECTANGLE and ROP\_RAW\_RECTANGLE.

The GPH receives data via the read interface of the FCT. The GPH uses the FCT's 18 KB FIFO to absorb command processing latency. In the event that the GPH can not keep up with the Bulk-Out traffic, the FIFO detects that it is approaching maximum capacity which will cause the URX to back pressure the USB host. Such a scenario is common when decompressing data with a high compression ratio. The amount of data ultimately written into the frame buffer will greatly exceed the original compressed data received on the Bulk-Out pipe.

It should be noted that the theoretical maximum bandwidth on the USB 2.0 bus is 480 Mbps. Due to overhead, this number will can not be sustained in actual operation. The maximum sustained ingress rate expected to be handled by the GPH is 320 Mbps.

The egress FCT interface, and the majority of the GPH, typically operates at 167 MHz, for maximum resolution.

The GPH accesses the frame buffer in SDRAM via a 64-bit 167MHz internal bus which interfaces to the DDR2 controller. The GPH operates off of the System PLL.



# 2.3 DDR2 Controller and PHY

The device features a DDR2 Memory Controller (DCTL) and integrated DDR2 PHY. The DCTL arbitrates between the GPH, DISP, and CTL modules via the 64-bit 167 MHz internal bus. The arbiter uses strict priority methodology, with the DISP always given highest priority. The DCTL aims to efficiently utilize DDR2 bandwidth when performing read and write burst accesses to DRAM.

The DCTL allows programming of various DDR2 timing parameters: TRTP, TWTR, TRP, TRCD TRAS, TRRD, TWR, TRFC and TREF. CAS latency, additive latency, burst length, and burst type. The pad strengths and pad delays are also programmable.

The DDR2 PHY interfaces to the DCTL via a 333 MHz 32-bit data bus and connects to external SDRAM with a 333 MHz 16-bit data bus. This allows for a total bandwidth, not accounting for refreshes and overhead, of 10.66 Gbps.

# 2.4 Display Controller (DISP)

The Display Controller (DISP) module implements a CRT/LCD Controller. The DISP reads the frame buffer from the SDRAM, via a DMA engine, and generates the video signals to the various display interfaces: HDMI/DVI, Video DAC, and the Digital RGB Interface.

The DISP is responsible for inserting borders and blanking. It has a programmable video resolution of up to 2048x1152 (QWXGA) and supports up to 60 frames per second (fps). It features 8, 16 and 24-bit color support, a 256 entry color lookup table, gamma correction, and a deep pixel FIFO.

The Pixel FIFO is used to store pixel data read from the SDRAM and helps prevent display underruns by buffering instantaneous bandwidth requirements. Under run prevention also requires the DISP to have priority access to the DCTL. The Pixel FIFO has a total buffer capacity of 3KB. Its ingress interface operates off of the core clock while the egress interface utilizes the pixel clock. The latter is required because the DISP logic that interfaces to the display operates off of the pixel clock.

Another notable component of the DISP is the Video Timing Generator. It is responsible for creating horizontal sync, vertical sync, composite sync, and video blank outputs. The timing of these video outputs is programmable. Additionally, the Video Timing Generator controls the read out timing of the Pixel FIFO.

The DISP provides video content off-chip through several mechanisms. The integrated Digital RGB Interface can be used for connection to an external video scaler or timing controller. Additionally, the DISP interfaces to the internally integrated HDMI/DVI Controller and Video DAC. The DISP can only drive a single video interface at any given point in time.

# 2.5 Pixel PLL (PIX)

The pixel clock used in the device is generated by the Pixel PLL. In order to minimize system cost, the Pixel PLL shares the 25 MHz crystal used by the USB PHY. The Pixel PLL supports the generation of a 200 MHz maximum pixel clock.

The PLL is programmable and allows support for a pixel clock at lower frequencies.

# 2.6 System PLL (SYS)

The DDR2 clock and system clock used in the device is generated by the System PLL. In order to minimize system cost, the System PLL shares the 25 MHz crystal used by the USB PHY.

In typical operation the System PLL is configured to provide a 333 MHz DDR2 clock and a 167 MHz system clock. As with the Pixel PLL, this PLL is programmable to support lower frequencies.



# 2.7 Video DAC (DAC)

The device integrates three 10-bit video DACs that are used to implement an analog RGB VGA interface. The video DACs are capable of running at frequencies up to 200 MHz, allowing for UXGA resolution support and a refresh rate of 60 Hz. The video DACs are driven by the DISP and utilize the pixel clock for timing generation.

# 2.8 Audio Controller (AUDIO)

The device audio controller forms accepts digital audio data via the S/PDIF input pin. The S/PDIF stream can carry 2-channel uncompressed PCM data (IEC 60958) or a compressed bit stream for multi-channel (IEC 61937) formats. The audio controller forms the audio data into packets according to the HDMI specification. The S/PDIF input supports rates from 32 to 192 kHz. Time stamping is accomplished via a separate master clock input (MCLK). MCLK is coherent with the S/PDIF input (both were created from the same clock source). There is no setup or hold timing requirement on an input with respect to MCLK.

Single channel I2S digital audio data is also accepted by the device. The I2SCLK is obtained from the I2SCLKALT0 pin or the I2SCLKALT1 pin, depending on the setting of the CSRs. The S/PDIF input pin of the chip may alternatively function as I2SDATA, when I2S digital data functionality is enabled. When I2S audio is being processed, the WS pin is used as the word select clock.

## 2.9 HDMI/DVI Controller

The device integrates an HDMI/DVI Controller which is compliant with revision 1.3 of the HDMI specification. It consists of both a transmitter and PHY. The transmitter is driven by the DISP module. DVI output is also supported.

Note: The HDMI/DVI Controller does not support HDCP.

# 2.10 I<sup>2</sup>C

The device's I<sup>2</sup>C controller features two I<sup>2</sup>C interfaces. Either one of these interfaces can be used to implement the Display Data Channel (DDC) interface for managing a Video DAC, HDMI, DVI, or external transmitter connected via digital RGB.

## 2.11 EEPROM

The device provides an integrated EEPROM controller that allows for customizing USB descriptors and configuration flags via an external EEPROM. The EEPROM controller contains a dual port RAM used for descriptor processing by the USB2.0 CTL module.

## 2.12 TAP Controller

The integrated IEEE 1149.1 compliant TAP controller provides boundary scan via JTAG.

# 2.13 Performance

The following maximum resolutions are supported by the device.

- 1920x1200, 32-bit color, 60 fps
- 2048x1152, 32-bit color, 60 fps

In order to support these resolutions, the DCTL egress and DISP must be capable of supplying data at a maximum rate of 3.3 Gbps to the external video interfaces. The ingress bandwidth requirements are less, as the targeted update rate for the maximum resolution is 30 fps, or 1.65 Gbps.



# 2.14 System Memory Map

Table 2.3 defines the system memory map.

| Table 2.3 | UFX6000 | Memory | / Map |
|-----------|---------|--------|-------|
|-----------|---------|--------|-------|

| STARTING<br>ADDRESS | ENDING<br>ADDRESS | SIZE<br>(BYTES) | DEVICE             | CSR<br>CLOCK<br>DOMAIN<br>Note 2.1 | DESCRIPTION                 |
|---------------------|-------------------|-----------------|--------------------|------------------------------------|-----------------------------|
| 0000h               | 0FFFh             | 4096            | DDR2               | sys_clk                            | DDR2 CSR                    |
| 1000h               | 1FFFh             | 4096            | l <sup>2</sup> C   | sys_clk                            | I <sup>2</sup> C CSR        |
| 2000h               | 2FFFh             | 4096            | Display Controller | sys_clk                            | Display Controller CSR      |
| 3000h               | 3FFFh             | 4096            | System             | clk_xtal                           | System Control CSR          |
| 4000h               | 4FFFh             | 4096            | Graphics Engine    | sys_clk                            | Graphics Engine CSR         |
| 5000h               | 5FFFh             | 4096            | USB                | sys_clk                            | USB Configuration           |
| 6000h               | 6FFFh             | 4096            | EEPROM             | clk_xtal                           | EEPROM CSR                  |
| 7000h               | 7FFFh             | 4096            | PMT                | clk_xtal                           | Clocks and Power Management |
| 8000h               | 8FFFh             | 4096            | Miscellaneous      | sys_clk                            | Miscellaneous CSR           |
| 9000h               | 9FFFh             | 4096            | HDMI               | sys_clk                            | HDMI Transmitter CSR        |
| A000h               | FFFFh             | 24576           | -                  | sys_clk                            | RESERVED                    |

**Note 2.1** CSRs on clk\_xtal may be accessed before the System PLL is programmed.



# **Chapter 3 Pin Description and Configuration**

### SMSC UFX6000 225-LFBGA TOP VIEW

| r | 1                  | 2                      | 3                      | 4                      | 5                  | 6           | 7                      | 8                      | 9                      | 10                     | 11                               | 12         | 13             | 14                  | 15                           |
|---|--------------------|------------------------|------------------------|------------------------|--------------------|-------------|------------------------|------------------------|------------------------|------------------------|----------------------------------|------------|----------------|---------------------|------------------------------|
|   |                    |                        | ODRDQ7                 | nDDRDQS0               | ODRDM0             | DDRDQ1      | nDDRWE                 | ODRA10                 | DDRA3                  | DDRA9                  | DDRCK                            | nDDRCAS    | DDRA2          | ODRA4               | DDRA8                        |
|   |                    | DDRDQ5                 |                        |                        | DDRDQ6             | DDRDQ3      | DDRCKE                 | DDRBA0                 | DDRA7                  | DDRA12                 | nDDRCK                           | nDDRCS     | DDRA6          | DDRA11              | vss                          |
|   |                    | DDRDQ11                | DDRDQ12                | DDRDQ2                 | VDD18DDR           | DDRDQ4      | DDRBA1                 | DDRA1                  | DDRA5                  | nDDRRAS                | VDD18DDR                         | DDRA0      | DDRODT         | vss                 | EXTSWING                     |
|   | ODRDQS1            | DDRDM1                 | DDRDQ14                | •<br>VDD18DDR          | •<br>VDD18DDR      | DDRVREF2    | VDD18DDR               | VDD18DDR               | VDD18DDR               | VDD18DDR               | VDD18DDR                         | VDD18DDR   | VDD18DDR       | ●<br>TX2P           | TX2N                         |
|   | nDDRDQS1           | DDRDQ8                 | DDRDQ15                | VDD18DDR               | VDD18DDR           | VDD12CORE   | ●<br>VSS               | VDD12CORE              | vss                    | VDD12CORE              | •<br>VDD18DDR                    | VSSHDMI    | VDD12HDMI      | ●<br>TX1P           | TX1N                         |
|   | DDRDQ13            | DDRDQ10                | DDRVREF1               | VDD18DDR               | VDD12CORE          | vss         | ●<br>VSS               | vss                    | vss                    | vss                    | VDD12CORE                        | VSSHDMI    | VDD12HDMI      | тхор                | TXON                         |
|   | ●<br>vss           | •<br>vss               | e<br>TEST1             | •<br>vss               | vss                | vss         | •<br>vss               | vss                    | vss                    | vss                    | VDD12CORE                        | VSSHDMI    | VDD12HDMI      | тхср                | TXCN                         |
|   | ●<br>NC            | ●<br>NC                | TEST2                  | TEST3                  | VDD12CORE          | vss         | •<br>vss               | vss                    | vss                    | vss                    | VSSVDAC                          | e<br>IREF  | VSSVDAC        | VDACR               | nVDACR                       |
|   | ●<br>NC            | ●<br>NC                | •<br>VSS               | ●<br>NC                | vss                | vss         | •<br>vss               | vss                    | vss                    | vss                    | VDD33VDAC                        | VDD33VDAC  | •<br>VDD33VDAC | ●<br>VDACG          | nVDACG                       |
|   | I2CSDA1/<br>GPI027 | e<br>I2CSDA0           | I2CSCL1/<br>GPI028     | e<br>I2CSCL0           | VDD12CORE          | vss         | ♥<br>VSS               | ●<br>vss               | vss                    | vss                    | VDACREF                          | VDAC_HSYNC | VDAC_VSYNC     | VDACB               | nVDACB                       |
|   | ●<br>USBDP         | USBDM                  | VBUS_DET               | AUDIO_DIS/<br>GPIO30   | VDD33IO            | VDD12CORE   | vss                    | VDD12CORE              | vss                    | VDD12CORE              | VDD33IO                          | VDD33IO    | WS/GPIO29      | MCLK/<br>GPI025     | SPDIF/<br>I2SDATA/<br>GPI026 |
|   | ●<br>VDD33USB      | ●<br>NC                | ●<br>HPD               | VDATAB4/<br>VD3/GPIO20 | VDD33IO            | VDD33IO     | VDD33IO                | VDATAG4/<br>VD9/GPI012 | VDD33IO                | VDATAR5/<br>GPIO5      | VDD33IO                          | ●<br>TDI   | ●<br>INT       | eecs                | EECLK                        |
| Ī | ●<br>XI            | VDD12USBPLL            | USBRBIAS               | VDATAB3/<br>VD4/GPI019 | VDATAB0/<br>GPI016 | ●<br>nBLANK | VDATAG7/<br>GPI015     | VDATAG3/<br>GPI011     | VDATAG0/<br>VD11/GPI08 | VDATAR4/<br>VD13/GPI04 | VDATAR1/<br>GPIO1                | ●<br>TDO   | nEXTRST        | ●<br>NC             | ●<br>NC                      |
| Í | ,<br>xo            | SYSPLLG                | VDATAB6/<br>VD1/GPI022 | VDATAB2/<br>VD5/GPI018 | HSYNC              | nVCLK       | VDATAG6/<br>VD7/GPI014 | VDATAG2/<br>GPIO10     | VDATAR7/<br>VD12/GPI07 | VDATAR3/<br>VD14/GPI03 | VDATAR0/<br>I2SCLKALT0/<br>GPIO0 | €<br>тск   | nSW_MODE       | nRESET              | EEDI                         |
|   | SYSPLLP            | VDATAB7/<br>VD0/GPI023 | VDATAB5/<br>VD2/GPIO21 | VDATAB1/<br>VD6/GPI017 | VSYNC              | VCLK        | VDATAG5/<br>VD8/GPI013 | VDATAG1/<br>VD10/GPIO9 | VDATAR6/<br>GPIO6      | VDATAR2/<br>VD15/GPI02 | nTRST                            | TMS        | ●<br>NC        | LED/<br>I2SCLKALT1/ | EEDO                         |
| ľ | 1                  | 2                      | 3                      | 4                      | 5                  | 6           | 7                      | 8                      | 9                      | 10                     | 11                               | 12         | 13             | <sup>GPIO24</sup>   | 15                           |

Figure 3.1 Pin Assignments (TOP VIEW)



| NUM PINS | NAME                          | SYMBOL   | BUFFER<br>TYPE | DESCRIPTION                                                                                                                                                                       |
|----------|-------------------------------|----------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1        | USB<br>DMINUS                 | USBDM    | AIO            | USB Data Minus.<br>Note: The functionality of this pin may be<br>swapped to USB DPLUS via the Port<br>Swap (CFG0_PORT_SWAP) bit of<br>Configuration Flags 0 of the EEPROM.        |
| 1        | USB<br>DPLUS                  | USBDP    | AIO            | USB Data Plus.<br>Note: The functionality of this pin may be<br>swapped to USB DMINUS via the Port<br>Swap (CFG0_PORT_SWAP) bit of<br>Configuration Flags 0 of the EEPROM.        |
| 1        | External USB<br>Bias Resistor | USBRBIAS | AI             | Used for setting HS transmit current level and on-<br>chip termination impedance. Connect to an<br>external 12K 1.0% resistor to ground.                                          |
| 1        | Crystal Input                 | XI       | ICLK           | External 25 MHz crystal input.<br><b>Note:</b> This pin can also be driven by a single-<br>ended clock oscillator. When this<br>method is used, XO should be left<br>unconnected. |
| 1        | Crystal<br>Output             | XO       | OCLK           | External 25 MHz crystal output.                                                                                                                                                   |

### Table 3.1 USB Pins



### Table 3.2 Digital RGB Pins

| NUM PINS | NAME                                | SYMBOL  | BUFFER<br>TYPE                    | DESCRIPTION                                                                                                                          |
|----------|-------------------------------------|---------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 1        | Video Clock<br>High                 | VCLK    | RGB                               | Active high video clock.                                                                                                             |
| 1        | Video Clock<br>Low                  | nVCLK   | RGB                               | Active low MHz video clock.                                                                                                          |
| 1        | Horizontal<br>Sync                  | HSYNC   | RGB                               | Video horizontal synchronization output.                                                                                             |
| 1        | Vertical Sync                       | VSYNC   | RGB                               | Video vertical synchronization output.                                                                                               |
| 1        | Video<br>Blanking                   | nBLANK  | RGB                               | Active low video blanking signal.                                                                                                    |
|          | Blue Pixel<br>Data Channel<br>Bit 7 | VDATAB7 | RGB                               | Blue Pixel Video Data Bit 7, RGB Single Ended Mode.                                                                                  |
| 1        | DDR RGB<br>Data 0                   | VD0     | RGB                               | Used in RGB DDR Mode, refer to Table 3.3.                                                                                            |
|          | General<br>Purpose I/O<br>23        | GPIO23  | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully programmable as either a push-pull output, an open-drain output, or a Schmitt-triggered input. |
|          | Blue Pixel<br>Data Channel<br>Bit 6 | VDATAB6 | RGB                               | Blue Pixel Video Data Bit 6, RGB Single Ended Mode.                                                                                  |
| 1        | DDR RGB<br>Data 1                   | VD1     | RGB                               | Used in RGB DDR Mode, refer to Table 3.3.                                                                                            |
|          | General<br>Purpose I/O<br>22        | GPIO22  | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully programmable as either a push-pull output, an open-drain output, or a Schmitt-triggered input. |
|          | Blue Pixel<br>Data Channel<br>Bit 5 | VDATAB5 | RGB                               | Blue Pixel Video Data Bit 5, RGB Single Ended Mode.                                                                                  |
| 1        | DDR RGB<br>Data 2                   | VD2     | RGB                               | Used in RGB DDR Mode, refer to Table 3.3.                                                                                            |
|          | General<br>Purpose I/O<br>21        | GPIO21  | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully programmable as either a push-pull output, an open-drain output, or a Schmitt-triggered input. |
|          | Blue Pixel<br>Data Channel<br>Bit 4 | VDATAB4 | RGB                               | Blue Pixel Video Data Bit 4, RGB Single Ended Mode.                                                                                  |
| 1        | DDR RGB<br>Data 3                   | VD3     | RGB                               | Used in RGB DDR Mode, refer to Table 3.3.                                                                                            |
|          | General<br>Purpose I/O<br>20        | GPIO20  | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully programmable as either a push-pull output, an open-drain output, or a Schmitt-triggered input. |



| NUM PINS | NAME                                 | SYMBOL  | BUFFER<br>TYPE                    | DESCRIPTION                                                                                                                                |
|----------|--------------------------------------|---------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
|          | Blue Pixel<br>Data Channel<br>Bit 3  | VDATAB3 | RGB                               | Blue Pixel Video Data Bit 3, RGB Single Ended Mode.                                                                                        |
| 1        | DDR RGB<br>Data 4                    | VD4     | RGB                               | Used in RGB DDR Mode, refer to Table 3.3.                                                                                                  |
|          | General<br>Purpose I/O<br>19         | GPIO19  | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully programmable as either a push-pull output, an open-drain output, or a Schmitt-triggered input.       |
|          | Blue Pixel<br>Data Channel<br>Bit 2  | VDATAB2 | RGB                               | Blue Pixel Video Data Bit 2, RGB Single Ended Mode.                                                                                        |
| 1        | DDR RGB<br>Data 5                    | VD5     | RGB                               | Used in RGB DDR Mode, refer to Table 3.3.                                                                                                  |
|          | General<br>Purpose I/O<br>18         | GPIO18  | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input. |
|          | Blue Pixel<br>Data Channel<br>Bit 1  | VDATAB1 | RGB                               | Blue Pixel Video Data Bit 1, RGB Single Ended Mode.                                                                                        |
| 1        | DDR RGB<br>Data 6                    | VD6     | RGB                               | Used in RGB DDR Mode, refer to Table 3.3.                                                                                                  |
|          | General<br>Purpose I/O<br>17         | GPIO17  | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input. |
|          | Blue Pixel<br>Data Channel<br>Bit 0  | VDATAB0 | RGB                               | Blue Pixel Video Data Bit 0, RGB Single Ended Mode.                                                                                        |
| 1        | General<br>Purpose I/O<br>16         | GPIO16  | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input. |
|          | Green Pixel<br>Data Channel<br>Bit 7 | VDATAG7 | RGB                               | Green Pixel Video Data Bit 7, RGB Single Ended Mode.                                                                                       |
| 1        | General<br>Purpose I/O<br>15         | GPIO15  | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input. |



| NUM PINS | NAME                                 | SYMBOL  | BUFFER<br>TYPE                    | DESCRIPTION                                                                                                                                |
|----------|--------------------------------------|---------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
|          | Green Pixel<br>Data Channel<br>Bit 6 | VDATAG6 | RGB                               | Green Pixel Video Data Bit 6, RGB Single Ended Mode.                                                                                       |
| 1        | DDR RGB<br>Data 7                    | VD7     | RGB                               | Used in RGB DDR Mode, refer to Table 3.3.                                                                                                  |
|          | General<br>Purpose I/O<br>14         | GPIO14  | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully programmable as either a push-pull output, an open-drain output, or a Schmitt-triggered input.       |
|          | Green Pixel<br>Data Channel<br>Bit 5 | VDATAG5 | RGB                               | Green Pixel Video Data Bit 5, RGB Single Ended Mode.                                                                                       |
| 1        | DDR RGB<br>Data 8                    | VD8     | RGB                               | Used in RGB DDR Mode, refer to Table 3.3.                                                                                                  |
|          | General<br>Purpose I/O<br>13         | GPIO13  | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully programmable as either a push-pull output, an open-drain output, or a Schmitt-triggered input.       |
|          | Green Pixel<br>Data Channel<br>Bit 4 | VDATAG4 | RGB                               | Green Pixel Video Data Bit 4, RGB Single Ended Mode.                                                                                       |
| 1        | DDR RGB<br>Data 9                    | VD9     | RGB                               | Used in RGB DDR Mode, refer to Table 3.3.                                                                                                  |
|          | General<br>Purpose I/O<br>12         | GPIO12  | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input. |
|          | Green Pixel<br>Data Channel<br>Bit 3 | VDATAG3 | RGB                               | Green Pixel Video Data Bit 3, RGB Single Ended Mode.                                                                                       |
| 1        | General<br>Purpose I/O<br>11         | GPIO11  | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input. |
|          | Green Pixel<br>Data Channel<br>Bit 2 | VDATAG2 | RGB                               | Green Pixel Video Data Bit 2, RGB Single Ended Mode.                                                                                       |
| 1        | General<br>Purpose I/O<br>10         | GPIO10  | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input. |



| NUM PINS | NAME                                 | SYMBOL  | BUFFER<br>TYPE                    | DESCRIPTION                                                                                                                                |
|----------|--------------------------------------|---------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
|          | Green Pixel<br>Data Channel<br>Bit 1 | VDATAG1 | RGB                               | Green Pixel Video Data Bit 1, RGB Single Ended Mode.                                                                                       |
| 1        | DDR RGB<br>Data 10                   | VD10    | RGB                               | Used in RGB DDR Mode, refer to Table 3.3.                                                                                                  |
|          | General<br>Purpose I/O 9             | GPIO9   | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input. |
|          | Green Pixel<br>Data Channel<br>Bit 0 | VDATAG0 | RGB                               | Green Pixel Video Data Bit 0, RGB Single Ended Mode.                                                                                       |
| 1        | DDR RGB<br>Data 11                   | VD11    | RGB                               | Used in RGB DDR Mode, refer to Table 3.3.                                                                                                  |
|          | General<br>Purpose I/O 8             | GPIO8   | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input. |
|          | Red Pixel<br>Data Channel<br>Bit 7   | VDATAR7 | RGB                               | Red Pixel Video Data Bit 7, RGB Single Ended Mode.                                                                                         |
| 1        | DDR RGB<br>Data 12                   | VD12    | RGB                               | Used in RGB DDR Mode, refer to Table 3.3.                                                                                                  |
|          | General<br>Purpose I/O 7             | GPIO7   | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input. |
|          | Red Pixel<br>Data Channel<br>Bit 6   | VDATAR6 | RGB                               | Red Pixel Video Data Bit 6, RGB Single Ended Mode.                                                                                         |
| 1        | General<br>Purpose I/O 6             | GPIO6   | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input. |
|          | Red Pixel<br>Data Channel<br>Bit 5   | VDATAR5 | RGB                               | Red Pixel Video Data Bit 5, RGB Single Ended Mode.                                                                                         |
| 1        | General<br>Purpose I/O 5             | GPIO5   | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input. |



| NUM PINS | NAME                               | SYMBOL  | BUFFER<br>TYPE                    | DESCRIPTION                                                                                                                                |  |  |  |  |  |
|----------|------------------------------------|---------|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|          | Red Pixel<br>Data Channel<br>Bit 4 | VDATAR4 | RGB                               | Red Pixel Video Data Bit 4, RGB Single Ended Mode.                                                                                         |  |  |  |  |  |
| 1        | DDR RGB<br>Data 13                 | VD13    | RGB                               | Used in RGB DDR Mode, refer to Table 3.3.                                                                                                  |  |  |  |  |  |
|          | General<br>Purpose I/O4            | GPIO4   | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input. |  |  |  |  |  |
|          | Red Pixel<br>Data Channel<br>Bit 3 | VDATAR3 | RGB                               | Red Pixel Video Data Bit 3, RGB Single Ended Mode.                                                                                         |  |  |  |  |  |
| 1        | DDR RGB<br>Data 14                 | VD14    | RGB                               | Used in RGB DDR Mode, refer to Table 3.3.                                                                                                  |  |  |  |  |  |
|          | General<br>Purpose I/O 3           | GPIO3   | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully programmable as either a push-pull output, an open-drain output, or a Schmitt-triggered input.       |  |  |  |  |  |
|          | Red Pixel<br>Data Channel<br>Bit 2 | VDATAR2 | RGB                               | Red Pixel Video Data Bit 2, RGB Single Ended Mode.                                                                                         |  |  |  |  |  |
| 1        | DDR RGB<br>Data 15                 | VD15    | RGB                               | Used in RGB DDR Mode, refer to Table 3.3.                                                                                                  |  |  |  |  |  |
|          | General<br>Purpose I/O 2           | GPIO2   | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input. |  |  |  |  |  |
|          | Red Pixel<br>Data Channel<br>Bit 1 | VDATAR1 | RGB                               | Red Pixel Video Data Bit 1, RGB Single Ended Mode.                                                                                         |  |  |  |  |  |
| 1        | General<br>Purpose I/O 1           | GPIO1   | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input. |  |  |  |  |  |



| NUM PINS | NAME                               | SYMBOL     | BUFFER<br>TYPE                    | DESCRIPTION                                                                                                                                                                            |  |  |
|----------|------------------------------------|------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|          | Red Pixel<br>Data Channel<br>Bit 0 | VDATAR0    | RGB                               | Red Pixel Video Data Bit 0, RGB Single Ende Mode.                                                                                                                                      |  |  |
|          | I2S Clock<br>Alternate<br>Input 0  | I2SCLKALT0 | IS                                | I <sup>2</sup> S Clock alternate input 0. The I <sup>2</sup> S clock input<br>pin is selectable between the I2SCLKALT0 or<br>I2SCLKALT1 pins.                                          |  |  |
| 1        |                                    |            |                                   | Note: If the single data rate RGB interface is<br>enabled, I2SCLKALT1 should be used.<br>I2SCLKALT0 should be used in all other<br>cases.<br>Refer to the Audio Configuration Register |  |  |
|          |                                    |            |                                   | (AUDIO_CFG) on page 336 for further details.                                                                                                                                           |  |  |
|          | General<br>Purpose I/O 0           | GPIO0      | IS/O8/<br>OD8<br>(PU)<br>Note 3.1 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input.                                             |  |  |

Note 3.1 The internal pull-up is disabled when the GPIO is configured as an O8 buffer type.



.

| SDR                       |          | DDR (12-BIT I       | MODE) Note 3.2       | DDR (15-            | BIT MODE)            |  |  |  |  |  |  |
|---------------------------|----------|---------------------|----------------------|---------------------|----------------------|--|--|--|--|--|--|
| (24-BIT MODE)<br>Note 3.2 | DDR NAME | VCLK<br>RISING EDGE | VCLK<br>FALLING EDGE | VCLK<br>RISING EDGE | VCLK<br>FALLING EDGE |  |  |  |  |  |  |
| VCLK                      |          |                     |                      |                     |                      |  |  |  |  |  |  |
|                           |          | n∖                  | /CLK                 |                     |                      |  |  |  |  |  |  |
|                           |          | HS                  | SYNC                 |                     |                      |  |  |  |  |  |  |
|                           |          | VS                  | SYNC                 |                     |                      |  |  |  |  |  |  |
|                           |          | nB                  | LANK                 |                     |                      |  |  |  |  |  |  |
| VDATAB7                   | VD0      | -                   | -                    | BLUE0               | GREEN5               |  |  |  |  |  |  |
| VDATAB6                   | VD1      | -                   | -                    | BLUE1               | GREEN6               |  |  |  |  |  |  |
| VDATAB5                   | VD2      | BLUE0               | GREEN4               | BLUE2               | GREEN7               |  |  |  |  |  |  |
| VDATAB4                   | VD3      | BLUE1               | GREEN5               | BLUE3               | GREEN8               |  |  |  |  |  |  |
| VDATAB3                   | VD4      | BLUE2               | GREEN6               | BLUE4               | GREEN9               |  |  |  |  |  |  |
| VDATAB2                   | VD5      | BLUE3               | GREEN7               | BLUE5               | RED0                 |  |  |  |  |  |  |
| VDATAB1                   | VD6      | BLUE4               | RED0                 | BLUE6               | RED1                 |  |  |  |  |  |  |
| VDATAB0                   | -        | -                   | -                    | -                   | -                    |  |  |  |  |  |  |
| VDATAG7                   | -        | -                   | -                    | -                   | -                    |  |  |  |  |  |  |
| VDATAG6                   | VD7      | BLUE5               | RED1                 | BLUE7               | RED2                 |  |  |  |  |  |  |
| VDATAG5                   | VD8      | BLUE6               | RED2                 | BLUE8               | RED3                 |  |  |  |  |  |  |
| VDATAG4                   | VD9      | BLUE7               | RED3                 | BLUE9               | RED4                 |  |  |  |  |  |  |
| VDATAG3                   | -        | -                   | -                    | -                   | -                    |  |  |  |  |  |  |
| VDATAG2                   | -        | -                   | -                    | -                   | -                    |  |  |  |  |  |  |
| VDATAG1                   | VD10     | -                   | -                    | GREEN0              | RED5                 |  |  |  |  |  |  |
| VDATAG0                   | VD11     | -                   | -                    | GREEN1              | RED6                 |  |  |  |  |  |  |
| VDATAR7                   | VD12     | GREEN0              | RED4                 | GREEN2              | RED7                 |  |  |  |  |  |  |
| VDATAR6                   | -        | -                   | -                    | -                   | -                    |  |  |  |  |  |  |
| VDATAR5                   | -        | -                   | -                    | -                   | -                    |  |  |  |  |  |  |
| VDATAR4                   | VD13     | GREEN1              | RED5                 | GREEN3              | RED8                 |  |  |  |  |  |  |
| VDATAR3                   | VD14     | GREEN2              | RED6                 | GREEN4              | RED9                 |  |  |  |  |  |  |
| VDATAR2                   | VD15     | GREEN3              | RED7                 | -                   | -                    |  |  |  |  |  |  |
| VDATAR1                   | -        | -                   | -                    | -                   | -                    |  |  |  |  |  |  |
| VDATAR0                   | -        | -                   | -                    | -                   | -                    |  |  |  |  |  |  |

### Table 3.3 RGB / DDR Mode Mapping Table



# **Note 3.2** For each color channel, the eight bits come from the upper bits of the Display Color Lookup Table (DISPLAY\_CLUT).

| NUM PINS | NAME                               | SYMBOL     | BUFFER<br>TYPE | DESCRIPTION                                                                                                                                           |
|----------|------------------------------------|------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1        | VDAC<br>VSYNC                      | VDAC_VSYNC | RGB            | VDAC vertical synchronization output.                                                                                                                 |
| 1        | VDAC<br>HSYNC                      | VDAC_HSYNC | RGB            | VDAC horizontal synchronization output.                                                                                                               |
| 1        | Positive Red<br>Analog<br>Output   | VDACR      | AO             | Positive Red VDAC analog output current.                                                                                                              |
| 1        | Negative Red<br>Analog<br>Output   | nVDACR     | AO             | Negative Red VDAC analog output current.                                                                                                              |
| 1        | Positive<br>Green Analog<br>Output | VDACG      | AO             | Positive Green VDAC analog output current.                                                                                                            |
| 1        | Negative<br>Green Analog<br>Output | nVDACG     | AO             | Negative Green VDAC analog output current.                                                                                                            |
| 1        | Positive Blue<br>Analog<br>Output  | VDACB      | AO             | Positive Blue VDAC analog output current.                                                                                                             |
| 1        | Negative Blue<br>Analog<br>Output  | nVDACB     | AO             | Negative Blue VDAC analog output current.                                                                                                             |
| 1        | VDAC<br>Reference<br>Current       | IREF       | AI             | VDAC reference current. Output current when<br>using External Reference Resistor or Input<br>Reference Current when using external current<br>source. |

### Table 3.4 VDAC Pins



### Table 3.5 DDR2 Memory Pins

| NUM PINS | NAME                                          | SYMBOL      | BUFFER<br>TYPE  | DESCRIPTION                                                     |
|----------|-----------------------------------------------|-------------|-----------------|-----------------------------------------------------------------|
| 13       | DDR2<br>Memory<br>Address Bus                 | DDRA[12:0]  | DDR2O           | Bits 12:0 of the external DDR2 memory address bus.              |
| 16       | DDR2<br>Memory Data<br>Bus                    | DDRDQ[15:0] | DDR2I/<br>DDR2O | Bits 15:0 of the external DDR2 memory data bus.                 |
| 2        | DDR2<br>Memory Bank<br>Address                | DDRBA[1:0]  | DDR2O           | DDR2 memory bank address.                                       |
| 1        | DDR2<br>Memory<br>Clock High                  | DDRCK       | DDR2O           | Active high DDR2 clock. This clock is the complement of nDDRCK. |
| 1        | DDR2<br>Memory<br>Clock Low                   | nDDRCK      | DDR2O           | Active low DDR2 clock. This clock is the complement of DDRCK.   |
| 1        | DDR2<br>Memory<br>Clock Enable<br>Output      | DDRCKE      | DDR2O           | DDR2 clock enable signal.                                       |
| 1        | DDR2<br>Memory Chip<br>Select                 | nDDRCS      | DDR2O           | Active low chip select                                          |
| 1        | DDR2<br>Memory Row<br>Address<br>Strobe       | nDDRRAS     | DDR2O           | Active low row address strobe.                                  |
| 1        | DDR2<br>Memory<br>Column<br>Address<br>Strobe | nDDRCAS     | DDR2O           | Active low column address strobe.                               |
| 1        | DDR2<br>Memory Write<br>Enable                | nDDRWE      | DDR2O           | Active low write enable.                                        |
| 1        | DDR2 On Die<br>Termination                    | DDRODT      | DDR20           | DDR2 on die termination.                                        |
| 1        | DDR2<br>Memory<br>Lower Byte<br>Mask          | DDRDM0      | DDR2O           | Mask bit for lower byte of DDR2 data word.                      |
| 1        | DDR2<br>Memory<br>Upper Byte<br>Mask          | DDRDM1      | DDR2O           | Mask bit for upper byte of DDR2 data word.                      |
| 1        | DDR2<br>Memory<br>Lower Byte<br>Strobe High   | DDRDQS0     | DDR2I/<br>DDR2O | Active high data strobe for lower byte of DDR2 data word.       |



### Table 3.5 DDR2 Memory Pins (continued)

| NUM PINS | NAME                                        | SYMBOL        | BUFFER<br>TYPE  | DESCRIPTION                                                                                    |
|----------|---------------------------------------------|---------------|-----------------|------------------------------------------------------------------------------------------------|
| 1        | DDR2<br>Memory<br>Lower Byte<br>Strobe Low  | nDDRDQS0      | DDR2I/<br>DDR2O | Active low data strobe for upper byte of DDR2 data word.                                       |
| 1        | DDR2<br>Memory<br>Upper Byte<br>Strobe High | DDRDQS1       | DDR2I/<br>DDR2O | Active high data strobe for upper byte of DDR2 data word.                                      |
| 1        | DDR2<br>Memory<br>Upper Byte<br>Strobe Low  | nDDRDQS1      | DDR2I/<br>DDR2O | Active low data strobe for upper byte of DDR2 data word.                                       |
| 1        | DDR2<br>Memory<br>Reference<br>Voltage 0    | DDRVREF0      | AI              | Reference voltage input pin for DDR2 Memory.<br>DDRVREF0 must be half the VDD18DDR<br>voltage. |
| 1        | DDR2<br>Memory<br>Reference<br>Voltage 1    | DDRVREF1      | AI              | Reference voltage input pin for DDR2 Memory.<br>DDRVREF1 must be half the VDD18DDR<br>voltage. |
| 1        | DDR2<br>Memory<br>Reference<br>Voltage 2    | DDRVREF2      | AI              | Reference voltage input pin for DDR2 Memory.<br>DDRVREF2 must be half the VDD18DDR<br>voltage. |
| 1        | DQS Enable<br>Timing Match<br>Input         | DDRFIFOWE_IN  | DDR2I           | DQS enable input for timing match between DQS and system clock.                                |
| 1        | DQS Enable<br>Timing Match<br>Output        | DDRFIFOWE_OUT | DDR2O           | DQS enable output for timing match between DQS and system clock.                               |

#### Table 3.6 HDMI Pins

| NUM PINS | NAME                      | SYMBOL | BUFFER<br>TYPE | DESCRIPTION                                     |
|----------|---------------------------|--------|----------------|-------------------------------------------------|
| 1        | TMDS<br>Clock<br>Positive | ТХСР   | AO             | TMDS clock output differential positive signal. |
| 1        | TMDS Clock<br>Negative    | TXCN   | AO             | TMDS clock output differential negative signal. |
| 1        | TMDS Out0<br>Positive     | TX0P   | AO             | TMDS Output 0 differential positive signal.     |
| 1        | TMDS Out0<br>Negative     | TX0N   | AO             | TMDS Output 0 differential negative signal.     |
| 1        | TMDS Out1<br>Positive     | TX1P   | AO             | TMDS Output 1 differential positive signal.     |



### Table 3.6 HDMI Pins (continued)

| NUM PINS | NAME                    | SYMBOL   | BUFFER<br>TYPE | DESCRIPTION                                                                                                                                                                                 |
|----------|-------------------------|----------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1        | TMDS Out1<br>Negative   | TX1N     | AO             | TMDS Output 1 differential negative signal.                                                                                                                                                 |
| 1        | TMDS Out2<br>Positive   | TX2P     | AO             | TMDS Output 2 differential positive signal.                                                                                                                                                 |
| 1        | TMDS Out2<br>Negative   | TX2N     | AO             | TMDS Output 2 differential negative signal.                                                                                                                                                 |
| 1        | Voltage<br>Swing Adjust | EXTSWING | AI             | Connect this pin to an external resistor going to ground. The resistor determines the amplitude of the voltage swing. A low capacitive connection is allowed. A value of 5K is recommended. |
| 1        | Hot Plug<br>Detect      | HPD      | IS_5V          | Note: Hot plug detect signal.                                                                                                                                                               |

#### Table 3.7 EEPROM Pins

| NUM PINS | NAME                  | SYMBOL | BUFFER<br>TYPE | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------|-----------------------|--------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1        | EEPROM<br>Data In     | EEDI   | IS<br>(PD)     | This pin is driven by the EEDO output of the external EEPROM.                                                                                                                                                                                                                                                                                                                                                              |
| 1        | EEPROM<br>Data Out    | EEDO   | O8             | This pin drives the EEDI input of the external EEPROM.                                                                                                                                                                                                                                                                                                                                                                     |
| 1        | EEPROM<br>Chip Select | EECS   | O8             | This pin drives the chip select output of the<br>external EEPROM.<br>Note: The EECS output may tri-state briefly<br>during power-up. Some EEPROM<br>devices may be prone to false selection<br>during this time. When an EEPROM is<br>used, an external pull-down resistor is<br>recommended on this signal to prevent<br>false selection. Refer to your EEPROM<br>manufacturer's datasheet for additional<br>information. |
| 1        | EEPROM<br>Clock       | EECLK  | O8             | This pin drives the EEPROM clock of the external EEPROM.                                                                                                                                                                                                                                                                                                                                                                   |

### Table 3.8 JTAG Pins

| NUM PINS | NAME                  | SYMBOL | BUFFER<br>TYPE | DESCRIPTION                                                                     |
|----------|-----------------------|--------|----------------|---------------------------------------------------------------------------------|
| 1        | JTAG Test<br>Data Out | TDO    | O8             | JTAG data output.                                                               |
| 1        | JTAG Test<br>Clock    | ТСК    | IS             | JTAG test clock.<br>The maximum operating frequency of this clock is<br>10 MHz. |



### Table 3.8 JTAG Pins (continued)

| NUM PINS | NAME                     | SYMBOL | BUFFER<br>TYPE | DESCRIPTION                              |
|----------|--------------------------|--------|----------------|------------------------------------------|
| 1        | JTAG Test<br>Mode Select | TMS    | IS             | JTAG test mode select.                   |
| 1        | JTAG Test<br>Data Input  | TDI    | IS             | JTAG data input.                         |
| 1        | JTAG Test<br>Port Reset  | nTRST  | IS             | <b>Note:</b> JTAG test port reset input. |

#### Table 3.9 Miscellaneous Pins

| NUM PINS | NAME                              | SYMBOL     | BUFFER<br>TYPE                    | DESCRIPTION                                                                                                                                                                                              |
|----------|-----------------------------------|------------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | LED                               | LED        | 08/<br>OD8<br>(PU)                | Can be used to provide device status.<br>Alternatively, the LED can be configured for a fast<br>or slow blink in accordance with the USB<br>graphics data receive rate.                                  |
|          | I2S Clock<br>Alternate<br>Input 1 | I2SCLKALT1 | IS                                | I <sup>2</sup> S Clock alternate input 1. The I <sup>2</sup> S clock input pin is selectable between the I2SCLKALT0 or I2SCLKALT1 pins.                                                                  |
| 1        |                                   |            |                                   | Note: If the single data rate RGB interface is<br>enabled, I2SCLKALT1 should be used.<br>I2SCLKALT0 should be used in all other<br>cases.                                                                |
|          |                                   |            |                                   | Refer to the Audio Configuration Register<br>(AUDIO_CFG) on page 336 for further details.                                                                                                                |
|          | General<br>Purpose I/O<br>24      | GPIO24     | IS/O8/<br>OD8<br>(PU)<br>Note 3.3 | This General Purpose I/O pin is fully programmable as either a push-pull output, an open-drain output, or a Schmitt-triggered input.                                                                     |
| 1        | Interrupt                         | INT        | IS                                | For use by external transmitter to signal an event requiring servicing.                                                                                                                                  |
| 1        | External<br>Reset                 | nEXTRST    | O8                                | Used to reset external transmitter.<br><b>Note:</b> The External Reset Configuration<br>Register (EXT_RST_CFG) on page 335<br>controls the characteristics of the reset<br>signal generated on this pin. |
|          | Switching<br>Regulator<br>Mode    | nSW_MODE   | O8                                | When asserted, this pin can be used to place the external switching regulator into power saving mode.                                                                                                    |
| 1        |                                   |            |                                   | Note: The SW_MODE Polarity<br>(CFG0_SW_MODE_POL) bit of<br>Configuration Flags 0 controls the<br>polarity of the pin.                                                                                    |



#### Table 3.9 Miscellaneous Pins (continued)

| NUM PINS | NAME                         | SYMBOL   | BUFFER<br>TYPE                           | DESCRIPTION                                                                                                                                                                                                                                                               |  |  |  |
|----------|------------------------------|----------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 1        | System Reset                 | nRESET   | IS                                       | This active-low pin allows external hardware to reset the device.                                                                                                                                                                                                         |  |  |  |
|          | Detect                       | VBUS_DET | IS_5V                                    | Detects state of upstream bus power.                                                                                                                                                                                                                                      |  |  |  |
|          | Upstream<br>VBUS Power       |          |                                          | For bus powered operation, this pin must be tied to VDD33IO.                                                                                                                                                                                                              |  |  |  |
| 1        |                              |          |                                          | For self powered operation, refer to the device reference schematics.                                                                                                                                                                                                     |  |  |  |
|          |                              |          |                                          | <b>Note:</b> The VBUS_DET signal is deglitched for a period of 10 ms.                                                                                                                                                                                                     |  |  |  |
| 1        | I <sup>2</sup> C Data 0      | I2CSDA0  | IS_5V/<br>OD8<br>Note 3.4                | Bi-directional I <sup>2</sup> C data 0 signal.                                                                                                                                                                                                                            |  |  |  |
| 1        | I <sup>2</sup> C Clock 0     | I2CSCL0  | IS_5V/<br>OD8<br>Note 3.4                | Bi-directional I <sup>2</sup> C clock 0 signal. All I <sup>2</sup> C transactions are synchronous to the rising edge of this clock. The device supports J <sup>2</sup> C standard mode operation (100 Kb/s). As an I <sup>2</sup> C master, the device drives this clock. |  |  |  |
| 1        | l <sup>2</sup> C Data 1      | I2CSDA1  | IS_5V/<br>OD8<br>Note 3.4                | Bi-directional I <sup>2</sup> C data 1 signal.                                                                                                                                                                                                                            |  |  |  |
|          | General<br>Purpose I/O<br>27 | GPIO27   | IS_5V/<br>08/<br>0D8<br>(PU)<br>Note 3.3 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input.                                                                                                                                |  |  |  |
|          | I <sup>2</sup> C Clock 1     | I2CSCL1  | IS_5V/<br>OD8<br>Note 3.4                | Bi-directional I <sup>2</sup> C clock 1 signal. All I <sup>2</sup> C transactions are synchronous to the rising edge of this clock. The device supports I <sup>2</sup> C standard mode operation (100 Kb/s). As an I <sup>2</sup> C master, the device drives this clock. |  |  |  |
| 1        | General<br>Purpose I/O<br>28 | GPIO28   | IS_5V/<br>O8/<br>OD8<br>(PU)<br>Note 3.3 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input.                                                                                                                                |  |  |  |
|          | Audio Input<br>Master Clock  | MCLK     | IS                                       | Audio input master clock is coherent with the S/PDIF audio input.                                                                                                                                                                                                         |  |  |  |
| 1        | General<br>Purpose I/O<br>25 | GPIO25   | IS/O8/<br>OD8<br>(PU)<br>Note 3.3        | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input.                                                                                                                                |  |  |  |



#### Table 3.9 Miscellaneous Pins (continued)

| NUM PINS | NAME                         | SYMBOL    | BUFFER<br>TYPE                    | DESCRIPTION                                                                                                                                                                      |
|----------|------------------------------|-----------|-----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | S/PDIF Audio<br>Input        | SPDIF     | IS                                | Digital audio interface input. Supports PCM,<br>Dolby Digital, and DTS Digital audio<br>transmission.<br>Note: Usage of SPDIF requires the MCLK<br>audio input master clock pin. |
| 1        | I2S Data                     | I2SDATA   | IS                                | I2S Data input.                                                                                                                                                                  |
|          | General<br>Purpose I/O<br>26 | GPIO26    | IS/O8/<br>OD8<br>(PU)<br>Note 3.3 | This General Purpose I/O pin is fully<br>programmable as either a push-pull output, an<br>open-drain output, or a Schmitt-triggered input.                                       |
|          | Audio Word<br>Select         | WS        | IS                                | Specifies the I <sup>2</sup> S word select input of the audio processor.                                                                                                         |
| 1        | General<br>Purpose I/O<br>29 | GPIO29    | IS/O8/<br>OD8<br>(PU)<br>Note 3.3 | This General Purpose I/O pin is fully programmable as either a push-pull output, an open-drain output, or a Schmitt-triggered input.                                             |
|          | Audio<br>CODEC<br>Disconnect | AUDIO_DIS | O8                                | This pin is used for disconnecting an external USB audio CODEC.<br>Refer to the UFX6000 reference schematic for                                                                  |
| 1        |                              |           |                                   | additional details.                                                                                                                                                              |
|          | General<br>Purpose I/O<br>30 | GPIO30    | IS/O8/<br>OD8<br>(PU)<br>Note 3.3 | This General Purpose I/O pin is fully programmable as either a push-pull output, an open-drain output, or a Schmitt-triggered input.                                             |
| 1        | Test 1                       | TEST1     | -                                 | This pin must always be connected to VSS.                                                                                                                                        |
| 1        | Test 2                       | TEST2     | -                                 | This pin must always be connected to VSS.                                                                                                                                        |
| 1        | Test 3                       | TEST3     | -                                 | This pin must always be connected to VSS.                                                                                                                                        |

Note 3.3 The internal pull-up is disabled when the GPIO is configured as an O8 buffer type.

Note 3.4 If unused, this signal must be pulled to a valid state.

SYSPLLG

VDD12HDMI

VSSHDMI

| NUM PINS | NAME                             | SYMBOL  | BUFFER<br>TYPE | DESCRIPTION                              |
|----------|----------------------------------|---------|----------------|------------------------------------------|
| 1        | +3.3 V SYS<br>PLL Power<br>Input | SYSPLLP | Р              | +3.3 V system and pixel PLL power input. |

Ρ

Ρ

Ρ

System and pixel PLL ground.

+1.2 V HDMI power input.

HDMI ground.

#### Table 3.10 I/O Power Pins, Core Power Pins, and Ground Pins

1

3

3

SYS PLL

Ground

+1.2 V HDMI

Power Input

HDMI Ground



| NUM PINS | NAME                                  | SYMBOL      | BUFFER<br>TYPE | DESCRIPTION                                             |
|----------|---------------------------------------|-------------|----------------|---------------------------------------------------------|
| 3        | +3.3 V VDAC<br>Power Input            | VDD33VDAC   | Р              | +3.3 V Video DAC power input. (Note 3.5)                |
| 1        | +3.3 V VDAC<br>Reference<br>Input     | VDACREF     | Р              | +3.3 V Video DAC reference voltage input.<br>(Note 3.5) |
| 2        | VDAC<br>Ground                        | VSSVDAC     | Р              | Video DAC ground.                                       |
| 1        | +3.3 V USB<br>Power Input             | VDD33USB    | Р              | +3.3 V USB power input. (Note 3.5)                      |
| 1        | +1.2 V USB<br>PLL Supply<br>Input     | VDD12USBPLL | Р              | +1.2 V USB PLL supply input. (Note 3.5)                 |
| 15       | +1.8 V DDR2<br>Power Input            | VDD18DDR    | Р              | 1.8 V DDR2 power input. (Note 3.5)                      |
| 8        | +3.3 V I/O<br>Power Input             | VDD33IO     | Р              | +3.3 V I/O power input. (Note 3.5)                      |
| 11       | +1.2 V Digital<br>Core Power<br>Input | VDD12CORE   | Р              | +1.2 V digital core power input. (Note 3.5)             |
| 37       | Ground                                | VSS         | Р              | Common Ground.                                          |

#### Table 3.10 I/O Power Pins, Core Power Pins, and Ground Pins (continued)

**Note 3.5** Refer to Chapter 17, "Power Connections," on page 367 and the device reference schematics for additional power connection information.

#### Table 3.11 No-Connect Pins

| NUM PINS | NAME       | SYMBOL | BUFFER<br>TYPE | DESCRIPTION                                                   |
|----------|------------|--------|----------------|---------------------------------------------------------------|
| 9        | No Connect | NC     | -              | These pins must be left floating for normal device operation. |



# 3.1 Pin Assignments

| PIN<br>NUM | PIN NAME      | PIN<br>NUM | PIN NAME  | PIN<br>NUM | PIN NAME  | PIN<br>NUM | PIN NAME  |
|------------|---------------|------------|-----------|------------|-----------|------------|-----------|
| A1         | DDRFIFOWE_IN  | B1         | DDRVREF0  | C1         | DDRDQ9    | D1         | DDRDQS1   |
| A2         | DDRFIFOWE_OUT | B2         | DDRDQ5    | C2         | DDRDQ11   | D2         | DDRDM1    |
| A3         | DDRDQ7        | B3         | DDRDQ0    | C3         | DDRDQ12   | D3         | DDRDQ14   |
| A4         | nDDRDQS0      | B4         | DDRDQS0   | C4         | DDRDQ2    | D4         | VDD18DDR  |
| A5         | DDRDM0        | B5         | DDRDQ6    | C5         | VDD18DDR  | D5         | VDD18DDR  |
| A6         | DDRDQ1        | B6         | DDRDQ3    | C6         | DDRDQ4    | D6         | DDRVREF2  |
| A7         | nDDRWE        | B7         | DDRCKE    | C7         | DDRBA1    | D7         | VDD18DDR  |
| A8         | DDRA10        | B8         | DDRBA0    | C8         | DDRA1     | D8         | VDD18DDR  |
| A9         | DDRA3         | B9         | DDRA7     | C9         | DDRA5     | D9         | VDD18DDR  |
| A10        | DDRA9         | B10        | DDRA12    | C10        | nDDRRAS   | D10        | VDD18DDR  |
| A11        | DDRCK         | B11        | nDDRCK    | C11        | VDD18DDR  | D11        | VDD18DDR  |
| A12        | nDDRCAS       | B12        | nDDRCS    | C12        | DDRA0     | D12        | VDD18DDR  |
| A13        | DDRA2         | B13        | DDRA6     | C13        | DDRODT    | D13        | VDD18DDR  |
| A14        | DDRA4         | B14        | DDRA11    | C14        | VSS       | D14        | TX2P      |
| A15        | DDRA8         | B15        | VSS       | C15        | EXTSWING  | D15        | TX2N      |
|            |               |            |           | •          |           |            |           |
| E1         | nDDRDQS1      | F1         | DDRDQ13   | G1         | VSS       | H1         | NC        |
| E2         | DDRDQ8        | F2         | DDRDQ10   | G2         | VSS       | H2         | NC        |
| E3         | DDRDQ15       | F3         | DDRVREF1  | G3         | TEST1     | H3         | TEST2     |
| E4         | VDD18DDR      | F4         | VDD18DDR  | G4         | VSS       | H4         | TEST3     |
| E5         | VDD18DDR      | F5         | VDD12CORE | G5         | VSS       | H5         | VDD12CORE |
| E6         | VDD12CORE     | F6         | VSS       | G6         | VSS       | H6         | VSS       |
| E7         | VSS           | F7         | VSS       | G7         | VSS       | H7         | VSS       |
| E8         | VDD12CORE     | F8         | VSS       | G8         | VSS       | H8         | VSS       |
| E9         | VSS           | F9         | VSS       | G9         | VSS       | H9         | VSS       |
| E10        | VDD12CORE     | F10        | VSS       | G10        | VSS       | H10        | VSS       |
| E11        | VDD18DDR      | F11        | VDD12CORE | G11        | VDD12CORE | H11        | VSSVDAC   |
| E12        | VSSHDMI       | F12        | VSSHDMI   | G12        | VSSHDMI   | H12        | IREF      |
| E13        | VDD12HDMI     | F13        | VDD12HDMI | G13        | VDD12HDMI | H13        | VSSVDAC   |
| E14        | TX1P          | F14        | TX0P      | G14        | TXCP      | H14        | VDACR     |
| E15        | TX1N          | F15        | TX0N      | G15        | TXCN      | H15        | nVDACR    |

Table 3.13 225-LFBGA Package Pin Assignments



| PIN<br>NUM | PIN NAME  | PIN<br>NUM | PIN NAME           | PIN<br>NUM | PIN NAME                 | PIN<br>NUM | PIN NAME               |
|------------|-----------|------------|--------------------|------------|--------------------------|------------|------------------------|
| J1         | NC        | K1         | I2CSDA1/<br>GPIO27 | L1         | USBDP                    | M1         | VDD33USB               |
| J2         | NC        | K2         | I2CSDA0            | L2         | USBDM                    | M2         | NC                     |
| J3         | VSS       | K3         | I2CSCL1/<br>GPIO28 | L3         | VBUS_DET                 | M3         | HPD                    |
| J4         | NC        | K4         | I2CSCL0            | L4         | AUDIO_DIS/<br>GPIO30     | M4         | VDATAB4/VD3/<br>GPIO20 |
| J5         | VSS       | K5         | VDD12CORE          | L5         | VDD33IO                  | M5         | VDD33IO                |
| J6         | VSS       | K6         | VSS                | L6         | VDD12CORE                | M6         | VDD33IO                |
| J7         | VSS       | K7         | VSS                | L7         | VSS                      | M7         | VDD33IO                |
| J8         | VSS       | K8         | VSS                | L8         | VDD12CORE                | M8         | VDATAG4/VD9/<br>GPIO12 |
| J9         | VSS       | K9         | VSS                | L9         | VSS                      | M9         | VDD33IO                |
| J10        | VSS       | K10        | VSS                | L10        | VDD12CORE                | M10        | VDATAR5/<br>GPIO5      |
| J11        | VDD33VDAC | K11        | VDACREF            | L11        | VDD33IO                  | M11        | VDD33IO                |
| J12        | VDD33VDAC | K12        | VDAC_HSYNC         | L12        | VDD33IO                  | M12        | TDI                    |
| J13        | VDD33VDAC | K13        | VDAC_VSYNC         | L13        | WS/GPIO29                | M13        | INT                    |
| J14        | VDACG     | K14        | VDACB              | L14        | MCLK/GPIO25              | M14        | EECS                   |
| J15        | nVDACG    | K15        | nVDACB             | L15        | SPDIF/I2SDATA/<br>GPIO26 | M15        | EECLK                  |

| Table 3.13 | 225-LFBGA | Package Pin | Assignments ( | (continued) |
|------------|-----------|-------------|---------------|-------------|



| PIN<br>NUM | PIN NAME               | PIN<br>NUM | PIN NAME                         | PIN<br>NUM | PIN NAME                      | PIN<br>NUM | PIN NAME |
|------------|------------------------|------------|----------------------------------|------------|-------------------------------|------------|----------|
| N1         | XI                     | P1         | ХО                               | R1         | SYSPLLP                       |            |          |
| N2         | VDD12USBPLL            | P2         | SYSPLLG                          | R2         | VDATAB7/VD0/<br>GPIO23        |            |          |
| N3         | USBRBIAS               | P3         | VDATAB6/VD1/<br>GPIO22           | R3         | VDATAB5/VD2/<br>GPIO21        |            |          |
| N4         | VDATAB3/VD4/<br>GPIO19 | P4         | VDATAB2/VD5/<br>GPIO18           | R4         | VDATAB1/VD6/<br>GPIO17        |            |          |
| N5         | VDATAB0/<br>GPIO16     | P5         | HSYNC                            | R5         | VSYNC                         |            |          |
| N6         | nBLANK                 | P6         | nVCLK                            | R6         | VCLK                          |            |          |
| N7         | VDATAG7/<br>GPIO15     | P7         | VDATAG6/VD7/<br>GPIO14           | R7         | VDATAG5/VD8/<br>GPIO13        |            |          |
| N8         | VDATAG3/<br>GPIO11     | P8         | VDATAG2/<br>GPIO10               | R8         | VDATAG1/VD10/<br>GPIO9        |            |          |
| N9         | VDATAG0/VD11/<br>GPIO8 | P9         | VDATAR7/VD12/<br>GPIO7           | R9         | VDATAR6/<br>GPIO6             |            |          |
| N10        | VDATAR4/VD13/<br>GPIO4 | P10        | VDATAR3/VD14/<br>GPIO3           | R10        | VDATAR2/VD15/<br>GPIO2        |            |          |
| N11        | VDATAR1/<br>GPIO1      | P11        | VDATAR0/<br>I2SCLKALT0/<br>GPIO0 | R11        | nTRST                         |            |          |
| N12        | TDO                    | P12        | тск                              | R12        | TMS                           |            |          |
| N13        | nEXTRST                | P13        | nSW_MODE                         | R13        | NC                            |            |          |
| N14        | NC                     | P14        | nRESET                           | R14        | LED/<br>I2SCLKALT1/<br>GPIO24 |            |          |
| N15        | NC                     | P15        | EEDI                             | R15        | EEDO                          |            |          |



# 3.2 Buffer Types

| BUFFER TYPE | DESCRIPTION                                                                                                                                                                                                                                          |  |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| IS          | Schmitt-triggered Input                                                                                                                                                                                                                              |  |  |
| IS_5V       | 5V Tolerant Schmitt-triggered Input                                                                                                                                                                                                                  |  |  |
| O8          | Output with 8mA sink and 8mA source                                                                                                                                                                                                                  |  |  |
| OD8         | Open-drain output with 8mA sink                                                                                                                                                                                                                      |  |  |
| O12         | Output with 12mA sink and 12mA source                                                                                                                                                                                                                |  |  |
| OD12        | Open-drain output with 12mA sink                                                                                                                                                                                                                     |  |  |
| PU          | 50uA (typical) internal pull-up. Unless otherwise noted in the pin description, internal pull-<br>ups are always enabled.                                                                                                                            |  |  |
|             | <b>Note:</b> Internal pull-up resistors prevent unconnected inputs from floating. Do not rely on internal resistors to drive signals external to the device. When connected to a load that must be pulled high, an external resistor must be added.  |  |  |
| PD          | 50uA (typical) internal pull-down. Unless otherwise noted in the pin description, internal pull-downs are always enabled.                                                                                                                            |  |  |
|             | <b>Note:</b> Internal pull-down resistors prevent unconnected inputs from floating. Do not rely on internal resistors to drive signals external to the device. When connected to a load that must be pulled low, an external resistor must be added. |  |  |
| AI          | Analog input                                                                                                                                                                                                                                         |  |  |
| AO          | Analog output                                                                                                                                                                                                                                        |  |  |
| AIO         | Analog bi-directional                                                                                                                                                                                                                                |  |  |
| DDR2I       | DDR2 input                                                                                                                                                                                                                                           |  |  |
| DDR2O       | DDR2 output                                                                                                                                                                                                                                          |  |  |
| RGB         | RGB output                                                                                                                                                                                                                                           |  |  |
| ICLK        | Crystal oscillator input pin                                                                                                                                                                                                                         |  |  |
| OCLK        | Crystal oscillator output pin                                                                                                                                                                                                                        |  |  |
| Р           | Power pin                                                                                                                                                                                                                                            |  |  |

#### Table 3.14 Buffer Types



# Chapter 4 USB Controller

## 4.1 Overview

UFX6000 complies with the USB 2.0 specification. A compliant UTMI interface is used to interface to the USB 2.0 PHY. LPM is supported in USB 2.0 mode.

The device support three endpoints: Control, Bulk-Out and Interrupt (Endpoint0, Endpoint1, and Endpoint2). HS and FS operation is supported. LS is not supported. Although the device can enumerate in FS mode, the graphics engine is not operational.

There is one configuration, one interface, and no alternate settings. Bus powered and self powered operation is supported. Remote wakeup is not supported.

# 4.2 USB Control Endpoint

The Control endpoint is handled by the CTL (USB Control) module. The CTL module is responsible for handling USB standard commands as well as USB vendor commands. In order to support these commands the CTL must compile a variety of statistics and store the programmable portions of the USB descriptors.

### 4.2.1 USB Vendor Commands

The device implements several vendor specific commands in order to access CSRs and efficiently gather statistics. The vendor commands allow direct access to Systems CSRs and DDR2 memory.

#### 4.2.1.1 Register Write Command

The commands allows the Host to write a single register. All writes are 32-bits.

| OFFSET | FIELD         | VALUE             |
|--------|---------------|-------------------|
| 0h     | bmRequestType | 40h               |
| 1h     | bRequest      | A0h               |
| 2h     | wValue        | 00h               |
| 4h     | wIndex        | CSR Address[15:0] |
| 6h     | wLength       | 04h               |

#### Table 4.1 Format of Register Write Setup Stage

#### Table 4.2 Format of Register Write Data Stage

| OFFSET | FIELD                      |  |  |  |
|--------|----------------------------|--|--|--|
| 0h     | Register Write Data [31:0] |  |  |  |

Special care needs to be taken when accessing the HDMI CSRs. The transmitter's CSRs are byte aligned. As a result the HDMI address must be converted into a dword boundary for use in the register write command.



Since, the HDMI CSRs have a 9-bit address the following equation is used to generate the value of CSR Address.

CSR Address = 9000h + (HDMI Address)\*4

Only bits 7:0 of the Register Write Data field are used when accessing the HDMI CSRs. All other bits are ignored.

#### 4.2.1.2 Register Read Command

The commands allows the Host to read a single register. All reads return 32-bits.

| OFFSET | FIELD         | VALUE             |
|--------|---------------|-------------------|
| 0h     | bmRequestType | C0h               |
| 1h     | bRequest      | A1h               |
| 2h     | wValue        | 00h               |
| 4h     | wIndex        | CSR Address[15:0] |
| 6h     | wLength       | 04h               |

#### Table 4.3 Format of Register Read Setup Stage

#### Table 4.4 Format of Register Read Data Stage

| OFFSET | FIELD                     |  |  |  |  |
|--------|---------------------------|--|--|--|--|
| 0h     | Register Read Data [31:0] |  |  |  |  |

As with the Register Write Command additional step needs to be taken for generating the CSR Address when accessing the HDMI CSRs. See Section 4.2.1.1 for a description.

Only bits 7:0 of the Register Read Data field are valid when accessing the HDMI CSRs. All other bits must be ignored.

#### 4.2.1.3 DDR2 Memory Read Command

The commands allows the Host to read 128 bytes of DDR2 Memory starting at the specified address.

| OFFSET | FIELD         | VALUE                          |
|--------|---------------|--------------------------------|
| 0h     | bmRequestType | C0h                            |
| 1h     | bRequest      | A2h                            |
| 2h     | wValue        | DDR2 Address[15:0]<br>Note 4.1 |
| 4h     | wIndex        | {7'b0, DDR2 Address[24:16]}    |
| 6h     | wLength       | Note 4.2                       |

#### Table 4.5 Format of Register Read Setup Stage



- **Note 4.1** The lower 3 bits of the specified address are ignored, resulting in QUAD WORD aligned data being returned.
- **Note 4.2** Any length up to FFFFh may be specified. Length should be specified in multiples of 64 bytes. If it is not, then any extra bytes specified in excess of the 64 byte multiple will result in an additional 64 bytes being transferred.

#### 4.2.1.4 Get Statistics Command

The Get Statistics Command returns the entire contents of the statistics counters.

**Note:** The contents of the statistics counters is snapshot when fulfilling the command request. The statistics counters rollover, hence the they are not cleared.

| OFFSET | FIELD         | VALUE |
|--------|---------------|-------|
| 0h     | bmRequestType | C0h   |
| 1h     | bRequest      | A3h   |
| 2h     | wValue        | 00h   |
| 4h     | wIndex        | 00h   |
| 6h     | wLength       | 2Ch   |

#### Table 4.6 Format of Get Statistics Setup Stage

#### Table 4.7 Format of Get Statistics Data Stage

| OFFSET    | FIELD                       | DESCRIPTION                                                                                                                                                          |
|-----------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00h       | Bulk Out Packets Received   | <ul> <li>Only data stage counted</li> <li>Only successfully received packets are counted</li> <li>ZLPs counted</li> </ul>                                            |
| 04h       | Control Packets Received    | <ul> <li>Only data stage counted</li> <li>Only successfully received packets are counted</li> <li>Only vendor command control packets are counted</li> </ul>         |
| 08h       | Control Packets Transmitted | <ul> <li>Only data stage counted</li> <li>Only successfully transmitted packets are counted</li> <li>Only responses to vendor command packets are counted</li> </ul> |
| 09h - 2Ch | RESERVED                    | Reserved for future use                                                                                                                                              |

# 4.3 USB Bulk Out Endpoint

The Bulk-out endpoint is responsible for receiving graphics commands and passing them to the Graphics Engine via an RX FIFO. An 18 KB FIFO allows for efficient utilization of USB bandwidth.



# 4.4 USB Interrupt Endpoint

The Interrupt endpoint is responsible for indicating the device status at each polling interval. When the endpoint is accessed, the following fields are presented to the host, when an enabled interrupt is asserted:

| OFFSET | BITS  | DESCRIPTION         |
|--------|-------|---------------------|
| 0      | 31:20 | RESERVED            |
| 0      | 19    | DISPLAY_BLANK_INT   |
| 0      | 18    | H_BLANK_START_INT   |
| 0      | 17    | V_BLANK_START_INT   |
| 0      | 16    | FRAME_BASE_ADDR_INT |
| 0      | 15:3  | RESERVED            |
| 0      | 2     | I2C_INT             |
| 0      | 1     | HDMI_INT            |
| 0      | 0     | INTPIN              |

#### Table 4.8 Interrupt Packet Format

If there is no interrupt status to report, the device responds with a NAK.

**Note:** The polling interval is static and set through the EEPROM. The polling interval can be changed by the host updating the contents of the EEPROM and resetting the part.

The interrupt status can be cleared by clearing the interrupt at its source. The means specific to each interrupt is indicated in Section 4.6.2, "USB Interrupt Endpoint Status Register (USB\_INT\_STS)," on page 61.

**Note:** If the interrupt packet is not sent successfully, the same interrupt packet, not an updated one, is resent.



# 4.5 USB Descriptors

### 4.5.1 USB Descriptors - UFX6000

The following tables illustrate the USB descriptor values for UFX6000.

#### 4.5.1.1 Device Descriptor

The Device Descriptors are initialized based on values stored in EEPROM. Table 4.9 shows the default Device Descriptor values. These values are used for both Full-Speed and High-Speed operation.

| OFFSET | FIELD              | SIZE<br>(BYTES) | DEFAULT<br>VALUE | LOADED<br>FROM<br>EEPROM | DESCRIPTION                                        |
|--------|--------------------|-----------------|------------------|--------------------------|----------------------------------------------------|
| 00h    | bLength            | 1               | 12h              | Note 4.3                 | Size of the Descriptor in Bytes (18 bytes)         |
| 01h    | bDescriptorType    | 1               | 01h              | Note 4.3                 | Device Descriptor (0x01)                           |
| 02h    | bcdUSB             | 2               | Note 4.4         | Note 4.5                 | USB Specification Number which device complies to. |
| 04h    | bDeviceClass       | 1               | FFh              | Yes                      | Class Code                                         |
| 05h    | bDeviceSubClass    | 1               | 00h              | Yes                      | Subclass Code                                      |
| 06h    | bDeviceProtocol    | 1               | FFh              | Yes                      | Protocol Code                                      |
| 07h    | bMaxPacketSize     | 1               | 40h              | Note 4.5                 | Maximum Packet Size for Endpoint 0                 |
| 08h    | ldVendor           | 2               | 0424h            | Yes                      | Vendor ID                                          |
| 0Ah    | IdProduct          | 2               | 9D01h            | Yes                      | Product ID                                         |
| 0Ch    | bcdDevice          | 2               | Note 4.6         | Yes                      | Device Release Number                              |
| 0Eh    | iManufacturer      | 1               | 00h              | Yes                      | Index of Manufacturer String<br>Descriptor         |
| 0Fh    | iProduct           | 1               | 00h              | Yes                      | Index of Product String Descriptor                 |
| 10h    | iSerialNumber      | 1               | 00h              | Yes                      | Index of Serial Number String<br>Descriptor        |
| 11h    | bNumConfigurations | 1               | 01h              | Note 4.5                 | Number of Possible Configurations                  |

#### Table 4.9 Device Descriptor

- **Note 4.3** The descriptor length and descriptor type for Device Descriptors specified in EEPROM are a "don't cares" and are always overwritten by hardware as 0x12 and 0x01, respectively.
- **Note 4.4** Default value is dependent on LPM\_ENABLE bit in the Configuration Flags byte of the EEPROM. If LPM\_ENABLE is set, the default value is 0210h (USB 2.10), otherwise the default value is 0200h (USB 2.0).
- **Note 4.5** Value is loaded from EEPROM, but must be equal to the Default Value in order to comply with the USB Specification and provide for normal device operation. Specification of any other value will result in unwanted behavior and untoward operation.
- **Note 4.6** Default value is dependent on device release. MSB matches the device release and LSB hardcoded to 00h. The initial release value is 01h for the MPW. The value for A0 is 02h. Subsequent versions after A0 will increment the value.



#### 4.5.1.2 Configuration Descriptor

The Configuration Descriptor is initialized based on values stored in EEPROM. Table 4.10 shows the default Configuration Descriptor values. These values are used for both Full-Speed and High-Speed operation.

| OFFSET | FIELD               | SIZE<br>(BYTES) | DEFAULT<br>VALUE | LOADED<br>FROM<br>EEPROM | DESCRIPTION                                              |
|--------|---------------------|-----------------|------------------|--------------------------|----------------------------------------------------------|
| 00h    | bLength             | 1               | 09h              | Note 4.7                 | Size of the Configuration Descriptor in bytes (9 bytes)  |
| 01h    | bDescriptorType     | 1               | 02h              | Note 4.8                 | Configuration Descriptor (0x02)                          |
| 02h    | wTotalLength        | 2               | 0020h            | Note 4.7                 | Total length in bytes of data returned (32 bytes).       |
| 04h    | bNumInterfaces      | 1               | 01h              | Note 4.7                 | Number of Interfaces                                     |
| 05h    | bConfigurationValue | 1               | 01h              | Note 4.7                 | Value to use as an argument to select this configuration |
| 06h    | iConfiguration      | 1               | 00h              | Yes                      | Index of String Descriptor describing this configuration |
| 07h    | bmAttributes        | 1               | 80h              | Yes                      | Bus powered and remote wakeup disabled.                  |
| 08h    | bMaxPower           | 1               | Note 4.9         | Yes                      | Maximum Power Consumption                                |

#### Table 4.10 Configuration Descriptor

- **Note 4.7** Value is loaded from EEPROM, but must be equal to the Default Value in order to comply with the USB Specification in effect and provide for normal device operation. Specification of any other value will result in unwanted behavior and untoward operation.
- **Note 4.8** The descriptor type for Configuration Descriptors specified in EEPROM is a "don't care" and is always overwritten by hardware as 0x02.
- Note 4.9 Default value is 01h in Self Powered mode and FAh (500mA) in Bus Powered mode.
- **Note:** The Power Method bit of the Configuration Flags of the EEPROM may affect the default value of bmAttributes.



#### 4.5.1.3 Interface Descriptor 0

Table 4.11 shows the default value for Interface Descriptor 0. This descriptor is initialized based on values stored in EEPROM.

| OFFSET | FIELD              | SIZE<br>(BYTES) | DEFAULT<br>VALUE | LOADED<br>FROM<br>EEPROM | DESCRIPTION                                                   |
|--------|--------------------|-----------------|------------------|--------------------------|---------------------------------------------------------------|
| 00h    | bLength            | 1               | 09h              | Note 4.10                | Size of Descriptor in Bytes (9 Bytes                          |
| 01h    | bDescriptorType    | 1               | 04h              | Note 4.10                | Interface Descriptor (0x04)                                   |
| 02h    | bInterfaceNumber   | 1               | 00h              | Note 4.10                | Number identifying this Interface                             |
| 03h    | bAlternateSetting  | 1               | 00h              | Note 4.10                | Value used to select alternative setting                      |
| 04h    | bNumEndpoints      | 1               | 02h              | Note 4.10                | Number of Endpoints used for this interface (Less endpoint 0) |
| 05h    | bInterfaceClass    | 1               | FFh              | Yes                      | Class Code                                                    |
| 06h    | bInterfaceSubClass | 1               | 00h              | Yes                      | Subclass Code                                                 |
| 07h    | bInterfaceProtocol | 1               | FFh              | Yes                      | Protocol Code                                                 |
| 08h    | iInterface         | 1               | 00h              | Yes                      | Index of String Descriptor Describing this interface          |

#### Table 4.11 Interface Descriptor 0

**Note 4.10** Value is loaded from EEPROM, but must be equal to the Default Value in order to comply with the USB Specification in effect and provide for normal device operation. Specification of any other value will result in unwanted behavior and untoward operation.



#### 4.5.1.4 Endpoint 1 Descriptor (Bulk-Out)

Table 4.12 shows the default value for Endpoint Descriptor 1. This descriptor is not initialized from values stored in EEPROM.

| OFFSET | FIELD            | SIZE<br>(BYTES) | DEFAULT<br>VALUE | LOADED<br>FROM<br>EEPROM | DESCRIPTION                                                               |
|--------|------------------|-----------------|------------------|--------------------------|---------------------------------------------------------------------------|
| 00h    | bLength          | 1               | 07h              | No                       | Size of Descriptor in bytes                                               |
| 01h    | bDescriptorType  | 1               | 05h              | No                       | Endpoint Descriptor                                                       |
| 02h    | bEndpointAddress | 1               | 01h              | No                       | Endpoint Address                                                          |
| 03h    | bmAttributes     | 1               | 02h              | No                       | Bulk Transfer Type                                                        |
| 04h    | wMaxPacketSize   | 2               | Note 4.11        | No                       | Maximum Packet Size this endpoint is capable of sending.                  |
| 06h    | bInterval        | 1               | 00h              | No                       | Interval for polling endpoint data transfers. Ignored for bulk endpoints. |

#### Table 4.12 Endpoint 1 Descriptor

**Note 4.11** 64 bytes for full-speed mode. 512 bytes for high-speed mode.



### 4.5.1.5 Endpoint 2 Descriptor (Interrupt)

Table 4.13 shows the default value for Endpoint Descriptor 2. Only the bInterval field of this descriptor is initialized from EEPROM.

| OFFSET | FIELD            | SIZE<br>(BYTES) | DEFAULT<br>VALUE | LOADED<br>FROM<br>EEPROM | DESCRIPTION                                              |
|--------|------------------|-----------------|------------------|--------------------------|----------------------------------------------------------|
| 00h    | bLength          | 1               | 07h              | No                       | Size of Descriptor in bytes                              |
| 01h    | bDescriptorType  | 1               | 05h              | No                       | Endpoint Descriptor                                      |
| 02h    | bEndpointAddress | 1               | 82h              | No                       | Endpoint Address                                         |
| 03h    | bmAttributes     | 1               | 03h              | No                       | Interrupt Transfer Type                                  |
| 04h    | wMaxPacketSize   | 2               | 10h              | No                       | Maximum Packet Size this endpoint is capable of sending. |
| 06h    | bInterval        | 1               | Note 4.12        | Yes                      | Interval for polling endpoint data transfers.            |

#### Table 4.13 Endpoint 2 Descriptor

**Note 4.12** This value is loaded from the EEPROM. A full-speed and high-speed polling interval exists. If no EEPROM exists than this value defaults to 04h for HS and 01h for FS.



#### 4.5.1.6 Other Speed Configuration Descriptor

The fields in this descriptor are derived from Configuration Descriptor information that is stored in the EEPROM.

| OFFSET | FIELD               | SIZE<br>(BYTES) | DEFAULT<br>VALUE | LOADED<br>FROM<br>EEPROM | DESCRIPTION                                              |
|--------|---------------------|-----------------|------------------|--------------------------|----------------------------------------------------------|
| 00h    | bLength             | 1               | 09h              | Note 4.13                | Size of Descriptor in bytes (9 bytes)                    |
| 01h    | bDescriptorType     | 1               | 07h              | No                       | Other Speed Configuration Descriptor (0x07)              |
| 02h    | wTotalLength        | 2               | 0020h            | Note 4.13                | Total length in bytes of data returned (32 bytes)        |
| 04h    | bNumInterfaces      | 1               | 01h              | Note 4.13                | Number of Interfaces                                     |
| 05h    | bConfigurationValue | 1               | 01h              | Note 4.13                | Value to use as an argument to select this configuration |
| 06h    | iConfiguration      | 1               | 00h              | Yes                      | Index of String Descriptor describing this configuration |
| 07h    | bmAttributes        | 1               | 80h              | Yes                      | Bus powered and remote wakeup disabled.                  |
| 08h    | bMaxPower           | 1               | Note 4.14        | Yes                      | Maximum Power Consumption                                |

#### Table 4.14 Other Speed Configuration Descriptor

- **Note:** EEPROM values are obtained for the Configuration Descriptor at the other USB speed. I.e., if the current operating speed is FS, then the HS Configuration Descriptor values are used, and vice-versa.
- **Note 4.13** Value is loaded from EEPROM, but must be equal to the Default Value in order to comply with the USB Specification in effect and provide for normal device operation. Specification of any other value will result in unwanted behavior and untoward operation.
- Note 4.14 Default value is 01h in Self Powered mode and FAh (500 mA) in Bus Powered mode.
- **Note:** The Power Method bit of the Configuration Flags of the EEPROM may affect the default value of bmAttributes.



#### 4.5.1.7 Device Qualifier Descriptor

The fields in this descriptor are derived from Device Descriptor information that is stored in the EEPROM.

| OFFSET | FIELD              | SIZE<br>(BYTES) | DEFAULT<br>VALUE | LOADED<br>FROM<br>EEPROM | DESCRIPTION                                        |
|--------|--------------------|-----------------|------------------|--------------------------|----------------------------------------------------|
| 00h    | bLength            | 1               | 0Ah              | No                       | Size of Descriptor in bytes (10 bytes)             |
| 01h    | bDescriptorType    | 1               | 06h              | No                       | Device Qualifier Descriptor (0x06)                 |
| 02h    | bcdUSB             | 2               | Note 4.15        | Note 4.16                | USB Specification Number which device complies to. |
| 04h    | bDeviceClass       | 1               | FFh              | Yes                      | Class Code                                         |
| 05h    | bDeviceSubClass    | 1               | 00h              | Yes                      | Subclass Code                                      |
| 06h    | bDeviceProtocol    | 1               | FFh              | Yes                      | Protocol Code                                      |
| 07h    | bMaxPacketSize0    | 1               | 40h              | Note 4.16                | Maximum Packet Size                                |
| 08h    | bNumConfigurations | 1               | 01h              | Note 4.16                | Number of Other-Speed<br>Configurations            |
| 09h    | Reserved           | 1               | 00h              | No                       | Must be zero                                       |

#### Table 4.15 Device Qualifier Descriptor

- **Note:** EEPROM values are from the Device Descriptor (including any EEPROM override) at the opposite HS/FS operating speed. I.e., if the current operating speed is HS, then Device Qualifier data is based on the FS Device Descriptor, and vice-versa.
- **Note 4.15** Default value is dependent on LPM\_ENABLE bit in the Configuration Flags byte of the EEPROM. If LPM\_ENABLE is set, the default value is 0210h (USB 2.1), otherwise default value is 0200h (USB 2.0).
- **Note 4.16** Value is loaded from EEPROM, but must be equal to the Default Value in order to comply with the USB Specification in effect and provide for normal device operation. Specification of any other value will result in unwanted behavior and untoward operation.



#### 4.5.1.8 Binary Device Object Store Descriptor

The Binary Device Object Store Descriptor is initialized based on values stored in EEPROM. Table 4.16 shows the default Binary Device Object Store Descriptor values.

**Note:** This descriptor is applicable when the LPM\_ENABLE bit is set in the Configuration Flags byte of the EEPROM. If LPM\_ENABLE is clear, the descriptor is unavailable.

| OFFSET | FIELD           | SIZE<br>(BYTES) | DEFAULT<br>VALUE | LOADED<br>FROM<br>EEPROM | DESCRIPTION                                                        |
|--------|-----------------|-----------------|------------------|--------------------------|--------------------------------------------------------------------|
| 00h    | bLength         | 1               | 05h              | Note 4.17                | Size of Descriptor in bytes (5 bytes)                              |
| 01h    | bDescriptorType | 1               | 0Fh              | Note 4.17                | BOS Descriptor (0x0F)                                              |
| 02h    | wTotalLength    | 2               | 000Ch            | Yes                      | Total length of this descriptor and its subdescriptors. (12 bytes) |
| 04h    | bNumDeviceCaps  | 1               | 01h              | Yes                      | Number of Device Capability Descriptors in this BOS.               |

#### Table 4.16 Binary Device Object Store Descriptor

**Note 4.17** The descriptor length and descriptor type for Binary Device Object Store Descriptors specified in EEPROM are "don't cares" and are always overwritten by hardware as 0x05 and 0x0F, respectively.



#### 4.5.1.9 USB 2.0 Extension Descriptor

The USB 2.0 Extension Descriptor is initialized based on values stored in EEPROM. Table 4.17 shows the default USB 2.0 Extension Descriptor values.

**Note:** This descriptor is applicable when the LPM\_ENABLE bit is set in the Configuration Flags byte of the EEPROM. If LPM ENABLE is clear, the descriptor is unavailable.

| OFFSET | FIELD              | SIZE<br>(BYTES) | DEFAULT<br>VALUE | LOADED<br>FROM<br>EEPROM | DESCRIPTION                                                                                                                                                                                              |                                                                                                                                                                                               |
|--------|--------------------|-----------------|------------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00h    | bLength            | 1               | 07h              | Note 4.18                | Size of Descriptor in bytes (7 bytes)                                                                                                                                                                    |                                                                                                                                                                                               |
| 01h    | bDescriptorType    | 1               | 10h              | Note 4.18                | Device C                                                                                                                                                                                                 | apability Descriptor (0x10)                                                                                                                                                                   |
| 02h    | bDevCapabilityType | 1               | 02h              | Note 4.18                | USB 2.0                                                                                                                                                                                                  | Extension Capability (0x02)                                                                                                                                                                   |
| 03h    | bmAttributes       | 4               | 0002h            | Yes                      | Bitmap encoding of number of<br>supported device level features. A<br>value of 1 in a bit location indicates a<br>feature is supported. A value of 0<br>indicates it is not supported.<br>Encodings are: |                                                                                                                                                                                               |
|        |                    |                 |                  |                          | BIT                                                                                                                                                                                                      | ENCODING                                                                                                                                                                                      |
|        |                    |                 |                  |                          | 31:2                                                                                                                                                                                                     | RESERVED (0)                                                                                                                                                                                  |
|        |                    |                 |                  |                          | 1                                                                                                                                                                                                        | 1 (LPM) Note 4.19<br>A value of 1 in this bit<br>position indicates that this<br>device supports the Link<br>Power Management<br>protocol. Super Speed<br>devices shall set this bit<br>to 1. |
|        |                    |                 |                  |                          | 0                                                                                                                                                                                                        | RESERVED (0)                                                                                                                                                                                  |

| Table 4.17 USB 2.0 Extension Descriptor | Table 4.17 | <b>USB 2.0</b> | Extension | Descriptor |
|-----------------------------------------|------------|----------------|-----------|------------|
|-----------------------------------------|------------|----------------|-----------|------------|

- **Note 4.18** The descriptor length, descriptor type, and device capability type for USB 2.0 Extension Descriptors specified in EEPROM are "don't cares" and are always overwritten by hardware as 0x07, 0x10, and 0x02, respectively.
- **Note 4.19** The value of this bit must match that of the LPM\_ENABLE bit contained in the Configuration Flags byte of the EEPROM, if present. If the bit values disagree, unexpected results and untoward operation may result.



#### 4.5.1.10 String Descriptors

#### 4.5.1.10.1 STRING INDEX = 0 (LANGID)

#### Table 4.18 LANGID String Descriptor

| OFFSET | FIELD           | SIZE<br>(BYTES) | DEFAULT<br>VALUE | LOADED<br>FROM<br>EEPROM | DESCRIPTION                                  |
|--------|-----------------|-----------------|------------------|--------------------------|----------------------------------------------|
| 00h    | bLength         | 1               | 04h              | No                       | Size of LANGID Descriptor in bytes (4 bytes) |
| 01h    | bDescriptorType | 1               | 03h              | No                       | String Descriptor (0x03)                     |
| 02h    | LANGID          | 2               | None             | Yes                      | Must be set to 0x0409 (US English).          |

#### 4.5.1.10.2 STRING INDICES 1-5

| OFFSET | FIELD           | SIZE<br>(BYTES) | DEFAULT<br>VALUE | LOADED<br>FROM<br>EEPROM | DESCRIPTION                                      |
|--------|-----------------|-----------------|------------------|--------------------------|--------------------------------------------------|
| 00h    | bLength         | 1               | none             | Yes                      | Size of the String Descriptor in bytes (4 bytes) |
| 01h    | bDescriptorType | 1               | none             | Yes                      | String Descriptor (0x03)                         |
| 02h    | Unicode String  | 2*N             | none             | Yes                      | 2 bytes per unicode character, no trailing NULL. |

#### Table 4.19 String Descriptor (Indices 1-5)

**Note:** UFX6000 returns whatever bytes are in the designated EEPROM area for each of these strings it is the responsibility of the EEPROM programmer to correctly set the bLength and bDescriptorType fields in the descriptor consistent with the byte length specified in the corresponding EEPROM locations.



# 4.6 Control and Status Registers

| ADDRESS<br>OFFSET | SYMBOL      | REGISTER NAME                           |
|-------------------|-------------|-----------------------------------------|
| 5000h             | USB_CFG     | USB Configuration Register              |
| 5004h             | USB_INT_STS | USB Interrupt Endpoint Status Register  |
| 5008h             | USB_INT_CTL | USB Interrupt Endpoint Control Register |
| 500Ch – 5FFFFh    | RESERVED    | Reserved for future expansion           |

### Table 4.20 USB Control and Status Register Map



# 4.6.1 USB Configuration Register (USB\_CFG)

```
Address:
```

0000h

Size:

32 bits

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                               | TYPE | DEFAULT   |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:14 | RESERVED                                                                                                                                                                                                                                                                                                                  | RO   | -         |
| 13    | Port Swap (PORT_SWAP)<br>Swaps the mapping of the USBDP and USBDM pins.                                                                                                                                                                                                                                                   | RO   | Note 4.20 |
|       | 0 = USBDP maps to the USB D+ line and USBDM maps to the USB D- line.<br>1 = USBDP maps to the USB D- line. USBDM maps to the USB D+ line.                                                                                                                                                                                 |      |           |
|       | Note:                                                                                                                                                                                                                                                                                                                     |      |           |
| 12:7  | RESERVED                                                                                                                                                                                                                                                                                                                  | RO   | -         |
| 6:5   | Squelch Threshold (SQU_THR)<br>Varies reference voltage levels for squelch and HS Disconnect.                                                                                                                                                                                                                             | R/W  | Note 4.21 |
|       | 00 = Default<br>01 = -25mV Change<br>10 = +25mV Change<br>11 = RESERVED                                                                                                                                                                                                                                                   |      |           |
|       | <b>Note:</b> This field is protected by Reset Protection (RST_PROTECT).                                                                                                                                                                                                                                                   |      |           |
| 4:3   | <b>PHY Boost (PHY_BOOST)</b><br>This field provides the ability to boost the electrical drive strength of the HS output current to the upstream port.                                                                                                                                                                     | R/W  | Note 4.22 |
|       | 00 = Normal electrical drive strength<br>01 = Elevated electrical drive strength (+4% boost)<br>10 = Elevated electrical drive strength (+8% boost)<br>11 = Elevated electrical drive strength (+12% boost)                                                                                                               |      |           |
|       | Note: This field is protected by Reset Protection (RST_PROTECT).                                                                                                                                                                                                                                                          |      |           |
| 2     | <b>LPM Enable (LPM_ENABLE)</b><br>This bit enables the support of the Link Power Management (LPM) protocol.                                                                                                                                                                                                               | R/W  | Note 4.23 |
|       | 0 = LPM not supported<br>1 = LPM supported.                                                                                                                                                                                                                                                                               |      |           |
|       | <b>Note:</b> This field is protected by Reset Protection (RST_PROTECT).                                                                                                                                                                                                                                                   |      |           |
| 1     | <b>Power Method (PWR_SEL)</b><br>This bit controls the device's USB power mode.                                                                                                                                                                                                                                           | R/W  | Note 4.24 |
|       | 0 = The device is bus powered.<br>1 = The device is self powered.                                                                                                                                                                                                                                                         |      |           |
|       | <b>Note:</b> This field is protected by Reset Protection (RST_PROTECT).                                                                                                                                                                                                                                                   |      |           |
| 0     | <b>Stall Bulk Out Pipe Disable (SBP)</b><br>This bit controls the operation of the Bulk Out pipe when the FCT detects<br>the loss of sync condition. Please refer to the Graphics Engine Error Status<br>(GE_ERROR_STAT) field of the Graphic Engine Command Status Register<br>(GE_CMD_STATUS) for error status details. | R/W  | Ob        |
|       | <ul><li>0 = Stall the Bulk Out pipe when loss of sync detected.</li><li>1 = Do not stall the Bulk Out pipe when loss of sync detected.</li></ul>                                                                                                                                                                          |      |           |

- Note 4.20 The default value of this bit is determined by the value of the Port Swap (CFG0\_PORT\_SWAP) bit of the Configuration Flags 0 contained within the EEPROM, if present. If no EEPROM is present, 0b is the default.
- Note 4.21 The default value of this field is determined by the value of the Squelch Threshold (CFG0\_SQU\_THR) field of the Configuration Flags 0 contained within the EEPROM, if present. If no EEPROM is present, 00b is the default. A USB Reset or Lite Reset (LRST) will cause this field to be restored to the image value last loaded from EEPROM, or to be set to 00b if no EEPROM is present.
- Note 4.22 The default value of this field is determined by the value of the PHY Boost (CFG0\_PHY\_BOOST) field of the Configuration Flags 0 contained within the EEPROM, if present. If no EEPROM is present, 00b is the default. A USB Reset or Lite Reset (LRST) will cause this field to be restored to the image value last loaded from EEPROM, or to be set to 00b if no EEPROM is present.
- Note 4.23 The default value of this field is determined by the value of the LPM Enable (CFG0\_LPM\_ENABLE) field of the Configuration Flags 0 contained within the EEPROM, if present. If no EEPROM is present, 1b is the default. A USB Reset or Lite Reset (LRST) will cause this field to be restored to the image value last loaded from EEPROM, or to be set to 1b if no EEPROM is present.
- Note 4.24 The default value of this field is determined by the value of the Power Method (CFG0\_PWR\_SEL) field of the Configuration Flags 0 contained within the EEPROM, if present. If no EEPROM is present, 0b is the default. A USB Reset or Lite Reset (LRST) will cause this field to be restored to the image value last loaded from EEPROM, or to be set to 0b if no EEPROM is present.



# 4.6.2 USB Interrupt Endpoint Status Register (USB\_INT\_STS)

Offset:

004h

```
Size:
```

32 bits

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                          | TYPE | DEFAULT   |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:20 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                             | RO   | -         |
| 19    | <b>Display Blank Interrupt (DISPLAY_BLANK_INT)</b><br>Cleared by writing a 1 to the Display Blank Interrupt (DISPLAY_BLANK_INT)<br>bit of the Display Status Register (DISPLAY_STATUS).                                                                                                                                                                                                                                              | RO   | Ob        |
| 18    | Horizontal Blank Start Interrupt (H_BLANK_START_INT)<br>Cleared by writing a 1 to the Horizontal Blank Start Interrupt<br>(H_BLANK_START_INT) bit of the Display Status Register<br>(DISPLAY_STATUS).                                                                                                                                                                                                                                | RO   | Ob        |
| 17    | Vertical Blank Start Interrupt (V_BLANK_START_INT)<br>Cleared by writing a 1 to the Vertical Blank Start Interrupt<br>(V_BLANK_START_INT) bit of the Display Status Register<br>(DISPLAY_STATUS).                                                                                                                                                                                                                                    | RO   | Ob        |
| 16    | Frame Base Address Interrupt (FRAME_BASE_ADDR_INT)<br>Cleared by writing a 1 to the Frame Base Address Interrupt<br>(FRAME_BASE_ADDR_INT) bit of the Display Status Register<br>(DISPLAY_STATUS).                                                                                                                                                                                                                                    | RO   | Ob        |
| 15:3  | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                             | RO   | -         |
| 2     | I <sup>2</sup> C Interrupt (I2C_INT)<br>If the interrupt is software clearable, it can be cleared by reading it's<br>corresponding interrupt clear register, or the I <sup>2</sup> C Clear Interrupt Register<br>(I2C_CLR_INTR) which clears all I <sup>2</sup> C software interrupts. If the interrupt is<br>clearable by hardware only, the interrupt will be cleared automatically when<br>the interrupt conditions have changed. | RO   | Ob        |
| 1     | HDMI Interrupt (HDMI_INT)<br>Cleared when all asserted interrupt bits in the HDMI block are cleared.                                                                                                                                                                                                                                                                                                                                 | RO   | Ob        |
| 0     | Interrupt Pin Assertion (INTPIN)<br>This interrupt is asserted when the INT pin is asserted.                                                                                                                                                                                                                                                                                                                                         | R/WC | Note 4.25 |
|       | The polarity of the INT pin is determined by the Interrupt Pin Polarity (INT_POL) bit of the Hardware Configuration Register (HW_CFG).                                                                                                                                                                                                                                                                                               |      |           |

Note 4.25 Default value depends on the state of the INT pin.



32 bits

## 4.6.3 USB Interrupt Endpoint Control Register (USB\_INT\_CTL)

Offset: 008h Size:

This register determines which events cause status to be reported by the interrupt endpoint. See Section 4.4, "USB Interrupt Endpoint" for more details.

| BITS  | DESCRIPTION                                                                                                                            | TYPE | DEFAULT |
|-------|----------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:20 | RESERVED                                                                                                                               | RO   | -       |
| 19    | Display Blank Enable (DISPLAY_BLANK_EN)                                                                                                | R/W  | 0b      |
| 18    | Horizontal Blank Start Enable (H_BLANK_START_EN)                                                                                       | R/W  | 0b      |
| 17    | Vertical Blank Start Enable (V_BLANK_START_EN)                                                                                         | R/W  | 0b      |
| 16    | Frame Base Address Enable (FRAME_BASE_ADDR_EN)                                                                                         | R/W  | 0b      |
| 15:3  | RESERVED                                                                                                                               | RO   | -       |
| 2     | I <sup>2</sup> C Interrupt Enable (I2C_EN)                                                                                             | R/W  | 0b      |
| 1     | HDMI Interrupt Enable (HDMI_EN)                                                                                                        | R/W  | 0b      |
| 0     | Interrupt Pin Assertion Enable (INTPIN_EN)<br>This interrupt is asserted when the INT pin is asserted.                                 | R/W  | 0b      |
|       | The polarity of the INT pin is determined by the Interrupt Pin Polarity (INT_POL) bit of the Hardware Configuration Register (HW_CFG). |      |         |



# **Chapter 5 Clocks and Power Management**

# 5.1 Overview

The Clock and Power Management module (CPM) is responsible for generating the clocks and controlling the power management logic for the device.

CPM automatically power downs various functional blocks in order to minimize power consumption with the assistance of system software. Specifically the CPM.

- Powers down/up the USB 2.0 PHY depending on the power state.
- Enables/Disables the crystal oscillator depending on the power state.

## 5.2 **Power States**

### 5.2.1 Power State Definitions

The following power states are supported.

#### Table 5.1 Power States

| Power State  | Description                                                                                                                                                                    |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RESET        | The device enters, and stays in, this state when the nReset pin asserted. This state is optimized for low power consumption.                                                   |
| UNPOWERED    | This state is only supported during self powered operation. It is entered when VBUS_DET is not asserted. Minimal circuitry is enabled to detect, and deglitch, VBUS assertion. |
| UNCONFIGURED | This is the state of the device after reset de-assertion but before being configured.                                                                                          |
|              | When bus powered, and operating in FS/HS mode, the current consumed in this state is limited to 100 mA. In SS mode the limit is 150 mA.                                        |
| CONFIGURED   | This is the state of the device after being configured. Only in this state is the device fully functional.                                                                     |
|              | When bus powered, and operating in FS/HS mode, the current consumed in this state is limited to 500 mA per USB specification. In SS mode the limit is 900 mA.                  |
| SUSPEND      | The USB Host places the device in this state to conserve power. When bus-powered the current consumed in this state is limited to 2.5 mA per USB specification.                |
|              | Remote wakeups are not supported by this device. The SUSPEND state can only be exited via a USB Resume or a system reset event.                                                |
|              | In USB 2.0 mode the CPM is able to detect USB Resume.                                                                                                                          |
|              | In USB 2.0 mode the CPM is able to support LPM low power states                                                                                                                |
|              | •                                                                                                                                                                              |





Figure 5.1 Power States

### 5.2.2 VBUS Detection

VBUS\_DET is deglitched for a period of 10 ms.

**Note:** The deglitch interval may exceed 10 ms due to startup time of the crystal oscillator and the lock time for the common block.

The logic doesn't propagate any transitions on VBUS for the duration of the deglitch timer, after VBUS\_DET changes state. The deglitcher logic must operate in the clk\_xtal domain. This is to ensure that VBUS\_DET assertion detection can occur while in the UNPOWERED state. Figure 5.2 illustrates the derivation of VBUS\_DET and its use as an enable for the crystal oscillator.



Figure 5.2 VBUS Detection



## 5.2.3 Power State Mapping Tables

|                         | -               |                          |                        | -               |                 |  |  |
|-------------------------|-----------------|--------------------------|------------------------|-----------------|-----------------|--|--|
| MODULE                  | RESET           | NORMAL<br>(UNCONFIGURED) | NORMAL<br>(CONFIGURED) | SUSPEND         | UNPOWERED       |  |  |
| Crystal Oscillator      | Off<br>Note 5.1 | On                       | On                     | Off<br>Note 5.1 | Off<br>Note 5.1 |  |  |
| USB 2.0 PHY             | Off             | On                       | On                     | On              | Off             |  |  |
| UDC 2.0                 | Off             | On                       | On                     | On              | Off             |  |  |
| USB 2.0 Common<br>Block | Off             | On                       | On                     | Off             | Off             |  |  |
| System PLL              | Off             | Off                      | On                     | Off             | Off             |  |  |
| Pixel PLL               | Off             | Off                      | On                     | Off             | Off             |  |  |
| URX                     | Off             | Off                      | On                     | Off             | Off             |  |  |
| CTL                     | Off             | On                       | On                     | Off             | Off             |  |  |
| System CSRs             | Off             | On                       | On                     | Off             | Off             |  |  |
| FCT                     | Off             | Off                      | On                     | Off             | Off             |  |  |
| GPH                     | Off             | Off                      | On                     | Off             | Off             |  |  |
| DDR2 CTL                | Off             | Off                      | On                     | Off             | Off             |  |  |
| DDR2 PHY                | Off             | Off                      | On                     | Off             | Off             |  |  |
| VDAC                    | Off             | Off                      | Note 5.3               | Off             | Off             |  |  |
| HDMI CTL                | Off             | Off                      | Note 5.3               | Off             | Off             |  |  |
| HDMI PHY                | Off             | Off                      | Note 5.3               | Off             | Off             |  |  |
| Digital RGB I/F         | Off             | Off                      | Note 5.3               | Off             | Off             |  |  |
| EPC                     | Off             | On                       | On                     | Off             | Off             |  |  |
| l <sup>2</sup> C        | Off             | Off                      | On                     | Off             | Off             |  |  |
| LED Pin                 | Off             | On                       | Note 5.2 Off           |                 | Off             |  |  |
| nSW_MODE Pin            | On              | Off                      | Off                    | On              | On              |  |  |

#### Table 5.2 Functionality to Power State Mapping - UFX6000

- **Note 5.1** When the Clock Crystal Keep Alive Enable (CLK\_XTAL\_EN) bit of the CPM Control Register (CPM\_CTL) is set, the crystal oscillator will never be turned off by the CPM.
- Note 5.2 The LED pin behavior is a function of its configuration and the amount of received traffic.
- Note 5.3 Only activated when the respective video interface is enabled and connected.
- Note: The DDR2 controller should be placed in self-refresh by system software before entering SUSPEND.

Note: The HDMI PHY and VDAC default to being in the power down state.

## 5.3 Clock Generation

The below table lists the clocks generated by the CPM and their respective frequency range.



| CLOCK NAME        | SOURCE                  | FREQUENCY RANGE                                                                                  | COMMENT                                                                                                                                                                                                                                                             |
|-------------------|-------------------------|--------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| clk_xtal          | USB 2.0 Common<br>Block | 25 MHz                                                                                           | This clock is generated by<br>the crystal oscillator which is<br>incorporated in the USB 2.0<br>common block.                                                                                                                                                       |
| clk_sys_pll       | System PLL<br>output    | Supported Operating<br>Range:<br>250 MHz to 666 MHz<br>Maximum Range of PLL:<br>5 MHz to 700 MHz | This clock is the output of the<br>system PLL.<br>The frequency is<br>programmed via CSRs.                                                                                                                                                                          |
| clk_sys_pll_180   | System PLL<br>output    | Supported Operating<br>Range:<br>250 MHz to 666 MHz<br>Maximum Range of PLL:<br>5 MHz to 700 MHz | This clock is a 180 degree<br>phase shifted version of the<br>clk_sys_pll.                                                                                                                                                                                          |
| clk_ddr2          | СРМ                     | 125 MHz to 333 MHz                                                                               | This clock generated from<br>the output of the System<br>PLL. It is obtained by digitally<br>dividing the output of the<br>System PLL by 2.                                                                                                                         |
| clk_sys           | СРМ                     | 62.5 MHz to 167 MHz                                                                              | This clock generated by<br>digitally dividing the output of<br>the System PLL by 4.                                                                                                                                                                                 |
| clk_pixel_pll     | Pixel PLL output        | Supported Operating<br>Range:<br>50 MHz to 400 MHz<br>Maximum Range of PLL:<br>5 MHz to 700 MHz  | This clock is the output of the<br>Pixel PLL.<br>The frequency is<br>programmed via CSRs.                                                                                                                                                                           |
| clk_pixel_pll_180 | Pixel PLL output        | Supported Operating<br>Range:<br>50 MHz to 400 MHz<br>Maximum Range of PLL:<br>5 MHz to 700 MHz  | This clock is a 180 degree<br>phase shifted version of the<br>clk_pixel_pll.<br>This clock is used to assist in<br>the generation of<br>clk_pixel_90.                                                                                                               |
| clk_pixel         | СРМ                     | 25 MHz to 200 MHz                                                                                | Source clock for the display<br>controller and video interface<br>modules. Derived by dividing<br>clk_pixel_pll in half.<br><b>Note:</b> The pixel clock<br>does not exceed<br>165 MHz in HDMI<br>mode. 200MHz is<br>the limit for digital<br>RGB and Video<br>DAC. |
| clk_jpg           | СРМ                     | 240 MHz USB2.0 mode                                                                              | Source clock for the JPEG<br>Decoder.                                                                                                                                                                                                                               |

#### Table 5.3 Clocks



#### Table 5.3 Clocks (continued)

| CLOCK NAME   | SOURCE        | FREQUENCY RANGE   | COMMENT                                                                                  |
|--------------|---------------|-------------------|------------------------------------------------------------------------------------------|
| clk_pixel_90 | СРМ           | 25 MHz to 200 MHz | 90 degree shifted version of clk_pixel.                                                  |
|              |               |                   | This clock is used to build the digital RGB interface when operating in 12-bit DDR mode. |
| clk_60m      | USB 2.0 PHY   | 60 MHz            | This is derived from the UTMI clock                                                      |
| clk_eep      | СРМ           | 25 MHz            | Based on clk_xtal                                                                        |
| clk_pmt      | СРМ           | 25 MHz            | Based on clk_xtal                                                                        |
| tck          | TCK input pin | <= 10 MHz         | Used by JTAG and test controller                                                         |
| clk_i2c      | СРМ           | 2.08 MHz          | Generated by digitally dividing clk_xtal.                                                |

The CPM may generate additional intermediary clocks.



# 5.4 Pixel and System PLLs

### 5.4.1 Overview

The Pixel and System PLLs create the source clocks for the majority of the datapath. Both PLLs are instances of the same IP module procured from Analog Bits. They have been optimized for size, power, and accuracy. The last point is critical for the Pixel PLL, as the VESA DMT specification requires a 0.5% accuracy for supported pixel clocks.

### 5.4.2 PLL Programming

Initially both PLLs are disabled. The respective bypass and reset bits asserted. Only after the device is configured and the PLLs are programmed by software will they be operational.

The following steps are required for programming the PLLs into their normal operating mode.

- 1. All operation should commence by setting PLL\_GATE*x* for the PLL. This glitchlessly disables all clocks derived from the PLL.
- Both stages of the PLL must be placed in the reset or bypass state (RESET*x*=1 or BYPASS*x*=1, *x* = 0 and 1) with the reference running stably and the clock feedback path intact.
- 3. Set normal operating mode for both PLL stages (RESET0 and RESET1 = 0 and BYPASS0 and BYPASS1 = 0).
- 4. Wait the specified lock time (100 us).
- 5. It is normal for the LOCK*x* signal to come high before the specified lock time, and may glitch as jitter is acquired. This shows that the PLL has achieved a lock, but it will continue adjusting itself to a more perfect operating point. In a jittery environment, it is possible that LOCK*x* will not assert, but this does not mean that the PLL stage is not working.
- 6. Clear PLL\_GATEx for the PLL. This glitchlessly enables all clocks derived from the PLL.
- 7. To leave normal operating mode, assert PLL\_GATE*x* and RESET*x* or BYPASS*x* for both PLL stages.

The DDR2 Controller must be placed in self-refresh before changing the frequency of the System PLL. Refer to Section 7.4, "Operating Modes," on page 97 for a description of how to place the controller in self refresh.

Note: All traffic to the controller must be disabled, otherwise it will not enter self-refresh.



## 5.4.3 PLL Programming Examples

Table 5.4 illustrates how some typical operating frequencies are generated.

| PLL STAGE 0                |                |                            |                  |                | PLL STAGE 1      |                            |                |                            |                  |                |                  |                 |
|----------------------------|----------------|----------------------------|------------------|----------------|------------------|----------------------------|----------------|----------------------------|------------------|----------------|------------------|-----------------|
| 1-32                       | 5-200<br>(MHZ) | 1-256                      | 350-700<br>(MHZ) | 1-64<br>(2^N)  | 5-700<br>(MHZ)   | 1-32                       | 5-200<br>(MHZ) | 1-256                      | 350-700<br>(MHZ) | 1-64<br>(2^N)  | 5-700<br>(MHZ)   |                 |
| DIVR0<br>[4:0]<br>Note 5.4 | REF0<br>(MHZ)  | DIVF0<br>[7:0]<br>Note 5.4 | VCO0<br>(MHZ)    | DIVQ0<br>[2:0] | PLLOUT0<br>(MHZ) | DIVR1<br>[4:0]<br>Note 5.4 | REF1<br>(MHZ)  | DIVF1<br>[7:0]<br>Note 5.4 | VCO1<br>(MHZ)    | DIVQ1<br>[2:0] | PLLOUT1<br>(MHZ) | TARGET<br>(MHZ) |
|                            | Note 5.5       |                            | 25               | 1              | 25               | 16                         | 400            | 8                          | 50               | 50.000         |                  |                 |
| 1                          | 25             | 16                         | 400              | 1              | 400              | 5                          | 80             | 6                          | 480              | 2              | 240              | 240.000         |
| Note 5.5                   |                |                            | 25               | 1              | 25               | 20                         | 500            | 2                          | 250              | 250.000        |                  |                 |
| Note 5.5                   |                |                            | 25               | 5              | 5                | 132                        | 660            | 2                          | 330              | 330.000        |                  |                 |
| 1                          | 25             | 16                         | 400              | 1              | 400              | 3                          | 133.333        | 5                          | 666.667          | 2              | 333.333          | 333.333         |
| Note 5.5                   |                |                            | 25               | 1              | 25               | 16                         | 400            | 1                          | 400              | 400.000        |                  |                 |
| 1                          | 25             | 16                         | 400              | 1              | 400              | 3                          | 133.333        | 4                          | 533.333          | 1              | 533.333          | 533.333         |
| 1                          | 25             | 16                         | 400              | 1              | 400              | 3                          | 133.333        | 5                          | 666.667          | 1              | 333.333          | 666.667         |

#### **Table 5.4 PLL Frequency Configurations**

**Note 5.4** The value to be written to the corresponding CSR field is the value indicated plus 1.

Note 5.5 Single stage configurations with PLL Stage 0 set to BYPASS mode.

Note: REF0, VCO0, REF1, and VCO1 are internal nodes, not primary inputs or outputs of the PLL.

### 5.4.4 DDR2 Clock Frequency Considerations

DDR2 controller operations required when changing clock frequencies are described herein:

- 1. Request the controller to enter self refresh by asserting the Self Refresh Enable (REG\_DDRC\_SELFREF\_EN) bit of the DDR2 Dynamic Register (DDR\_DYN\_REG).
- 2. Wait until DDR2 Controller Operating Mode (DDRC\_REG\_OPERATING\_MODE) field of DDR2 Control Register 10 (DDR\_CONTROL\_10) == 3h, indicating that the DRAM is in self refresh.
- 3. Glitchlessly change the clock frequency to the controller.
- 4. Update any registers which may be required to change for the new frequency.
- 5. Take the controller out of self refresh by de-asserting the Self Refresh Enable (REG\_DDRC\_SELFREF\_EN) bit of the DDR2 Dynamic Register (DDR\_DYN\_REG).



# 5.5 USB Suspend

The Figure 5.3 illustrates the steps taken by system software and the CPM to place the device into the SUSPEND state from the CONFIGURED state.



Figure 5.3 USB Suspend Sequence



DDR2 self-refresh, HDMI PHY power down, Video DAC power down, and Digital RGB pads are controlled via CSRs. The Self Refresh Enable (REG\_DDRC\_SELFREF\_EN) bit of the DDR2 Dynamic Register (DDR\_DYN\_REG) controls DDR2 self-refresh. HDMI PHY power down is controlled by the Enable HDMI PHY (EN\_HDMI) bit of the HDMI Configuration Register (HDMI\_CFG). Video DAC power down is controlled by the Enable DAC Channel 0 (EN\_DAC0), Enable DAC Channel 1 (EN\_DAC1), and Enable DAC Channel 2 (EN\_DAC2) bits of the Video DAC Configuration Register (VDAC\_CFG). The Digital RGB pads are controlled by the RGB Configuration Register (RGB\_CFG).

The PWD and OEN for DDR2 non-CKE pads are controlled by the DDR2 Pads Power Down Control (REG\_DDR2\_PWD) and the DDR2 Pads Output Enable Disable (REG\_DDR2\_OE\_DISABLE) bits of the DDR2 PHY Control Register 0 (DDR\_PHY\_CTL\_0).

Note: Setting the Self Refresh Enable (REG\_DDRC\_SELFREF\_EN) bit of the DDR2 Dynamic Register (DDR\_DYN\_REG) automatically disables OEN for non-CKE pads. The DDR2 Pads Output Enable Disable (REG\_DDR2\_OE\_DISABLE) bit does not need to be programmed to do this.

The DCTL interface select CSRs disable the respective video interface. The clock to the interface is shut down when the interface is disabled. Refer to the Interface 0 Select (INTF\_SEL\_0), Interface 1 Select (INTF\_SEL\_1), and Interface 2 Select (INTF\_SEL\_2) bits of the Display Interface Control 0 Register (DISPLAY\_INTERFACE\_CTRL\_0), Display Interface Control 1 Register (DISPLAY\_INTERFACE\_CTRL\_1), and the Display Interface Control 2 Register (DISPLAY\_INTERFACE\_CTRL\_2), respectively, for additional information.

The actions illustrated in Figure 5.4 are performed when the Auto Suspend (AUTO\_SUSPEND) bit of the CPM Control Register (CPM\_CTL) is set. This feature is used when the driver is unable to manually place the part in suspend.





**Figure 5.4 Auto Suspend Actions** 

**Note:** Software should issue a Lite Reset (LRST) when resuming, as portions of the chip are reset during the Auto Suspend sequence.



# 5.6 USB Resume

The Figure 5.5 illustrates the steps taken by system software and the CPM to place the device into the SUSPEND state from the CONFIGURED state.



Figure 5.5 USB Resume Sequence



# 5.7 LPM Support

The device supports LPM.

## Table 5.5 LPM States

| LPM STATE    | DESCRIPTION                                                                                                                                                                                                                                              |  |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| L0 (On)      | his is the full operational state of the device.                                                                                                                                                                                                         |  |
| L1 (Sleep)   | This state is meant to provide finer granularity than the L2 state. Because of the short resume time required per LPM spec the CPM will not power down any modules.<br><b>Note:</b> There are no specific power draw requirements on VBUS in this state. |  |
| L2 (Suspend) | This state is equivalent to USB suspend state.                                                                                                                                                                                                           |  |
| L3 (Off)     | In this state, the device is not capable of performing any data signaling. It corresponds to the USB powered-off, disconnected, and disabled states.                                                                                                     |  |

# 5.8 U0, U1, U2, U3 States

### Table 5.6 LFPS States

| LFPS STATE | DESCRIPTION                                                                                         |  |
|------------|-----------------------------------------------------------------------------------------------------|--|
| UO         | This is the CONFIGURED state after PLLs and datapath have been configured to receive/transmit data. |  |
| U1         | CPM does not take any actions to suspend power.                                                     |  |
| U2         | CPM does not take any actions to suspend power.                                                     |  |
| U3         | Equivalent to the SUSPEND state.                                                                    |  |



# 5.9 Control and Status Registers

The CPM CSRs are implemented in the clk\_xtal domain. Therefore, they can be accessed via the control endpoint before enabling the System or Pixel PLLs.

| ADDRESS<br>OFFSET | SYMBOL       | REGISTER NAME                                   |
|-------------------|--------------|-------------------------------------------------|
| 7000h             | PIX_PLL_CTL  | Pixel Clock PLL Control Register                |
| 7004h             | PIX_PLL0_CFG | Pixel Clock PLL Stage 0 Configuration Register  |
| 7008h             | PIX_PLL1_CFG | Pixel Clock PLL Stage 1 Configuration Register  |
| 700Ch             | SYS_PLL_CTL  | System Clock PLL Control Register               |
| 7010h             | SYS_PLL0_CFG | System Clock PLL Stage 0 Configuration Register |
| 7014h             | SYS_PLL1_CFG | System Clock PLL Stage 1Configuration Register  |
| 7018h – 701Ch     | RESERVED     | Reserved for future expansion                   |
| 7020h             | CPM_CTL      | CPM Control Register                            |
| 7024h-7FFFh       | RESERVED     | Reserved for future expansion                   |

## Table 5.7 Clocks and Power Management Control and Status Register Map



# 5.9.1 Pixel Clock PLL Control Register (PIX\_PLL\_CTL)

0000h

Offset:

```
Size:
```

| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                         | TYPE | DEFAULT |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31   | <b>PIX PLL Gate (PIX_GATE)</b><br>When set, will glitchlessly stop all clocks derived from the PIX PLL.<br>When cleared, will glitchlessly enable all clocks derived from the PIX PLL.                                                                                                                                              |      | 1b      |
|      | Note: This bit should only be cleared when the PIX PLL is in a stable state.                                                                                                                                                                                                                                                        |      |         |
| 30:6 | RESERVED                                                                                                                                                                                                                                                                                                                            | RO   | -       |
| 5    | <b>PIX PLL Stage 1 Lock (PIX_LOCK1)</b><br>When high, this bit indicates that PIX PLL Stage 1 has locked on to the incoming signal. It indicates that the PLL has achieved frequency lock with a good phase lock. PIX_LOCK0 and PIX_LOCK1 are asynchronous.                                                                         | RO   | Ob      |
|      | <b>Note:</b> In the case of jittery source clock or feedback tree, it is possible that this bit does not assert because the phases do not match perfectly.                                                                                                                                                                          |      |         |
|      | <b>Note:</b> It is recommended that PIX_LOCK0 and PIX_LOCK1 are only used for test and system status information and not for critical system functions without thorough characterization in the host system.                                                                                                                        |      |         |
| 4    | <b>PIX PLL Stage 0 Lock (PIX_LOCK0)</b><br>When high, this bit indicates that PIX PLL Stage 0 has locked on to the incoming signal. It indicates that the PLL has achieved frequency lock with a good phase lock. PIX_LOCK0 and PIX_LOCK1 are asynchronous.                                                                         |      | Ob      |
|      | <b>Note:</b> In the case of jittery source clock or feedback tree, it is possible that this bit does not assert because the phases do not match perfectly.                                                                                                                                                                          |      |         |
|      | <b>Note:</b> It is recommended that PIX_LOCK0 and PIX_LOCK1 are only used for test and system status information and not for critical system functions without thorough characterization in the host system.                                                                                                                        |      |         |
| 3    | <b>PIX PLL Stage 1 Bypass (PIX_BYPASS1)</b><br>A BYPASS signal is provided for each PLL stage, which both powers-down<br>the PLL stage and bypasses it such that PIX PLLOUT/ PIX PLLOUTB tracks<br>PIX REF. When this bit is asserted, the PIX PLLOUT/PIX PLLOUTB output<br>tracks the PIX PLLOUT0 node (input to the Stage 1 PLL). |      | 1b      |
|      | Note: In order to completely bypass both PLL Stages (from PIX REF to PIX PLLOUT/PIX PLLOUTB), both PIX_BYPASS0 and PIX_BYPASS1 will need to be asserted simultaneously.                                                                                                                                                             |      |         |
| 2    | <b>PIX PLL Stage 0 Bypass (PIX_BYPASS0)</b><br>A BYPASS signal is provided for each PLL stage, which both powers-down<br>the PLL stage and bypasses it such that PIX PLLOUT/ PIX PLLOUTB tracks<br>PIX REF. When this bit is asserted, the node PIX PLLOUT0 tracks the PIX<br>REF input.                                            |      | 1b      |
|      | Note: In order to completely bypass both PLL Stages (from PIX REF to PIX PLLOUT/PIX PLLOUTB), both PIX_BYPASS0 and PIX_BYPASS1 will need to be asserted simultaneously.                                                                                                                                                             |      |         |
| 1    | <b>PIX PLL Stage 1 Reset (PIX_RESET1)</b><br>A RESET signal is provided for each PLL stage to power down the PLL and<br>reset it to a known state (low). When this bit is asserted, PIX PLL stage 1<br>will be powered down and PIX PLLOUT/PIX PLLOUTB will be held low.                                                            | R/W  | 1b      |



| BITS | DESCRIPTION                                                                                                                                                                                                                                                  | TYPE | DEFAULT |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 0    | <b>PIX PLL Stage 0 Reset (PIX_RESET0)</b><br>A RESET signal is provided for each PLL stage to power down the PLL and reset it to a known state (low). When this bit is asserted, PIX PLL stage 0 will be powered down and node PIX PLLOUT0 will be held low. | R/W  | 1b      |



# 5.9.2 Pixel Clock PLL Stage 0 Configuration Register (PIX\_PLL0\_CFG)

Offset:

0004h

Size:

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                            | TYPE | DEFAULT |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:23 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RO   | -       |
| 22:20 | PIX PLL Stage 0 Filter Range (PIX_RANGE0)<br>This field sets the PLL loop filter for PIX PLL Stage 0 to work with the post-<br>reference divider frequency (PIX REF0). The highest valid range should be<br>specified for best jitter performance.<br>000 = BYPASS<br>001 = 5 - 10 MHz<br>010 = 8 - 16 MHz<br>011 = 13 - 26 MHz<br>100 = 21 - 42 MHz<br>101 = 34 - 68 MHz<br>110 = 54 - 108 MHz<br>111 = 88 - 200 MHz                                                  | R/W  | 000b    |
| 19    | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RO   | -       |
| 18:16 | PIX PLL Stage 0 Output Divider Value (PIX_DIVQ0)         The Output Divider value is 2 raised to the power of this field, i.e., 2 <sup>0</sup> = 1.         PIX PLLOUT0 should be within the range of 350 MHz to 700 MHz. (When either of the PLL Stages are in BYPASS, PIX PLLOUT0 should be within the range of 5MHz to 200 MHz.)         Note:       111 is not a valid setting for this field. Only divide by 1-64 (2 <sup>0</sup> - 2 <sup>6</sup> ) are allowed. |      | 000b    |
| 15:13 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RO   | -       |
| 12:8  | PIX PLL Stage 0 Reference Divider Value (PIX_DIVR0)         The Reference Divider value is the value of this field + 1.         Note:       PIX REF and divided PIX REF (PIX REF0) must be within the range of 5MHz to 200MHz                                                                                                                                                                                                                                          | R/W  | 00000b  |
| 7:0   | <b>PIX PLL Stage 0 Feedback Divider Value (PIX_DIVF0)</b><br>The Feedback Divider value is the value of this field + 1.<br><b>Note:</b> VCO0 must be with the range of 350 MHz to 700 MHz.                                                                                                                                                                                                                                                                             | R/W  | 00h     |



# 5.9.3 Pixel Clock PLL Stage 1 Configuration Register (PIX\_PLL1\_CFG)

Offset:

0008h

```
Size:
```

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                      | TYPE | DEFAULT |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:23 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                         | RO   | -       |
| 22:20 | PIX PLL Stage 1 Filter Range (PIX_RANGE1)<br>This field sets the PLL loop filter for PIX PLL Stage 1 to work with the post-<br>reference divider frequency (PIX REF1). The highest valid range should be<br>specified for best jitter performance.<br>000 = BYPASS<br>001 = 5 - 10 MHz<br>010 = 8 - 16 MHz<br>011 = 13 - 26 MHz<br>100 = 21 - 42 MHz<br>110 = 54 - 108 MHz<br>111 = 88 - 200 MHz |      | 000Ь    |
| 19    | RESERVED                                                                                                                                                                                                                                                                                                                                                                                         |      | -       |
| 18:16 | <ul> <li>PIX PLL Stage 1 Output Divider Value (PIX_DIVQ1)</li> <li>The Output Divider value is 2 raised to the power of this field, i.e., 2<sup>0</sup> = 1.</li> <li>Note: 111 is not a valid setting for this field. Only divide by 1-64 (2<sup>0</sup> - 2<sup>6</sup>) are allowed.</li> </ul>                                                                                               |      | 000b    |
| 15:13 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                         | RO   | -       |
| 12:8  | <b>PIX PLL Stage 1 Reference Divider Value (PIX_DIVR1)</b><br>The Reference Divider value is the value of this field + 1.<br><b>Note:</b> The PIX REF1 node must be within the range of 5MHz to 200MHz                                                                                                                                                                                           |      | 00000b  |
| 7:0   | PIX PLL Stage 1 Feedback Divider Value (PIX_DIVF1)         The Feedback Divider value is the value of this field + 1.         Note:       VCO1 must be with the range of 350 MHz to 700 MHz.                                                                                                                                                                                                     | R/W  | 00h     |



# 5.9.4 System Clock PLL Control Register (SYS\_PLL\_CTL)

000Ch

Offset:

Size:

32 bits

BITS DESCRIPTION TYPE DEFAULT 31 SYS PLL Gate (SYS\_GATE) R/W 1b When set, will glitchlessly stop all clocks derived from the SYS PLL. When cleared, will glitchlessly enable all clocks derived from the SYS PLL. This bit should only be cleared when the SYS PLL is in a stable Note: state RESERVED 30:6 RO -5 SYS PLL Stage 1 Lock (SYS\_LOCK1) RO 0bWhen high, this bit indicates that SYS PLL Stage 1 has locked on to the incoming signal. It indicates that the PLL has achieved frequency lock with a good phase lock. SYS LOCK0 and SYS LOCK1 are asynchronous. In the case of jittery source clock or feedback tree, it is possible Note: that this bit does not assert because the phases do not match perfectlv. It is recommended that SYS\_LOCK0 and SYS\_LOCK1 are only Note: used for test and system status information and not for critical system functions without thorough characterization in the host system. SYS PLL Stage 0 Lock (SYS\_LOCK0) When high, this bit indicates that SYS PLL Stage 0 has locked on to the incoming signal. It indicates that the PLL has achieved frequency lock with 4 RO 0b a good phase lock. SYS LOCK0 and SYS LOCK1 are asynchronous. In the case of jittery source clock or feedback tree, it is possible Note: that this bit does not assert because the phases do not match perfectly. It is recommended that SYS LOCK0 and SYS LOCK1 are only Note: used for test and system status information and not for critical system functions without thorough characterization in the host system. SYS PLL Stage 1 Bypass (SYS\_BYPASS1) 3 R/W 1b A BYPASS signal is provided for each PLL stage, which both powers-down the PLL stage and bypasses it such that SYS PLLOUT/ SYS PLLOUTB tracks SYS REF. When this bit is asserted, the SYS PLLOUT/SYS PLLOUTB output tracks the SYS PLLOUT0 node (input to the Stage 1 PLL). Note: In order to completely bypass both PLL Stages (from SYS REF to SYS PLLOUT/SYS PLLOUTB), both SYS BYPASS0 and SYS BYPASS1 will need to be asserted simultaneously. 2 SYS PLL Stage 0 Bypass (SYS\_BYPASS0) R/W 1b A BYPASS signal is provided for each PLL stage, which both powers-down the PLL stage and bypasses it such that SYS PLLOUT/ SYS PLLOUTB tracks SYS REF. When this bit is asserted, the node SYS PLLOUT0 tracks the SYS REF input. Note: In order to completely bypass both PLL Stages (from SYS REF to SYS PLLOUT/SYS PLLOUTB), both SYS BYPASS0 and SYS BYPASS1 will need to be asserted simultaneously.



| BITS | DESCRIPTION                                                                                                                                                                                                                                                       | TYPE | DEFAULT |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 1    | SYS PLL Stage 1 Reset (SYS_RESET1)<br>A RESET signal is provided for each PLL stage to power down the PLL and<br>reset it to a known state (low). When this bit is asserted, SYS PLL stage 1<br>will be powered down and SYS PLLOUT/SYS PLLOUTB will be held low. |      | 1b      |
| 0    | SYS PLL Stage 0 Reset (SYS_RESET0)<br>A RESET signal is provided for each PLL stage to power down the PLL and<br>reset it to a known state (low). When this bit is asserted, SYS PLL stage 0<br>will be powered down and node SYS PLLOUT0 will be held low.       | R/W  | 1b      |



# 5.9.5 System Clock PLL Stage 0 Configuration Register (SYS\_PLL0\_CFG)

Offset:

0010h

Size:

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                   | TYPE | DEFAULT |  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|--|
| 31:23 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                      | RO   | -       |  |
| 22:20 | SYS PLL Stage 0 Filter Range (SYS_RANGE0)<br>This field sets the PLL loop filter for SYS PLL Stage 0 to work with the post-<br>reference divider frequency (SYS REF0). The highest valid range should be<br>specified for best jitter performance.<br>000 = BYPASS<br>001 = 5 - 10 MHz<br>010 = 8 - 16 MHz<br>101 = 13 - 26 MHz<br>101 = 34 - 68 MHz<br>110 = 54 - 108 MHz<br>111 = 88 - 200 MHz                                              |      | 000Ь    |  |
| 19    | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                      | RO   | -       |  |
| 18:16 | SYS PLL Stage 0 Output Divider Value (SYS_DIVQ0)The Output Divider value is 2 raised to the power of this field, i.e., 2 <sup>0</sup> = 1.SYS PLLOUT0 should be within the range of 350 MHz to 700 MHz. (When<br>either of the PLL Stages are in BYPASS, SYS PLLOUT0 should be within<br>the range of 5MHz to 200 MHz.)Note:111 is not a valid setting for this field. Only divide by 1-64 (2 <sup>0</sup> - 2 <sup>6</sup> )<br>are allowed. |      | 000b    |  |
| 15:13 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                      | RO   | -       |  |
| 12:8  | SYS PLL Stage 0 Reference Divider Value (SYS_DIVR0)<br>The Reference Divider value is the value of this field + 1.R/W00000Note:SYS REF and divided SYS REF (SYS REF0) must be within the<br>range of 5MHz to 200MHzSYS REF (SYS REF0)SYS REF                                                                                                                                                                                                  |      |         |  |
| 7:0   | SYS PLL Stage 0 Feedback Divider Value (SYS_DIVF0)       R/W         The Feedback Divider value is the value of this field + 1.       Note:         Note:       VCO0 must be with the range of 350 MHz to 700 MHz.                                                                                                                                                                                                                            |      |         |  |



# 5.9.6 System Clock PLL Stage 1 Configuration Register (SYS\_PLL1\_CFG)

Offset:

0014h

```
Size:
```

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                           | TYPE | DEFAULT |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:23 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                              | RO   | -       |
| 22:20 | SYS PLL Stage 1 Filter Range (SYS_RANGE1)<br>This field sets the PLL loop filter for SYS PLL Stage 1 to work with the post-<br>reference divider frequency (SYS REF1). The highest valid range should be<br>specified for best jitter performance.<br>000 = BYPASS<br>001 = 5 - 10 MHz<br>010 = 8 - 16 MHz<br>011 = 13 - 26 MHz<br>100 = 21 - 42 MHz<br>101 = 34 - 68 MHz<br>110 = 54 - 108 MHz<br>111 = 88 - 200 MHz |      | 000Ь    |
| 19    | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                              | RO   | -       |
| 18:16 | <ul> <li>SYS PLL Stage 1 Output Divider Value (SYS_DIVQ1)</li> <li>The Output Divider value is 2 raised to the power of this field, i.e., 2<sup>0</sup> = 1.</li> <li>Note: 111 is not a valid setting for this field. Only divide by 1-64 (2<sup>0</sup> - 2<sup>6</sup>) are allowed.</li> </ul>                                                                                                                    |      | 000b    |
| 15:13 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                              | RO   | -       |
| 12:8  | <b>SYS PLL Stage 1 Reference Divider Value (SYS_DIVR1)</b><br>The Reference Divider value is the value of this field + 1.<br><b>Note:</b> The SYS REF1 node must be within the range of 5MHz to 200MHz                                                                                                                                                                                                                |      | 00000b  |
| 7:0   | SYS PLL Stage 1 Feedback Divider Value (SYS_DIVF1)       R/W         The Feedback Divider value is the value of this field + 1.       R/W         Note:       VCO1 must be with the range of 350 MHz to 700 MHz.                                                                                                                                                                                                      |      |         |



# 5.9.7 CPM Control Register (CPM\_CTL)

```
Offset:
```

0020h

```
Size:
```

32 bits

| BITS | DESCRIPTION                                                                                                                                                                                                                      | TYPE | DEFAULT  |  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|--|
| 31:3 | RESERVED                                                                                                                                                                                                                         | RO   | -        |  |
| 2    | Clock JPEG Source Select (CLK_JPG_SRC_SEL)       R/W       0b         Selects the source for clk_jpg. This clock is only used by the JPEG decoder.       This bit does not affect the operation of the JPEG-LS decoder.       0b |      | Ob       |  |
|      | 0b: clk_jpg operates at 240 MHz.<br>1b: clk_jpg uses clk_sys as its source.                                                                                                                                                      |      |          |  |
|      | <b>Note:</b> Using clk_sys as a source will lower the performance of the JPEG decoder, however it will result in lower power consumption. When operating in lower resolutions it may be advisable to use clk_sys as the source.  |      |          |  |
| 1    | Clock Crystal Keep Alive Enable (CLK_XTAL_EN)         R/W           When set, the xtal oscillator will never be turned off by the CPM.         R/W                                                                               |      | Note 5.6 |  |
|      | Note: This field is protected by Reset Protection (RST_PROTECT)                                                                                                                                                                  |      |          |  |
| 0    | Auto Suspend (AUTO_SUSPEND)<br>When set, the CPM puts the chip in low power state automatically when<br>SUSPENDed. Refer to Figure 5.4 Auto Suspend Actions on page 72 for<br>further details.                                   | R/W  | 1b       |  |

**Note 5.6** The default value of this bit is determined by the value of the Clock Crystal Keep Alive Enable (CFG0\_CLK\_XTAL\_EN) bit of Configuration Flags 0 contained within the EEPROM, if present. If no EEPROM is present, 0b is the default. A USB Reset or Lite Reset (LRST) will cause this field to be restored to the image value last loaded from EEPROM, or to be set to 0b if no EEPROM is present.



# **Chapter 6 Reset Generator**

# 6.1 Description

The reset generator module (RST) drives all of the resets required by the device. This module asserts resets as a result of hardware or software events as described below. The reset generator has various clock inputs. The resets are deasserted synchronously to the corresponding clock.

Table 6.1 describes the chip level reset events.

#### Table 6.1 Chip Level Resets

| RESET EVENT                     | DESCRIPTION                                                                                                                                                                                                           |                                                                                                                                                                                                                              |  |
|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| External Chip Reset<br>(nRESET) | This active-low signal is an input from the external nRESET pin.<br><b>Note:</b> The EEPROM contents are loaded by this reset.                                                                                        |                                                                                                                                                                                                                              |  |
| Power on Reset (POR)            | POR is based on the 1.8V (POR from DDR2 pad cells), 3.3V, and 1.2 V (both POR from the USB PHY) being stable.<br><b>Note:</b> The EEPROM contents are loaded by this reset.                                           |                                                                                                                                                                                                                              |  |
| Lite Reset (LRST)               | This reset is initiated via the Soft Lite Reset (LRST) bit of the Hardware Configuration Register (HW_CFG).<br>Resets the entire chip with the exception of the enabled USB controller, control endpoint and USB PHY. |                                                                                                                                                                                                                              |  |
|                                 | Note:                                                                                                                                                                                                                 | This reset does not cause the USB contents from the EEPROM to be reloaded.                                                                                                                                                   |  |
|                                 | Note:                                                                                                                                                                                                                 | This reset does not place the device into the Unconfigured state.                                                                                                                                                            |  |
|                                 | Note:                                                                                                                                                                                                                 | After the LRST, the USB pipes corresponding to the Bulk<br>Out and Interrupt endpoints must be reset. This process<br>entails clearing the device's ENDPOINT_HALT feature and<br>resetting the data toggle on the host side. |  |
|                                 | Note:                                                                                                                                                                                                                 | The System and Pixel PLLs are reset.                                                                                                                                                                                         |  |



| Table 6.1 Chip Level Resets (continued) |                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|-----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| RESET EVENT                             | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| Software Reset (SRST)                   | This reset is initiated via the Soft Reset (SRST) bit in the Hardware Configuration Register (HW_CFG). It will cause the entire chip to reset and the USB PHY to disconnect.                                                                                                                                                                                                                    |  |  |
|                                         | Note: The EEPROM contents are reloaded by this reset.                                                                                                                                                                                                                                                                                                                                           |  |  |
|                                         | <b>Note:</b> Writing SRST=1 will cause the device to disconnect from the USB shortly after the first good OUT Data packet during the Data Phase.                                                                                                                                                                                                                                                |  |  |
|                                         | In HS mode, a brief delay will allow enough time for the device to send the ACK for the Data Stage, but the device will be disconnected (causing a 3-strikes timeout failure) for any next transaction (e.g., the Status Stage, or a repeated Data Stage, if there were any bus errors).                                                                                                        |  |  |
|                                         | In FS mode, the brief delay will be short enough that the device will disconnect during the ACK packet, causing CRC, bit-stuff, etc. errors on USB.                                                                                                                                                                                                                                             |  |  |
|                                         | To the USB Host, the aforementioned behaviors are the<br>same as what happens during any Surprise Removal of a<br>USB Device. This behavior is completely normal, and a<br>compliant Host must be tolerant of it.                                                                                                                                                                               |  |  |
| Auto Suspend                            | This reset is asserted whenever the Auto Suspend<br>(AUTO_SUSPEND) bit in the CPM Control Register (CPM_CTL<br>set and a USB SUSPEND signal is received. Refer to Figure 5.<br>Auto Suspend Actions on page 72 for details on CPM actions and<br>portions of the chip that are reset when this event occurs. It is<br>recommended that software should issue a Lite Reset (LRST) a<br>resuming. |  |  |
|                                         | Note: This reset does not cause the contents from the EEPROM to be reloaded.                                                                                                                                                                                                                                                                                                                    |  |  |
| USB Reset                               | Resets the entire chip with the exception of the enabled USB device controller, control endpoint and USB PHY.                                                                                                                                                                                                                                                                                   |  |  |
|                                         | Note: This reset does not cause the contents from the EEPROM to be reloaded.                                                                                                                                                                                                                                                                                                                    |  |  |
| TAP Reset (nTRST)                       | This active-low reset is used by the TAP controller.                                                                                                                                                                                                                                                                                                                                            |  |  |
| HDMI Reset                              | This reset is initiated via the Reset HDMI (RST_HDMI) bit in the HDMI Configuration Register (HDMI_CFG). It will cause the HDMI controller to be reset.                                                                                                                                                                                                                                         |  |  |
| External Transmitter<br>Reset (nEXTRST) | <ul> <li>This reset is used for an external transmitter. This reset is asserted under the following conditions.</li> <li>When the device is in the USB UNCONFIGURED state. After the device is configured the reset is deasserted.</li> </ul>                                                                                                                                                   |  |  |
|                                         | <ul> <li>When programmed to be asserted via the External Reset<br/>Configuration Register (EXT_RST_CFG).</li> </ul>                                                                                                                                                                                                                                                                             |  |  |
| VBUS Detection<br>(VBUS_DET)            | The removal of USB power causes the device to transition to the UNPOWERED state. The chip is held in reset while in the UNPOWERED state.                                                                                                                                                                                                                                                        |  |  |
|                                         | <b>Note:</b> After VBUS is applied, the contents of the EEPROM are reloaded.                                                                                                                                                                                                                                                                                                                    |  |  |

## Table 6.1 Chip Level Resets (continued)



# **Chapter 7 Memory Controller**

# 7.1 Overview

The device contains a DDR2 controller and PHY. The DDR2 controller operates at a speed up to 333 MHz, while the DDR2 PHY operates at maximum of DDR2-666. While the DDR2 PHY has a 13-bit address bus capable of supporting up to 512 Mbit DDR2 RAM, only 12 address bits are used, as the device only utilizes a 256 Mbit RAM. The DDR2 PHY has 2 bank pins, thus supports up to four memory banks. Its data bus is 16-bits wide. The device can read and write in burst mode with a burst length of 16-bits.

The DDR2 controller's flexible address mapper logic allows for application specific mapping of system addresses to DRAM addresses (rank, bank, row, and column). The controller performs dynamic scheduling to optimize bandwidth and latency. It prioritizes requests to minimize the latency of reads (especially high priority reads) and maximize page hits. It also ensures that the DRAM is properly initialized, that all requests are legal (depending on DRAM constraints), that refreshes are inserted as required, and that the DRAM enters and exits power-saving modes in an appropriate manner. Delayed writes are also used for optimum performance on DRAM data bus.

The device's advanced power-saving design includes no unnecessary toggling of command, address, and data pins(CA/RAS/CAS/WE/BA/A hold last state after each command; DQ does not transition on writes when bytes are disabled).

DRAM operational parameters are programmable via Control and Status Registers (CSR). Support is provided for explicit software-controlled mode register updates, as well as for 2T timing, where the clock edge that the chip select signal is asserted (the address and command is registered into memory) is statically selectable via a programming register.

There are four modes of operations: Uninitialized, Normal, Powerdown, and Self Refresh. Autonomous DRAM power down with entry and exit based on programmable idle periods is supported. Support for Self Refresh entry on software command and automatic exit on command arrival is provided. The clock frequency may be dynamically changed while in Self Refresh.

When in USB SUSPEND mode, DDR2 pads will be disabled, with the exception of CKE. Pads are disabled only after the controller has been being successfully placed in Self Refresh mode. ODT is supported in pads, however, ODT tuning is not available. ODT tolerance across PVT is +/- 20%.

Access to DDR2 RAM is provided via a register based Data Port. The Data Port Select Register (DP\_SEL) is used to select the DDR2 RAM, while the Data Port Address Register (DP\_ADDR) is used to specify the address of the DDR2 RAM element to be accessed. Read/Write selection is controlled by the Data Port Command Register (DP\_CMD). Data to Read/Written is accessed via the Data Port Data 0 Register (DP\_DATA0). Refer to the definition of these registers for details on their use.

# 7.2 Description of Controller Functions

## 7.2.1 Address Mapper

Read and write requests are provided to the controller with a system address. The controller is responsible for mapping this system address to rank, bank, row, and column address to DRAM.

## 7.2.1.1 DDRC Register Fields Related to the Address Mapper

The following CSR register fields are related to DRAM Initialization and must be set appropriately:

DDR2 Bank/CS Address Mapping Register (DDR\_AD\_MAP\_BA\_CS): Address Map Bank Address Bit 0 (REG\_DDRC\_ADDRMAP\_BANK\_B0) Address Map Bank Address Bit 1 (REG\_DDRC\_ADDRMAP\_BANK\_B1) Address Map Bank Address Bit 2 (REG\_DDRC\_ADDRMAP\_BANK\_B2)



Address Map Rank Address Bit 0 (REG\_DDRC\_ADDRMAP\_CS\_BIT0)

DDR2 Column Address Mapping Register (DDR\_AD\_MAP\_COL): Address Map Column Address Bit 2 (REG\_DDRC\_ADDRMAP\_COL\_B2) Address Map Column Address Bit 3 (REG\_DDRC\_ADDRMAP\_COL\_B3) Address Map Column Address Bits 4 To 6 (REG\_DDRC\_ADDRMAP\_COL\_B4\_6) Address Map Column Address Bit 7 (REG\_DDRC\_ADDRMAP\_COL\_B7) Address Map Column Address Bit 8 (REG\_DDRC\_ADDRMAP\_COL\_B8) Address Map Column Address Bit 9 (REG\_DDRC\_ADDRMAP\_COL\_B8) Address Map Column Address Bit 9 (REG\_DDRC\_ADDRMAP\_COL\_B9) Address Map Column Address Bit 10 (REG\_DDRC\_ADDRMAP\_COL\_B10) Address Map Column Address Bit 11 (REG\_DDRC\_ADDRMAP\_COL\_B10) Address Map Column Address Bit 11 (REG\_DDRC\_ADDRMAP\_COL\_B11) DDR2 Row Address Mapping Register (DDR\_AD\_MAP\_ROW): Address Map Row Address Bit 0 (REG DDRC\_ADDRMAP\_ROW B0)

Address Map Row Address Bit 0 (REG\_DDRC\_ADDRMAP\_ROW\_B0) Address Map Row Address Bit 1 (REG\_DDRC\_ADDRMAP\_ROW\_B1) Address Map Row Address Bits 2 To 11 (REG\_DDRC\_ADDRMAP\_ROW\_B2\_11) Address Map Row Address Bit 12 (REG\_DDRC\_ADDRMAP\_ROW\_B12) Address Map Row Address Bit 13 (REG\_DDRC\_ADDRMAP\_ROW\_B13) Address Map Row Address Bit 14 (REG\_DDRC\_ADDRMAP\_ROW\_B14) Address Map Row Address Bit 15 (REG\_DDRC\_ADDRMAP\_ROW\_B15)

#### 7.2.1.2 Address Mapper Description

The address mapper maps linear request addresses to DRAM addresses by selecting the source bit that will map to each and every applicable DRAM address bit. While it's possible to map source address bits to DRAM address in any manner the user desires, the full available address space is only accessible to the user when no two DRAM address bits are determined by the same source address bit; therefore the address map must always be programmed to ensure that this is the case. Each DRAM address bit has an associated register vector to determine its source. The source address bit number is determined by adding the "internal base" of a given register to the programmed value for that register, as described in the following equation:

[internal base] + [register value] = [source address bit number]

For one example, reading the description for Address Map Column Address Bit 7 (REG\_DDRC\_ADDRMAP\_COL\_B7), we see that the internal base is 7; so when the full data bus is in use, column bit 7 is determined by the following: 7 + [register value] If this register were programmed to "2", then the source address bit would be: 7 + 2 = 9.

In other words, the column address bit 7 sent to DRAM would always be equal to bit 9 of the corresponding source address.

Note that all of the column bits shift up 1 bit when only half of the data bus in use. In this case, we would need to look at Address Map Column Address Bits 4 To 6 (REG DDRC ADDRMAP COL B4 6) instead to determine the value of column address bit 7.

Also, note that some registers map multiple source address bits (Address Map Column Address Bits 4 To 6 (REG\_DDRC\_ADDRMAP\_COL\_B4\_6)).

Finally, note that for any address bits which may not be in use in all cases, the associated address map register must be set to all ones when the associated DRAM address bit it is not in use.



## 7.2.2 ODT Controls

Register inputs are provided for controlling:

- The value desired for local ODT following a read command (DDR2 PHY Read Local ODT (REG\_PHY\_RD\_LOCAL\_ODT), typically programmed to 1 if used).
- The value desired for local ODT following a write command (DDR2 PHY Write ODT Control (REG PHY WR LOCAL ODT), typically programmed to 0 if used).
- The number of cycles to delay following a write command before driving the programmed values for write ODT (Write ODT Delay (REG\_DDRC\_WR\_ODT\_DELAY), which will depend primarily on CAS latency).
- The number of cycles to hold the programmed write value after it is first driven (Write ODT Hold (REG\_DDRC\_WR\_ODT\_HOLD)).
- **Note:** The number of cycles to delay following a read command before driving the programmed values for read ODT (Read ODT Delay) is determined by the controller.
- **Note:** The number of cycles to hold the programmed read value after it is first driven (Read ODT Hold) is determined by the controller.

These quantities must all be set before taking the controller out of soft reset; they will then be applied to every read or write issued by the controller.

## 7.2.2.1 ODT Write Timing

Figure 7.1 illustrates ODT Write Timing. The following defaults are assumed for the indicated fields of DDR2 Control Register 3 (DDR\_CONTROL\_3):

Rank 0 Write ODT (REG\_DDRC\_RANK0\_WR\_ODT) = 10b (DRAM ODT on, local ODT off during writes).



Figure 7.1 ODT Write Timing Diagram



## 7.2.2.2 ODT Read Timing

Figure 7.2 illustrates ODT Read Timing. The following defaults are assumed for the indicated fields of DDR2 Control Register 3 (DDR\_CONTROL\_3):

Rank 0 Read ODT (REG\_DDRC\_RANK0\_RD\_ODT) = 01b (DRAM ODT off, local ODT on during reads).



Figure 7.2 ODT Read Timing Diagram

## 7.2.3 Refresh Controls

The controller provides advanced refresh controls that support fully-configurable refresh constraints ( $t_{RFC(min)}$  and  $t_{REFI}$ ).

### 7.2.3.1 DDRC Register Fields Related to Refresh Control

The following CSR register fields are related to refresh control and must be set appropriately:

DDR2 Refresh Register (DDR\_REFRESH): Refresh Burst (REG\_DDRC\_REFRESH\_BURST)

DDR2 Refresh Register (DDR\_REFRESH): Refresh Idle Timeout (REG\_DDRC\_REFRESH\_TO\_X32)

## 7.2.3.2 Refresh Controls Description

The goals of the refresh controls are:

Reduce the bandwidth impact of refresh cycles.



- Increase the likelihood of refreshes being serviced during idle periods.
- Fine-grain control of the trading off the above benefits (for gathering refreshes) versus the increased worst case latencies associated with gathering refreshes, and

The controller can be programmed to issue single refreshes at a time (refresh\_burst=0) to minimize the worst-case impact of a forced refresh cycle. It can be programmed to burst the maximum number of refreshes allowed to be gathered for DDR2 (refresh\_burst=7, for performing 8 refreshes at a time) to minimize the bandwidth lost to closing pages for refresh and to increase the likelihood that refreshes may be serviced during idle periods. It may also be programmed to any number in between to trade-off the benefits of each.

#### 7.2.3.2.1 SINGLE REFRESH

When using single refresh (refresh\_burst=0), the controller will issue refreshes every time the refresh timer ( $t_{\mathsf{REFI}}$ ) expires. This is the optimal mode of operation for systems that must minimize the maximum latency associated with refresh cycles.

#### 7.2.3.2.2 BURST REFRESH

When refresh\_burst>0, the controller will issue refreshes in bursts of (refresh\_burst+1) refreshes at one time. Bursting refreshes reducing the total latency associated with those refreshes by reducing the number of precharges and activates required for refresh (because banks must be precharged only once to perform the entire group of refreshes, instead of once for each refresh).

#### 7.2.3.2.3 SPECULATIVE REFRESH

When burst refresh is enabled (refresh\_burst>0), the user may also utilize speculative refresh.

Burst refresh is implemented by counting the number of times  $t_{REFI}$  expires, and issuing a group of refreshes when that number reaches the refresh burst number. Once  $t_{REFI}$  has expired at least, the controller may also perform speculative refreshes. This is done by automatically inserting refreshes when the controller is idle.

The Refresh Idle Timeout (REG\_DDRC\_REFRESH\_TO\_X32) determines how long the controller must be idle before considering inserting these speculative refreshes. Each time a speculative refresh is performed, the count of  $t_{REFI}$  expirations will be decremented, and thus increasing the time before a burst of refreshes will be required. This also ensures that speculative refreshes never occur any more often than is required to keep the DRAM properly refreshed.

If a new read or write transaction is accepted by the controller during speculative refresh, the controller will service it as soon as legally possible. Most often that will entail waiting for the required NOP cycles after a refresh before performing an activate and then servicing the read or write. If the controller has begun closing pages for a speculative refresh but has not yet issued the refresh when the new transaction arrives, the speculative refresh will be cancelled.

## 7.2.4 DLL Calibration

#### 7.2.4.1 DLL Calibration Overview

DLL calibration is a signal to the PHY indicating that the PHY may update delay line values from the master DLL. The co\_gs\_dll\_calib signal serves this function; it is a synchronous signal that may be pulsed or held asserted longer. This must be asserted periodically to ensure that PVT (process/voltage/temperature) variations are accounted for in the delay line over time. It is important to control this carefully to ensure that the delay line is never updated during a read or a write, as this could degrade the data eye. There are 2 methods for doing the DLL Calibration:

1. Automatic DLL Calibration by the controller.



2. Forced DLL Calibration using a command from the user on co\_gs\_dll\_calib input.

#### 7.2.4.2 Automatic DLL Calibration Policy

This method is used when Disable DLL Calibration (REG\_DDRC\_DIS\_DLL\_CALIB) is set to 0.

As noted in the overview, the controller must carefully control the assertion of co\_gs\_dll\_calib. The controller uses the following policy to do this:

- 1. Assert co\_gs\_dll\_calib any time the controller is idle.
- Use a timeout mechanism to force DLL calibrations if controller is not idle for a long period of time. When a DLL calibration timeout occurs, the controller ceases to schedule reads and writes until calibration is performed.

#### 7.2.4.3 Forced DLL Calibration

This method is used when Disable DLL Calibration (REG DDRC DIS DLL CALIB) is set to 1.

In this case, the user decides when to do the DLL Calibration. This is useful in cases where the bandwidth utilization of the DRAM bus is extremely crucial and the core doesn't want any break in transactions. The user utilizes Request DLL Calibration (CO\_GS\_DLL\_CALIB) to invoke the operation.

When the controller is running with auto\_refresh disabled, co\_gs\_dll\_calib must be disabled as well (Disable DLL Calibration (REG\_DDRC\_DIS\_DLL\_CALIB) =1). The user may assert co\_gs\_dll\_calib at the same time as refresh assertion. For both the refresh and the co\_gs\_dll\_calib, the controller will take care to ensure that these happen in a functionally-correct manner.

## 7.2.5 Power Saving Features

The controller supports two power-saving modes: precharge power down and self refresh. When enabled, the controller automatically enters and exits precharge power down mode based on a programmable idle timeout period. Self refresh entry and exit is explicitly controlled by software. This section describes the signals that control both of those activities as well as the controls for the constraints related to exiting each mode properly.

### 7.2.5.1 DDRC Register Fields Related to Power Saving Features

DDR2 Timing Register 3 (DDR\_TIMING\_3): CKE Minimum Pulse Width (REG DDRC T CKE)

DDR2 Dynamic Register (DDR\_DYN\_REG): Power Down Enable (REG\_DDRC\_POWERDOWN\_EN) Self Refresh Enable (REG\_DDRC\_SELFREF\_EN)

DDR2 Control Register 8 (DDR\_CONTROL\_8): Precharge Power Down Timeout (REG\_DDRC\_POWERDOWN\_TO\_X32)

DDR2 Timing Register 2 (DDR\_TIMING\_2): Minimum Idle Precharge Power Down To Command (REG DDRC T XP)

DDR2 Timing Register 0 (DDR\_TIMING\_0): Self Refresh Wait (REG\_DDRC\_POST\_SELFREF\_GAP\_X32)

## 7.2.5.2 Power Saving Modes

The memory controller supports two power saving modes: Precharge Power Down and Self Refresh mode.

Note: These power saving modes must never be enabled simultaneously.



#### 7.2.5.2.1 ENTERING PRECHARGE POWER DOWN

When Power Down Enable (REG\_DDRC\_POWERDOWN\_EN) =1, the controller automatically enters precharge power down when the period specified by Precharge Power Down Timeout (REG\_DDRC\_POWERDOWN\_TO\_X32) has passed while the controller is idle (except for issuing refreshes).

Entering precharge power down involves the following steps:

- 1. Precharging (closing) all open pages. Pages are closed one-at-a-time in no specified order.
- 2. Waiting for tRP (row precharge) idle period.

Issuing the command to enter precharge power down (NOP/Deselect with CKE=0).

If the controller receives a read or write request from the core logic during steps 1. and 2. above, the power down entry will be immediately aborted. The same is true if Power Down Enable (REG\_DDRC\_POWERDOWN\_EN) is driven to '0' during steps 1. or 2. Once the power down entry command has been issued, and proper power down exit is required, as described in the following section.

#### 7.2.5.2.2 EXITING PRECHARGE POWER DOWN

Once the controller has put the DDR DRAM device(s) in precharge power down mode, the controller automatically performs the precharge power down exit sequence for any of the following reasons:

- Refresh cycle is required to any rank in the system,
- The controller receives a new request from the core logic, or
- Power Down Enable (REG\_DDRC\_POWERDOWN\_EN) is set to '0'.

To exit precharge power down, the controller does the following:

- 1. Insert any NOP/Deselect commands required to satisfy the t<sub>CKE</sub> requirement after entering precharge power down.
- 2. Issuing the power down exit command (NOP/Deselect with CKE=1).
- 3. Issuing NOP/Deselect for the period defined by txp.

#### Note: Fast Exit vs. Slow Exit Active Power Down

The DDR specs describe 2 different variations on active power down exit, depending on the programmed value of MR bit 12. Since the controller uses precharge power down rather than active power down, this programming has no effect on the controller or the DRAM devices.

#### 7.2.5.2.3 ENTERING SELF REFRESH

The controller puts the DDR DRAM device(s) in self refresh mode whenever the Self Refresh Enable (REG\_DDRC\_SELFREF\_EN) bit is set and either (a) no reads or writes are pending in the controller or (b) Disable Dequeue (REG\_DDRC\_DIS\_DQ) is set.

Entering self refresh mode involves the following steps:

- 1. Precharging (closing) all open pages. Pages are closed one-at-a-time in no specified order.
- 2. Waiting for  $t_{RP}$  (row precharge) idle period.
- 3. Issuing the command to enter self refresh mode (asserting RAS and CAS with CKE=0).

#### 7.2.5.2.4 EXITING SELF REFRESH

The controller takes the DDR DRAM out of self refresh mode whenever the Self Refresh Enable (REG\_DDRC\_SELFREF\_EN) input is deasserted or new commands are received by the controller.

To exit self refresh, the controller typically does the following:

1. Insert any NOP/Deselect commands required to satisfy the t<sub>CKE</sub> requirement after entering precharge power down.



- 2. Issuing the self refresh exit command (refresh with CKE=1).
- 3. Issuing NOP/Deselect for the period defined by txp.

#### 7.2.5.2.5 RESTARTING TO EXIT SELF REFRESH

In self-refresh mode, the DRAM will maintain itself as long it is properly powered and CKE is held low. This may allow the core logic to be completely powered down. If this is done, the controller will perform the standard initialization sequence when reset is de-asserted to the controller. The standard initialization sequence will properly bring the DRAM out of self refresh mode.

Refer to Section 7.2.6 for details on the initialization sequence.

## 7.2.6 DRAM Initialization Sequence

A specific command sequence must be followed to properly initialize DRAM modules. Much of the sequence is standard for all parts, but parts of it must be controlled differently according to system configuration, clock speeds, and the specific DRAM parts in use. For this reason, the controller provides a great deal of flexibility in how the initialization sequence will be performed.

This section describes the initialization sequence and programmability provided by the controller.

### 7.2.6.1 DDRC Register Fields Related to the DRAM Initialization Sequence

The following CSR register fields are related to DRAM Initialization and must be set appropriately:

DDR2 Control Register 4 (DDR\_CONTROL\_4):

Minimum Idle Time After Reset Before First CKE Assertion (REG\_DDRC\_PRE\_CKE\_X1024) Minimum Idle Time After First CKE Assertion (REG\_DDRC\_POST\_CKE\_X1024)

DDR2 Timing Register 4 (DDR\_TIMING\_4): Mode Register Delay (REG\_DDRC\_T\_MRD)

DDR2 Control Register 8 (DDR\_CONTROL\_8): Wait Period Before OCD Complete (REG\_DDRC\_PRE\_OCD\_X32) Final Wait (REG\_DDRC\_FINAL\_WAIT\_X32)

DDR2 Control Register 2 (DDR\_CONTROL\_2): Mode Register Value (REG\_DDRC\_MR) Extended Mode Register 3 Value (REG\_DDRC\_EMR3)

DDR2 Control Register 1 (DDR\_CONTROL\_1): Extended Mode Register Value (REG\_DDRC\_EMR) Extended Mode Register 2 Value (REG\_DDRC\_EMR2)

### 7.2.6.2 DRAM Initialization Sequence Description

When the CSR fields listed in Section 7.2.6.1 are set appropriately, the controller automatically performs the sequence necessary to properly initialize the DDR DRAM devices.

**Note:** In addition to initializing the DRAM after a hard reset, the initialization sequence may also be used to bring the DRAM out of self-refresh mode.

The initialization state machine will execute the following initialization sequence:

1. Power up.



- Issue NOP/Deselect for the duration specified by Minimum Idle Time After Reset Before First CKE Assertion (REG\_DDRC\_PRE\_CKE\_X1024) (spec requires at least 200 us with stable power and clock).
- Assert CKE and issue NOP/Deselect for Minimum Idle Time After First CKE Assertion (REG\_DDRC\_POST\_CKE\_X1024) (spec requires at least 400 ns).
- 4. Issue PRECHARGE ALL followed by NOP/Deselect for Precharge Command Period (REG\_DDRC\_T\_RP) cycles.
- Program EMR2 to the Extended Mode Register 2 Value (REG\_DDRC\_EMR2) value followed by NOP/Deselect for Mode Register Delay (REG\_DDRC\_T\_MRD) cycles.
- Program EMR3 to the Extended Mode Register 3 Value (REG\_DDRC\_EMR3) value followed by NOP/Deselect for Mode Register Delay (REG\_DDRC\_T\_MRD) cycles.
- 7. Enable DLL by programming EMR to the Extended Mode Register Value (REG\_DDRC\_EMR) value followed by NOP/deselect for Mode Register Delay (REG\_DDRC\_T\_MRD) cycles.
- Issue DLL reset by programming MR to the Mode Register Value (REG\_DDRC\_MR) value followed by NOP/Deselect for Mode Register Delay (REG\_DDRC\_T\_MRD) cycles.
- 9. Issue Precharge All followed by NOP/Deselect for Precharge Command Period (REG\_DDRC\_T\_RP) +1 cycles.
- 10. Issue Refresh followed by NOP/Deselect for Minimum Refresh Cycle Time (REG\_DDRC\_T\_RFC\_MIN) cycles. Repeat 9 times.
- 11. Program MR without resetting the DLL by setting MR to Mode Register Value (REG\_DDRC\_MR) value with bit 8 set to '1'.
- 12. Issue NOP/Deselect for duration specified by Wait Period Before OCD Complete (REG\_DDRC\_PRE\_OCD\_X32) (no spec requirement).
- 13. Issue "OCD complete" command, indicating that no on-chip driver calibration will be performed.
- 14. Issue NOP/Deselect for Final Wait (REG\_DDRC\_FINAL\_WAIT\_X32) cycles (no spec requirement).

15. Begin normal operation.

## 7.3 DDR2 Controller Configuration

## 7.3.1 Auto Initialization

After a hard reset, the DDR2 controller will be in soft reset. Power and clocks must be brought up in accordance with the requirements of the full ASIC/SoC design requirements and the DRAM power and clocks must be brought up in accordance with the appropriate DRAM spec prior to removing the controller from soft reset. (See JEDEC document JESD79-2C section 2.3.1 steps a and b.) A state machine inside the DDR2 controller automatically programs the DDR2 in accordance with the CSR values defined in Table 7.1.

When in soft reset, initialize all registers. The behavior of the controller is unpredictable if registers contain illegal values at the time that the controller is brought out of soft reset, or any time thereafter.

After all registers have been programmed, set the Soft Reset (REG\_DDRC\_SOFT\_RSTB) bit of the DDR2 Dynamic Register (DDR\_DYN\_REG) to take the controller out of soft reset. The DDR controller will initialize and bring up the DRAM. Software can poll the status bits within the CSRs (DDR Controller Initialization Done (DDRC\_INIT\_DONE) and PHY Initialization Done (PHY\_INIT\_DONE) bits of the DDR2 Dynamic Register (DDR\_DYN\_REG) and the DDR2 Controller Operating Mode (DDRC\_REG\_OPERATING\_MODE) bits of DDR2 Control Register 10 (DDR\_CONTROL\_10)) to determine when initialization is complete.



# 7.3.2 Configuration Example

Table 7.1 illustrates the programming values for SDRAM under DDR2 operation. When supporting lower display resolutions, it is possible to run the DDR2 at a lower speed.

| PARAMETER                                                                         | DDR2-400C<br>4-4-4 | DDR2-533C<br>5-5-5 | DDR2-667D<br>5-5-5 |
|-----------------------------------------------------------------------------------|--------------------|--------------------|--------------------|
| Burst Length (REG_DDRC_BURST8_RDWR)                                               |                    |                    | 0b                 |
| Nominal Refresh Cycle Time (REG_DDRC_T_RFC_NOM_X32)                               |                    |                    | 50h                |
| Self Refresh Wait (REG_DDRC_POST_SELFREF_GAP_X32)                                 |                    |                    | 8h                 |
| Minimum Refresh Cycle Time (REG_DDRC_T_RFC_MIN)                                   |                    |                    | 19h                |
| Active to Active Command Period (REG_DDRC_T_RC)                                   |                    |                    | 14h                |
| Minimum Bank Active Time (REG_DDRC_T_RAS_MIN)                                     |                    |                    | Ch                 |
| Maximum Bank Active Time<br>(REG_DDRC_T_RAS_MAX_X1024)                            |                    |                    | 11h                |
| Precharge Command Period (REG_DDRC_T_RP)                                          |                    |                    | 5h                 |
| RAS To RAS Delay (REG_DDRC_T_RRD)                                                 |                    |                    | 3h                 |
| Minimum Time Between Two Reads Or Two Writes (REG_DDRC_T_CCD)                     |                    |                    | 2h                 |
| RAS TO CAS Delay (REG_DDRC_T_RCD)                                                 |                    |                    | 5h                 |
| Mode Register Delay (REG_DDRC_T_MRD)                                              |                    |                    | 2h                 |
| Final Wait (REG_DDRC_FINAL_WAIT_X32)                                              |                    |                    | 4h                 |
| Minimum Idle Time After Reset Before First CKE Assertion (REG_DDRC_PRE_CKE_X1024) |                    |                    | 43h                |
| Mode Register Value (REG_DDRC_MR)                                                 |                    |                    | 952h               |
| Extended Mode Register Value (REG_DDRC_EMR)                                       |                    |                    | 40h                |
| Extended Mode Register 2 Value (REG_DDRC_EMR2)                                    |                    |                    | 0h                 |
| Extended Mode Register 3 Value (REG_DDRC_EMR3)                                    |                    |                    | 0h                 |
| Write To Precharge Turnaround Time (REG_DDRC_WR2PRE)                              |                    |                    | Bh                 |
| Read To Precharge Turnaround Time (REG_DDRC_RD2PRE)                               |                    |                    | 3h                 |
| Write To Read Turnaround Time (REG_DDRC_WR2RD)                                    |                    |                    | 9h                 |
| Read To Write Turnaround Time (REG_DDRC_RD2WR)                                    |                    |                    | 5h                 |
| Write Latency (REG_DDRC_WRITE_LATENCY)                                            |                    |                    | 3h                 |
| Four Active Window (REG_DDRC_T_FAW)                                               |                    |                    | Ah                 |
| Disable DLL Calibration (REG_DDRC_DIS_DLL_CALIB)                                  |                    |                    | 0h                 |
| Skip On-Chip_drive Calibration (REG_DDRC_SKIP_OCD)                                |                    |                    | 1h                 |
| Write ODT Hold (REG_DDRC_WR_ODT_HOLD)                                             |                    |                    | 2h                 |

#### Table 7.1 Sample Programming Values for DDR2



#### Table 7.1 Sample Programming Values for DDR2

| PARAMETER                                | DDR2-400C<br>4-4-4 | DDR2-533C<br>5-5-5 | DDR2-667D<br>5-5-5 |
|------------------------------------------|--------------------|--------------------|--------------------|
| Rank 0 Write ODT (REG_DDRC_RANK0_WR_ODT) |                    |                    | 1h                 |
| Rank 0 Read ODT (REG_DDRC_RANK0_RD_ODT)  |                    |                    | 2h                 |
| Write ODT Delay (REG_DDRC_WR_ODT_DELAY)  |                    |                    | 1h                 |

# 7.4 Operating Modes

The DDR2 Controller Operating Mode (DDRC\_REG\_OPERATING\_MODE) field of DDR2 Control Register 10 (DDR\_CONTROL\_10) can be polled to determine the current mode of operation of the controller. The modes are:

- 00 un-initialized. The controller may be in soft reset, or it may be out of soft reset, but the DRAM initialization sequence has not yet completed.
- 01 "normal" operating mode. The controller is ready to accept read and write requests and the controller may issue reads and writes to DRAM.
- 10 DRAM is in power down.
- 11 DRAM is in self refresh.

## 7.4.1 Moving To Power Down

Enable power down mode in the Master Control register. Once enabled, DDRC will automatically put the DRAM into precharge all power down after the programmed number of idle cycles.

A refresh request will bring the DRAM out of power down. It will go back into power down after the idle period.

Any transaction will bring the DRAM out of power down automatically.

Clearing the power down enable bit will also bring the DRAM out of power down.

**Note:** The DDR2 CKE Pads Output Enable Disable (REG\_DDR2\_OE\_CKE\_DISABLE), DDR2 CKE Pads Power Down Control (REG\_DDR2\_PWD\_CKE), DDR2 Pads Output Enable Disable (REG\_DDR2\_OE\_DISABLE), and DDR2 Pads Power Down Control (REG\_DDR2\_PWD) fields of the DDR2 PHY Control Register 0 (DDR\_PHY\_CTL\_0) facilitate configuring the DDR2 pads for minimal power consumption.

## 7.4.2 Moving To Self Refresh

To place the DRAM in self refresh, Set the Self Refresh Enable (REG\_DDRC\_SELFREF\_EN) bit in DDR2 Dynamic Register (DDR\_DYN\_REG). The DDRC will put the DRAM into self refresh as soon as the transaction buffers are empty. Software must ensure that no transactions arrive. If transactions keep arriving the DDRC will never put the DRAM into self refresh. The first valid transaction will bring the DRAM out of self refresh.

Note: Clock frequency can not be changed if the DRAM is not in self refresh mode.

Placing the DRAM in self refresh is part of the USB Suspend sequence and is illustrated in Figure 5.3 USB Suspend Sequence on page 70.



## 7.4.3 List of Dynamic Registers

Most registers are meant to be programmed while the controller is in soft reset. The exceptions are referred to as "dynamic registers". In the event that the register control is not in the same clock domain as the controller, these signals will need to be synchronized to the controller core clock domain. This synchronization must be done 'outside' of the DRAM Interface hierarchy. The following is a list of such signals.

- 1. Soft Reset (REG\_DDRC\_SOFT\_RSTB)
- 2. Self Refresh Enable (REG\_DDRC\_SELFREF\_EN)
- 3. Power Down Enable (REG\_DDRC\_POWERDOWN\_EN)
- 4. Disable Dequeue (REG\_DDRC\_DIS\_DQ)
- 5. Refresh Update (REG\_DDRC\_REFRESH\_UPDATE\_LEVEL)
- 6. Disable Auto Refresh (REG\_DDRC\_DIS\_AUTO\_REFRESH)

## 7.4.4 Refresh Related Signals

Any time a refresh-related signal is updated, the following must be done:

- 1. Change the refresh-associated register as desired.
- 2. After the changed register is known stable, toggle the Refresh Update (REG\_DDRC\_REFRESH\_UPDATE\_LEVEL) signal.

The DRAM Controller will note the refresh\_update\_level signal change and update all refresh-related register values accordingly. This mechanism is needed to avoid sampling errors in the target clock domain as well as to allow the controller to provide special handling (such as issuing an additional refresh and resetting the refresh timer if needed) when a refresh-related timing register has changed.

## 7.4.5 Changing Clock Frequencies

Changing clock frequencies is a simple process, described here:

- 1. Request the controller to enter self refresh by asserting Self Refresh Enable (REG\_DDRC\_SELFREF\_EN).
- 2. Wait until DDR2 Controller Operating Mode (DDRC\_REG\_OPERATING\_MODE) is equal to 03h, indicating that the controller is in self refresh.
- 3. Glitchlessly change the clock frequency to the controller.
- 4. Update any registers which may be required to change for the new frequency.
- 5. Take the controller out of self refresh by de-asserting Self Refresh Enable (REG\_DDRC\_SELFREF\_EN).



# 7.5 Control and Status Registers

| ADDRESS<br>OFFSET | SYMBOL           | REGISTER NAME                         |
|-------------------|------------------|---------------------------------------|
| 0000h             | DDR_DYN_REG      | DDR2 Dynamic Register                 |
| 0004h             | DDR_AD_MAP_BA_CS | DDR2 Bank/CS Address Mapping Register |
| 0008h             | DDR_AD_MAP_COL   | DDR2 Column Address Mapping Register  |
| 000Ch             | DDR_AD_MAP_ROW   | DDR2 Row Address Mapping Register     |
| 0010h             | DDR_TIMING_0     | DDR2 Timing Register 0                |
| 0014h             | DDR_TIMING_1     | DDR2 Timing Register 1                |
| 0018h             | DDR_TIMING_2     | DDR2 Timing Register 2                |
| 001Ch             | DDR_TIMING_3     | DDR2 Timing Register 3                |
| 0020h             | DDR_TIMING_4     | DDR2 Timing Register 4                |
| 0024h             | DDR_REFRESH      | DDR2 Refresh Register                 |
| 0028h             | DDR_CONTROL_0    | DDR2 Control Register 0               |
| 002Ch             | DDR_CONTROL_1    | DDR2 Control Register 1               |
| 0030h             | DDR_CONTROL_2    | DDR2 Control Register 2               |
| 0034h             | DDR_CONTROL_3    | DDR2 Control Register 3               |
| 0038h             | DDR_CONTROL_4    | DDR2 Control Register 4               |
| 003Ch             | DDR_CONTROL_5    | DDR2 Control Register 5               |
| 0040h             | DDR_CONTROL_6    | DDR2 Control Register 6               |
| 0044h             | DDR_CONTROL_7    | DDR2 Control Register 7               |
| 0048h             | DDR_CONTROL_8    | DDR2 Control Register 8               |
| 004Ch             | DDR_CONTROL_9    | DDR2 Control Register 9               |
| 0050h             | DDR_CONTROL_10   | DDR2 Control Register 10              |
| 0054h             | DDR_CONTROL_11   | DDR2 Control Register 11              |
| 0058h             | DDR_CONTROL_12   | DDR2 Control Register 12              |
| 005Ch             | DDR_CONTROL_13   | DDR2 Control Register 13              |
| 0060h – 00FFh     | RESERVED         | Reserved for future expansion         |
| 0100h             | DDR_PHY_CTL_0    | DDR2 PHY Control Register 0           |
| 0104h             | DDR_PHY_CTL_1    | DDR2 PHY Control Register 1           |
| 0108h – 010Fh     | RESERVED         | Reserved for future expansion         |
| 0110h             | DDR_PHY_DEBUG_0  | DDR2 PHY Debug Register 0             |
| 0114h             | DDR_PHY_DEBUG_1  | DDR2 PHY Debug Register 1             |
| 0118h             | DDR_PHY_DEBUG_2  | DDR2 PHY Debug Register 2             |
| 011Ch             | DDR_PHY_DEBUG_3  | DDR2 PHY Debug Register 3             |
| 0120h             | DDR_PHY_DEBUG_4  | DDR2 PHY Debug Register 4             |
| 0124h             | DDR_PHY_DEBUG_5  | DDR2 PHY Debug Register 5             |
| 0128h             | DDR_PHY_DEBUG_6  | DDR2 PHY Debug Register 6             |
| 012C              | DDR_PHY_DEBUG_7  | DDR2 PHY Debug Register 7             |
| 0130h             | DDR_PHY_DEBUG_8  | DDR2 PHY Debug Register 8             |
| 0134h – 0FFFh     | RESERVED         | Reserved for future expansion         |

#### Table 7.2 Memory Controller Control and Status Register Map



# 7.5.1 DDR2 Dynamic Register (DDR\_DYN\_REG)

Offset:

0000h

Size: 32 bits

| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                  | TYPE | DEFAULT |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31   | <b>PHY Initialization Done (PHY_INIT_DONE)</b><br>Indicates that the PHY initialization is complete. After reset has been<br>released, this bit should be polled for a 0x1 value before the DDR2 controller<br>is used.                                                                      | RO   | Ob      |
| 30   | <b>DDR Controller Initialization Done (DDRC_INIT_DONE)</b><br>Indicates that the DDRC initialization is complete. PHY initialization does not<br>begin until DDRC initialization completes.                                                                                                  | RO   | 0b      |
| 29:6 | RESERVED                                                                                                                                                                                                                                                                                     | RO   | -       |
| 5    | <b>Loopback Mode (REG_DDRC_LOOPBACK)</b><br>When this bit is set, the controller is put in a "loopback" mode for test<br>purposes. This signal should only be toggled when the controller is idle (i.e.,<br>no commands have been issued to the controller which are yet to be<br>serviced.) | R/W  | Ob      |
| 4    | <b>Disable Dequeue (REG_DDRC_DIS_DQ)</b><br>When set, DDRC will not de-queue any transactions from the CAM. Bypass<br>will also be disabled. All transactions will be queued in the CAM. This is for<br>debug only; no reads or writes are issued to DRAM as long as this is<br>asserted.    | R/W  | Ob      |
|      | <b>Note:</b> This bit is intended to be switched on-the-fly.                                                                                                                                                                                                                                 |      |         |
|      | Note: FOR DEBUG ONLY                                                                                                                                                                                                                                                                         |      |         |
| 3    | <b>Refresh Update (REG_DDRC_REFRESH_UPDATE_LEVEL)</b><br>This bit must be toggled to indicate that refresh register(s) have been updated.                                                                                                                                                    | R/W  | 0b      |
|      | Note: The value will be automatically updated when exiting soft reset.<br>Therefore, it does not need to be toggled initially.                                                                                                                                                               |      |         |
| 2    | Self Refresh Enable (REG_DDRC_SELFREF_EN)<br>When set, the controller will put the DRAM into self refresh when the<br>transaction store is empty.                                                                                                                                            | R/W  | 0b      |
| 1    | <b>Power Down Enable (REG_DDRC_POWERDOWN_EN)</b><br>When set, the controller will go into power down after a programmable<br>number of cycles "Max idle clocks before power down" Precharge Power<br>Down Timeout (REG_DDRC_POWERDOWN_TO_X32)                                                | R/W  | Ob      |
|      | This register bit may be reprogrammed during the course of normal operation.                                                                                                                                                                                                                 |      |         |
| 0    | Soft Reset (REG_DDRC_SOFT_RSTB)<br>This bit is used to reset the controller.                                                                                                                                                                                                                 | R/W  | 0b      |
|      | 0 = Resets the controller<br>1 = Takes the controller out of reset                                                                                                                                                                                                                           |      |         |
|      | <b>Note:</b> The controller should be taken out of reset only after all other registers have been programmed.                                                                                                                                                                                |      |         |



# 7.5.2 DDR2 Bank/CS Address Mapping Register (DDR\_AD\_MAP\_BA\_CS)

Offset:

0004h

Size: 32 bits

| BITS  | DESCRIPTION                                                                                                                                                                                                                                              | TYPE | DEFAULT |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:21 | RESERVED                                                                                                                                                                                                                                                 | RO   | -       |
| 20:16 | Address Map Rank Address Bit 0 (REG_DDRC_ADDRMAP_CS_BIT0)<br>Selects the address bit used as rank address bit 0. The selected address bit<br>is determined by adding the Internal Base to the value of this field.                                       | R/W  | 00h     |
|       | Valid Range: 0 to 22, and 31<br>Internal Base: 9                                                                                                                                                                                                         |      |         |
|       | Note: If set to 31, rank address bit 0 is set to 0.                                                                                                                                                                                                      |      |         |
| 15:12 | RESERVED                                                                                                                                                                                                                                                 | RO   | -       |
| 11:8  | Address Map Bank Address Bit 2 (REG_DDRC_ADDRMAP_BANK_B2)<br>Selects the address bit used as bank address bit 2. The selected address<br>bit for each of the bank address bits is determined by adding the Internal<br>Base to the value of this field.  | R/W  | 0h      |
|       | Valid Range: 0 to 14, and 15<br>Internal Base: 4                                                                                                                                                                                                         |      |         |
|       | Note: If set to 15, bank address bit 2 is set to 0.                                                                                                                                                                                                      |      |         |
|       | <b>Note:</b> The device only supports two bank pins (four banks). This register must always be set to Fh.                                                                                                                                                |      |         |
| 7:4   | Address Map Bank Address Bit 1 (REG_DDRC_ADDRMAP_BANK_B1)<br>Selects the address bits used as bank address bit 1. The selected address<br>bit for each of the bank address bits is determined by adding the Internal<br>Base to the value of this field. | R/W  | 0h      |
|       | Valid Range: 0 to 14<br>Internal Base: 3                                                                                                                                                                                                                 |      |         |
| 3:0   | Address Map Bank Address Bit 0 (REG_DDRC_ADDRMAP_BANK_B0)<br>Selects the address bits used as bank address bit 0. The selected address<br>bit for each of the bank address bits is determined by adding the Internal<br>Base to the value of this field. | R/W  | Oh      |
|       | Valid Range: 0 to 14<br>Internal Base: 2                                                                                                                                                                                                                 |      |         |



# 7.5.3 DDR2 Column Address Mapping Register (DDR\_AD\_MAP\_COL)

Offset:

0008h

Size: 32 bits

| BITS  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | DESCRIPTION                                                                                                                                                                  | TYPE | DEFAULT |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:28 | (REG_D<br>Full Bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | s Map Column Address Bit 11<br>DDRC_ADDRMAP_COL_B11)<br>s Width Mode:<br>the address bit used as column address bit 12.                                                      | R/W  | Oh      |
|       | Half Bus Width Mode:<br>Unused. Should be tied to 4'hF.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                              |      |         |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Bus Width Mode:<br>. To make it unused, this must be tied to 4'hF.                                                                                                           |      |         |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ected address bit is determined by adding the Internal Base to the fibild.                                                                                                   |      |         |
|       | Valid Ra<br>Internal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ange: 0 to 7, and 15<br>Base: 11                                                                                                                                             |      |         |
|       | Note:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | If set to 15, this column address bit is set to 0.                                                                                                                           |      |         |
|       | Note:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Per JEDEC DDR2 specification, column address bit 10 is reserved<br>for indicating auto-precharge, therefore no source address bit can<br>be mapped to column address bit 10. |      |         |
| 27:24 | (REG_D<br>Full Bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | s Map Column Address Bit 10<br>DRC_ADDRMAP_COL_B10)<br>s Width Mode:<br>the address bit used as column address bit 11.                                                       | R/W  | Oh      |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | s Width Mode:<br>the address bit used as column address bit 12.                                                                                                              |      |         |
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Bus Width Mode:<br>. To make it unused, this must be tied to 4'hF.                                                                                                           |      |         |
|       | The selevation of the selevati | ected address bit is determined by adding the Internal Base to the fibild.                                                                                                   |      |         |
|       | Valid Ra<br>Internal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ange: 0 to 7, and 15<br>Base: 10                                                                                                                                             |      |         |
|       | Note: If set to 15, this column address bit is set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                              |      |         |
|       | Note:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Per JEDEC DDR2 specification, column address bit 10 is reserved<br>for indicating auto-precharge, therefore no source address bit can<br>be mapped to column address bit 10. |      |         |



| BITS  | DESCRIPTION                                                                                                                                                                         | TYPE | DEFAULT |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 23:20 | Address Map Column Address Bit 9 (REG_DDRC_ADDRMAP_COL_B9)<br>Full Bus Width Mode:<br>Selects the address bit used as column address bit 9.                                         | R/W  | 0h      |
|       | Half Bus Width Mode:<br>Selects the address bit used as column address bit 11.                                                                                                      |      |         |
|       | Quarter Bus Width Mode:<br>Selects the address bit used as column address bit 12.                                                                                                   |      |         |
|       | The selected address bit is determined by adding the Internal Base to the value of this field.                                                                                      |      |         |
|       | Valid Range: 0 to 7, and 15<br>Internal Base: 9                                                                                                                                     |      |         |
|       | Note: If set to 15, this column address bit is set to 0.                                                                                                                            |      |         |
|       | <b>Note:</b> Per JEDEC DDR2 specification, column address bit 10 is reserved for indicating auto-precharge, therefore no source address bit can be mapped to column address bit 10. |      |         |
| 19:16 | Address Map Column Address Bit 8 (REG_DDRC_ADDRMAP_COL_B8)<br>Full Bus Width Mode:<br>Selects the address bit used as column address bit 8.                                         | R/W  | 0h      |
|       | Half Bus Width Mode:<br>Selects the address bit used as column address bit 9.                                                                                                       |      |         |
|       | Quarter Bus Width Mode:<br>Selects the address bit used as column address bit 11.                                                                                                   |      |         |
|       | The selected address bit is determined by adding the Internal Base to the value of this field.                                                                                      |      |         |
|       | Valid Range: 0 to 7, and 15<br>Internal Base: 8                                                                                                                                     |      |         |
|       | <b>Note:</b> If set to 15, this column address bit is set to 0.                                                                                                                     |      |         |
|       | <b>Note:</b> Note: Per JEDEC DDR2 spec, column address bit 10 is reserved for indicating auto-precharge, and hence no source address bit can be mapped to column address bit 10.    |      |         |
| 15:12 | Address Map Column Address Bit 7 (REG_DDRC_ADDRMAP_COL_B7)<br>Full Bus Width Mode:<br>Selects the address bit used as column address bit 7.                                         | R/W  | 0h      |
|       | Half Bus Width Mode:<br>Selects the address bit used as column address bit 8.                                                                                                       |      |         |
|       | Quarter Bus Width Mode:<br>Selects the address bit used as column address bit 9.                                                                                                    |      |         |
|       | The selected address bit is determined by adding the Internal Base to the value of this field.                                                                                      |      |         |
|       | Valid Range: 0 to 7, and 15<br>Internal Base: 7                                                                                                                                     |      |         |
|       | <b>Note:</b> If set to 15, this column address bit is set to 0.                                                                                                                     |      |         |

| BITS | DESCRIPTION                                                                                                                                                        | TYPE | DEFAULT |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 11:8 | Address Map Column Address Bits 4 To 6<br>(REG_DDRC_ADDRMAP_COL_B4_6)<br>Full Bus Width Mode:<br>Selects the address bits used as column address bits 4 through 6. | R/W  | Oh      |
|      | Half Bus Width Mode:<br>Selects the address bit used as column address bits 5 through 7.                                                                           |      |         |
|      | Quarter Bus Width Mode:<br>Selects the address bit used as column address bits 6 through 8.                                                                        |      |         |
|      | The selected address bit for each of the column address bits is determined by adding the Internal Base to the value of this field.                                 |      |         |
|      | Valid Range: 0 to 7<br>Internal Base: 4 (for column address bit 4) to 6 (for column address bit 6).                                                                |      |         |
| 7:4  | Address Map Column Address Bit 3 (REG_DDRC_ADDRMAP_COL_B3)<br>Full Bus Width Mode:<br>Selects the address bit used as column address bit 3.                        | R/W  | Oh      |
|      | Half Bus Width Mode:<br>Selects the address bit used as column address bit 4.                                                                                      |      |         |
|      | Quarter Bus Width Mode:<br>Selects the address bit used as column address bit 5.                                                                                   |      |         |
|      | The selected address bit is determined by adding the Internal Base to the value of this field.                                                                     |      |         |
|      | Valid Range: 0 to 7<br>In'1ernal Base: 3                                                                                                                           |      |         |
| 3:0  | Address Map Column Address Bit 2 (REG_DDRC_ADDRMAP_COL_B2)<br>Full Bus Width Mode:<br>Selects the address bit used as column address bit 2.                        | R/W  | 0h      |
|      | Half Bus Width Mode:<br>Selects the address bit used as column address bit 3.                                                                                      |      |         |
|      | Quarter Bus Width Mode:<br>Selects the address bit used as column address bit 4.                                                                                   |      |         |
|      | The selected address bit is determined by adding the Internal Base to the value of this field.                                                                     |      |         |
|      | Valid Range: 0 to 7<br>Internal Base: 2                                                                                                                            |      |         |



# 7.5.4 DDR2 Row Address Mapping Register (DDR\_AD\_MAP\_ROW)

Offset:

000Ch

32 bits

Size:

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                   | TYPE | DEFAULT |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:28 | RESERVED                                                                                                                                                                                                                                                                      | RO   | -       |
| 27:24 | Address Map Row Address Bit 15 (REG_DDRC_ADDRMAP_ROW_B15)<br>Selects the address bit used as row address bit 15. The selected address<br>bit is determined by adding the Internal Base to the value of this field.                                                            | R/W  | 0h      |
|       | Valid Range: 0 to 8, and 15<br>Internal Base: 24                                                                                                                                                                                                                              |      |         |
|       | <b>Note:</b> If set to 15, row address bit 15 is set to 0.                                                                                                                                                                                                                    |      |         |
| 23:20 | Address Map Row Address Bit 14 (REG_DDRC_ADDRMAP_ROW_B14)<br>Selects the address bit used as row address bit 14. The selected address<br>bit is determined by adding the Internal Base to the value of this field.                                                            | R/W  | Oh      |
|       | Valid Range: 0 to 8, and 15<br>Internal Base: 23                                                                                                                                                                                                                              |      |         |
|       | Note: If set to 15, row address bit 14 is set to 0.                                                                                                                                                                                                                           |      |         |
| 19:16 | Address Map Row Address Bit 13 (REG_DDRC_ADDRMAP_ROW_B13)<br>Selects the address bit used as row address bit 13. The selected address<br>bit is determined by adding the Internal Base to the value of this field.                                                            | R/W  | Oh      |
|       | Valid Range: 0 to 8, and 15<br>Internal Base: 22                                                                                                                                                                                                                              |      |         |
|       | <b>Note:</b> If set to 15, row address bit 13 is set to 0.                                                                                                                                                                                                                    |      |         |
| 15:12 | Address Map Row Address Bit 12 (REG_DDRC_ADDRMAP_ROW_B12)<br>Selects the address bit used as row address bit 12. The selected address<br>bit is determined by adding the Internal Base to the value of this field.                                                            | R/W  | Oh      |
|       | Valid Range: 0 to 8, and 15<br>Internal Base: 21                                                                                                                                                                                                                              |      |         |
|       | Note: If set to 15, row address bit 12 is set to 0.                                                                                                                                                                                                                           |      |         |
| 11:8  | Address Map Row Address Bits 2 To 11<br>(REG_DDRC_ADDRMAP_ROW_B2_11)<br>Selects the address bits used as row address bits 2 through 11. The<br>selected address bit for each of the row address bits is determined by adding<br>the Internal Base to the value of this field. | R/W  | 0h      |
|       | Valid Range: 0 to 8<br>Internal Base: 11 (for row address bit 2) to 20 (for row address bit 11).                                                                                                                                                                              |      |         |
| 7:4   | Address Map Row Address Bit 1 (REG_DDRC_ADDRMAP_ROW_B1)<br>Selects the address bits used as row address bit 1. The selected address<br>bit for each of the row address bits is determined by adding the Internal Base<br>to the value of this field.                          | R/W  | Oh      |
|       | Valid Range: 0 to 8<br>Internal Base: 10                                                                                                                                                                                                                                      |      |         |



| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                     | TYPE | DEFAULT |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 3:0  | Address Map Row Address Bit 0 (REG_DDRC_ADDRMAP_ROW_B0)<br>Selects the address bits used as row address bit 0. The selected address<br>bit for each of the row address bits is determined by adding the Internal Base<br>to the value of this field.<br>Valid Range: 0 to 8<br>Internal Base: 9 | R/W  | Oh      |



# 7.5.5 DDR2 Timing Register 0 (DDR\_TIMING\_0)

Offset:

0010h

Size:

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                        | TYPE | DEFAULT |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:21 | RESERVED                                                                                                                                                                                                                                                           | RO   | -       |
| 20:16 | Write Latency (REG_DDRC_WRITE_LATENCY)Time from write command to write data on DDRC to PHY interface.AL + CL - 2(PHY adds an extra flop delay on the write data, hence the "-2" here).Note:Each unit is a clock cycle.                                             | R/W  | 0h      |
| 15    | RESERVED                                                                                                                                                                                                                                                           | RO   | -       |
| 14:8  | Self Refresh Wait (REG_DDRC_POST_SELFREF_GAP_X32)<br>Minimum time to wait after coming out of self refresh before doing anything.<br>This must be bigger than all the constraints that exist.<br>(spec: maximum of tXSNR and tXSRD and tXSDLL which is 512 clocks) | R/W  | 0h      |
|       | Note: Each unit is a multiple of 32 clocks.                                                                                                                                                                                                                        |      |         |
| 7:6   | RESERVED                                                                                                                                                                                                                                                           | RO   | -       |
| 5:0   | Active to Active Command Period (REG_DDRC_T_RC)Minimum time between activates to the same bank (tRC).(spec: 65 ns for DDR2-400 and smaller for faster parts)Note:Each unit is a clock cycle.                                                                       | R/W  | Oh      |



# 7.5.6 DDR2 Timing Register 1 (DDR\_TIMING\_1)

Offset:

0014h

```
Size:
```

| BITS  | DESCRIPTION                                                                                                                                                        | TYPE | DEFAULT |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:28 | RESERVED                                                                                                                                                           | RO   | -       |
| 27:16 | Nominal Refresh Cycle Time (REG_DDRC_T_RFC_NOM_X32)Average time between refreshes (t <sub>REFI</sub> ).(spec:7.8 uS)Note:Each unit is a multiple of 32 clocks.     | RW   | 0h      |
| 15:8  | RESERVED                                                                                                                                                           | RO   | -       |
| 7:0   | Minimum Refresh Cycle Time (REG_DDRC_T_RFC_MIN)Minimum time from refresh to refresh or activate tRFC (min).(spec: 75 ns to 195 ns)Note:Each unit is a clock cycle. | RW   | 0h      |



# 7.5.7 DDR2 Timing Register 2 (DDR\_TIMING\_2)

Offset:

0018h

```
Size:
```

| BITS  | DESCRIPTION                                                                                                                                                                                                                                    | TYPE | DEFAULT |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:29 | RESERVED                                                                                                                                                                                                                                       | RO   | -       |
| 28:24 | <b>Minimum Idle Precharge Power Down To Command (REG_DDRC_T_XP)</b><br>Minimum time after exiting pre-charge power down to any operation $(t_{XP})$ .                                                                                          | R/W  | 0h      |
|       | Note: Each unit is a clock cycle.                                                                                                                                                                                                              |      |         |
| 23:22 | RESERVED                                                                                                                                                                                                                                       | RO   | -       |
| 21:16 | Four Active Window (REG_DDRC_T_FAW)<br>Sliding time window in which a maximum of 4 bank activates are allowed<br>( $t_{FAW}$ ). Valid only in burst of 8 mode. Four banks at most may be activated<br>in a rolling window of $t_{FAW}$ cycles. | R/W  | 0h      |
|       | Note: Each unit is a clock cycle.                                                                                                                                                                                                              |      |         |
| 15:13 | RESERVED                                                                                                                                                                                                                                       | RO   | -       |
| 12:8  | <b>Minimum Bank Active Time (REG_DDRC_T_RAS_MIN)</b><br>Minimum time between an activate command and a precharge command to<br>the same bank (t <sub>RAS(MIN)</sub> ).<br>(spec: 45 ns)                                                        | R/W  | 0h      |
|       | Note: Each unit is a clock cycle.                                                                                                                                                                                                              |      |         |
| 7:6   | RESERVED                                                                                                                                                                                                                                       | RO   | -       |
| 5:0   | <b>Maximum Bank Active Time (REG_DDRC_T_RAS_MAX_X1024)</b><br>Maximum time between an activate and a precharge command to the same<br>bank (t <sub>RAS(MAX)</sub> ). Maximum time that a page can be kept open.                                | R/W  | 0h      |
|       | Note: Each unit is a multiple of 1024 clock cycles.                                                                                                                                                                                            |      |         |
|       | <b>Note:</b> If this is zero, the page is closed after each transaction.                                                                                                                                                                       |      |         |



# 7.5.8 DDR2 Timing Register 3 (DDR\_TIMING\_3)

```
Offset:
```

001Ch

Size:

| BITS  | DESCRIPTION                                                                                                                                                                                                                  | TYPE | DEFAULT |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:27 | RESERVED                                                                                                                                                                                                                     | RO   | -       |
| 26:24 | <b>Mode Register Delay (REG_DDRC_T_MRD)</b><br>Cycles between Load Mode commands (t <sub>MRD</sub> ). Required period of<br>NOP/Deselect after programming a mode register.                                                  | R/W  | 0h      |
| 23:20 | Precharge Command Period (REG_DDRC_T_RP)         Minimum time from precharge to activate of the same bank (t <sub>RP</sub> ).         Note:       Each unit is a clock cycle.                                                | R/W  | 0h      |
| 19    | RESERVED                                                                                                                                                                                                                     | RO   | -       |
| 18:16 | <b>RAS To RAS Delay (REG_DDRC_T_RRD)</b><br>Minimum time between activate commands from bank a to bank b (t <sub>RRD</sub> ).<br>(spec: 10 ns or less)                                                                       | R/W  | 0h      |
|       | Note: Each unit is a clock cycle.                                                                                                                                                                                            |      |         |
| 15    | RESERVED                                                                                                                                                                                                                     | RO   | -       |
| 14:12 | Minimum Time Between Two Reads Or Two Writes<br>(REG_DDRC_T_CCD)<br>The value of this field plus one is the minimum time between two reads or<br>two writes (from bank a to bank b) (t <sub>CCD</sub> ).<br>(spec: 2 cycles) | R/W  | 0h      |
|       | Note: Each unit is a clock cycle.                                                                                                                                                                                            |      |         |
| 11:10 | RESERVED                                                                                                                                                                                                                     | RO   | -       |
| 9:8   | <b>CKE Minimum Pulse Width (REG_DDRC_T_CKE)</b><br>Minimum number of cycles of CKE HIGH/LOW during power down and self refresh (t <sub>CKE</sub> ).<br><b>Note:</b> Each unit is a clock cycle.                              | R/W  | 0h      |
| 7:4   | RESERVED                                                                                                                                                                                                                     | RO   | -       |
| 3:0   | RAS TO CAS Delay (REG_DDRC_T_RCD)<br>Minimum time from an activate command to a read or write command in the<br>same bank.<br>(spec: 15ns for DDR2-400 and lower for faster devices)                                         | R/W  | 0h      |
|       | Note: Each unit is a clock cycle.                                                                                                                                                                                            |      |         |



# 7.5.9 DDR2 Timing Register 4 (DDR\_TIMING\_4)

Offset:

0020h

Size:

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                          | TYPE | DEFAULT |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:29 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO   | -       |
| 28:24 | Write To Precharge Turnaround Time (REG_DDRC_WR2PRE)Minimum time between write and precharge to same bank.(spec: WL + BL/2 +t <sub>WR</sub> = approx 8 cycles + 15 ns = 14 clocks @ 400MHzand less for lower frequencies)Where:WL = write latencyBL = burst length. This must match the value programmed in the BL bit ofthe mode register to the DRAM.t <sub>WR</sub> = write recovery timeThis comes directly from the DRAM specs.Note:Each unit is a clock cycle. | R/W  | Oh      |
| 23:21 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO   | -       |
| 20:16 | <b>Read To Precharge Turnaround Time (REG_DDRC_RD2PRE)</b><br>Minimum time from read to precharge of same bank ( $t_{RTP}$ ).<br>(spec: $t_{RTP}$ for BL=4 and $t_{RTP}$ +2 for BL=8. $t_{RTP}$ = 7.5 ns)<br><b>Note:</b> Each unit is a clock cycle.                                                                                                                                                                                                                | R/W  | Oh      |
| 15:13 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO   | -       |
| 12:8  | Write To Read Turnaround Time (REG_DDRC_WR2RD)<br>Minimum time from write command to read command. Includes time for bus<br>turnaround and recovery times and all per-bank, per-rank, and global constraints.<br>WL + t <sub>WTR</sub> + BL/2<br>Where:                                                                                                                                                                                                              | R/W  | Oh      |
|       | <ul> <li>WL = write latency.</li> <li>BL = burst length. This must match the value programmed in the BL bit of the mode register to the DRAM.</li> <li>t<sub>WTR</sub> = internal write to read command delay. This comes directly from the DRAM specs.</li> <li>Note: Each unit is a clock cycle.</li> </ul>                                                                                                                                                        |      |         |
| 7:5   | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO   | -       |
| 4:0   | Read To Write Turnaround Time (REG_DDRC_RD2WR)<br>Minimum time from read command to write command.<br>Include time for bus turnaround and all per-bank, per-rank, and global<br>constraints.                                                                                                                                                                                                                                                                         | R/W  | Oh      |
|       | RL + BL/2 + 2 – WL                                                                                                                                                                                                                                                                                                                                                                                                                                                   |      |         |
|       | Where:<br>WL = write latency.<br>BL = burst length. This must match the value programmed in the BL bit of<br>the mode register to the DRAM.<br>RL = read latency = CAS latency<br>Each unit is a clock cycle.                                                                                                                                                                                                                                                        |      |         |



#### 7.5.10 DDR2 Refresh Register (DDR\_REFRESH)

```
Offset:
```

0024h

Size:

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | TYPE | DEFAULT |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:13 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RO   | -       |
| 12:8  | <b>Refresh Idle Timeout (REG_DDRC_REFRESH_TO_X32)</b><br>If the refresh timer ( $t_{RFC}$ _nom, as known as $t_{REFI}$ ) has expired at least once,<br>but has not expired burst of N_refresh times yet, then a "speculative<br>refresh" may be performed. This refresh is performed at a time when refresh<br>would be useful, but before it is absolutely required. When the DRAM bus is<br>idle for a period of time determined by this refresh idle timeout and the<br>refresh timer has expired at least once since the last refresh, then a<br>speculative refresh will be performed. Speculative refreshes will continue<br>successively until there are no refreshes pending or until new reads or writes<br>are issued to the controller. | R/W  | 0h      |
|       | Note:FOR PERFORMANCE ONLYNote:Each unit is a multiple of 32 clocks.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |         |
| 7:4   | Refresh Margin (REG_DDRC_REFRESH_MARGIN)         Issue critical refresh or page close this many cycles before the critical refresh or page timer expires.         Note:       It is recommended that values other than the default value NOT be used.         Note:       Each unit is a multiple of 32 clocks.                                                                                                                                                                                                                                                                                                                                                                                                                                    | R/W  | Oh      |
| 3     | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RO   | -       |
| 2:0   | <b>Refresh Burst (REG_DDRC_REFRESH_BURST)</b><br>The programmed value plus one will be the number of refresh timeouts that<br>will be allowed to accumulate before traffic is blocked and the refreshes are<br>forced to execute. Closing pages to perform a refresh is a one-time penalty<br>that must be paid for each group of refreshes; therefore, performing<br>refreshes in a burst reduces the per-refresh penalty of these page closings.<br>Higher numbers for burst_of_N_refresh will slightly increase utilization; lower<br>numbers will decrease the worst-case latency associated with refreshes.<br>0 = single refresh<br>1 = burst-of-2<br>7 = burst-of-8 refresh.                                                                | R/W  | Oh      |



#### 7.5.11 DDR2 Control Register 0 (DDR\_CONTROL\_0)

Offset:

0028h

```
Size:
```

32 bits

BITS TYPE DEFAULT DESCRIPTION 31:11 RESERVED RO 10 Disable Active Bypass Path (REG\_DDRC\_DIS\_ACT\_BYPASS) R/W 0b Only present in designs supporting activate bypass. When 1, disable bypass path for high priority read activates. FOR DEBUG ONLY Note: 9 Disable Read Bypass Path (REG\_DDRC\_DIS\_RD\_BYPASS) R/W 0b Only present in designs supporting read bypass. When 1, disable bypass path for high priority read page hits. FOR DEBUG ONLY Note: Collision Page Option (REG\_DDRC\_DIS\_COLLISION\_PAGE\_OPT) R/W 8 0bWhen clear, auto-precharge will be disabled for the flushed command in a collision case. Collision cases are write followed by read to the same address, read followed by write to the same address, or write followed by write to the same address with Disable Write Combine (REG\_DDRC\_DIS\_WC) bit = 1 (where "same address" comparisons exclude the two address bits representing critical word). Note: FOR DEBUG ONLY. 7 Disable Write Combine (REG\_DDRC\_DIS\_WC) R/W 0b When set, disables Write Combine. FOR DEBUG ONLY. Note: 6 Prefer Writes (REG\_DDRC\_PREFER\_WRITE) R/W 0b When set, the bank selector prefers writes over reads. Note: FOR DEBUG ONLY. Force To Low Priority (REG DDRC FORCE LOW PRI N) 5 R/W 0b This is an active low signal. When clear (asserted), all incoming transactions will be forced to low priority. Forcing the incoming transactions to low priority implicitly turns off Bypass. FOR PERFORMANCE ONLY. Note: Auto Precharge Enable (REG DDRC AUTO PRE EN) 4 R/W 0b When set, most reads and writes will be issued with auto-precharge. Exceptions can be made for collision cases. Note: FOR PERFORMANCE ONLY. Keep Bank Closed (REG\_DDRC\_PAGECLOSE) When set, bank will be closed and kept closed if no transactions are 3 R/W 0b available for it. This is different from auto-precharge for the following reasons: Explicit precharge commands are used, and not read/write with autoprecharge Page is not closed after a read/write if there is another read/write pending to the same page. When clear, bank will remain open until there is a need to close it (i.e., to

Note:

applicable when auto-refresh is used.

FOR PERFORMANCE ONLY.

open a different page, or for page timeout or refresh timeout). This is not



| BITS | DESCRIPTION                                                                                                                                                                                                            | TYPE | DEFAULT |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 2    | Enable 2T Timing (REG_DDRC_EN_2T_TIMING_MODE)<br>If set, then DDRC will use 2T timing. Otherwise 1T timing is used.                                                                                                    | R/W  | Ob      |
| 1    | Data Bus Width (REG_DDRC_DATA_BUS_WIDTH)<br>0 = Full DQ bus width to DRAM<br>1 = Half DQ bus width to DRAM                                                                                                             | R/W  | 0b      |
| 0    | <b>Burst Length (REG_DDRC_BURST8_RDWR)</b><br>This bit controls the burst size used to access the DRAM. This must match<br>the BL mode register setting in the DRAM.<br>0 = Burst length of 4<br>1 = Burst length of 8 | R/W  | Ob      |



## 7.5.12 DDR2 Control Register 1 (DDR\_CONTROL\_1)

```
Offset: 002Ch
```

```
Size:
```

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                           | TYPE | DEFAULT |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:16 | Extended Mode Register 2 Value (REG_DDRC_EMR2)<br>Value to be loaded into DRAM EMR2 registers. May be referred to as "MR2"<br>in some DDR devices.                                                                                                                    | R/W  | 0000h   |
| 15:0  | <b>Extended Mode Register Value (REG_DDRC_EMR)</b><br>Value to be loaded into DRAM EMR registers. May be referred to as "MR1" in some DDR devices. Bits [9:7] are for OCD and the setting in this field is ignored. The controller will set those bits appropriately. | R/W  | 0000h   |



#### 7.5.13 DDR2 Control Register 2 (DDR\_CONTROL\_2)

Offset:

```
0030h
```

```
Size:
```

| BITS  | DESCRIPTION                                                                                                                                                                                                                                             | TYPE | DEFAULT |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:16 | <b>Mode Register Value (REG_DDRC_MR)</b><br>Value to be loaded into the DRAM Mode register. May be referred to as<br>"MR0" in some DDR devices. Bit 8 is for DLL and the setting in this field is<br>ignored. The controller will set it appropriately. | R/W  | 0000h   |
| 15:0  | Extended Mode Register 3 Value (REG_DDRC_EMR3)<br>Value to be loaded into DRAM EMR3 registers. May be referred to as "MR3"<br>in some DDR devices.                                                                                                      | R/W  | 0000h   |



#### 7.5.14 DDR2 Control Register 3 (DDR\_CONTROL\_3)

Offset:

0034h

```
Size:
```

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                    | TYPE | DEFAULT |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:26 | RESERVED                                                                                                                                                                                                                                                                                                       | RO   | -       |
| 25    | Skip On-Chip_drive Calibration (REG_DDRC_SKIP_OCD)<br>Skip on-chip-driver calibration in init sequence                                                                                                                                                                                                         | R/W  | 0b      |
| 24    | RESERVED                                                                                                                                                                                                                                                                                                       | RO   | -       |
| 23:20 | Write ODT Hold (REG_DDRC_WR_ODT_HOLD)<br>The value of this field + 1 is the number of cycles to hold ODT for a Write<br>command. I.e., when this field is 0h, the ODT signal is on for 1 cycle, etc.<br>The values to program in different modes are as follows:<br>DRAM Burst of 4 – 2<br>DRAM Burst of 8 – 4 | R/W  | Oh      |
| 19:14 | RESERVED                                                                                                                                                                                                                                                                                                       | RO   | -       |
| 13:12 | Rank 0 Write ODT (REG_DDRC_RANK0_WR_ODT)<br>Bit [0]:<br>When set, enables remote ODT during a write to Rank 0.<br>Bit [1]:                                                                                                                                                                                     | R/W  | 00b     |
|       | If set, then local ODT is enabled during writes to Rank 0.                                                                                                                                                                                                                                                     |      |         |
| 11:10 | RESERVED                                                                                                                                                                                                                                                                                                       | RO   | -       |
| 9:8   | Rank 0 Read ODT (REG_DDRC_RANK0_RD_ODT)<br>Bit [0]:<br>When set, enables remote ODT during a read to Rank 0.<br>Bit [1]:                                                                                                                                                                                       | R/W  | 00b     |
|       | If set, then local ODT is enabled during reads to Rank 0.                                                                                                                                                                                                                                                      |      |         |
| 7:4   | Write ODT Delay (REG_DDRC_WR_ODT_DELAY)<br>The delay, in clock cycles, from issuing a write command to setting ODT<br>values associated with that command. ODT setting should remain constant<br>for the entire time that DQS is driven by the controller.                                                     | R/W  | Oh      |
|       | The suggested value for DDR2 is WL – 3, where WL is Write latency (WL=CL-1).                                                                                                                                                                                                                                   |      |         |
|       | DDR2 ODT has a 2-cycle on-time delay and a 2.5-cycle off-time delay. The extra 1 cycle is to turn ON ODT during Write Preamble.                                                                                                                                                                                |      |         |
| 3:0   | RESERVED                                                                                                                                                                                                                                                                                                       | RO   | -       |



.

#### 7.5.15 DDR2 Control Register 4 (DDR\_CONTROL\_4)

0038h

Offset:

```
Size:
```

32 bits

BITS DESCRIPTION TYPE DEFAULT 31:16 RESERVED RO \_ Minimum Idle Time After First CKE Assertion (REG\_DDRC\_POST\_CKE\_X1024) Cycles to wait after driving CKE high to start the DRAM initialization 25:16 R/W 0h sequence. DDR2 specifications require a delay of >= 200 uS. DDR2 typically require a 400 ns delay, requiring this value to be programmed to 2 at all clock speeds. Note: Each unit is a multiple of 1024 clock cycles. RESERVED 15:10 RO -Minimum Idle Time After Reset Before First CKE Assertion (REG\_DDRC\_PRE\_CKE\_X1024) 9:0 R/W 0h Cycles to wait after reset before driving CKE high to start the DRAM initialization sequence. DDR2 specifications require a delay of >= 200 uS. Note: Each unit is a multiple of 1024 clock cycles.



### 7.5.16 DDR2 Control Register 5 (DDR\_CONTROL\_5)

003Ch

```
Offset:
```

```
Size:
```

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                   | TYPE | DEFAULT |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:28 | High Priority Transaction Run Length<br>(REG_DDRC_HPR_XACT_RUN_LENGTH)<br>Number of transactions that will be serviced once the High Priority Read<br>queue goes critical. The value is the minimum of this field or the number of<br>transactions available. | R/W  | 0h      |
|       | Note: FOR PERFORMANCE ONLY.                                                                                                                                                                                                                                   |      |         |
|       | Note: Each unit is a transaction.                                                                                                                                                                                                                             |      |         |
| 27    | RESERVED                                                                                                                                                                                                                                                      | RO   | -       |
| 26:16 | HPR Max Starve (REG_DDRC_HPR_MAX_STARVE_X32)<br>Number of clocks that the High Priority Read queue can be starved before<br>it goes critical.                                                                                                                 | R/W  | 0h      |
|       | Note: FOR PERFORMANCE ONLY.                                                                                                                                                                                                                                   |      |         |
|       | Note: Each unit is a multiple of 32 clocks.                                                                                                                                                                                                                   |      |         |
| 15:11 | RESERVED                                                                                                                                                                                                                                                      | RO   | -       |
| 10:0  | HPR Min Non Critical (REG_DDRC_HPR_MIN_NON_CRITICAL_X32)<br>Number of clocks that the High Priority Read queue is guaranteed to be non-<br>critical.                                                                                                          | R/W  | 0h      |
|       | Note: FOR PERFORMANCE ONLY.                                                                                                                                                                                                                                   |      |         |
|       | Note: Each unit is a multiple of 32 clocks.                                                                                                                                                                                                                   |      |         |



#### 7.5.17 DDR2 Control Register 6 (DDR\_CONTROL\_6)

Offset:

0040h

Size:

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                              | TYPE | DEFAULT |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:28 | Low Priority Transaction Run Length<br>(REG_DDRC_LPR_XACT_RUN_LENGTH)<br>Number of transactions that will be serviced once the Low Priority Read<br>queue goes critical. The value is the minimum of this field or the number of<br>transactions available.              | R/W  | 0h      |
|       | Note: FOR PERFORMANCE ONLY.                                                                                                                                                                                                                                              |      |         |
|       | Note: Each unit is a transaction.                                                                                                                                                                                                                                        |      |         |
| 27:23 | <b>Low Priority Number of Entries (REG_DDRC_LPR_NUM_ENTRIES)</b><br>Number of entries in the low priority transaction store is this value plus 1.<br>Value must be 11 or less and 3 or more. Sum of low and high priority read<br>transaction stores must be 16 or less. | R/W  | 0h      |
|       | Note: FOR PERFORMANCE ONLY.                                                                                                                                                                                                                                              |      |         |
|       | Note: Each unit is a transaction.                                                                                                                                                                                                                                        |      |         |
| 22:12 | Low Priority Max Starve (REG_DDRC_LPR_MAX_STARVE_X32)<br>Number of clocks that the Low Priority Read queue can be starved before it<br>goes critical.                                                                                                                    | R/W  | 0h      |
|       | Note: FOR PERFORMANCE ONLY.                                                                                                                                                                                                                                              |      |         |
|       | Note: Each unit is a multiple of 32 clocks.                                                                                                                                                                                                                              |      |         |
| 11    | RESERVED                                                                                                                                                                                                                                                                 | RO   | -       |
| 10:0  | Low Priority Min Non-Critical<br>(REG_DDRC_LPR_MIN_NON_CRITICAL_X32)<br>Number of clocks that the Low Priority Read queue is guaranteed to be non-<br>critical.                                                                                                          | R/W  | 0h      |
|       | Note: FOR PERFORMANCE ONLY.                                                                                                                                                                                                                                              |      |         |
|       | Note: Each unit is a multiple of 32 clocks.                                                                                                                                                                                                                              |      |         |



#### 7.5.18 DDR2 Control Register 7 (DDR\_CONTROL\_7)

0044h

```
Offset:
```

Size:

32 bits

BITS TYPE DEFAULT DESCRIPTION 31:28 Write Transaction Run Length (REG\_DDRC\_W\_XACT\_RUN\_LENGTH) R/W 0h Number of transactions that will be serviced once the WR queue goes critical. The value is the minimum of this field or the number of transactions available. FOR PERFORMANCE ONLY. Note: Note: Each unit is a transaction. 27 RESERVED RO \_ Write Min Non-Critical (REG\_DDRC\_W\_MIN\_NON\_CRITICAL\_X32) R/W 26:16 0h Number of clocks that the Write queue is guaranteed to be non-critical. Note: FOR PERFORMANCE ONLY. Each unit is a multiple of 32 clocks. Note: RESERVED RO 15 Read Write Idle Gap (REG\_DDRC\_RDWR\_IDLE\_GAP) R/W 14:8 0h When the preferred transaction store is empty for the number of clock cycles specified in this field, switch to the alternate transaction store, if it is nonempty. The read transaction store (both hi and low priority) is the default preferred transaction store, while the write transaction store is the alternate store. When Prefer Writes (REG DDRC PREFER WRITE) is set, this is reversed. Note: FOR PERFORMANCE ONLY. DLL Calibration Timeout (REG\_DDRC\_DLL\_CALIB\_TO\_X1024) 7:0 R/W 0h This field specifies the time between DLL calibrations, which will be executed when the controller is idle.



#### 7.5.19 DDR2 Control Register 8 (DDR\_CONTROL\_8)

```
Offset:
```

```
0048h
```

```
Size:
```

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                  | TYPE | DEFAULT |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:24 | DRAM Reset to Low Time (REG_DDRC_DRAM_RSTN_X1024)<br>Cycle for the dram reset to stay low.                                                                                                                                                                                                                                                                                                   | R/W  | 0h      |
|       | Note: Each unit is a multiple of 1024 clocks.                                                                                                                                                                                                                                                                                                                                                |      |         |
| 23:20 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                     | RO   | -       |
| 19:16 | Wait Period Before OCD Complete (REG_DDRC_PRE_OCD_X32)<br>This field defines the wait period before driving the "OCD Complete"<br>command to DRAM.                                                                                                                                                                                                                                           | R/W  | 0h      |
|       | <b>Note:</b> Each unit is a multiple of 32 clocks. A global timer is assumed to pulse every 32 clock cycles.                                                                                                                                                                                                                                                                                 |      |         |
| 15    | RESERVED                                                                                                                                                                                                                                                                                                                                                                                     | RO   | -       |
| 14:8  | Final Wait (REG_DDRC_FINAL_WAIT_X32)<br>This field defines the number of cycles to wait after completing the DRAM<br>initialization sequence before starting the dynamic scheduler.                                                                                                                                                                                                          | R/W  | 0h      |
|       | <b>Note:</b> Each unit is a multiple of 32 clocks. A global timer is assumed to pulse every 32 clock cycles.                                                                                                                                                                                                                                                                                 |      |         |
| 7:5   | RESERVED                                                                                                                                                                                                                                                                                                                                                                                     | RO   | -       |
| 4:0   | <b>Precharge Power Down Timeout (REG_DDRC_POWERDOWN_TO_X32)</b><br>Idle period required before entering precharge power down. After the number<br>of clocks specified by this field of NOP or DESELECT, the controller will put<br>the DRAM into power down. Only applicable when the Power Down Enable<br>(REG_DDRC_POWERDOWN_EN) bit of the DDR2 Dynamic Register<br>(DDR_DYN_REG) is set. | R/W  | Oh      |
|       | Note: Each unit is a multiple of 32 clocks.                                                                                                                                                                                                                                                                                                                                                  |      |         |



#### 7.5.20 DDR2 Control Register 9 (DDR\_CONTROL\_9)

Offset:

004Ch

Size:

| BITS  | DESCRIPTION                                                                                                                                                                                                                            | TYPE | DEFAULT |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:13 | RESERVED                                                                                                                                                                                                                               | RO   | -       |
| 12    | Pad Powerdown Disable (REG_DDRC_DIS_PAD_PD)<br>0 = Enable the pad power down feature.<br>1 = Disable the pad power down feature.                                                                                                       | R/W  | 0b      |
|       | <b>Note:</b> This field is protected by Reset Protection (RST_PROTECT).                                                                                                                                                                |      |         |
| 11    | RESERVED                                                                                                                                                                                                                               | RO   | -       |
| 10:8  | Pad Powerdown Time (REG_DDRC_PAD_PD)<br>If pads have a power-saving mode, this is the maximum of the time for the<br>pads to enter powerdown or the time for the pads to exit powerdown.<br>Note: Units here are clock cycles.         | R/W  | 7h      |
|       | <b>Note:</b> This field is protected by Reset Protection (RST_PROTECT).                                                                                                                                                                |      |         |
| 7:0   | GO_2_CRITICAL_HYSTERESIS<br>(REG_DDRC_GO2CRITICAL_HYSTERESIS)<br>The number of cycles that co_gs_go2critical_rd or co_gs_go2critical_wr<br>must be asserted before the corresponding queue moves to the critical state<br>in the DDRC. | R/W  | Oh      |
|       | Note: FOR PERFORMANCE ONLY.                                                                                                                                                                                                            |      |         |



#### 7.5.21 DDR2 Control Register 10 (DDR\_CONTROL\_10)

0050h

Offset:

Size:

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                            | TYPE | DEFAULT |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:30 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                               | RO   | -       |
| 29:28 | DDR2 Controller Operating Mode (DDRC_REG_OPERATING_MODE)<br>Gives the status of the controller.                                                                                                                                                                                                                                                                                                        | RO   | 0h      |
|       | <ul> <li>00 = Uninitialized. The controller may be in soft reset, or it may be out of soft reset, but DRAM initialization sequence has not yet completed.</li> <li>01 = "Normal" operating mode. The controller is ready to accept read and write requests and the controller may issue reads and writes to DRAM.</li> <li>10 = DRAM is in powerdown.</li> <li>11 = DRAM is in self refresh</li> </ul> |      |         |
| 27:24 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                               | RO   | -       |
| 23:20 | Number of Entries in the High Priority CAM<br>(DDRC_REG_DBG_HPR_Q_DEPTH)<br>Indicates the number of entries currently in the HPR CAM                                                                                                                                                                                                                                                                   | RO   | 0h      |
| 19:16 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                               | RO   | -       |
| 15:12 | Number of Entries in the Low Priority CAM<br>(DDRC_REG_DBG_LPR_Q_DEPTH)<br>Indicates the number of entries currently in the LPR CAM                                                                                                                                                                                                                                                                    | RO   | 0h      |
| 11:8  | RESERVED                                                                                                                                                                                                                                                                                                                                                                                               | RO   | -       |
| 7:4   | Number of Entries in the Write CAM (DDRC_REG_DBG_WR_Q_DEPTH)<br>Indicates the number of entries currently in the WR CAM                                                                                                                                                                                                                                                                                | RO   | 0h      |
| 3:1   | RESERVED                                                                                                                                                                                                                                                                                                                                                                                               | RO   | -       |
| 0     | <b>DDR2 Controller Stalled (DDRC_REG_DBG_STALL)</b><br>0 = Indicates that commands are being accepted<br>1 = Indicates that no commands are accepted by the controller                                                                                                                                                                                                                                 | RO   | 0h      |



## 7.5.22 DDR2 Control Register 11 (DDR\_CONTROL\_11)

```
Offset: 0054h Size: 32 bits
```

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | TYPE | DEFAULT |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31    | <ul> <li>Mode Register Busy (DDRC_REG_MR_WR_BUSY)</li> <li>0 = Indicates that the core can initiate a mode register read or write operation. Core must initiate a MR read or write operation only if this signal is low. This signal goes high in the clock after the controller accepts the read or write request. During MR writes, it goes low when the MR write command has been issued to the DRAM. During MR Reads, it goes low when MR Read data has been delivered to the core interface. Any MR read or write command that is received when Mode Register Busy (DDRC_REG_MR_WR_BUSY) is high, is not accepted.</li> <li>1 = Indicates that mode register read or write operation is in progress.</li> </ul> | RO   | Ob      |
| 30:22 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO   | -       |
| 21:20 | Mode Register Address (REG_DDRC_MR_ADDR)<br>Address of the Mode register that is to be written to.<br>00 = MR0<br>01 = MR1<br>10 = MR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R/W  | 00b     |
|       | 11 = MR3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |         |
| 19:17 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO   | -       |
| 16    | Mode Register Write (REG_DDRC_MR_WR)<br>Pulse this signal for 1 clock to do a mode register write. Controller will accept<br>this command, if this signal is detected high and Mode Register Busy<br>(DDRC_REG_MR_WR_BUSY) is detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R/W  | Ob      |
| 15:0  | Mode Register Write Data (REG_DDRC_MR_DATA)<br>Write data to the mode register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W  | 0000h   |



### 7.5.23 DDR2 Control Register 12 (DDR\_CONTROL\_12)

0058h

Offset:

Size:

| BITS | DESCRIPTION                                                                                                                                                                                                                                                                | TYPE | DEFAULT |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:6 | RESERVED                                                                                                                                                                                                                                                                   | RO   | -       |
| 5    | Disable DLL Calibration (REG_DDRC_DIS_DLL_CALIB)<br>When '0', the controller will issue dll_calib periodically.                                                                                                                                                            | R/W  | 0b      |
|      | When '1', disable dll_calib generated by the controller. The user must issue the dll_calib signal using Request DLL Calibration (CO_GS_DLL_CALIB) input. This input is changeable on the fly.                                                                              |      |         |
| 4    | <b>Request DLL Calibration (CO_GS_DLL_CALIB)</b><br>Command that indicates to the controller to issue a dll_calib to the DRAM.                                                                                                                                             | R/SC | 0b      |
| 3:2  | RESERVED                                                                                                                                                                                                                                                                   | RO   | -       |
| 1    | Rank Refresh (CO_GS_RANK_REFRESH)<br>Command that indicates to the controller to issue a refresh to the DRAM.                                                                                                                                                              | R/SC | Ob      |
| 0    | <b>Disable Auto Refresh (REG_DDRC_DIS_AUTO_REFRESH)</b><br>When '1', disable auto-refresh generated by the controller. This input is<br>changeable on the fly. When this transitions from 0 to 1, any pending<br>refreshes will be immediately scheduled by the controller | R/W  | 0b      |



## 7.5.24 DDR2 Control Register 13 (DDR\_CONTROL\_13)

Offset:

005Ch

Size:

| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                          | TYPE | DEFAULT |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:8 | RESERVED                                                                                                                                                                                                                                                                                                                                                                             | RO   | -       |
| 7:0  | Minimum Time Between DLL Calibrations<br>(REG_DDRC_DLL_CALIB_TO_MIN_X1024)<br>This is the minimum amount of time between DLL calibrations (which will be<br>executed whenever the controller is idle). Set this number higher to reduce<br>the frequency of DLL calibrations, which can have a small impact on the<br>latency of the first read request when the controller is idle. | R/W  | 00h     |



32 bits

#### 7.5.25 DDR2 PHY Control Register 0 (DDR\_PHY\_CTL\_0)

0100h

Offset:

Size:

BITS DESCRIPTION TYPE DEFAULT 31:28 First Read (REG\_FIRST\_RD) R/W 0h This value defines the delay from when a read command is issued by the DDR Controller to when the DRAM device sends out the first piece of read data Set this value to AL+CL (Additive Latency + CAS Latency) 27:24 First Write (REG FIRST WR) R/W 0h This value defines the delay from when a write command is issued by the DDR controller to when the first piece of write data is sent by the controller. Set this value to AL+CL -1 (Additive Latency + CAS Latency -1) S1 Strength for Clock Signal (REG\_DDR2\_S1\_CLK) 23 R/W 0b Pad strength control for the DDR2 clock signal 22 S1 Strength for Control Signals (REG\_DDR2\_S1\_CONTROL) R/W 0bPad strength control for the DDR2 control signals except the clock S1 Strength for Byte Lane 1 (REG DDR2 S1 BYTE LANE1) R/W 21 0b Pad strength control for the DDR2 data signals - Byte Lane 1. 20 S1 Strength for Byte Lane 0 (REG\_DDR2\_S1\_BYTE\_LANE0) R/W 0b Pad strength control for the DDR2 data signals - Byte Lane 0. 19:18 RESERVED RO -DDR2 PHY Global ODT Control (REG\_DDR2\_ODT) 17:16 R/W 0b ODT pad control for all DDR2 signals (except DQ & DQS which come from the DDR2 PHY) DDR2 CKE Pads Output Enable Disable R/W 15 1b (REG\_DDR2\_OE\_CKE\_DISABLE) This bit controls output enable (OÉN) for the CKE pads. Its default state forces the outputs off. This bit must be programmed to 0b for normal PHY control of the Note: CKE pad OE inputs. This field is protected by Reset Protection (RST PROTECT). DDR2 Pads Output Enable Disable (REG\_DDR2\_OE\_DISABLE) This bit controls output enable (OEN) for all DDR2 pads except for CKE 14 R/W 1b pads. Its default state forces the outputs off. This bit must be programmed to 0b for normal PHY control of the Note: DDR2 pad OE inputs. This field is protected by Reset Protection (RST PROTECT). DDR2 CKE Pads Power Down Control (REG\_DDR2\_PWD\_CKE) 13 R/W 1b This bit controls power down (PWD) for the CKE pads. It is used to power down the pad's receiving circuits. This bit must be programmed to 0b for proper operation. Note: This field is protected by Reset Protection (RST PROTECT).



| BITS  | DESCRIPTION                                                                                                                                                                   | TYPE | DEFAULT |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 12    | DDR2 Pads Power Down Control (REG_DDR2_PWD)<br>This bit controls power down (PWD) for all pads except for CKE pads. It is<br>used to power down the pad's receiving circuits. | R/W  | 1b      |
|       | <b>Note:</b> This bit must be programmed to 0b for proper operation.<br>This field is protected by Reset Protection (RST_PROTECT).                                            |      |         |
| 11:10 | RESERVED                                                                                                                                                                      | RO   | -       |
| 9:8   | DDR2 PHY Idle ODT Control (REG_PHY_IDLE_LOCAL_ODT)<br>Value to drive on the 2-bit local_odt PHY outputs when not in write and read<br>operation.                              | R/W  | 0b      |
| 7:6   | RESERVED                                                                                                                                                                      | RO   | -       |
| 5:4   | <b>DDR2 PHY Write ODT Control (REG_PHY_WR_LOCAL_ODT)</b><br>Value to drive on the 2-bit local_odt PHY outputs when output is enabled on DQ and DQS (write operation).         | R/W  | 0b      |
| 3:2   | RESERVED                                                                                                                                                                      | RO   | -       |
| 1:0   | <b>DDR2 PHY Read Local ODT (REG_PHY_RD_LOCAL_ODT)</b><br>Value to drive on the 2-bit local_odt PHY outputs when output is not enabled<br>on DQ and DQS (read operation).      | R/W  | 0b      |



#### 7.5.26 DDR2 PHY Control Register 1 (DDR\_PHY\_CTL\_1)

Offset:

0104h

```
Size:
```

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                        | TYPE | DEFAULT |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31    | Disable DRAM Clock (STOP_CLK)<br>0 = dram_clk is running<br>1 = dram_clk is stopped                                                                                                                                                                                                                                                                                                                                | R/W  | 0b      |
| 30:21 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                           | RO   | -       |
| 20    | Clear Read Pointer Reset Counter (RDC_FIFO_RST_ERR_CNT_CLR)<br>Clear/reset for counter Read Pointer Reset Count<br>(RDC_FIFO_RST_ERR_CNT)[3:0].<br>0 = Not cleared<br>1 = Clear                                                                                                                                                                                                                                    | R/W  | Ob      |
| 19:16 | <b>Read Pointer Reset Count (RDC_FIFO_RST_ERR_CNT)</b><br>Counter for counting how many times the pointers of read data capture FIFO<br>are reset when the FIFO is not empty (an error). It gets saturated after<br>reaching 0xF. Cleared by Clear Read Pointer Reset Counter<br>(RDC_FIFO_RST_ERR_CNT_CLR). It is recommended that connecting this<br>output to a register so that it can be checked when needed. | RO   | Oh      |
| 15:12 | <b>Maximum Lock Delay Difference (REG_MAX_LOCK_DIFF)</b><br>Master DLL lock signal is asserted when the difference between averaged<br>delay sr_out and incoming delay sr_in in output filter module is less than (or<br>equal to) the value of this field.                                                                                                                                                        | R/W  | 4h      |
| 11:7  | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                           | RO   | -       |
| 6     | <b>Disable Resetting of the Read Capture FIFO Pointers (DIS_CALIB_RST)</b><br>Disable the resetting of the Read Capture FIFO pointers. The pointers are<br>reset to ensure that the PHY can recover if the appropriate number of DQS<br>edges is not observed after a read command (which can happen when the<br>DQS squelch timing is manually overridden via the debug registers.                                | R/W  | Ob      |
|       | 0 = Enable<br>1 = Disable.                                                                                                                                                                                                                                                                                                                                                                                         |      |         |
| 5     | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                           | RO   | -       |
| 4     | Use Fixed Delay for FIFO Read Enable (USE_FIXED_RE)<br>When 0, PHY uses the not_empty method to generate FIFO read enable.<br>When 1, PHY generates FIFO read enable after fixed number of clock<br>cycles.<br>Note: THIS FIELD SHOULD ALWAYS BE INITIALIZED TO 1 BY THE<br>SOFTWARE.                                                                                                                              | R/W  | Ob      |
| 2.0   |                                                                                                                                                                                                                                                                                                                                                                                                                    | PO   |         |
| 3:2   | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                           | RO   | -       |
| 1:0   | Read Capture FIFO Read Enable Delay (RDC_WE_TO_RE_DELAY)<br>Read Capture FIFO read is enabled after (Write Latency<br>(REG_DDRC_WRITE_LATENCY) + RDC_WE_TO_RE_DELAY +2) clock<br>cycles.                                                                                                                                                                                                                           | R/W  | Oh      |
|       | Valid if Use Fixed Delay for FIFO Read Enable (USE_FIXED_RE) is high.                                                                                                                                                                                                                                                                                                                                              |      |         |
|       | Note: THIS FIELD SHOULD ALWAYS BE INITIALIZED TO 2 BY THE SOFTWARE.                                                                                                                                                                                                                                                                                                                                                |      |         |



## 7.5.27 DDR2 PHY Debug Register 0 (DDR\_PHY\_DEBUG\_0)

| Offset: 01 |
|------------|
|------------|

.

```
Size:
```

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                     | TYPE | DEFAULT |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31    | <b>Debug WL DLL Force 1 (DBG_WL_DLL_FORCE1)</b><br>0 = Use the value from the Master DLL<br>1 = Overwrite the coarse and fine values calculated by the Master DLL going<br>to the write slave, with the value in Debug WL DLL Value 1<br>(DBG_WL_DLL_VALUE1).                                                                   | R/W  | Ob      |
| 30:25 | RESERVED                                                                                                                                                                                                                                                                                                                        | RO   | -       |
| 24:16 | <ul> <li>Debug WL DLL Value 1 (DBG_WL_DLL_VALUE1)<br/>If Debug WL DLL Force 1 (DBG_WL_DLL_FORCE1) is one, replace:</li> <li>Fine value from the Master DLL going to write slave 1 with<br/>DBG_WL_DLL_VALUE1[1:0].</li> <li>Coarse Value from the Master DLL going to write slave 1 with<br/>DBG_WL_DLL_VALUE1[8:2].</li> </ul> | R/W  | 000h    |
| 15    | <b>Debug WL DLL Force 0 (DBG_WL_DLL_FORCE0)</b><br>0 = Use the value from the Master DLL.<br>1 = Overwrite the coarse and fine values calculated by the Master DLL going<br>to the write slave, with the value in Debug WL DLL Value 0<br>(DBG_WL_DLL_VALUE0).                                                                  | R/W  | Ob      |
| 14:9  | RESERVED                                                                                                                                                                                                                                                                                                                        | RO   | -       |
| 8:0   | <ul> <li>Debug WL DLL Value 0 (DBG_WL_DLL_VALUE0)</li> <li>If Debug WL DLL Force 0 (DBG_WL_DLL_FORCE0) is one, replace:</li> <li>Fine value from the Master DLL going to write slave 0 with DBG_WL_DLL_VALUE0[1:0].</li> <li>Coarse Value from the Master DLL going to write slave 0 with DBG_WL_DLL_VALUE0[8:2].</li> </ul>    | R/W  | 000h    |



#### 7.5.28 DDR2 PHY Debug Register 1 (DDR\_PHY\_DEBUG\_1)

Offset: 0114h

Size:

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                   | TYPE | DEFAULT |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31    | <b>Debug RC DLL Force 1 (DBG_RC_DLL_FORCE1)</b><br>0 = Use the value from the Master DLL.<br>1 = Overwrite the coarse and fine values calculated by the Master DLLs<br>going to data slice "1" with the value in Debug RC DLL Value 1<br>(DBG_RC_DLL_VALUE1). | R/W  | Ob      |
| 30:25 | RESERVED                                                                                                                                                                                                                                                      | RO   | -       |
| 24:16 | Debug RC DLL Value 1 (DBG_RC_DLL_VALUE1)<br>If Debug RC DLL Force 1 (DBG_RC_DLL_FORCE1) is one, replace:<br>Fine value from the Master DLL with DBG_RC_DLL_VALUE1[1:0].<br>Coarse Value from the Master DLL with DBG_RC_DLL_VALUE1[8:2].                      | R/W  | 000h    |
| 15    | <b>Debug RC DLL Force 0 (DBG_RC_DLL_FORCE0)</b><br>0 = Use the value from the Master DLL<br>1 = Overwrite the coarse and fine values calculated by the Master DLLs<br>going to data slice "0" with the value in Debug RC DLL Value 0<br>(DBG_RC_DLL_VALUE0).  | R/W  | Ob      |
| 14:9  | RESERVED                                                                                                                                                                                                                                                      | RO   | -       |
| 8:0   | Debug RC DLL Value 0 (DBG_RC_DLL_VALUE0)<br>If Debug RC DLL Force 0 (DBG_RC_DLL_FORCE0) is one, replace:<br>• Fine value from the Master DLL with DBG_RC_DLL_VALUE0[1:0].<br>• Coarse Value from the Master DLL with DBG_RC_DLL_VALUE0[8:2].                  | R/W  | 000h    |



## 7.5.29 DDR2 PHY Debug Register 2 (DDR\_PHY\_DEBUG\_2)

```
Offset: 0118h Size: 32 bits
```

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                               | TYPE | DEFAULT |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:24 | <b>Read DQS Slave Ratio 1 (RD_DQS_SLAVE_RATIO1)</b><br>Ratio value for read DQS slave DLL. This is the fraction of a clock cycle<br>represented by the shift to be applied to the read DQS in units of 256ths. In<br>other words, the full-cycle tap value from the master DLL will be scaled by<br>this number over 256 to get the delay value for the slave delay line. | R/W  | 00h     |
| 23:16 | <b>Read DQS Slave Ratio 0 (RD_DQS_SLAVE_RATIO0)</b><br>Ratio value for read DQS slave DLL. This is the fraction of a clock cycle represented by the shift to be applied to the read DQS in units of 256ths. In other words, the full-cycle tap value from the master DLL will be scaled by this number over 256 to get the delay value for the slave delay line.          | R/W  | 00h     |
| 15:8  | Write DQS Slave Ratio 1 (WR_DQS_SLAVE_RATIO1)<br>Ratio value for write DQS slave DLL. This is the fraction of a clock cycle<br>represented by the shift to be applied to the read DQS in units of 256ths. In<br>other words, the full-cycle tap value from the master DLL will be scaled by<br>this number over 256 to get the delay value for the slave delay line.      | R/W  | 00h     |
| 7:0   | Write DQS Slave Ratio 0 (WR_DQS_SLAVE_RATIO0)<br>Ratio value for write DQS slave DLL. This is the fraction of a clock cycle<br>represented by the shift to be applied to the read DQS in units of 256ths. In<br>other words, the full-cycle tap value from the master DLL will be scaled by<br>this number over 256 to get the delay value for the slave delay line.      | R/W  | 00h     |



#### 7.5.30 DDR2 PHY Debug Register 3 (DDR\_PHY\_DEBUG\_3)

011Ch

Offset:

Size:

| BITS  | DESCRIPTION                                                                                                                                                  | TYPE | DEFAULT |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:25 | RESERVED                                                                                                                                                     | RO   | -       |
| 24:16 | <b>Debug Status of In Delay Value 0 (DGB_STATUS_IN_DELAY_VALUE0)</b><br>The Coarse and Fine values going into the Filter in Master DLL 0.                    | RO   | х       |
|       | DGB_STATUS_IN_DELAY_VALUE0[1:0] = Fine value<br>DGB_STATUS_IN_DELAY_VALUE0[8:2] = Coarse value                                                               |      |         |
| 15:9  | RESERVED                                                                                                                                                     | RO   | -       |
| 8:0   | Debug Status Master DLL Slave Value 0<br>(DGB_STATUS_MASTER_DLL_SLAVE_VALUE0)<br>Shows the current Coarse and Fine values going to all the Write Slave DLLs. | RO   | Х       |
|       | DGB_STATUS_MASTER_DLL_SLAVE_VALUE0[1:0] = Fine value<br>DGB_STATUS_MASTER_DLL_SLAVE_VALUE0[8:2] = Coarse value                                               |      |         |



#### 7.5.31 DDR2 PHY Debug Register 4 (DDR\_PHY\_DEBUG\_4)

Offset:

0120

Size:

32 bits

TYPE BITS DEFAULT DESCRIPTION RESERVED 31:21 RO -20 Master DLL 0 Locked (DBG\_STATUS\_MASTER\_DLL\_LOCK0) RO Х Status signal: 0 = Master DLL is not locked 1 = Master DLL is locked RESERVED RO 19:18 -Debug Status of In Lock State 0 (DBG\_STATUS\_IN\_LOCK\_STATE0) Х 17:16 RO Lock status from the Output Filter module inside the Master DLL 0. DBG\_STATUS\_IN\_LOCK\_STATE0[0] = Fine lock DBG\_STATUS\_IN\_LOCK\_STATE0[1] = Coarse lock 15:0 RESERVED RO -



#### 7.5.32 DDR2 PHY Debug Register 5 (DDR\_PHY\_DEBUG\_5)

Offset: 0124h

Size:

| BITS  | DESCRIPTION                                                                                                                                                                       | TYPE | DEFAULT |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:25 | RESERVED                                                                                                                                                                          | RO   | -       |
| 24:16 | <b>Debug Status of In Delay Value 1 (DBG_STATUS_IN_DELAY_VALUE_1)</b><br>The Coarse and Fine values going into the Filter in Master DLL 1.                                        | RO   | х       |
|       | DBG_STATUS_IN_DELAY_VALUE_1[1:0] = Fine value<br>DBG_STATUS_IN_DELAY_VALUE_1[6:0] = Coarse value                                                                                  |      |         |
| 15:9  | RESERVED                                                                                                                                                                          | RO   |         |
| 8:0   | Debug Status Master DLL Slave Value 1<br>(DGB_STATUS_MASTER_DLL_SLAVE_VALUE1)<br>Shows the current Coarse and Fine values going to all the Write Slave DLLs<br>from master DLL 1. | RO   | Х       |
|       | DGB_STATUS_MASTER_DLL_SLAVE_VALUE1[1:0] = Fine value<br>DGB_STATUS_MASTER_DLL_SLAVE_VALUE1[8:2] = Coarse value                                                                    |      |         |



#### 7.5.33 DDR2 PHY Debug Register 6 (DDR\_PHY\_DEBUG\_6)

Offset:

0128h

Size:

| BITS  | DESCRIPTION                                                                                                                                                                                                                     | TYPE | DEFAULT |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:21 | RESERVED                                                                                                                                                                                                                        | RO   | -       |
| 20    | Master DLL 1 Locked (DBG_STATUS_MASTER_DLL_LOCK1)<br>Status signal:<br>0 = Master DLL 1 is not locked<br>1 = Master DLL 1 is locked                                                                                             | RO   | Х       |
| 19:18 | RESERVED                                                                                                                                                                                                                        | RO   | -       |
| 17:16 | <b>Debug Status of In Lock State 1 (DBG_STATUS_IN_LOC_STATE1)</b><br>Lock status from the Output Filter module inside the Master DLL 1.<br>DBG_STATUS_IN_LOC_STATE1[0] = Fine lock<br>DBG_STATUS_IN_LOC_STATE1[1] = Coarse lock | RO   | х       |
| 15:0  | RESERVED                                                                                                                                                                                                                        | RO   | -       |



32 bits

#### 7.5.34 DDR2 PHY Debug Register 7 (DDR\_PHY\_DEBUG\_7)

Offset: 012Ch

Size:

TYPE BITS DEFAULT DESCRIPTION RESERVED 31:25 RO -Debug Status RC DLL Slave Value 1 (DBG\_STATUS\_RC\_DLL\_SLAVE\_VALUE1) 24:16 RO Х Shows the current Coarse and Fine values going to the Read Slave DLLs in data slice 1. DBG\_STATUS\_RC\_DLL\_SLAVE\_VALUE1[1:0] = Fine value DBG\_STATUS\_RC\_DLL\_SLAVE\_VALUE1[8:2] = Coarse value 15:9 RESERVED RO \_ Debug Status RC DLL Slave Value 0 (DBG\_STATUS\_RC\_DLL\_SLAVE\_VALUE0) 8:0 RO Х Shows the current Coarse and Fine values going to the Read Slave DLLs in data slice 0. DBG\_STATUS\_RC\_DLL\_SLAVE\_VALUE0[1:0] = Fine value DBG\_STATUS\_RC\_DLL\_SLAVE\_VALUE0[8:2] = Coarse value



32 bits

#### 7.5.35 DDR2 PHY Debug Register 8 (DDR\_PHY\_DEBUG\_8)

| Offset: 01 | 30h S | Size: |
|------------|-------|-------|
|------------|-------|-------|

TYPE BITS DESCRIPTION DEFAULT RESERVED 31:25 RO -24:16 Debug Write Slave DLL 1 Value (DBG\_WR\_SLAVE\_DLL\_1\_VALUE) RO Х Shows the current coarse and fine values going to all the write slave delay lines in the PHY top module from master DLL 1: DBG\_WR\_SLAVE\_DLL\_1\_VALUE[1:0] = Fine value. DBG\_WR\_SLAVE\_DLL\_1\_VALUE[8:2] = Coarse value. 15:9 RESERVED RO -8:0 Debug Write Slave DLL 0 Value (DBG\_WR\_SLAVE\_DLL\_0\_VALUE) RO Х Shows the current coarse and fine values going to all the write slave delay lines in the PHY top module from master DLL 1: DBG\_WR\_SLAVE\_DLL\_0\_VALUE[1:0] = Fine value. DBG\_WR\_SLAVE\_DLL\_0\_VALUE[8:2] = Coarse value.



# Chapter 8 EEPROM

#### 8.1 Description

The device uses a EEPROM to store the default values for the USB descriptors. It supports most Atmel 93C46x type of EEPROMs.

Note: A 3-wire style 4K EEPROM that is organized for 256/512 x 8-bit operation must be used.

Various system level resets, as specified in Table 6.1, "Chip Level Resets," on page 85, cause the EEPROM contents to be loaded into the device. After a reset, the EEPROM controller attempts to read the first byte of data from the EEPROM. If the value 0xA5 is read from the first address, then the EEPROM controller will assume that an external Serial EEPROM is present.

The EEPROM Controller will then load the entire contents of the EEPROM into an internal 512 byte SRAM. The contents of the SRAM are accessed by the CTL block as needed (I.E. to fill Get Descriptor commands).

The device may not respond to the USB host until the EEPROM loading sequence has completed. Therefore, after reset the USB PHY is kept in the disconnect state until the EEPROM load has completed.

The host can initiate a reload of the EEPROM by issuing the RELOAD command via the EEPROM Command Register (E2P\_CMD). If the first byte read from the EEPROM is not 0xA5, it is assumed that the EEPROM is not present, or not programmed, and the reload will fail. The EPC Data Loaded (EPC\_LOADED) bit indicates a successful reload of the EEPROM data.

**Note:** It is not recommended that the reload be used as part of normal operation as race conditions can occur with USB Commands that access descriptor data. It is best for the host to issue a SRST to reload the EEPROM data.

The EEPROM Controller also allows the Host system to read, write and erase the contents of the Serial EEPROM using the EEPROM Command Register (E2P\_CMD) and EEPROM Data Register (E2P\_DATA). The Command and Data registers are accessed through the SCSR.

**Note:** The EEPROM device powers-up in the erase/write disabled state. To modify the contents of the EEPROM the host must first issue the EWEN command.

To write to the EEPROM the host must first write the desired data into the Data register. It must then initiate the cycle by performing a single write to the E2P\_CMD register in which it sets the EPC Busy (EPC\_BSY) bit, writes the appropriate address, and sets the EPC Command (EPC\_CMD) field to WRITE. The completion of the write cycle is indicated when the EPC Busy (EPC\_BSY) bit is cleared. Other commands that modify the EEPROM contents are executed using the same mechanism.

If an operation is attempted, and an EEPROM device does not respond within 30mS, the EPC must time-out, and the EPC Time-out (EPC\_TIMEOUT) bit in the EEPROM Command Register (E2P\_CMD) must be set.

To read from the EEPROM, the host must first initiate the cycle by performing a single write to the Command register in which it sets the EPC Busy (EPC\_BSY) bit, writes the appropriate address and sets the EPC Command (EPC\_CMD) field to READ. Valid data is available when the EPC Busy (EPC\_BSY) bit is cleared, indicating to the host that it can read valid data from the Data register.



Figure 8.1 illustrates the host accesses required to perform an EEPROM Read or Write.



Figure 8.1 EEPROM Access Flow Diagram

#### 8.1.1 Command Register Format

Refer to Section 8.5.1, "EEPROM Command Register (E2P\_CMD)" for a detailed description of this register.

#### 8.1.2 Data Register Format

Refer to Section 8.5.2, "EEPROM Data Register (E2P\_DATA)" for a detailed description of this register.

#### 8.2 **EEPROM Format**

Table 8.1 illustrates the format in which data is stored inside of the EEPROM.

Note the EEPROM offsets are given in units of 16-bit word offsets. A length field with a value of zero indicates that the field does not exist in the EEPROM. The device will use the field's HW default value in this case.



Note: For the device descriptor the only valid values for the length are 0 and 18.

Note: For the configuration and interface descriptor the only valid values for the length are 0 and 18.

- Note: For the BOS Block, the length varies and is dependent on block components.
- **Note:** The EEPROM programmer must ensure that if a string descriptor does not exist in the EEPROM, the referencing descriptor must contain 00h for the respective string index field.
- Note: If all string descriptor lengths are zero, then a Language ID will not be supported.
- Note: All reserved EEPROM bits must be set to 0.

| Table 8 | 8.1 | EEPROM | Format |
|---------|-----|--------|--------|
|---------|-----|--------|--------|

| EEPROM ADDRESS | EEPROM CONTENTS                                                                                                    |  |
|----------------|--------------------------------------------------------------------------------------------------------------------|--|
| 00h            | 0xA5                                                                                                               |  |
| 01h            | Full-Speed Polling Interval for Interrupt Endpoint                                                                 |  |
| 02h            | High-Speed Polling Interval for Interrupt Endpoint                                                                 |  |
| 03h            | RESERVED                                                                                                           |  |
| 04h            | Configuration Flags 0 [7:0]                                                                                        |  |
| 05h            | Configuration Flags 0 [15:8]                                                                                       |  |
| 06h            | Configuration Flags 0 [23:16]                                                                                      |  |
| 07h            | Configuration Flags 0 [31:24]                                                                                      |  |
| 08h - 13h      | RESERVED                                                                                                           |  |
| 14h            | Software Configuration Data Structure Length (bytes)<br>Note 8.1                                                   |  |
| 15h            | Software Configuration Data Structure Word Offset<br>Note 8.1                                                      |  |
| 16h - 1Fh      | RESERVED                                                                                                           |  |
| 20h            | GPIO Enable Config Byte 0 (GPIOEN_CFG0)<br>GPIO Enable Register (GPIO_ENABLE) [7:0] initialization value           |  |
| 21h            | GPIO Enable Config Byte 1 (GPIOEN_CFG1)<br>GPIO Enable Register (GPIO_ENABLE) [15:8] initialization value          |  |
| 22h            | GPIO Enable Config Byte 2 (GPIOEN_CFG2)<br>GPIO Enable Register (GPIO_ENABLE) [23:16] initialization value         |  |
| 23h            | GPIO Enable Config Byte 3 (GPIOEN_CFG3)<br>GPIO Enable Register (GPIO_ENABLE) [31:24] initialization value         |  |
| 24h            | GPIO Buffer Type Config Byte 0 (GPIOBUF_CFG0)<br>GPIO Buffer Type Register (GPIO_BUF) [7:0] initialization value   |  |
| 25h            | GPIO Buffer Type Config Byte 1 (GPIOBUF_CFG1)<br>GPIO Buffer Type Register (GPIO_BUF) [15:8] initialization value  |  |
| 26h            | GPIO Buffer Type Config Byte 2 (GPIOBUF_CFG2)<br>GPIO Buffer Type Register (GPIO_BUF) [23:16] initialization value |  |
| 27h            | GPIO Buffer Type Config Byte 3 (GPIOBUF_CFG3)<br>GPIO Buffer Type Register (GPIO_BUF) [31:24] initialization value |  |



#### Table 8.1 EEPROM Format

| 28h       | GPIO Direction Config Byte 0 (GPIODIR_CFG0)<br>GPIO Direction Register (GPIO_DIR) [7:0] initialization value   |  |
|-----------|----------------------------------------------------------------------------------------------------------------|--|
| 29h       | GPIO Direction Config Byte 1 (GPIODIR_CFG1)<br>GPIO Direction Register (GPIO_DIR) [15:8] initialization value  |  |
| 2Ah       | GPIO Direction Config Byte 2 (GPIODIR_CFG2)<br>GPIO Direction Register (GPIO_DIR) [23:16] initialization value |  |
| 2Bh       | GPIO Direction Config Byte 3 (GPIODIR_CFG3)<br>GPIO Direction Register (GPIO_DIR) [31:24] initialization value |  |
| 2Ch       | GPIO Data Config Byte 0 (GPIOD_CFG0)<br>GPIO Data Register (GPIO_DATA) [7:0] initialization value              |  |
| 2Dh       | GPIO Data Config Byte 1 (GPIOD_CFG1)<br>GPIO Data Register (GPIO_DATA) [15:8] initialization value             |  |
| 2Eh       | GPIO Data Config Byte 2 (GPIOD_CFG2)<br>GPIO Data Register (GPIO_DATA) [23:16] initialization value            |  |
| 2Fh       | GPIO Data Config Byte 3 (GPIOD_CFG3)<br>GPIO Data Register (GPIO_DATA) [31:24] initialization value            |  |
| 30h       | Language ID [7:0]                                                                                              |  |
| 31h       | Language ID [15:8]                                                                                             |  |
| 32h       | Manufacturer ID String Descriptor Length (bytes)                                                               |  |
| 33h       | Manufacturer ID String Descriptor EEPROM Word Offset                                                           |  |
| 34h       | Product Name String Descriptor Length (bytes)                                                                  |  |
| 35h       | Product Name String Descriptor EEPROM Word Offset                                                              |  |
| 36h       | Serial Number String Descriptor Length (bytes)                                                                 |  |
| 37h       | Serial Number String Descriptor EEPROM Word Offset                                                             |  |
| 38h       | Configuration String Descriptor Length (bytes)                                                                 |  |
| 39h       | Configuration String Descriptor Word Offset                                                                    |  |
| 3Ah       | Interface String Descriptor Length (bytes)                                                                     |  |
| 3Bh       | Interface String Descriptor Word Offset                                                                        |  |
| 3Ch       | Binary Object Store (BOS) Block Length (Bytes)<br>Note 8.2 Note 8.3                                            |  |
| 3Dh       | Binary Object Store (BOS) Block Word Offset<br>Note 8.2                                                        |  |
| 3Eh - 41h | RESERVED                                                                                                       |  |
| 42h       | High-Speed Device Descriptor Length (bytes)                                                                    |  |
| 43h       | High-Speed Device Descriptor Word Offset                                                                       |  |
| 44h       | High-Speed Configuration and Interface Descriptor Length (bytes)                                               |  |
| 45h       | High-Speed Configuration and Interface Descriptor Word Offset                                                  |  |
| 46h       | Full-Speed Device Descriptor Length (bytes)                                                                    |  |
| 47h       | Full-Speed Device Descriptor Word Offset                                                                       |  |



#### Table 8.1 EEPROM Format

| 48h | Full-Speed Configuration and Interface Descriptor Length (bytes) |
|-----|------------------------------------------------------------------|
| 49h | Full-Speed Configuration and Interface Descriptor Word Offset    |

Note: Locations 4Ah and above may be used for any purpose.

- Note 8.1 Refer to the software programming manual for information concerning this data structure.
- **Note 8.2** RESERVED when LPM Enable (LPM\_ENABLE) is clear in the USB Configuration Register (USB\_CFG).
- **Note 8.3** This block may include Binary Object Store (BOS) Descriptor, USB 2.0 Extension Descriptor, and Container ID Descriptor.



Table 8.2 describes Configuration Flags 0. If a configuration descriptor exists in the EEPROM, its values must agree with analogous values contained in the Configuration Flags 0. If they do not, unexpected results and untoward operation may occur.

#### Table 8.2 Configuration Flags 0

| BITS  | DESCRIPTION                                                                                                                                                                                    |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:14 | RESERVED                                                                                                                                                                                       |
| 13    | Clock Crystal Keep Alive Enable (CFG0_CLK_XTAL_EN)<br>Refer to the Clock Crystal Keep Alive Enable (CLK_XTAL_EN) bit of the CPM Control Register<br>(CPM_CTL) for permissible values.          |
| 12    | <b>Port Swap (CFG0_PORT_SWAP)</b><br>Refer to the Port Swap (PORT_SWAP) bit of the USB Configuration Register (USB_CFG) for permissible values.                                                |
| 11    | <b>SW_MODE Polarity (CFG0_SW_MODE_POL)</b><br>Refer to the SW_MODE Polarity (SW_MODE_POL) bit of the Hardware Configuration Register (HW_CFG) for permissible values.                          |
| 10    | <b>LED Buffer Type (CFG0_LED_TYPE)</b><br>Refer to the LED Buffer Type (LED_TYPE) bit of the LED Configuration Register 0 (LED_CFG0) for permissible values.                                   |
| 9     | <b>LED Polarity (CFG0_LED_POL)</b><br>Refer to the LED Polarity (LED_POL) bit of the LED Configuration Register 0 (LED_CFG0) for permissible values.                                           |
| 8     | <b>LED Enable (CFG0_LED_ENABLE)</b><br>Refer to the LED Enable (LED_EN) bit of the LED Configuration Register 0 (LED_CFG0) for permissible values.                                             |
| 7     | Interrupt Pin Polarity (CFG0_INT_PIN_POL)<br>Refer to the Interrupt Pin Polarity (INT_POL) bit of the Hardware Configuration Register (HW_CFG) for<br>permissible values.                      |
| 6     | <b>External Reset Polarity (CFG0_EXT_RST_POL)</b><br>Refer to the External Reset Polarity (EXT_RST_POL) bit of the External Reset Configuration Register (EXT_RST_CFG) for permissible values. |
| 5:4   | Squelch Threshold (CFG0_SQU_THR)<br>Refer to the Squelch Threshold (SQU_THR) field of the USB Configuration Register (USB_CFG) on<br>page 59 for permissible values.                           |
| 3     | <b>LPM Enable (CFG0_LPM_ENABLE)</b><br>Refer to the LPM Enable (LPM_ENABLE) bit of the USB Configuration Register (USB_CFG) on page 59 for permissible values.                                 |
| 2:1   | <b>PHY Boost (CFG0_PHY_BOOST)</b><br>Refer to the PHY Boost (PHY_BOOST) field of the USB Configuration Register (USB_CFG) on page 59 for permissible values.                                   |
| 0     | <b>Power Method (CFG0_PWR_SEL)</b><br>Refer to the Power Method (PWR_SEL) bit of the USB Configuration Register (USB_CFG) on page 59 for permissible values.                                   |

**Note:** LPM Enable and Power method specified in Configuration Flags 0 must agree with analogous quantities specified in descriptors. If they do not, unexpected results and untoward operation may occur.



# 8.3 **EEPROM** Defaults

The signature value of 0xA5 is stored at address 0. A different signature value indicates to the EEPROM controller that no EEPROM is attached to the device. In this case, the hardware default values used are as shown in Table 8.3. See Section 4.5, "USB Descriptors," on page 48 for more information about the default USB values.

| FIELD                                       | DEFAULT VALUE |
|---------------------------------------------|---------------|
| Full-Speed Polling<br>Interval              | 01h           |
| High-Speed Polling<br>Interval              | 04h           |
| Maximum Burst Size for<br>Bulk-Out Endpoint | 07h           |
| Configuration Flags 0                       | 0000008h      |
| Maximum Power                               | Note 8.4      |
| Vendor ID                                   | 0424h         |
| Product ID                                  | 9D01h         |

#### Table 8.3 EEPROM Defaults

Note 8.4 Default value is FA (500mA).



# 8.4 Customized Operation Without EEPROM

The device provides the capability to customize operation without the use of an EEPROM. Descriptor information and initialization quantities normally fetched from EEPROM and used to initialize descriptors and elements of the Control and Status Registers may be specified via an alternate mechanism. This alternate mechanism involves the use of the Descriptor RAM in conjunction with the Attribute Registers and select elements of the System Control and Status Registers. The software device driver orchestrates the process by performing the following actions in the order indicated:

- Initialization of SCSR Elements in Lieu of EEPROM Load
- Attribute Register Initialization
- Descriptor RAM Initialization
- Enable Descriptor RAM and Attribute Registers as Source
- Inhibit Reset of Select SCSR Elements

The following subsections explain these actions. The attribute registers must be written prior to initializing the Descriptor RAM. Failure to do this will prevent the PWR\_SEL and RMT\_WKUP flags from being overwritten by the bmAttributes of the Configuration Descriptor.

### 8.4.1 Initialization of SCSR Elements in Lieu of EEPROM Load

During EEPROM operation, the following register fields are initialized by the hardware using the values contained in the EEPROM. In the absence of an EEPROM, the software device driver must initialize these quantities:

- LED Enable (LED\_EN) bit of the LED Configuration Register 0 (LED\_CFG0)
- LED Polarity (LED\_POL) bit of the LED Configuration Register 0 (LED\_CFG0)
- LED Buffer Type (LED\_TYPE) bit of the LED Configuration Register 0 (LED\_CFG0)
- GPIO Enable Register (GPIO ENABLE)
- GPIO Buffer Type Register (GPIO BUF)
- GPIO Direction Register (GPIO DIR)
- GPIO Data Register (GPIO DATA)
- SW\_MODE Polarity (SW\_MODE\_POL) bit of the Hardware Configuration Register (HW\_CFG)
- Interrupt Pin Polarity (INT\_POL) bit of the Hardware Configuration Register (HW\_CFG)
- External Reset Polarity (EXT\_RST\_POL) bit of the External Reset Configuration Register (EXT\_RST\_CFG)
- Clock Crystal Keep Alive Enable (CFG0\_CLK\_XTAL\_EN) bit of the CPM Control Register (CPM\_CTL)
- Squelch Threshold (SQU\_THR) field of the USB Configuration Register (USB\_CFG)
- PHY Boost (PHY BOOST) field of the USB Configuration Register (USB CFG)
- LPM Enable (LPM ENABLE) field of the USB Configuration Register (USB CFG)
- Power Method (PWR\_SEL) field of the USB Configuration Register (USB\_CFG)

### 8.4.2 Attribute Register Initialization

The Attribute Registers are as follows:

- BOS Attributes Register (BOS\_ATTR)
- HS Attributes Register (HS\_ATTR)
- FS Attributes Register (FS\_ATTR)
- String Attributes Register 0 (STRNG\_ATTR0)

#### • String Attributes Register 1 (STRNG\_ATTR1)

All of these registers contain fields defining the lengths of the descriptors or block contents written into the Descriptor RAM. If an item is not written into the Descriptor RAM, the associated entry in the Attributes Register must be written as 0. Writing an erroneous or illegal length will result in untoward operation and unexpected results.

- Note: The software device driver must initialize these registers prior to initializing the Descriptor RAM.
- **Note:** The bmAttributes field of the HS and FS descriptors in descriptor RAM (if present) must be consistent with the contents of the Power Method (PWR\_SEL) field of the USB Configuration Register (USB\_CFG).

### 8.4.3 Descriptor RAM Initialization

The Descriptor RAM contents are initialized using the Data Port registers. The Data Port registers are used to select the Descriptor RAM and write the descriptor elements into it. The Descriptor RAM is 512 bytes in length. Every descriptor/block written into the Descriptor RAM must be DWORD aligned. The Attribute Registers discussed in Section 8.4.2 must be written with the length of the descriptors written into the Descriptor RAM. If a descriptor/block is not used, hence not written into Descriptor RAM, its length must be written as 0 into the associated Attribute Register.

Note: The Attribute Registers must be initialized before the Descriptor RAM.

**Note:** Address 0 of the Descriptor RAM is always reserved for the Language ID, even if it will not be supported.

The descriptors/blocks must be written in the following order, starting at address 0 of the RAM and observing the DWORD alignment rule:

- Language ID (2 bytes)
- Manufacturing String Descriptor (String Index 1)
- Product Name String Descriptor (String Index 2)
- Serial Number String Descriptor (String Index 3)
- Configuration String Descriptor (String Index 4)
- Interface String Descriptor (String Index 5)
- BOS Block
- HS Device Descriptor
- HS Configuration Descriptor
- FS Device Descriptor
- FS Configuration Descriptor

An example of Descriptor RAM use is illustrated in Figure 8.2. In it, the BOS Block contains the BOS Descriptor (5 Bytes) and a USB 2.0 Extension Descriptor (7 bytes), for a total length of 12 bytes.

As in the case of descriptors specified in EEPROM, the following restrictions apply to descriptors written into Descriptor RAM:

- For Device Descriptors, the only valid values for the length are 0 and 18. The descriptor size for the Device Descriptors specified in the Descriptor RAM is a don't care and always overwritten by HW to 0x12 when transmitting the descriptor to the host.
- 2. The descriptor type for Device Descriptors specified in the Descriptor RAM is a don't care and is always overwritten by HW to 0x1 when transmitting the descriptor to the host.
- 3. For the Configuration and Interface descriptor, the only valid values for the length are 0 and 18. The descriptor size for the Device Descriptors specified in the Descriptor RAM is a don't care and always overwritten by HW to 0x12 when transmitting the descriptor to the host.



- 4. The descriptor type for the configuration descriptors specified in the Descriptor RAM is a don't care and always overwritten by HW to 0x2 when transmitting the descriptor to the host.
- 5. If a string descriptor does not exist in the Descriptor RAM, the referencing descriptor must contain 00h for the respective string index field.
- 6. If all string descriptor lengths are zero, then a Language ID will not be supported.
- **Note:** The first entry in the Descriptor RAM is always reserved for the Language ID, even if it will not be supported.
- **Note:** When the LPM Enable (LPM\_ENABLE) bit of the USB Configuration Register (USB\_CFG) is clear, descriptors having bcdUSB, bMaxPacketSize, and bNumConfigurations with values other than 0200h, 40h, and 1, respectively, will result in unwanted behavior and untoward results. When LPM Enable (LPM\_ENABLE) is set, descriptors having values other that 0210h, 40h, and 1, respectively, will result in unwanted behavior and untoward results.

The RAM Test Mode Enable (DP\_SEL\_TESTEN) bit must be deasserted after programming the descriptor RAM.



= Unused Space Required For Alignment Purposes

Figure 8.2 Descriptor RAM Example



### 8.4.4 Enable Descriptor RAM and Attribute Registers as Source

The EEPROM Emulation Enable (EEM) bit of the Hardware Configuration Register (HW\_CFG) must be configured by the software device driver to use the Descriptor RAM and the Attribute Registers for custom operation. Upon assertion of EEPROM Emulation Enable (EEM), the hardware will utilize the Descriptor information contained in the Descriptor RAM, the Attributes Registers, and the values of the items listed in Section 8.4.1 to facilitate custom operation.

### 8.4.5 Inhibit Reset of Select SCSR Elements

The software device driver must take care to ensure that the contents of the Descriptor RAM and SCSR register content critical to custom operation using Descriptor RAM are preserved across reset operations other than POR. The driver must configure the Reset Protection (RST\_PROTECT) bit of the Hardware Configuration Register (HW\_CFG) in order to accomplish this.

The following registers have contents that can be preserved across all resets other than POR. Consult the register's description for additional details.

- Descriptor RAM
- Attribute Registers
- Hardware Configuration Register (HW\_CFG)
- External Reset Configuration Register (EXT\_RST\_CFG)
- LED Configuration Register 0 (LED\_CFG0)
- GPIO Enable Register (GPIO\_ENABLE)
- GPIO Buffer Type Register (GPIO\_BUF)
- GPIO Direction Register (GPIO\_DIR)
- GPIO Data Register (GPIO\_DATA)
- USB Configuration Register (USB\_CFG)
- CPM Control Register (CPM\_CTL)
- DDR2 Control Register 9 (DDR\_CONTROL\_9)
- DDR2 PHY Control Register 0 (DDR\_PHY\_CTL\_0)



# 8.5 Control and Status Registers

These CSRs are available when sys\_clk is disabled. This permits software to access system level configuration information such as audio characteristics and DDR2 speed.

### Table 8.4 USB Control and Status Register Map

|   | ADDRESS<br>OFFSET | SYMBOL   | REGISTER NAME                 |
|---|-------------------|----------|-------------------------------|
| ĺ | 6000h             | E2P_CMD  | EEPROM Command Register       |
| Ī | 6004h             | E2P_DATA | EEPROM Data Register          |
|   | 6008h – 6FFFh     | RESERVED | Reserved for future expansion |



# 8.5.1 EEPROM Command Register (E2P\_CMD)

```
Offset: 0000h Size: 32 bits
```

This register is used to control the read and write operations on the Serial EEPROM.

| BITS |                                                                              | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | TYPE | DEFAULT |
|------|------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31   | When a<br>Comman<br>remain s<br>that the H<br>and E2P<br>the case<br>EPC Bus | sy (EPC_BSY)<br>"1" is written into this bit, the operation specified in the EPC<br>ad field is performed at the specified EEPROM address. This bit will<br>et until the operation is complete. In the case of a read, this means<br>Host can read valid data from the E2P Data register. The E2P_CMD<br>_DATA registers should not be modified until this bit is cleared. In<br>where a write is attempted and an EEPROM is not present, the<br>sy remains busy until the EPC Time-out occurs. At that time, the<br>is cleared. | SC   | Ob      |
|      |                                                                              | EPC busy will be high immediately following power-up, chip-level,<br>or USB reset. After the EEPROM controller has finished reading (or<br>attempting to read) the USB Descriptors and Ethernet default<br>register values, the EPC Busy bit is cleared.                                                                                                                                                                                                                                                                         |      |         |



| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                      | TYPE | DEFAULT |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 30:28 | <b>EPC Command (EPC_CMD)</b><br>This field is used to issue commands to the EEPROM controller. The EPC will execute commands when the EPC Busy bit is set. A new command must not be issued until the previous command completes. This field is encoded as follows:                                              | R/W  | 000b    |
|       | 000 = READ<br>001 = EWDS<br>010 = EWEN<br>011 = WRITE<br>100 = WRAL<br>101 = ERASE<br>110 = ERAL<br>111 = RELOAD                                                                                                                                                                                                 |      |         |
|       | <b>READ (Read Location):</b> This command will cause a read of the EEPROM location pointed to by EPC Address. The result of the read is available in the E2P_DATA register.                                                                                                                                      |      |         |
|       | <b>EWDS (Erase/Write Disable):</b> After issued, the EEPROM will ignore erase and write commands. To re-enable erase/write operations, issue the EWEN command.                                                                                                                                                   |      |         |
|       | <b>EWEN (Erase/Write Enable):</b> Enables the EEPROM for erase and write operations. The EEPROM will allow erase and write operations until the Erase/Write Disable command is sent, or until power is cycled.                                                                                                   |      |         |
|       | <b>Note:</b> The EEPROM device will power-up in the erase/write-disabled state. Any erase or write operations will fail until an Erase/Write Enable command is issued.                                                                                                                                           |      |         |
|       | <b>WRITE (Write Location):</b> If erase/write operations are enabled in the EEPROM, this command will cause the contents of the E2P_DATA register to be written to the EEPROM location selected by the EPC Address field.                                                                                        |      |         |
|       | <b>WRAL (Write All):</b> If erase/write operations are enabled in the EEPROM, this command will cause the contents of the E2P_DATA register to be written to every EEPROM memory location.                                                                                                                       |      |         |
|       | <b>ERASE (Erase Location):</b> If erase/write operations are enabled in the EEPROM, this command will erase the location selected by the EPC Address field.                                                                                                                                                      |      |         |
|       | <b>ERAL (Erase All):</b> If erase/write operations are enabled in the EEPROM, this command will initiate a bulk erase of the entire EEPROM.                                                                                                                                                                      |      |         |
|       | <b>RELOAD (Data Reload):</b> Instructs the EEPROM controller to reload the data from the EEPROM. If a value of A5h is not found in the first address of the EEPROM, the EEPROM is assumed to be un-programmed and the Reload operation will fail. The "Data Loaded" bit indicates a successful load of the data. |      |         |
|       | <b>Note:</b> A failed reload operation will result in no change to descriptor information or register contents. These items will not be set to default values as a result of the reload failure.                                                                                                                 |      |         |
| 27:11 | RESERVED                                                                                                                                                                                                                                                                                                         | RO   | -       |



| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                     | TYPE | DEFAULT |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 10   | <b>EPC Time-out (EPC_TIMEOUT)</b><br>If an EEPROM operation is performed, and there is no response from the<br>EEPROM within 30mS, the EEPROM controller will time-out and return to its<br>idle state. This bit is set when a time-out occurs, indicating that the last<br>operation was unsuccessful.                                                                                                                         |      | 0       |
|      | <b>Note:</b> If the EEDI pin is pulled-high (default if left unconnected), EPC commands will not time out if the EEPROM device is missing. In this case, the EPC Busy bit will be cleared as soon as the command sequence is complete. It should also be noted that the ERASE, ERAL, WRITE and WRAL commands are the only EPC commands that will time-out if an EEPROM device is not present and the EEDI signal is pulled low. |      |         |
| 9    | <b>EPC Data Loaded (EPC_LOADED)</b><br>When set, this bit indicates that a valid EEPROM was found, and that the<br>USB and Data programming has completed normally. This bit is set after a<br>successful load of the data after power-up, or after a RELOAD command has<br>completed.                                                                                                                                          | R/WC | 0       |
| 8:0  | <b>EPC Address (EPC_ADDR)</b><br>The 9-bit value in this field is used by the EEPROM Controller to address a specific memory location in the Serial EEPROM. This is a BYTE aligned address.                                                                                                                                                                                                                                     | R/W  | 00h     |

0004h



# 8.5.2 EEPROM Data Register (E2P\_DATA)

Offset:

Size:

32 bits

This register is used in conjunction with the E2P\_CMD register to perform read and write operations to the Serial EEPROM.

| BITS | DESCRIPTION                                                         | TYPE | DEFAULT |
|------|---------------------------------------------------------------------|------|---------|
| 31:8 | RESERVED                                                            | RO   | -       |
| 7:0  | EEPROM Data (EPC_DATA)<br>Value read from or written to the EEPROM. | R/W  | 00h     |



### 9.1 Overview

The device integrates an HDMI/DVI Controller that is compliant with revision 1.3 of the HDMI specification. It consists of both a transmitter and PHY. DVI output, compliant with revision 1.0 of the DVI specification, is also supported. Deep color and High-bandwidth Digital Content Protection (HDCP) are not supported. RGB video pixel encoding is supported, while YCbCr 4:4:4 and YCbCr 4:2:2 are not.

S/PDIF and single channel I2S audio are supported. A separate master clock input (MCLK), coherent with the input, is required for time-stamping purposes. Due to bandwidth requirements MLP (18 Mbps) and DTS-HD are not supported. The controller supports 2-channel uncompressed PCM data (IEC 60958) and compressed bit stream data for multi-channel (IEC 61937) formats. Audio is transmitted with HDMI data and audio sampling rates range from 32 to 192 KHz. Typical usage would be two channel uncompressed audio, with a target sampling rate of 44.1 or 48 KHz.

Master I2C interface for Display Data Channel (DDC) connection is available. Pins are shared with the internal I2C controller.

Monitor detection is supported via Hot Plug and Receiver detection. The Hot Plug Detect (HPD) pin is 5V tolerant.

**Note:** Detailed HDMI information is confidential. Contact your Microchip sales representative for additional information.



# **Chapter 10 Display Controller**

# **10.1** Introduction

The UFX7000/UFX6000 Display Controller Subsystem (DCTL) is a basic CRT/LCD display controller that interfaces to a frame buffer on one side and the display on the other.

Features include:

- Programmable video resolution of up to 2048 x 1152 or 1920 x 1200 (WUXGA).
- 8, 16 and 24 bit color.
- 8 to 30 bit color table lookup.
- Gamma correction (3 x 8 bit to 10 bit color table lookup).
- Deep pixel FIFO buffer to tolerate frame buffer read access latency and to minimize instantaneous frame buffer RAM bandwidth requirements.
- vsync, hsync, composite sync, composite blank.
- Programmable sync and blank polarities.

# 10.2 Block Diagram



Figure 10.1 Display Controller Block Diagram

# 10.3 Configuration

### 10.3.1 Controller Reset / Enable / Status

The DCTL is reset by setting the Reset (RESET) bit of the Display Control Register (DISPLAY\_CTRL). Setting this self-clearing bit causes the controller to be reset to its initial state. All registers are set to their default values.

The Video Sub-system Enable (ENABLE) bit of the Display Control Register (DISPLAY\_CTRL) enables/disables the video sub-system. When this bit is set, frame buffers are read from system memory and the color and timing outputs are generated. When the bit is cleared, the video sub-system is reset. The controller finishes the current frame prior to stopping. After setting this bit, the Display Controller Status (DC\_STS) bit of the Display Status Register (DISPLAY\_STATUS) must be read to determine when the Display Controller has actually stopped.



**Note:** Configuration changes should only be attempted when the Display Controller is stopped, as determined by the Display Controller Status (DC STS) bit.

In addition to containing the Display Controller Status (DC\_STS) bit, the Display Status Register (DISPLAY\_STATUS) contains interrupt and status bits that determine the operational state of the DCTL. Refer to Display Status Register (DISPLAY\_STATUS) on page 174 for a complete description of these bits.

### **10.3.2** Horizontal and Vertical Timing Configuration

Figure 10.2 and Figure 10.3 illustrate the Horizontal and Vertical Timing of the DCTL. The units of horizontal and vertical timing are pixel clocks and lines, respectively. The pixel clock frequency must be set to support the desired screen resolution, based on industry standards. The labels within these figures correspond to the range values defined in the Display Horizontal Size Register (DISPLAY\_H\_SIZE), Display Horizontal Blank Register (DISPLAY\_H\_BLANK), Display Horizontal Sync Register (DISPLAY\_H\_SYNC), Display Vertical Size Register (DISPLAY\_V\_SIZE), Display Vertical Size Register (DISPLAY\_V\_SIZE), Display Vertical Blank Register (DISPLAY\_V\_SIZE), Display Vertical Blank Register (DISPLAY\_V\_SIZE), Display Vertical Size Register (DISPLAY\_V\_SIZE), Display Vertical Blank Register (DISPLAY\_V\_SYNC). All fields within these registers are programmed to the desired value -1.

Note: The aforementioned registers should only be changed when the DCTL is stopped, as indicated by the Display Controller Status (DC\_STS) bit of the Display Status Register (DISPLAY\_STATUS).



Figure 10.2 Horizontal Timing



#### Figure 10.3 Vertical Timing

The Display Horizontal Size Register (DISPLAY\_H\_SIZE) contains the values for the Horizontal Total (H\_TOTAL) and Horizontal Active (H\_ACTIVE) fields illustrated in Figure 10.2. Horizontal Total (H\_TOTAL) is the total horizontal time in pixels that encompasses the active display, left and right borders, front and back porches, and horizontal sync pulse time. Horizontal Active (H\_ACTIVE) is the



horizontal active (addressable) resolution. The first active display pixel is considered to be pixel number 0. This field should be programmed to less than Horizontal Total (H\_TOTAL).

The Display Horizontal Blank Register (DISPLAY\_H\_BLANK) contains the values for the Horizontal Blank Start (H\_BLANK\_START) and Horizontal Blank End (H\_BLANK\_END) fields illustrated in Figure 10.2. Horizontal Blank Start (H\_BLANK\_START) is the horizontal blanking start time relative to the start of the active display. The first active pixel is considered to be pixel number 0. This field is programmed to the desired right border size plus the horizontal active resolution minus 1. If this field is programmed to the same pixel as Horizontal Active (H\_ACTIVE), then there is no right border. This field should be programmed in the range >= Horizontal Active (H\_ACTIVE) and < Horizontal Total (H\_TOTAL). Horizontal Blank End (H\_BLANK\_END) is the horizontal blanking end time relative to the start of the active display. This field is programmed to Horizontal Total (H\_TOTAL) minus the desired left border size minus 1. If this field is programmed to the same value as Horizontal Total (H\_TOTAL), then there is no left border. This field should be programmed to the same value as Horizontal Total (H\_TOTAL), then there is no left border. This field should be programmed to the same value as Horizontal Total (H\_TOTAL), then there is no left border. This field should be programmed in the range > Horizontal Total (H\_TOTAL).

The Display Horizontal Sync Register (DISPLAY\_H\_SYNC) contains the values for the Horizontal Sync Start (H\_SYNC\_START) and Horizontal Sync End (H\_SYNC\_END) fields illustrated in Figure 10.2. Horizontal Sync Start (H\_SYNC\_START) is the horizontal sync start time relative to the start of the active display. This field is programmed to the desired VESA value minus 1. Horizontal Sync End (H\_SYNC\_END) is the horizontal sync end time relative to the start of the active display. This field is programmed to the start of the start of the active display. This field is programmed to the start of the start of the active display. This field is programmed to the start of the active display. This field is programmed to the desired VESA value minus 1.

The Display Vertical Size Register (DISPLAY\_V\_SIZE) contains the values for the Vertical Total (V\_TOTAL) and Vertical Active (V\_ACTIVE) fields illustrated in Figure 10.2. Vertical Total (V\_TOTAL) is the total vertical time in lines that encompasses the active display, top and bottom borders, front and back porches, and vertical sync pulse time. Vertical Active (V\_ACTIVE) is the vertical active resolution in lines. This field should be programmed to the number of lines desired minus 1. The first vertical active display line is considered to be line number 0.

The Display Vertical Blank Register (DISPLAY\_V\_BLANK) contains the values for the Vertical Blank Start (V\_BLANK\_START) and Vertical Blank End (V\_BLANK\_END) fields illustrated in Figure 10.2. Vertical Blank Start (V\_BLANK\_START) is the start time in lines relative to the start of the active display. The first active line is considered to be line number 0. This field is programmed to the desired bottom border size plus the vertical active resolution minus 1. If this field is programmed to the same line as Vertical Active (V\_ACTIVE), then there is no bottom border. This field should be programmed in the range >= Vertical Active (V\_ACTIVE) and < Vertical Total (V\_TOTAL). Vertical Blank End (V\_BLANK\_END) is the vertical blanking end time in lines relative to the start of the active display. This field is programmed to the same value as Vertical Total (V\_TOTAL), then there is no top border. This field should be programmed to the same value as Vertical Total (V\_TOTAL), then there is no top border. This field should be programmed in the range > Vertical Total (V\_TOTAL), then there is no top border. This field should be programmed in the range > Vertical Total (V\_TOTAL), then there is no top border. This field should be programmed in the range > Vertical Blank Start (V\_BLANK\_START) and <= Vertical Total (V\_TOTAL).

The Display Vertical Sync Register (DISPLAY\_V\_SYNC) contains the values for the Vertical Sync Start (V\_SYNC\_START) and Vertical Sync End (V\_SYNC\_END) fields illustrated in Figure 10.2. Vertical Sync Start (V\_SYNC\_START) is the vertical sync start time in lines relative to the start of the active display. The first active line is considered to be line number 0. This field is programmed to the desired VESA value minus 1. Vertical Sync End (V\_SYNC\_END) is the vertical sync end time in lines relative to the start of the active display. This field is programmed to the desired VESA value minus 1.



An example of the combined horizontal and vertical timing is show in Figure 10.4. The vertical sync pulse and vertical blank change on the same clock as the leading edge of the horizontal sync pulse. Note that the top/bottom/left/right borders are not shown.



Figure 10.4 Combined Vertical and Horizontal Timing

### 10.3.2.1 Horizontal and Vertical Blanking Interrupts

During system operation, the Horizontal Blank Start Interrupt (H\_BLANK\_START\_INT) and the Vertical Blank Start Interrupt (V\_BLANK\_START\_INT) are propagated from the Display Controller to the USB Interrupt Endpoint Status Register (USB\_INT\_STS). These interrupts occur at the start of the Horizontal and Vertical Blank times, respectively. They are cleared by writing a 1 to the Horizontal Blank Start Interrupt (H\_BLANK\_START\_INT) and Vertical Blank Start Interrupt (V\_BLANK\_START\_INT) and Vertical Blank Start Interrupt (V\_BLANK\_START\_INT) and Vertical Blank Start Interrupt (V\_BLANK\_START\_INT) bits of the Display Status Register (DISPLAY\_STATUS).

### 10.3.3 Display Blanking

The display may be forced into blanking by setting the Force Display Blanking (DISPLAY\_BLANK) bit of the Display Control Register (DISPLAY\_CTRL). When this bit is set, the RGB output is forced to zero and blanking is asserted. This bit may be changed at any time, however, it takes effect when either the current frame is finished or if the DCTL has been disabled via the Video Sub-system Enable (ENABLE).

**Note:** if the DCTL has not been disabled, then the HSYNC and VSYNC signals are still active and color output is turned off.

The Blank Status (BLANK\_STS) and Display Blank Pending (DISPLAY\_BLANK\_PENDING) bits of the Display Status Register (DISPLAY\_STATUS) are used to determine when a Force Display Blanking (DISPLAY\_BLANK) request has been accomplished. Display Blank Pending (DISPLAY\_BLANK\_PENDING) is set when Force Display Blanking (DISPLAY\_BLANK) is changed. It is cleared when Blank Status (BLANK\_STS) has been updated to reflect the new setting of Force Display Blanking (DISPLAY\_BLANK).

The Display Blank Interrupt (DISPLAY\_BLANK\_INT) is asserted whenever Blank Status (BLANK\_STS) bit is updated to reflect a change in Force Display Blanking (DISPLAY\_BLANK) and the Display Blank Pending (DISPLAY\_BLANK\_PENDING) bit was set. This interrupt is propagated to the USB Interrupt Endpoint Status Register (USB\_INT\_STS). It is cleared by writing a 1 to Display Blank Interrupt (DISPLAY\_BLANK\_INT).

**Note:** Display Blank Pending (DISPLAY\_BLANK\_PENDING) is also cleared whenever the Display Controller Status (DC\_STS) bit is cleared.



**Note:** If the display is forced into blanking, scanning resumes on line 0, pixel 0 when blanking is deasserted.

### **10.3.4** Display Frame Buffer Processing

Display frames are resident in DRAM and the information contained therein is translated into video signals for display, under DMA control. The base addresses of the frame buffers are written into the Display Frame Buffer Base Address Register (DISPLAY\_FRAME\_BASE\_ADDR) for use by the DMA controller. Up to four base addresses may be resident in the Display Frame Buffer Base Address Queue. As the DMA Engine starts each new frame, an address is removed from the queue. When the queue becomes empty, the last address is reused repeatedly. The maximum depth of the queue is specified by the Frame Base Address Maximum Count (FRAME\_BASE\_ADDR\_MAX\_COUNT) field of the Display Control Register (DISPLAY\_CTRL) (maximum is 4). The current entry count can be read from the Frame Base Address Pending Count (FRAME\_BASE\_ADDR\_PENDING\_CNT) field of the Display Status Register (DISPLAY\_STATUS). Once the queue is full, subsequent writes are ignored. The Frame Base Address Queue Full (FRAME\_BASE\_ADDR\_QUEUE\_FULL) flag of the Display Status Register (DISPLAY\_STATUS) is set whenever the queue is full. The number of times the active Frame Base Address has changes is indicated by the Display Frame Base Address Changed Count Register (DISPLAY\_FRAME\_BASE\_ADDR\_CHANGED\_CNT).

When the Frame Base Address Queue Full (FRAME\_BASE\_ADDR\_QUEUE\_FULL) flag goes low due to the DMA Controller utilizing the Display Frame Buffer Address at the head of the Display Frame Buffer Base Address Queue, the Frame Base Address Interrupt (FRAME\_BASE\_ADDR\_INT) is asserted. This interrupt is propagated to the USB Interrupt Endpoint Status Register (USB\_INT\_STS). It is cleared by writing a 1 to the Frame Base Address Interrupt (FRAME\_BASE\_ADDR\_INT) bit.

Note: Thus two mechanisms exist for determining whether the Display Frame Buffer Base Address queue may be replenished by writing to the Display Frame Buffer Base Address Register (DISPLAY\_FRAME\_BASE\_ADDR). The Frame Base Address Interrupt (FRAME\_BASE\_ADDR\_INT) can be used in conjunction with the Frame Base Address Pending Count (FRAME\_BASE\_ADDR\_PENDING\_CNT) to determine how many buffers may be written. Alternatively, the Frame Base Address Pending Count (FRAME\_BASE\_ADDR\_PENDING\_CNT) may be periodically polled.

The Display Frame Buffer Length Register (DISPLAY\_FRAME\_LEN) must be configured to the length of the display frame buffer in bytes. The value is set to the total pixel count multiplied by the bytes per pixel (bpp) value for the current display mode (1, 2, or 3 for 8-bit, 16-bit, and 24-bit modes, respectively, as determined by the Color Depth (COLOR\_DEPTH) field of the Display Control Register (DISPLAY\_CTRL). Total pixel count is (Horizontal Active (H\_ACTIVE) + 1) \* (Vertical Active (V\_ACTIVE) + 1).

Normally the memory slave to the DMA controller returns an OKAY bus response. In the event that a ERROR response is returned, the DMA controller will stop transfers, enter an error state and set the Bus Error (BUS\_ERROR) bit in the Display Status Register (DISPLAY\_STATUS). The error state is left only when the DCTL is disabled.

### **10.3.5** Display Data Interpretation

#### 10.3.5.1 Border Generation

Border dimensions are determined by the horizontal and vertical timing registers. Right border size is Horizontal Blank Start (H\_BLANK\_START) - Horizontal Active (H\_ACTIVE), left border size is Horizontal Total (H\_TOTAL) - Horizontal Blank End (H\_BLANK\_END), top border size is Vertical Total (V\_TOTAL) - Vertical Blank End (V\_BLANK\_END), and bottom border size is Vertical Blank Start (V\_BLANK\_START) - Vertical Active (V\_ACTIVE).

The Display Border Color Register (DISPLAY\_BORDER\_COLOR) is used to set the desired Border Red, Green, and Blue values for all pixels within the border area.

The Border color is handled as specified in Section 10.3.9, "Border and Blanking Insert, Color Lookup/Gamma Correction," on page 167. Refer to that section for details. The term "designated



register" used in that section refers to the Display Border Color Register (DISPLAY\_BORDER\_COLOR).

#### 10.3.5.2 Display of Frame Buffer Contents

The DMA Controller moves Frame Buffer Data from DRAM to an internal FIFO whenever the DCTL is enabled and the Display Frame Buffer Base Address Register (DISPLAY\_FRAME\_BASE\_ADDR) has been written with at least one Frame Buffer Base Address. Whenever the Frame Buffer Base Address Queue goes empty, the last Frame Buffer Base Address read will be used repeatedly.

The Pixel Extractor interfaces to the output of the DMA FIFO. It fetches Quad words from the DMA FIFO and extracts pixels from them. The pixel information is in RGB24 format (8-bits each of Red, Green, and Blue). Two pixels are generated on each system clock. Pixel FIFO underrun/overrun should never occur. However, the Pixel FIFO Overrun (PIXEL\_FIFO\_OVERRUN) and Pixel FIFO Underrun (PIXEL\_FIFO\_UNDERRUN) flags in the Display Status Register (DISPLAY\_STATUS) permit the software to poll for these untoward conditions.

Depending upon the Color Depth (COLOR\_DEPTH) setting, a pixel either occupies 8, 16 or 24 bits. Conversely, a 64 memory QWORD either contains 2 2/3, 4 or 8 pixels. Each system clock (assuming data is available), two pixels are extracted, converted (if necessary) and written into the Pixel FIFO (assuming the FIFO is not full). The quad word to pixel mapping is shown in Figure 10.5, Figure 10.6, and Figure 10.7 for each color depth setting.

As shown, in 24 bit mode, three quad words are mapped to eight pixels. Any unused bytes from a quad word are used to form the next pixel before the next quad word is processed.



Figure 10.5 Quad Word to Pixel Mapping 24 bbp

16 bit mode splits each 16 bits into a 5 bit Red, a 6 bit Green and a 5 bit Blue value, each with leading 0's.



Figure 10.6 Quad Word to Pixel Mapping 16 bbp



8 bit mode replicates a byte onto each color of the pixel. Mapping / replicating at this point makes the subsequent color lookup function a uniform operation.



Figure 10.7 Quad Word to Pixel Mapping 8 bbp

Once a complete quad word is used, an acknowledge is sent to the DMA controller so that it may present the next quad word. A quad word is consumed every other system clock in 16 bit mode and every four clocks in 8 bit mode, In 24 bit mode, 3 quad words are used every four clocks. (All of the above assume that the Pixel FIFO is not full).

The mapped pixel data in RGB24 format contained within the Pixel FIFO is then presented to the HW cursor module, where it is combined with any active cursor information. Refer to Section 10.3.7, "Combining Cursor and Display Frame Data," on page 166 for details.

### 10.3.6 Display Cursor

#### 10.3.6.1 Double Buffered Display Cursor Registers Description

Pairs of registers are used to configure and determine the configuration status of the Display Cursor. One register, the Control Register of the pair, is R/W and is written to set the configuration parameter. The other register of the pair, the Status Register, is RO and provides the configuration parameter value currently in effect The registers that are written to set the configuration parameters are double buffered. Writes to this type of register are performed to a holding register, not the actual hardware register controlling the cursor parameter. The contents of the holding register are transferred into the actual hardware register controlling the cursor following the vertical blank signal that occurs after a write to the Display Cursor Position Register (DISPLAY\_CURSOR\_POSITION). Writing to DISPLAY\_CURSOR\_POSITION also sets the Cursor Trigger Armed (CURSOR\_TRIG) bit in the Display Cursor Status Register (DISPLAY\_CURSOR\_STATUS). Whenever CURSOR\_TRIG is set, the contents of the control register should not be changed. Note also that double buffering is in effect only when the DCTL is running. If it is stopped, as indicated by the Display Controller Status (DC\_STS) bit in the Display Status Register (DISPLAY\_STATUS), the writes have immediate effect. Table 10.1 enumerates the Display Cursor register pairs having the aforementioned properties.

| Control Register                | Status Register                |
|---------------------------------|--------------------------------|
| Display Cursor Control Register | Display Cursor Status Register |
| (DISPLAY_CURSOR_CTRL)           | (DISPLAY_CURSOR_STATUS)        |

#### Table 10.1 Display Cursor Status/Control Register Pairs



| Control Register                                                   | Status Register                                                                   |
|--------------------------------------------------------------------|-----------------------------------------------------------------------------------|
| Display Cursor Base Address Register<br>(DISPLAY_CURSOR_BASE_ADDR) | Display Cursor Current Base Address<br>Register<br>(DISPLAY_CURSOR_CUR_BASE_ADDR) |
| Display Cursor Position Register                                   | Display Cursor Current Position Register                                          |
| (DISPLAY_CURSOR_POSITION)                                          | (DISPLAY_CURSOR_CUR_POSITION)                                                     |
| Display Cursor Color 0 Register                                    | Display Cursor Current Color 0 Register                                           |
| (DISPLAY_CURSOR_COLOR_0)                                           | (DISPLAY_CURSOR_CUR_COLOR_0)                                                      |
| Display Cursor Color 1 Register                                    | Display Cursor Current Color 1 Register                                           |
| (DISPLAY_CURSOR_COLOR_1)                                           | (DISPLAY_CURSOR_CUR_COLOR_1)                                                      |
| Display Cursor Color 2 Register                                    | Display Cursor Current Color 2 Register                                           |
| (DISPLAY_CURSOR_COLOR_2)                                           | (DISPLAY_CURSOR_CUR_COLOR_2)                                                      |
| Display Cursor Color 3 Register                                    | Display Cursor Current Color 3 Register                                           |
| (DISPLAY_CURSOR_COLOR_3)                                           | (DISPLAY_CURSOR_CUR_COLOR_3)                                                      |

#### Table 10.1 Display Cursor Status/Control Register Pairs

The phrase "is determined by" in the following discussion refers to the control register of a pair. It should be construed as meaning that the register must be written to configure the parameter, regardless of when the parameter takes effect.

### 10.3.6.2 General Cursor Control/Status Parameters

Status information concerning the cursor is obtained by reading the contents of the Display Cursor Status Register (DISPLAY\_CURSOR\_STATUS), while the operational characteristics of the cursor are controlled by fields within the Display Cursor Control Register (DISPLAY\_CURSOR\_CTRL).

The operational mode of the cursor is determined by the Cursor Mode (CURSOR\_MODE) field of the Display Cursor Control Register (DISPLAY\_CURSOR\_CTRL). Table 10.3, "Cursor Modes," on page 191 describes each mode. Color 0, Color 1, Color 2, and Color 3 referred to in this table are the Display Cursor Color 0 Register (DISPLAY\_CURSOR\_COLOR\_0), Display Cursor Color 1 Register (DISPLAY\_CURSOR\_COLOR\_1), Display Cursor Color 2 Register (DISPLAY\_CURSOR\_COLOR\_2), and Display Cursor Color 3 Register (DISPLAY\_CURSOR\_COLOR\_3), respectively, which are discussed in Section 10.3.6.5.

The cursor size is determined by the Cursor Size (CURSOR\_SIZE) field of the Display Cursor Control Register (DISPLAY\_CURSOR\_CTRL).

Enabling/Disabling the cursor is accomplished by setting/clearing the Cursor Enable (CURSOR\_ENABLE) bit of the Display Cursor Control Register (DISPLAY\_CURSOR\_CTRL). Setting the bit causes cursor information to be read from system memory and generation of the cursor image. Clearing the bit terminates the reading of cursor information from system memory and stops display of the cursor. Clearing the bit does not result in the immediate cessation of cursor display.

**Note:** The Display Cursor Control Register (DISPLAY\_CURSOR\_CTRL) is double buffered and has the properties listed in Section 10.3.6.1.

The current cursor mode, size and enable status in effect maybe determined by examining the Cursor Current Mode (CURSOR\_CUR\_MODE), Cursor Current Size (CURSOR\_CUR\_SIZE), and Cursor Status (CURSOR\_STAT) fields of the Display Cursor Status Register (DISPLAY\_CURSOR\_STATUS).

Note, as previously discussed in Section 10.3.6.1, the Cursor Trigger Armed (CURSOR\_TRIG) bit of the Display Cursor Status Register (DISPLAY\_CURSOR\_STATUS) returns status indicating whether or not there is a pending cursor change. If set, a change is pending, if clear, no change is pending. A pending change may be cancelled by writing a one to this bit, however, there is no guarantee that the attempt at cancellation will be successful, as the time window formed by the CURSOR\_TRIG being



set to the time when it is cleared as a result of transfer of data from the holding register to the hardware is quite narrow.

#### 10.3.6.3 Setting Source of Cursor Image Data

Multiple cursor images may be stored in system memory. The Display Cursor Base Address Register (DISPLAY\_CURSOR\_BASE\_ADDR) is used to set the 128 byte aligned starting address of the cursor image buffer to be used.

**Note:** The Display Cursor Base Address Register (DISPLAY\_CURSOR\_BASE\_ADDR) is double buffered and has the properties listed in Section 10.3.6.1.

The current cursor base address in effect can be obtained by reading the Display Cursor Current Base Address Register (DISPLAY\_CURSOR\_CUR\_BASE\_ADDR).

The DMA Engine uses the current base address to move cursor data from the DRAM into the Cursor Buffer. The system memory byte address for the cursor data is generated by a Y offset (line number within the cursor - provided by the Cursor Buffer block), along with Cursor Current Base Address Upper Bits (CURSOR\_CUR\_BASE\_ADDR\_HI), Cursor Current Base Address Lower Bits (CURSOR\_CUR\_BASE\_ADDR\_LO), Cursor Current Size (CURSOR\_CUR\_SIZE) (32x32, 48x48 or 64x64) and Cursor Current Mode (CURSOR\_CUR\_MODE) (2 bpp or 32 bpp).

The number of bytes/cursor line image is based on Cursor Current Size (CURSOR\_CUR\_SIZE) (32x32, 48x48 or 64x64) and Cursor Current Mode (CURSOR\_CUR\_MODE) (2 bpp or 32 bpp) and is as illustrated in the following table:.

| CURSOR MODE | CURSOR WIDTH | BYTES PER LINE<br>OF CURSOR<br>IMAGE |
|-------------|--------------|--------------------------------------|
| 2 bpp       | 32           | 8                                    |
| 2 bpp       | 48           | 12                                   |
| 2 bpp       | 64           | 16                                   |
| 32 bpp      | 32           | 128                                  |
| 32 bpp      | 38           | 192                                  |
| 32 bpp      | 64           | 256                                  |

#### 10.3.6.4 Display Cursor Positioning

Cursor Position on the screen is specified by the Display Cursor Position Register (DISPLAY\_CURSOR\_POSITION). It specifies the signed X, Y coordinates of the cursor, corresponding to the cursor's top left corner. Cursor pixels outside the active screen are clipped. When using negative values, at least one pixel must be positioned on the active screen. Writing this register sets Cursor Trigger Armed (CURSOR\_TRIG).

**Note:** This register is also double buffered and operates with the constraints outlined in Section 10.3.6.1, with the exception that it can be changed when Cursor Trigger Armed (CURSOR\_TRIG) is set, however, the new value will be used only if the write occurs before the vertical blank signal.

The X, Y coordinates of the current cursor position in effect can be obtained by reading the Display Cursor Current Position Register (DISPLAY\_CURSOR\_CUR\_POSITION).



#### 10.3.6.5 Display Cursor Color Registers

The Display Cursor Color x Registers (DISPLAY CURSOR x), 0<=x<=3, are used to specify the Red, Green, and Blue portions of color x when operating in the 2 Color, 3 Color, or 4 Color cursor mode. These operating modes are all 2 bits per pixel modes and their use is determined by the setting of the Cursor Current Mode (CURSOR CUR MODE) field of the Display Cursor Status Register (DISPLAY CURSOR STATUS). These registers are also double buffered and operate with the constraints outlined in Section 10.3.6.1. Like all the other double buffered registers associated with the cursor, these registers have analogs that indicate the current values in effect for the particular color they correspond to, I.e., Display Cursor Current Color 0 Register (DISPLAY CURSOR CUR COLOR 0) indicates the Cursor Current Red (CURSOR CUR RED 0), Cursor Current Green (CURSOR CUR GREEN 0), and Cursor Current Blue (CURSOR CUR BLUE 0) values for color 0 that are in effect. In general, DISPLAY CURSOR CUR COLOR x can be accessed to determine CURSOR CUR RED x, CURSOR CUR GREEN x, and CURSOR CUR BLUE x values.

### 10.3.7 Combining Cursor and Display Frame Data

The HW Cursor module is responsible for determining whether to display frame data from the Pixel FIFO or cursor data from the Cursor Buffer. It reads both data sources in parallel and utilizes the data read according to the values of the Cursor Current Mode (CURSOR\_CUR\_MODE), and the internal hardware pixel and line counters. Either 2-bits or 32-bits are read by the HW Cursor Module from the Cursor Buffer, depending on whether the Cursor Current Mode (CURSOR\_CUR\_MODE) indicates 2-bits/pixel or 32-bits/pixel operation.

The cursor timing is based on a comparison of the internal hardware horizontal pixel and vertical line counters with the left, right, top and bottom cursor positions. If the cursor is partially off screen, it is clipped. If it is fully off screen, or not enabled, it is not displayed.

Whenever the internal counters determine that a cursor element is not currently being processed, the pixel data read from the Pixel FIFO is passed on to the Border and Blanking Insert, Color Lookup/Gamma Correction Module without modification and the cursor data is ignored.

When the internal counters indicate cursor data is being processed, the HW Cursor Module performs the following processing, based on the Cursor Current Mode (CURSOR\_CUR\_MODE):

- Cursor Current Mode (CURSOR\_CUR\_MODE) = 000 = 2 Color (Monochrome)
- Cursor Current Mode (CURSOR\_CUR\_MODE) = 001 = 3 Color
- Cursor Current Mode (CURSOR\_CUR\_MODE) = 010 = 4 Color

The 2-bits read from the Cursor Buffer indicate the data source to be used, as indicated in Table 10.3. If the data source is a color register, then the current value of that color register is fetched by the HW Cursor module and output to the Border and Blanking Insert, Color Lookup/Gamma Correction Module. If the data source is Frame data, then the Pixel FIFO element that was read is transformed as indicated in Table 10.3 and output to the Border and Blanking Insert, Color Lookup/Gamma Correction Module. Refer to Section 10.3.9 for details.

- Cursor Current Mode (CURSOR\_CUR\_MODE) = 011 = RGB Color The 32-bit cursor data and the Frame Pixel data read by the HW Cursor Module are transformed by the algorithm indicated in Table 10.3. The result is output to the Border and Blanking Insert, Color Lookup/Gamma Correction Module. Refer to Section 10.3.9 for details.
- **Note:** When in 8-bits per pixel display color mode, only the Blue Pixel data and Cursor Data byte are used by the algorithm. The Red and Green outputs of the HW Cursor Module are "don't cares".
- **Note:** When in 16-bits per pixel display color mode, only the lower 5, 6, and 5 bits of Red, Blue, and Green are used. are used by the algorithm. The outputs of the HW Cursor Module associated with the remaining bits are "don't cares".
- Cursor Current Mode (CURSOR\_CUR\_MODE) = 100 = Masked RGB Color



The 32-bit cursor data and the Frame Pixel data read by the HW Cursor Module are transformed by the algorithm indicated in Table 10.3. The result is output to the Border and Blanking Insert, Color Lookup/Gamma Correction Module. Refer to Section 10.3.9 for details.

- **Note:** When in 8-bits per pixel display color mode, only the Blue Pixel data and Cursor Data byte are used by the algorithm. The Red and Green outputs of the HW Cursor Module are "don't cares".
- **Note:** When in 16-bits per pixel display color mode, only the lower 5, 6, and 5 bits of Red, Blue, and Green are used. are used by the algorithm. The outputs of the HW Cursor Module associated with the remaining bits are "don't cares".

### 10.3.8 Color Lookup/Gamma Correction Via The Color Lookup Table

The Display Color Lookup Table (DISPLAY\_CLUT) is a 256 entry table that must be initialized by software prior to its use. Each entry in the table contains 10-bit Red, Green, and Blue values that are used to map RGB24 pixel data to a 30-bit color.

### **10.3.9** Border and Blanking Insert, Color Lookup/Gamma Correction

The Border and Blanking Insert, Color Lookup/Gamma Correction Module is responsible for displaying the border area of the screen, applying Color Lookup/Gamma correction values via use of the CLUT entries, and blanking the screen. Output data from this module is zeroed during the blanking time, which is determined by the setting of the Horizontal Blank Start (H\_BLANK\_START), Horizontal Blank End (H\_BLANK\_END), Vertical Blank Start (V\_BLANK\_START) and Vertical Blank End (V\_BLANK\_END) fields of the Display Horizontal Blank Register (DISPLAY\_H\_BLANK) and Display Vertical Blank Register (DISPLAY\_V\_BLANK), as well as the setting of the Force Display Blanking (DISPLAY\_BLANK) bit of the Display Control Register (DISPLAY\_CTRL). The polarity of the sync and blanking outputs is selectable via CSR settings.

Whenever the internal timing registers indicate blanking is to occur, all color output data is driven to zero.

Whenever the internal timing registers indicate a border element is to be displayed, the RGB24 value of the Display Border Color Register (DISPLAY\_BORDER\_COLOR) is read as used as the "designated item". In all other cases, the RGB24 output of the HW Cursor Module is read and used as the "designated item".

Use of the Color Lookup Table (CLUT) is enabled whenever Gamma Correction and Color Lookup Enable (COLOR EN) bit in the Display Control Register (DISPLAY CTRL) is set.

If COLOR\_EN is set, designated item is mapped as follows, depending on the value of Color Depth (COLOR\_DEPTH) specified in the Display Control Register (DISPLAY\_CTRL):

COLOR\_DEPTH = 24-bits

Each byte of data in the designated item will be mapped separately to form the 30-bit color. The value of the 8-bit red portion of the designated item is used to index into the CLUT and the CLUT Red (RED) value at the indexed location is the 10-bit red value output. The values of 8-bit green and blue portions of the designated item are similarly used as indices into the CLUT and the values associated with the indices, CLUT Green (GREEN) and CLUT Blue (BLUE) are used as the remaining 20-bits of color.

COLOR\_DEPTH = 16-bits

The low order 5-bits of the red portion, 6-bits of the green portion, and 5-bits of the blue portion of the designated item are each packed into a byte and padded with leading 0s. The resulting bytes are mapped separately, using the CLUT, as described in the previous bulleted item, to form the 30-bit color.

COLOR\_DEPTH = 8-bits

The 8-bit blue data portion of the designated item is mapped into a 30-bit color. The 8-bit data is used to index into the CLUT and the CLUT Red (RED), CLUT Green (GREEN), and CLUT Blue (BLUE) entries at that index are used as a 3 color set and form the 30-bit color.



Use of the CLUT is disabled whenever COLOR\_EN is cleared. Pixel data is not mapped, but is output as follows, depending on the value of Color Depth (COLOR\_DEPTH) specified in the Display Control Register (DISPLAY\_CTRL):

COLOR\_DEPTH = 24-bits

Each byte of data in the designated item will be used separately to form the 30-bit color. The value of the 8-bit red portion of the designated item has two bits of zero appended to the low order end to compose the 10-bit red value output. The values of the 8-bit green and 8-bit blue portions of the designated item are similarly appended with two bits of zero at their lower ends to formulate the remaining 20-bits of color output.

COLOR\_DEPTH = 16-bits

The low order 5-bits of the red portion, 6-bits of the green portion, and 5-bits of the blue portion of the designated item are each appended with 5-bits, 4-bits, and 5-bits, respectively of trailing zeros, to formulate the 30-bit color output.

COLOR\_DEPTH = 8 bits

The 8-bit blue color portion of the designated item is used to generate the 30-bit color. Two bits of zero are appended to the low order end of the blue color value of the designated item to form a 10-bit color value. This value is then replicated onto each color output (grey scale).

### 10.3.10 Interface Control

The Display Controller controls its output interfaces via three interface registers. Only one of these output interfaces should be selected at any time. Display Interface Control 0 Register (DISPLAY\_INTERFACE\_CTRL\_0) controls the internal DAC interface, Display Interface Control 1 Register (DISPLAY\_INTERFACE\_CTRL\_1) controls the internal HDMI interface, and Display Interface Control 2 Register (DISPLAY\_INTERFACE\_CTRL\_2) controls the external RGB interface.

**Note:** The values in these registers should be changed only when the Display Controller is stopped, as indicated by the Display Controller Status (DC\_STS) bit in the Display Status Register (DISPLAY STATUS).

#### 10.3.10.1 DAC Interface Control

This interface is enabled by setting the Interface 0 Select (INTF\_SEL\_0) bit of the Display Interface Control 0 Register (DISPLAY\_INTERFACE\_CTRL\_0). When this interface is selected, the following fields should be initialized to the settings required by the externally connected device:

- Interface 0 Horizontal Sync Polarity (HSYNC\_POL\_0)
- Interface 0 Vertical Sync Polarity (VSYNC\_POL\_0)

The following field is set to its default value:

Interface 0 Vertical and Horizontal Sync Output Delay (V\_H\_SYNC\_DELAY\_0)

When the DAC Interface is selected, the VDAC pins, shown in Table 3.4, "VDAC Pins," on page 32 of Chapter 3, Pin Description and Configuration, are active.

#### 10.3.10.2 HDMI Interface Control

This interface is enabled by setting the Interface 1 Select (INTF\_SEL\_1) bit of the Display Interface Control 1 Register (DISPLAY\_INTERFACE\_CTRL\_1). When this interface is selected, the following fields must be set to the values required for proper operation:

- Interface 1 Horizontal Sync Polarity (HSYNC\_POL\_1)
- Interface 1 Vertical Sync Polarity (VSYNC\_POL\_1)

The following field is set to its default value:

Interface 1 Vertical and Horizontal Sync Output Delay (V\_H\_SYNC\_DELAY\_1)



When the HDMI Interface is selected, the HDMI pins, shown in Table 3.6, "HDMI Pins," on page 34 of Chapter 3, Pin Description and Configuration, are active.

#### 10.3.10.3 RGB Interface Control

This interface is enabled by setting the Interface 2 Select (INTF\_SEL\_2) bit of the Display Interface Control 2 Register (DISPLAY\_INTERFACE\_CTRL\_2). When this interface is selected, the following fields should be initialized to the settings required by the externally connected device:

- Interface 2 Double Data Rate Select (DDR\_SEL\_2)
- Interface 2 Double Data Rate Deep Color Enable (DDR\_COLOR\_2)
- Interface 2 Vertical and Horizontal Sync Output Delay (V\_H\_SYNC\_DELAY\_2)
- Interface 2 Output Clock Polarity (OUT\_CLOCK\_POL\_2)
- Interface 2 Horizontal Sync Polarity (HSYNC\_POL\_2)
- Interface 2 Vertical Sync Polarity (VSYNC\_POL\_2)
- Interface 2 Blanking Polarity (BLANK\_POL\_2)

When the RGB Interface is selected, the RGB pins, shown in Chapter 3, Pin Description and Configuration, are active.

- **Note:** The Interface 2 Double Data Rate Select (DDR\_SEL\_2) and Interface 2 Double Data Rate Deep Color Enable (DDR\_COLOR\_2) settings affect the pins used during RGB operations. Refer to table Table 3.3, "RGB / DDR Mode Mapping Table," on page 31 for details.
- **Note:** 1x data rate RGB data is mapped to the double data rate output whenever Interface 2 Double Data Rate Select (DDR\_SEL\_2) is set.

### **10.4 Display Controller Programming Outline**

### 10.4.1 Initialization

If required, reset the Display Controller by writing the 8000h into the Display Control Register (DISPLAY\_CTRL). Wait until the bit is clear before continuing, to ensure that the reset has been accomplished.

Configure screen size by programming the Display Vertical Size Register (DISPLAY\_V\_SIZE) and the Display Horizontal Size Register (DISPLAY\_H\_SIZE).

Configure the blank timing by programming the Display Vertical Blank Register (DISPLAY\_V\_BLANK) and the Display Horizontal Blank Register (DISPLAY\_H\_BLANK).

Configure the sync timing by programming the Display Vertical Sync Register (DISPLAY\_V\_SYNC) and the Display Horizontal Sync Register (DISPLAY\_H\_SYNC).

Configure the color used for the frame border by programming the Display Border Color Register (DISPLAY\_BORDER\_COLOR).

If the Display Color Lookup Table (DISPLAY\_CLUT) will be utilized, initialize the 256 words of the table with the desired values.

Initialize the appropriate Interface Control Register, depending on the desired output:

- Display Interface Control 0 Register (DISPLAY\_INTERFACE\_CTRL\_0) for VDAC output.
- Display Interface Control 1 Register (DISPLAY\_INTERFACE\_CTRL\_1) for HDMI output.
- Display Interface Control 2 Register (DISPLAY\_INTERFACE\_CTRL\_2) for RGB output.

If the Cursor is to be used, perform the following initialization:



- Configure the Cursor Mode (CURSOR\_MODE), Cursor Size (CURSOR\_SIZE) and Cursor Enable (CURSOR\_ENABLE)fields of the Display Cursor Control Register (DISPLAY\_CURSOR\_CTRL).
- Depending on the selected Cursor Mode (CURSOR\_MODE) Initialize the Display Cursor Color Registers (Display Cursor Color 0 Register (DISPLAY\_CURSOR\_COLOR\_0) through Display Cursor Color 3 Register (DISPLAY\_CURSOR\_COLOR\_3)) as required, with the desired RGB color characteristics.
- Program the Display Cursor Base Address Register (DISPLAY\_CURSOR\_BASE\_ADDR) with the cursor image base address.
- Write the initial cursor x, y position into the Display Cursor Position Register (DISPLAY CURSOR POSITION).

Program the Display Frame Buffer Length Register (DISPLAY\_FRAME\_LEN) with the desired frame length.

Program the Display Control Register (DISPLAY\_CTRL) with the desired values for the following fields. Make sure the Video Sub-system Enable (ENABLE) bit is set, in order to enable the Display Controller:

- Frame Base Address Maximum Count (FRAME\_BASE\_ADDR\_MAX\_COUNT)
- Color Depth (COLOR\_DEPTH)
- Gamma Correction and Color Lookup Enable (COLOR\_EN) (if the lookup table is to be utilized)

### 10.4.2 System Operation

While the Display Controller is enabled, write Display Frame Buffer Base Addresses into the Display Frame Buffer Base Address Register (DISPLAY\_FRAME\_BASE\_ADDR). Make sure that entries are not written while the queue is full, otherwise they will be ignored.

**Note:** The Frame Base Address Interrupt (FRAME\_BASE\_ADDR\_INT) may be used to signal when the Frame Base Address Queue has room for queuing the addresses of frames for display. Status of this interrupt appears in the Display Status Register (DISPLAY STATUS).

If a change in Cursor Mode, Size, or Visibility is desired, update the Display Cursor Control Register (DISPLAY\_CURSOR\_CTRL) register as required. If a change in the cursor image is desired, update the Display Cursor Base Address Register (DISPLAY\_CURSOR\_BASE\_ADDR) with the address of the buffer containing cursor image information. To invoke updates made to Display Cursor Control Register (DISPLAY\_CURSOR\_CTRL) or Display Cursor Base Address Register (DISPLAY\_CURSOR\_BASE\_ADDR), or to update the Cursor's position, write the current or updated Cursor position to the Display Cursor Position Register (DISPLAY\_CURSOR\_POSITION).

During system operation, the following four interrupts are propagated from the Display Controller to the USB Interrupt Endpoint Status Register (USB\_INT\_STS):

- Display Blank Interrupt (DISPLAY\_BLANK\_INT)
- Horizontal Blank Start Interrupt (H\_BLANK\_START\_INT)
- Vertical Blank Start Interrupt (V BLANK START INT)
- Frame Base Address Interrupt (FRAME BASE ADDR INT)

All of these interrupts may cleared by writing a 1 to the analogous bits of the Display Status Register (DISPLAY\_STATUS).

**Note:** The Display Status Register (DISPLAY\_STATUS) may be queried at any time to determine the status of the Display Controller.



# **10.5** Control and Status Registers

| ADDRESS<br>OFFSET            | REGISTER NAME (SYMBOL)                                                                     |  |  |  |
|------------------------------|--------------------------------------------------------------------------------------------|--|--|--|
| Control and Status Registers |                                                                                            |  |  |  |
| 000h                         | Display Control Register (DISPLAY_CTRL)                                                    |  |  |  |
| 004h                         | Display Status Register (DISPLAY_STATUS)                                                   |  |  |  |
|                              | Video Timing Registers                                                                     |  |  |  |
| 008h                         | Display Horizontal Size Register (DISPLAY_H_SIZE)                                          |  |  |  |
| 00Ch                         | Display Horizontal Blank Register (DISPLAY_H_BLANK)                                        |  |  |  |
| 010h                         | Display Horizontal Sync Register (DISPLAY_H_SYNC)                                          |  |  |  |
| 014h                         | Display Vertical Size Register (DISPLAY_V_SIZE)                                            |  |  |  |
| 018h                         | Display Vertical Blank Register (DISPLAY_V_BLANK)                                          |  |  |  |
| 01Ch                         | Display Vertical Sync Register (DISPLAY_V_SYNC)                                            |  |  |  |
|                              | DMA Control Registers                                                                      |  |  |  |
| 020h                         | Display Frame Buffer Base Address Register (DISPLAY_FRAME_BASE_ADDR)                       |  |  |  |
| 028h                         | Display Frame Buffer Length Register (DISPLAY_FRAME_LEN)                                   |  |  |  |
| 02Ch                         | Display Frame Base Address Changed Count Register<br>(DISPLAY_FRAME_BASE_ADDR_CHANGED_CNT) |  |  |  |
|                              | Interface Control Registers                                                                |  |  |  |
| 040h                         | Display Interface Control 0 Register (DISPLAY_INTERFACE_CTRL_0)                            |  |  |  |
| 044h                         | Display Interface Control 1 Register (DISPLAY_INTERFACE_CTRL_1)                            |  |  |  |
| 048h                         | Display Interface Control 2 Register (DISPLAY_INTERFACE_CTRL_2)                            |  |  |  |
|                              | Cursor Registers                                                                           |  |  |  |
| 080h                         | Display Cursor Control Register (DISPLAY_CURSOR_CTRL)                                      |  |  |  |
| 084h                         | Display Cursor Status Register (DISPLAY_CURSOR_STATUS)                                     |  |  |  |
| 088h                         | Display Cursor Base Address Register (DISPLAY_CURSOR_BASE_ADDR)                            |  |  |  |
| 08Ch                         | Display Cursor Current Base Address Register<br>(DISPLAY_CURSOR_CUR_BASE_ADDR)             |  |  |  |
| 090h                         | Display Cursor Position Register (DISPLAY_CURSOR_POSITION)                                 |  |  |  |
| 094h                         | Display Cursor Current Position Register (DISPLAY_CURSOR_CUR_POSITION)                     |  |  |  |
| 098h                         | Display Cursor Color 0 Register (DISPLAY_CURSOR_COLOR_0)                                   |  |  |  |
| 09Ch                         | Display Cursor Current Color 0 Register (DISPLAY_CURSOR_CUR_COLOR_0)                       |  |  |  |
| 0A0h                         | Display Cursor Color 1 Register (DISPLAY_CURSOR_COLOR_1)                                   |  |  |  |
| 0A4h                         | Display Cursor Current Color 1 Register (DISPLAY_CURSOR_CUR_COLOR_1)                       |  |  |  |
| 0A8h                         | Display Cursor Color 2 Register (DISPLAY_CURSOR_COLOR_2)                                   |  |  |  |
| 0ACh                         | Display Cursor Current Color 2 Register (DISPLAY_CURSOR_CUR_COLOR_2)                       |  |  |  |
| 0B0h                         | Display Cursor Color 3 Register (DISPLAY_CURSOR_COLOR_3)                                   |  |  |  |
| 0B4h                         | Display Cursor Current Color 3 Register (DISPLAY_CURSOR_CUR_COLOR_3)                       |  |  |  |
|                              | Color Lookup Registers                                                                     |  |  |  |
| 024h                         | Display Border Color Register (DISPLAY_BORDER_COLOR)                                       |  |  |  |
| 400h-7FCh                    | Display Color Lookup Table (DISPLAY_CLUT)                                                  |  |  |  |
|                              | Reserved                                                                                   |  |  |  |
| 030h – 03Fh                  | Reserved for future expansion                                                              |  |  |  |
| 04Ch – 07Fh                  | Reserved for future expansion                                                              |  |  |  |
| 0B8h – 3FFh                  | Reserved for future expansion                                                              |  |  |  |
| 800h – FFFh                  | Reserved for future expansion                                                              |  |  |  |

### Table 10.2 Display Controller Control and Status Register Map



# 10.5.1 Display Control Register (DISPLAY\_CTRL)

Address:

000h

32 bits

Size:

This register is used to configure and control the Display Controller.

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | TYPE | DEFAULT |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31    | <b>Reset (RESET)</b><br>When set, the display controller will be reset into its initial condition. This bit takes effect immediately upon being set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | SC   | 0b      |
| 30:27 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO   | -       |
| 26:24 | <ul> <li>Frame Base Address Maximum Count<br/>(FRAME_BASE_ADDR_MAX_COUNT)</li> <li>This field specifies the maximum number of entries that can be queued into<br/>Display Frame Buffer Base Address Register<br/>(DISPLAY_FRAME_BASE_ADDR). Any additional entries will be ignored.</li> <li>The maximum allowable value is 4.</li> <li>Note: This value should only be changed when the display controller is<br/>stopped as indicated by the Display Controller Status (DC_STS) bit<br/>in the Display Status Register (DISPLAY_STATUS) or when there<br/>are no entries queued as indicated by Frame Base Address<br/>Pending Count (FRAME_BASE_ADDR_PENDING_CNT) in the<br/>Display Status Register (DISPLAY_STATUS).</li> </ul> | R/W  | 001b    |
| 23:9  | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO   | -       |
| 8     | Force Display Blanking (DISPLAY_BLANK)<br>When set, the display will be forced into blanking. The RGB output will be<br>forced to zero and the blanking output set active.<br>This bit can be changed at any time but takes affect once the current frame<br>is finished or if the display has been disabled via the ENABLE bit. The actual<br>blanking status can be check via the BLANK_STS bit in the Display Status<br>register.                                                                                                                                                                                                                                                                                                 | R/W  | 1b      |
| 7:4   | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO   | -       |
| 3:2   | Color Depth (COLOR_DEPTH)         11: reserved         10: 24 bits per pixel         01: 16 bits per pixel         00: 8 bits per pixel         Note:       This value should only be changed when the display controller is stopped as indicated by the Display Controller Status (DC_STS) bit in the Display Status Register (DISPLAY STATUS).                                                                                                                                                                                                                                                                                                                                                                                     | R/W  | 10b     |



| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                     | TYPE | DEFAULT |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 1    | Gamma Correction and Color Lookup Enable (COLOR_EN)<br>When cleared, pixel data is not mapped. 8 bit data is replicated on to each<br>output color (grey scale). 16 bit data is interpreted as 5 bits of red, 6 bits of<br>green and 5 bits of blue. 24 bit data is used directly. Since the RGB output<br>is 10 bits, padded with trailing 0s is used to place the color data on the most<br>significant bits. | R/W  | Ob      |
|      | When set, pixel data is mapped using the color lookup table. 8 bit data is mapped into a 30 bit color. 16 bit data is interpreted as 5 bits of red, 6 bits of green and 5 bits of blue, padded with leading 0s, and each resulting byte is mapped separately to form the 30 bit color. Each byte of 24 bit data is mapped separately to form the 30 bit color.                                                  |      |         |
| 0    | Video Sub-system Enable (ENABLE)<br>When set, the video sub-system will read from system memory and generate<br>color and timing outputs.                                                                                                                                                                                                                                                                       | R/W  | Ob      |
|      | When cleared, the video sub-system is reset. When set to stop, the display controller will finish the current frame before actually stopping. The stopped status can be check via the DC_STS bit in the Display Status register.                                                                                                                                                                                |      |         |
|      | The disabled condition corresponds to the starting point of vertical blanking just before the sync pulses. In this condition:                                                                                                                                                                                                                                                                                   |      |         |
|      | HCount is set to HBlankStart<br>VCount is set to VBlankStart<br>Blank output is active<br>HSync, VSync and CSync outputs are inactive<br>DAC and DVO output clocks are stopped                                                                                                                                                                                                                                  |      |         |



# 10.5.2 Display Status Register (DISPLAY\_STATUS)

Address:

004h

32 bits

Size:

This register indicates the current state of the Display Controller.

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | TYPE | DEFAULT |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:27 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RO   | -       |
| 26:24 | Frame Base Address Pending Count<br>(FRAME_BASE_ADDR_PENDING_CNT)This field indicates the number of pending frame base address changes. It<br>is incremented when Display Frame Buffer Base Address Register<br>(DISPLAY_FRAME_BASE_ADDR) is written and is decremented when the<br>current frame base address in use changes.This field is cleared when the Display Controller is stopped as indicated by<br>the Display Controller Status (DC_STS) bit in this register.                                              | RO   | 000b    |
| 23:16 | <b>Revision (REV)</b><br>Indicates the current revision if we remember to update it. Otherwise<br>indicates the revision the last time it was updated.                                                                                                                                                                                                                                                                                                                                                                  | RO   | 03h     |
| 15:13 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RO   | -       |
| 12    | <b>Display Blank Interrupt (DISPLAY_BLANK_INT)</b><br>Set when the Blank Status (BLANK_STS) bit is updated to reflect the new<br>setting of Force Display Blanking (DISPLAY_BLANK) and the Display Blank<br>Pending (DISPLAY_BLANK_PENDING) bit was set.                                                                                                                                                                                                                                                                | R/WC | Ob      |
| 11    | <b>Display Blank Pending (DISPLAY_BLANK_PENDING)</b><br>Set when the Force Display Blanking (DISPLAY_BLANK) bit in the Display<br>Control Register (DISPLAY_CTRL) is changed. Cleared when the Blank<br>Status (BLANK_STS) bit is updated to reflect the new setting of Force<br>Display Blanking (DISPLAY_BLANK). Also cleared when the Display<br>Controller Status (DC_STS) bit is cleared.                                                                                                                          | RO   | Ob      |
| 10:9  | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RO   | -       |
| 8     | Blank Status (BLANK_STS)<br>Indicates that the request to blank the display, via the Force Display Blanking<br>(DISPLAY_BLANK) bit, in the Display Control Register (DISPLAY_CTRL) is<br>in affect.                                                                                                                                                                                                                                                                                                                     | RO   | 1b      |
| 7     | Horizontal Blank Start Interrupt (H_BLANK_START_INT)<br>Set at the start of the horizontal blank time.                                                                                                                                                                                                                                                                                                                                                                                                                  | R/WC | 0b      |
| 6     | Vertical Blank Start Interrupt (V_BLANK_START_INT)<br>Set at the start of the vertical blank time.                                                                                                                                                                                                                                                                                                                                                                                                                      | R/WC | 0b      |
| 5     | Frame Base Address Interrupt (FRAME_BASE_ADDR_INT)<br>Set when Frame Base Address Queue Full<br>(FRAME_BASE_ADDR_QUEUE_FULL) goes low due to the DMA Engine<br>reading from the start of a new frame buffer.                                                                                                                                                                                                                                                                                                            | R/WC | Ob      |
| 4     | Frame Base Address Queue Full (FRAME_BASE_ADDR_QUEUE_FULL)<br>This field indicates that the Frame Base Address Queue is full. It is set when<br>Frame Base Address Pending Count<br>(FRAME_BASE_ADDR_PENDING_CNT) reaches Frame Base Address<br>Maximum Count (FRAME_BASE_ADDR_MAX_COUNT) and is cleared<br>when the DMA Engine starts reading from a new frame buffer.<br>This field is cleared when the Display Controller is stopped as indicated by<br>the Display Controller Status (DC_STS) bit in this register. | RO   | Ob      |



| BITS | DESCRIPTION                                                                                                                                                                                                                          | TYPE | DEFAULT |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 3    | <b>Bus Error (BUS_ERROR)</b><br>When set indicates that the bus master experienced a transfer error and has stopped.                                                                                                                 | R/WC | 0b      |
| 2    | <b>Pixel FIFO Overrun (PIXEL_FIFO_OVERRUN)</b><br>Indicates that the Pixel FIFO was written while full. Should never happen<br>since Pixel extractor is not supposed to cause over-runs. Basically if this is<br>set, it's not good. | R/WC | 0b      |
| 1    | <b>Pixel FIFO Underrun (PIXEL_FIFO_UNDERRUN)</b><br>Indicates that the Pixel FIFO ran out of data. Should never happen in a<br>properly configured system. Basically if this is set, it's not good.                                  | R/WC | 0b      |
| 0    | <b>Display Controller Status (DC_STS)</b><br>Returns the actual run/stop status of the Display Controller.<br>1=Running, 0=Stopped.                                                                                                  | RO   | 0b      |



# 10.5.3 Display Horizontal Size Register (DISPLAY\_H\_SIZE)

008h

Address:

32 bits

Size:

This register controls the horizontal timing.

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                      | TYPE | DEFAULT |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:28 | RESERVED                                                                                                                                                                                                                                                                                         | RO   | -       |
| 27:16 | <b>Horizontal Total (H_TOTAL)</b><br>Total horizontal time in pixels encompassing the active display, left and right<br>borders, front and back porches and sync pulse time. Programmed to the<br>number of clocks desired minus 1.                                                              | R/W  | 000h    |
| 15:12 | RESERVED                                                                                                                                                                                                                                                                                         | RO   | -       |
| 11:0  | Horizontal Active (H_ACTIVE)<br>Horizontal active (addressable) resolution in pixels. The first horizontal active<br>display pixel is considered pixel number 0. Programmed to the desired<br>number of pixels per line minus 1. Should be programmed to less than the<br>total horizontal time. | R/W  | 000h    |
|       | <b>Note:</b> The horizontal active pixel count must be a) a multiple of 8 in 8 bpp mode, b) a multiple of 4 in 16 bpp mode and c) a multiple of 8 in 24 bpp mode.                                                                                                                                |      |         |

**Note:** This register should only be changed when the display controller is stopped as indicated by the Display Controller Status (DC\_STS) bit in the Display Status Register (DISPLAY\_STATUS).



# 10.5.4 Display Horizontal Blank Register (DISPLAY\_H\_BLANK)

00Ch

Address:

32 bits

Size:

This register controls the horizontal blank timing.

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | TYPE | DEFAULT |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:28 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RO   | -       |
| 27:16 | Horizontal Blank Start (H_BLANK_START)<br>Horizontal blanking start time in pixels relative to the start of the active<br>display. The first active pixel is considered pixel number 0. Programmed to<br>the desired right border size plus the horizontal active resolution minus 1. A<br>setting at the same point as the horizontal active implies no right border.<br>Should be programmed to greater than or equal to the horizontal active time<br>and less than the total horizontal time. | R/W  | 000h    |
| 15:12 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RO   | -       |
| 11:0  | Horizontal Blank End (H_BLANK_END)<br>Horizontal blanking end time in pixels relative to the start of the active<br>display. The first active pixel is considered pixel number 0. Programmed to<br>the horizontal total time minus the desired left border size minus 1. A setting<br>at the same point as the horizontal total time implies no left border. Should<br>be programmed to greater than the horizontal blanking start point and less<br>than or equal to the total horizontal time.  | R/W  | 000h    |

**Note:** This register should only be changed when the display controller is stopped as indicated by the Display Controller Status (DC\_STS) bit in the Display Status Register (DISPLAY\_STATUS).



# 10.5.5 Display Horizontal Sync Register (DISPLAY\_H\_SYNC)

010h

Address:

32 bits

Size:

This register controls the horizontal sync timing.

| BITS  | DESCRIPTION                                                                                                                                                                                                                        | TYPE | DEFAULT |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:28 | RESERVED                                                                                                                                                                                                                           | RO   | -       |
| 27:16 | Horizontal Sync Start (H_SYNC_START)<br>Horizontal sync start time in pixels relative to the start of the active display.<br>The first active pixel is considered pixel number 0. Programmed to the<br>desired VESA value minus 1. | R/W  | 000h    |
| 15:12 | RESERVED                                                                                                                                                                                                                           | RO   | -       |
| 11:0  | Horizontal Sync End (H_SYNC_END)<br>Horizontal sync end time in pixels relative to the start of the active display.<br>The first active pixel is considered pixel number 0. Programmed to the<br>desired VESA value minus 1.       | R/W  | 000h    |

**Note:** This register should only be changed when the display controller is stopped as indicated by the Display Controller Status (DC STS) bit in the Display Status Register (DISPLAY STATUS).



# 10.5.6 Display Vertical Size Register (DISPLAY\_V\_SIZE)

014h

Address:

32 bits

Size:

This register controls the vertical timing.

| BITS  | DESCRIPTION                                                                                                                                                                                                                   | TYPE | DEFAULT |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:28 | RESERVED                                                                                                                                                                                                                      | RO   | -       |
| 27:16 | <b>Vertical Total (V_TOTAL)</b><br>Total vertical time in lines encompassing the active display, top and bottom<br>borders, front and back porches and sync pulse time. Programmed to the<br>number of lines desired minus 1. | R/W  | 000h    |
| 15:12 | RESERVED                                                                                                                                                                                                                      | RO   | -       |
| 11:0  | <b>Vertical Active (V_ACTIVE)</b><br>Vertical active resolution in lines. The first vertical active display line is considered line number 0. Programmed to the desired number of lines minus 1.                              | R/W  | 000h    |

**Note:** This register should only be changed when the display controller is stopped as indicated by the Display Controller Status (DC\_STS) bit in the Display Status Register (DISPLAY\_STATUS).



32 bits

# 10.5.7 Display Vertical Blank Register (DISPLAY\_V\_BLANK)

Address:

018h

Size:

This register controls the vertical blank timing.

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | TYPE | DEFAULT |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:28 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO   | -       |
| 27:16 | Vertical Blank Start (V_BLANK_START)<br>Vertical blanking start time in lines relative to the start of the active display.<br>The first active line is considered line number 0. Programmed to the desired<br>bottom border size plus the vertical active resolution minus 1. A setting at<br>the same point as the vertical active implies no bottom border. Should be<br>programmed to greater than or equal to the vertical active time and less than<br>the total vertical time. | R/W  | 000h    |
| 15:12 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO   | -       |
| 11:0  | Vertical Blank End (V_BLANK_END)<br>Vertical blanking end time in lines relative to the start of the active display.<br>The first active line is considered line number 0. Programmed to the vertical<br>total time minus the desired top border size minus 1. A setting at the same<br>point as the vertical total time implies no top border. Should be programmed<br>to greater than the vertical blanking start point and less than or equal to the<br>total vertical time.      | R/W  | 000h    |

**Note:** This register should only be changed when the display controller is stopped as indicated by the Display Controller Status (DC\_STS) bit in the Display Status Register (DISPLAY\_STATUS).



## 10.5.8 Display Vertical Sync Register (DISPLAY\_V\_SYNC)

01Ch

Address:

32 bits

Size:

This register controls the vertical sync timing.

| BITS  | DESCRIPTION                                                                                                                                                                                                                  | TYPE | DEFAULT |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:28 | RESERVED                                                                                                                                                                                                                     | RO   | -       |
| 27:16 | <b>Vertical Sync Start (V_SYNC_START)</b><br>Vertical sync start time in lines relative to the start of the active display. The first active line is considered line number 0. Programmed to the desired VESA value minus 1. | R/W  | 000h    |
| 15:12 | RESERVED                                                                                                                                                                                                                     | RO   | -       |
| 11:0  | <b>Vertical Sync End (V_SYNC_END)</b><br>Vertical sync end time in lines relative to the start of the active display. The first active line is considered line number 0. Programmed to the desired VESA value minus 1.       | R/W  | 000h    |

**Note:** This register should only be changed when the display controller is stopped as indicated by the Display Controller Status (DC\_STS) bit in the Display Status Register (DISPLAY\_STATUS).



# 10.5.9 Display Frame Buffer Base Address Register (DISPLAY\_FRAME\_BASE\_ADDR)

Address: 020h Size: 32 bits

This register specifies the starting address in system memory of the frame buffer.

Writes into this register go into a queue. The maximum depth of the queue is specified by Frame Base Address Maximum Count (FRAME\_BASE\_ADDR\_MAX\_COUNT) in Display Control Register (DISPLAY\_CTRL). Once the queue is full, further writes are ignored. An entry is used once the DMA Engine finishes the current display buffer. If the queue empties, the last entry is reused for subsequent display refreshes.

When the Display Controller is stopped, as indicated by the Display Controller Status (DC\_STS) bit in the Display Status Register (DISPLAY\_STATUS), the queue is held reset and this register may be written multiple times with the last write being the only retained value.

| BITS | DESCRIPTION                                                                                                                                                                                                               | TYPE | DEFAULT  |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:7 | <b>Frame Base Address Upper Bits (FRAME_BASE_ADDR_HI)</b><br>When combined with the 7 read only bits below, this field specifies the starting address, in system memory, of the display frame buffer, specified in bytes. | R/W  | 0000000h |
|      | The byte offset of pixel XY within the frame buffer is given by Adr = (Y * $H_ACTIVE + X$ ) * Bytes_per_pixel. Where Bytes_per_pixel is 1, 2 or 3 for 8 bit, 16 bit and 24 bit modes respectively.                        |      |          |
| 6:0  | Frame Base Address Lower Bits (FRAME_BASE_ADDR_LO)<br>These are the lower 7 bits of the frame buffer base address.                                                                                                        | RO   | 00h      |

**Note:** The base address is aligned on 128 byte boundaries.



# 10.5.10 Display Border Color Register (DISPLAY\_BORDER\_COLOR)

Address:

024h

Size: 32 bits

This register specifies the color used for the frame border.

| BITS  | DESCRIPTION                                                                                                                                                                                               | TYPE | DEFAULT |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:24 | RESERVED                                                                                                                                                                                                  | RO   | -       |
| 23:16 | <b>Border Red (RED)</b><br>The red portion of color level sent during the border region, the periods<br>between the end of blank and the start of active and the end of active and<br>the start of blank. | R/W  | 00h     |
| 15:8  | <b>Border Green (GREEN)</b><br>The green portion of color level sent during the border region, the periods between the end of blank and the start of active and the end of active and the start of blank. | R/W  | 00h     |
| 7:0   | <b>Border Blue (BLUE)</b><br>The blue portion of color level sent during the border region, the periods between the end of blank and the start of active and the end of active and the start of blank.    | R/W  | 00h     |

**Note:** The border color is handled the same as any pixel data. In 16 bit mode, only the lowest 5 bits of Red, 6 bits of Green and 5 bits of blue are used. In 8 bit mode, only the blue field is used as either the index into the CLUT or as an 8 bit grey scale value. If gamma correction / color lookup is enabled, the values are mapped through the CLUT.



# 10.5.11 Display Frame Buffer Length Register (DISPLAY\_FRAME\_LEN)

Address:

32 bits

Size:

This register specifies the length of the frame buffer.

028h

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | TYPE | DEFAULT |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:24 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RO   | -       |
| 23:3  | Frame Length Upper Bits (FRAME_LEN_HI)<br>When combined with the 3 read only bits below, this field specifies the length<br>of the display frame buffer, specified in bytes. This value can be changed at<br>any time but does not take affect until the current frame is fully read from<br>system memory.<br>The value set should be the total pixel count (H_ACTIVE+1 * V_ACTIVE+1)<br>multiplied by the bytes per pixel (bytes per pixel is 1, 2 or 3 for 8 bit, 16 bit<br>and 24 bit modes respectively). | R/W  | 000000h |
| 2:0   | Frame Length Lower Bits (FRAME_LEN_LO)<br>These are the lower 3 bits of the frame buffer length.                                                                                                                                                                                                                                                                                                                                                                                                               | RO   | 000b    |

**Note:** The frame length is always a multiple of 8 bytes in 8 bpp and 16 bpp modes and 24 bytes in 24 bpp mode due to the requirements on Horizontal Active (H\_ACTIVE) listed above.



# 10.5.12 Display Frame Base Address Changed Count Register (DISPLAY\_FRAME\_BASE\_ADDR\_CHANGED\_CNT)

Address: 02Ch Size: 32 bits

This register indicates the number of times the active Frame Base Address has been changed.

| BITS | DESCRIPTION                                                                                                                                                              | TYPE | DEFAULT   |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:0 | Frame Base Address Changed Count<br>(FRAME_BASE_ADDR_CHANGED_CNT)<br>Indicates the number of times the active Frame Base Address has been<br>changed.                    | R/W  | 00000000h |
|      | This field is cleared when the Display Controller is stopped as indicated by the Display Controller Status (DC_STS) bit in the Display Status Register (DISPLAY_STATUS). |      |           |



# 10.5.13 Display Interface Control 0 Register (DISPLAY\_INTERFACE\_CTRL\_0)

Size:

Address:

040h

32 bits

This register is used to configure and control interface 0 of the Display Controller.

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                      | TYPE | DEFAULT |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:10 | RESERVED                                                                                                                                                                                                                                                                                                                                         | RO   | -       |
| 9     | RESERVED                                                                                                                                                                                                                                                                                                                                         | RO   | -       |
| 8     | RESERVED                                                                                                                                                                                                                                                                                                                                         | RO   | -       |
| 7:6   | Interface 0 Vertical and Horizontal Sync Output Delay<br>(V_H_SYNC_DELAY_0)<br>This field is used to specify a 0 to 3 clock delay on interface 0, vertical and<br>horizontal sync outputs. This may be used to match the data delay of the<br>interface's transmitter or DAC.<br>00 = 0 clocks<br>01 = 1 clock<br>10 = 2 clocks<br>11 = 3 clocks | R/W  | 00b     |
| 5     | RESERVED                                                                                                                                                                                                                                                                                                                                         | RO   | 0       |
| 4     | Interface 0 Horizontal Sync Polarity (HSYNC_POL_0)<br>1 = active high, 0 = active low                                                                                                                                                                                                                                                            | R/W  | 0b      |
| 3     | Interface 0 Vertical Sync Polarity (VSYNC_POL_0)<br>1 = active high, 0 = active low                                                                                                                                                                                                                                                              | R/W  | 0b      |
| 2     | RESERVED                                                                                                                                                                                                                                                                                                                                         | RO   | -       |
| 1     | RESERVED                                                                                                                                                                                                                                                                                                                                         | RO   | -       |
| 0     | <ul> <li>Interface 0 Select (INTF_SEL_0)<br/>When set, interface 0 is selected.</li> <li>When not selected, the blank output is active, the sync signals, output data<br/>and output clock are inactive.</li> <li>Note: This enable is not synchronized to any internal frame timing and<br/>changes are immediate.</li> </ul>                   | R/W  | Ob      |

**Note:** The values in this register should only be changed when the display controller is stopped as indicated by the Display Controller Status (DC\_STS) bit in the Display Status Register (DISPLAY\_STATUS).



# 10.5.14 Display Interface Control 1 Register (DISPLAY\_INTERFACE\_CTRL\_1)

Address:

044h

32 bits

Size:

This register is used to configure and control interface 1 of the Display Controller.

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                      | TYPE | DEFAULT |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:10 | RESERVED                                                                                                                                                                                                                                                                                                                                         | RO   | -       |
| 9     | RESERVED                                                                                                                                                                                                                                                                                                                                         | RO   | -       |
| 8     | RESERVED                                                                                                                                                                                                                                                                                                                                         | RO   | -       |
| 7:6   | Interface 1 Vertical and Horizontal Sync Output Delay<br>(V_H_SYNC_DELAY_1)<br>This field is used to specify a 0 to 3 clock delay on interface 1, vertical and<br>horizontal sync outputs. This may be used to match the data delay of the<br>interface's transmitter or DAC.<br>00 = 0 clocks<br>01 = 1 clock<br>10 = 2 clocks<br>11 = 3 clocks | R/W  | 00b     |
| 5     | RESERVED                                                                                                                                                                                                                                                                                                                                         | RO   | -       |
| 4     | Interface 1 Horizontal Sync Polarity (HSYNC_POL_1)<br>1 = active high, 0 = active low                                                                                                                                                                                                                                                            | R/W  | Ob      |
| 3     | Interface 1 Vertical Sync Polarity (VSYNC_POL_1)<br>1 = active high, 0 = active low                                                                                                                                                                                                                                                              | R/W  | 0b      |
| 2     | RESERVED                                                                                                                                                                                                                                                                                                                                         | RO   | -       |
| 1     | RESERVED                                                                                                                                                                                                                                                                                                                                         | RO   | Ob      |
| 0     | <ul> <li>Interface 1 Select (INTF_SEL_1)<br/>When set, interface 1 is selected.</li> <li>When not selected, the blank output is active, the sync signals, output data<br/>and output clock are inactive.</li> <li>Note: This enable is not synchronized to any internal frame timing and<br/>changes are immediate.</li> </ul>                   | R/W  | Ob      |

**Note:** The values in this register should only be changed when the display controller is stopped as indicated by the Display Controller Status (DC\_STS) bit in the Display Status Register (DISPLAY\_STATUS).



# 10.5.15 Display Interface Control 2 Register (DISPLAY\_INTERFACE\_CTRL\_2)

Address:

048h

Size:

32 bits

This register is used to configure and control interface 2 of the Display Controller.

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                    | TYPE | DEFAULT |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:10 | RESERVED                                                                                                                                                                                                                                                                                                                                                                       | RO   | -       |
| 9     | Interface 2 Double Data Rate Select (DDR_SEL_2)<br>When set, interface 2 supplies data at twice the clock rate. When cleared,<br>single data rate is selected.                                                                                                                                                                                                                 | R/W  | 0       |
| 8     | Interface 2 Double Data Rate Deep Color Enable (DDR_COLOR_2)<br>When set, interface 2 generates 15 bit DDR data. When cleared, 12 bit DDR<br>data is generated.                                                                                                                                                                                                                | R/W  | 0       |
| 7:6   | Interface 2 Vertical and Horizontal Sync Output Delay (V_H_SYNC_DELAY_2)                                                                                                                                                                                                                                                                                                       | R/W  | 00b     |
|       | This field is used to specify a 0 to 3 clock delay on interface 2, vertical and horizontal sync outputs. This may be used to match the data delay of the interface's transmitter or DAC.                                                                                                                                                                                       |      |         |
|       | 00 = 0 clocks<br>01 = 1 clock<br>10 = 2 clocks<br>11 = 3 clocks                                                                                                                                                                                                                                                                                                                |      |         |
| 5     | Interface 2 Output Clock Polarity (OUT_CLOCK_POL_2)<br>This bit inverts the clock for use with single rate data. It is a don't care for<br>double data rate mode. When cleared, the output pixel clock to interface 2<br>is edge aligned with the positive edge clocked data. When set, the output<br>pixel clock is inverted so that the rising edge is centered in the data. | R/W  | 1b      |
| 4     | Interface 2 Horizontal Sync Polarity (HSYNC_POL_2)<br>1 = active high, 0 = active low                                                                                                                                                                                                                                                                                          | R/W  | 0b      |
| 3     | Interface 2 Vertical Sync Polarity (VSYNC_POL_2)<br>1 = active high, 0 = active low                                                                                                                                                                                                                                                                                            | R/W  | 0b      |
| 2     | RESERVED                                                                                                                                                                                                                                                                                                                                                                       | RO   | -       |
| 1     | Interface 2 Blanking Polarity (BLANK_POL_2)<br>1 = active high, 0 = active low                                                                                                                                                                                                                                                                                                 | R/W  | Ob      |
| 0     | Interface 2 Select (INTF_SEL_2)<br>When set, interface 2 is selected.                                                                                                                                                                                                                                                                                                          | R/W  | 0b      |
|       | When not selected, the blank output is active, the sync signals, output data and output clock are inactive.                                                                                                                                                                                                                                                                    |      |         |
|       | <b>Note:</b> This enable is not synchronized to any internal frame timing and changes are immediate.                                                                                                                                                                                                                                                                           |      |         |



**Note:** The values in this register should only be changed when the display controller is stopped as indicated by the Display Controller Status (DC\_STS) bit in the Display Status Register (DISPLAY\_STATUS).



# 10.5.16 Display Cursor Control Register (DISPLAY\_CURSOR\_CTRL)

Address: 080h Size: 32 bits

This register is used to configure and control the Cursor.

This register is double buffered. Writes to it are performed into a holding register. The register value will be used following the vertical blank signal only after a write cycle to the Display Cursor Position Register (DISPLAY\_CURSOR\_POSITION) (setting Cursor Trigger Armed (CURSOR\_TRIG)). Double buffering is not used if the display controller is stopped as indicated by the Display Controller Status (DC\_STS) bit in the Display Status Register (DISPLAY\_STATUS), in which case writes to this register have immediate affect.

| BITS | DESCRIPTION                                                                                                                                                                                                               | TYPE | DEFAULT |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:7 | RESERVED                                                                                                                                                                                                                  | RO   | -       |
| 6:4  | Cursor Mode (CURSOR_MODE)<br>000 = 2 Color (Monochrome)<br>001 = 3 Color<br>010 = 4 Color<br>011 = RGB Color<br>100 = Masked RGB Color<br>others = reserved                                                               | R/W  | 000b    |
|      | See Table 10.3 for the descriptions of each mode.                                                                                                                                                                         |      |         |
|      | The current cursor mode in affect can be checked via Display Cursor Status Register (DISPLAY_CURSOR_STATUS).                                                                                                              |      |         |
|      | This value normally should not be changed when Cursor Trigger Armed (CURSOR_TRIG) in Display Cursor Status Register (DISPLAY_CURSOR_STATUS) is set.                                                                       |      |         |
| 3:1  | Cursor Size (CURSOR_SIZE)<br>000 = 32 x 32<br>001 = 48 x 48<br>010 = 64 x 64<br>others = reserved                                                                                                                         | R/W  | 000b    |
|      | The current cursor size in affect can be checked via Display Cursor Status Register (DISPLAY_CURSOR_STATUS).                                                                                                              |      |         |
|      | This value normally should not be changed when Cursor Trigger Armed (CURSOR_TRIG) in Display Cursor Status Register (DISPLAY_CURSOR_STATUS) is set.                                                                       |      |         |
| 0    | <b>Cursor Enable (CURSOR_ENABLE)</b><br>When set, the video sub-system will read from system memory and generate<br>a cursor image as specified.                                                                          | R/W  | 0b      |
|      | When cleared, the video sub-system will not read the cursor image from system memory nor display the cursor.                                                                                                              |      |         |
|      | When changed, the display controller will finish the current frame before enabling or disabling the cursor. The current cursor state in affect can be checked via Display Cursor Status Register (DISPLAY_CURSOR_STATUS). |      |         |
|      | This value normally should not be changed when Cursor Trigger Armed (CURSOR_TRIG) in Display Cursor Status Register (DISPLAY_CURSOR_STATUS) is set.                                                                       |      |         |



| CURSOR MODE          | DESCRIPTION                                                                                                                                                                                                                                        |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2 Color (Monochrome) | 2 bits per pixel<br>00 = Color 0<br>01 = Color 1<br>10 = Transparent (use frame data)<br>11 = Transparent Inverted (use inverted frame data)                                                                                                       |
| 3 Color              | 2 bits per pixel<br>00 = Color 0<br>01 = Color 1<br>10 = Color 2<br>11 = Transparent (use frame data)                                                                                                                                              |
| 4 Color              | 2 bits per pixel<br>00 = Color 0<br>01 = Color 1<br>10 = Color 2<br>11 = Color 3                                                                                                                                                                   |
| RGB Color            | 32 bits per pixel in ARGB format. The Alpha value is used to blend the cursor data<br>and the frame data using the formula Pixel = Alpha * cursor + (255 - Alpha) * frame<br>data<br>When in 8 bpp display color mode, only the Blue byte is used. |
|                      | When in 16 bpp display color mode, only the lower 5, 6, and 5 bits of Red, Blue and Green respectively are used.                                                                                                                                   |
| Masked RGB Color     | 32 bits per pixel in ARGB format. The Alpha value specifies:<br>0h = Opaque<br>1h - FEh = Transparent (use frame data)<br>FFh = XOR of RGB and frame data                                                                                          |
|                      | When in 8 bpp display color mode, only the Blue byte is used.<br>When in 16 bpp display color mode, only the lower 5, 6, and 5 bits of Red, Blue and<br>Green respectively are used.                                                               |

### Table 10.3 Cursor Modes

Note: All cursor colors are specified before color look / gamma correction.



# 10.5.17 Display Cursor Status Register (DISPLAY\_CURSOR\_STATUS)

084h

Address:

Size:

32 bits

This register indicates the cursor status.

| BITS | DESCRIPTION                                                                                                                            | TYPE | DEFAULT |
|------|----------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31   | <b>Cursor Trigger Armed (CURSOR_TRIG)</b><br>This bit returns the status of a pending cursor change.<br>1=Pending, 0=Not Pending.      | WC   | Ob      |
|      | A pending cursor change can be canceled by writing a one to this bit.                                                                  |      |         |
| 30:7 | RESERVED                                                                                                                               | RO   | -       |
| 6:4  | Cursor Current Mode (CURSOR_CUR_MODE)<br>This field indicates the current cursor mode.                                                 | RO   | 00b     |
| 3:1  | Cursor Current Size (CURSOR_CUR_SIZE)<br>This field indicates the current cursor size.                                                 | RO   | 000b    |
| 0    | <b>Cursor Status (CURSOR_STAT)</b><br>This field indicates the actual enabled/disabled status of the Cursor.<br>1=Enabled, 0=Disabled. | RO   | 0b      |



# 10.5.18 Display Cursor Base Address Register (DISPLAY\_CURSOR\_BASE\_ADDR)

Address: 088h Size: 32 bits

This register specifies the starting address in system memory of the cursor image.

This register is double buffered. Writes to it are performed into a holding register. The register value will be used following the vertical blank signal only after a write cycle to the Display Cursor Position Register (DISPLAY\_CURSOR\_POSITION) (setting Cursor Trigger Armed (CURSOR\_TRIG)). Double buffering is not used if the display controller is stopped as indicated by the Display Controller Status (DC\_STS) bit in the Display Status Register (DISPLAY\_STATUS), in which case writes to this register have immediate affect.

| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | TYPE | DEFAULT  |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:7 | Cursor Base Address Upper Bits (CURSOR_BASE_ADDR_HI)<br>When combined with the 7 read only bits below, this field specifies the<br>starting address, in system memory, of the cursor image, specified in bytes.<br>The current cursor base address in affect can be checked via Display Cursor<br>Current Base Address Register (DISPLAY_CURSOR_CUR_BASE_ADDR).<br>This value normally should not be changed when Cursor Trigger Armed<br>(CURSOR_TRIG) in Display Cursor Status Register<br>(DISPLAY_CURSOR_STATUS) is set. | R/W  | 0000000h |
| 6:0  | Cursor Base Address Lower Bits (CURSOR_BASE_ADDR_LO)<br>These are the lower 7 bits of the cursor image base address.                                                                                                                                                                                                                                                                                                                                                                                                         | RO   | 00h      |

Note: The base address is aligned on 128 byte boundaries.



# 10.5.19 Display Cursor Current Base Address Register (DISPLAY\_CURSOR\_CUR\_BASE\_ADDR)

Address: 08Ch Size: 32 bits

This register indicates the current cursor base address that is in affect.

| BITS | DESCRIPTION                                                                                                                         | TYPE | DEFAULT  |
|------|-------------------------------------------------------------------------------------------------------------------------------------|------|----------|
| 31:7 | Cursor Current Base Address Upper Bits<br>(CURSOR_CUR_BASE_ADDR_Hi)<br>This field indicates the current cursor base address.        | RO   | 0000000h |
| 6:0  | Cursor Current Base Address Lower Bits<br>(CURSOR_CUR_BASE_ADDR_LO)<br>These are the lower 7 bits of the cursor image base address. | RO   | 00h      |

Note: The base address is aligned on 128 byte boundaries.



## 10.5.20 Display Cursor Position Register (DISPLAY\_CURSOR\_POSITION)

Address: 090h Size:

32 bits

This register specifies the cursor position on the screen. This corresponds to the top left corner of the cursor image. The top-left of the screen is position 0,0. Cursor pixels outside the active screen are clipped. However, when using negative values, at least one pixel must be positioned on the active screen.

This register is double buffered. Writes to it are performed into a holding register. The register value will be used following the vertical blank signal. Writing this register sets Cursor Trigger Armed (CURSOR\_TRIG)). Double buffering is not used if the display controller is stopped as indicated by the Display Controller Status (DC\_STS) bit in the Display Status Register (DISPLAY\_STATUS), in which case writes to this register have immediate affect.

| BITS  | DESCRIPTION                                                                                                                                                                                                           | TYPE | DEFAULT |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:16 | Cursor Y Position (CURSOR_Y_POSITION)<br>This field specifies the Y coordinate of the cursor as a signed value.                                                                                                       | R/W  | 0000h   |
|       | The current cursor position in affect can be checked via Display Cursor Current Position Register (DISPLAY_CURSOR_CUR_POSITION).                                                                                      |      |         |
|       | This value can be changed when Cursor Trigger Armed (CURSOR_TRIG) in Display Cursor Status Register (DISPLAY_CURSOR_STATUS) is set. The new value will be used if the write happens before the vertical blank signal. |      |         |
| 15:0  | Cursor X Position (CURSOR_X_POSITION)<br>This field specifies the X coordinate of the cursor as a signed value.                                                                                                       | R/W  | 0000h   |
|       | The current cursor position in affect can be checked via Display Cursor Current Position Register (DISPLAY_CURSOR_CUR_POSITION).                                                                                      |      |         |
|       | This value can be changed when Cursor Trigger Armed (CURSOR_TRIG) in Display Cursor Status Register (DISPLAY_CURSOR_STATUS) is set. The new value will be used if the write happens before the vertical blank signal. |      |         |



# 10.5.21 Display Cursor Current Position Register (DISPLAY\_CURSOR\_CUR\_POSITION)

Address: 094h Size: 32 bits

This register indicates the current cursor position that is in affect.

| BITS  | DESCRIPTION                                                                                            | TYPE | DEFAULT |
|-------|--------------------------------------------------------------------------------------------------------|------|---------|
| 31:16 | Cursor Current Y Position (CURSOR_CUR_Y_POSITION)<br>This field indicates the current cursor position. | RO   | 0000h   |
| 15:0  | Cursor Current X Position (CURSOR_CUR_X_POSITION)<br>This field indicates the current cursor position. | RO   | 0000h   |



# 10.5.22 Display Cursor Color 0 Register (DISPLAY\_CURSOR\_COLOR\_0)

Address: 098h Size: 32 bits

This register specifies cursor color 0 when using a 2 bpp cursor mode.

This register is double buffered. Writes to it are performed into a holding register. The register value will be used following the vertical blank signal only after a write cycle to the Display Cursor Position Register (DISPLAY\_CURSOR\_POSITION) (setting Cursor Trigger Armed (CURSOR\_TRIG)). Double buffering is not used if the display controller is stopped as indicated by the Display Controller Status (DC\_STS) bit in the Display Status Register (DISPLAY\_STATUS), in which case writes to this register have immediate affect.

| BITS  | DESCRIPTION                                                                                                                                         | TYPE | DEFAULT |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:24 | RESERVED                                                                                                                                            | RO   | -       |
| 23:16 | Cursor Red (CURSOR_RED_0)<br>The red portion of cursor color 0.                                                                                     | R/W  | 00h     |
|       | The current cursor color in affect can be checked via Display Cursor Current Color 0 Register (DISPLAY_CURSOR_CUR_COLOR_0).                         |      |         |
|       | This value normally should not be changed when Cursor Trigger Armed (CURSOR_TRIG) in Display Cursor Status Register (DISPLAY_CURSOR_STATUS) is set. |      |         |
| 15:8  | Cursor Green (CURSOR_GREEN_0)<br>The green portion of cursor color 0.                                                                               | R/W  | 00h     |
|       | The current cursor color in affect can be checked via Display Cursor Current Color 0 Register (DISPLAY_CURSOR_CUR_COLOR_0).                         |      |         |
|       | This value normally should not be changed when Cursor Trigger Armed (CURSOR_TRIG) in Display Cursor Status Register (DISPLAY_CURSOR_STATUS) is set. |      |         |
| 7:0   | Cursor Blue (CURSOR_BLUE_0)<br>The blue portion of cursor color 0.                                                                                  | R/W  | 00h     |
|       | The current cursor color in affect can be checked via Display Cursor Current Color 0 Register (DISPLAY_CURSOR_CUR_COLOR_0).                         |      |         |
|       | This value normally should not be changed when Cursor Trigger Armed (CURSOR_TRIG) in Display Cursor Status Register (DISPLAY_CURSOR_STATUS) is set. |      |         |

**Note:** The cursor color is handled the same as any pixel data. In 16 bit mode, only the lowest 5 bits of Red, 6 bits of Green and 5 bits of blue are used. In 8 bit mode, only the blue field is used as either the index into the CLUT or as an 8 bit grey scale value. If gamma correction / color lookup is enabled, the values are mapped through the CLUT.



# 10.5.23 Display Cursor Current Color 0 Register (DISPLAY\_CURSOR\_CUR\_COLOR\_0)

Address: 09Ch Size: 32 bits

This register indicates the current cursor color 0 that is in affect.

| BITS  | DESCRIPTION                                                                                   | TYPE | DEFAULT |
|-------|-----------------------------------------------------------------------------------------------|------|---------|
| 31:24 | RESERVED                                                                                      | RO   | -       |
| 23:16 | Cursor Current Red (CURSOR_CUR_RED_0)<br>This field indicates the current cursor color 0.     | RO   | 00h     |
| 15:8  | Cursor Current Green (CURSOR_CUR_GREEN_0)<br>This field indicates the current cursor color 0. | RO   | 00h     |
| 7:0   | Cursor Current Blue (CURSOR_CUR_BLUE_0)<br>This field indicates the current cursor color 0.   | RO   | 00h     |



# 10.5.24 Display Cursor Color 1 Register (DISPLAY\_CURSOR\_COLOR\_1)

Address: 0A0h Size: 32 bits

This register specifies cursor color 1 when using a 2 bpp cursor mode.

This register is double buffered. Writes to it are performed into a holding register. The register value will be used following the vertical blank signal only after a write cycle to the Display Cursor Position Register (DISPLAY\_CURSOR\_POSITION) (setting Cursor Trigger Armed (CURSOR\_TRIG)). Double buffering is not used if the display controller is stopped as indicated by the Display Controller Status (DC\_STS) bit in the Display Status Register (DISPLAY\_STATUS), in which case writes to this register have immediate affect.

| BITS  | DESCRIPTION                                                                                                                                         | TYPE | DEFAULT |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:24 | RESERVED                                                                                                                                            | RO   | -       |
| 23:16 | Cursor Red (CURSOR_RED_1)<br>The red portion of cursor color 1.                                                                                     | R/W  | 00h     |
|       | The current cursor color in affect can be checked via Display Cursor Current Color 1 Register (DISPLAY_CURSOR_CUR_COLOR_1).                         |      |         |
|       | This value normally should not be changed when Cursor Trigger Armed (CURSOR_TRIG) in Display Cursor Status Register (DISPLAY_CURSOR_STATUS) is set. |      |         |
| 15:8  | Cursor Green (CURSOR_GREEN_1)<br>The green portion of cursor color 1.                                                                               | R/W  | 00h     |
|       | The current cursor color in affect can be checked via Display Cursor Current Color 1 Register (DISPLAY_CURSOR_CUR_COLOR_1).                         |      |         |
|       | This value normally should not be changed when Cursor Trigger Armed (CURSOR_TRIG) in Display Cursor Status Register (DISPLAY_CURSOR_STATUS) is set. |      |         |
| 7:0   | Cursor Blue (CURSOR_BLUE_1)<br>The blue portion of cursor color 1.                                                                                  | R/W  | 00h     |
|       | The current cursor color in affect can be checked via Display Cursor Current Color 1 Register (DISPLAY_CURSOR_CUR_COLOR_1).                         |      |         |
|       | This value normally should not be changed when Cursor Trigger Armed (CURSOR_TRIG) in Display Cursor Status Register (DISPLAY_CURSOR_STATUS) is set. |      |         |

**Note:** The cursor color is handled the same as any pixel data. In 16 bit mode, only the lowest 5 bits of Red, 6 bits of Green and 5 bits of blue are used. In 8 bit mode, only the blue field is used as either the index into the CLUT or as an 8 bit grey scale value. If gamma correction / color lookup is enabled, the values are mapped through the CLUT.



# 10.5.25 Display Cursor Current Color 1 Register (DISPLAY\_CURSOR\_CUR\_COLOR\_1)

Address: 0A4h Size: 32 bits

This register indicates the current cursor color 1 that is in affect.

| BITS  | DESCRIPTION                                                                                   | TYPE | DEFAULT |
|-------|-----------------------------------------------------------------------------------------------|------|---------|
| 31:24 | RESERVED                                                                                      | RO   | -       |
| 23:16 | Cursor Current Red (CURSOR_CUR_RED_1)<br>This field indicates the current cursor color 1.     | RO   | 00h     |
| 15:8  | Cursor Current Green (CURSOR_CUR_GREEN_1)<br>This field indicates the current cursor color 1. | RO   | 00h     |
| 7:0   | Cursor Current Blue (CURSOR_CUR_BLUE_1)<br>This field indicates the current cursor color 1.   | RO   | 00h     |



# 10.5.26 Display Cursor Color 2 Register (DISPLAY\_CURSOR\_COLOR\_2)

Address: 0A8h Size: 32 bits

This register specifies cursor color 2 when using a 2 bpp cursor mode.

This register is double buffered. Writes to it are performed into a holding register. The register value will be used following the vertical blank signal only after a write cycle to the Display Cursor Position Register (DISPLAY\_CURSOR\_POSITION) (setting Cursor Trigger Armed (CURSOR\_TRIG)). Double buffering is not used if the display controller is stopped as indicated by the Display Controller Status (DC\_STS) bit in the Display Status Register (DISPLAY\_STATUS), in which case writes to this register have immediate affect.

| BITS  | DESCRIPTION                                                                                                                                         | TYPE | DEFAULT |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:24 | RESERVED                                                                                                                                            | RO   | -       |
| 23:16 | Cursor Red (CURSOR_RED_2)<br>The red portion of cursor color 2.                                                                                     | R/W  | 00h     |
|       | The current cursor color in affect can be checked via Display Cursor Current Color 2 Register (DISPLAY_CURSOR_CUR_COLOR_2).                         |      |         |
|       | This value normally should not be changed when Cursor Trigger Armed (CURSOR_TRIG) in Display Cursor Status Register (DISPLAY_CURSOR_STATUS) is set. |      |         |
| 15:8  | Cursor Green (CURSOR_GREEN_2)<br>The green portion of cursor color 2.                                                                               | R/W  | 00h     |
|       | The current cursor color in affect can be checked via Display Cursor Current Color 2 Register (DISPLAY_CURSOR_CUR_COLOR_2).                         |      |         |
|       | This value normally should not be changed when Cursor Trigger Armed (CURSOR_TRIG) in Display Cursor Status Register (DISPLAY_CURSOR_STATUS) is set. |      |         |
| 7:0   | Cursor Blue (CURSOR_BLUE_2)<br>The blue portion of cursor color 2.                                                                                  | R/W  | 00h     |
|       | The current cursor color in affect can be checked via Display Cursor Current Color 2 Register (DISPLAY_CURSOR_CUR_COLOR_2).                         |      |         |
|       | This value normally should not be changed when Cursor Trigger Armed (CURSOR_TRIG) in Display Cursor Status Register (DISPLAY_CURSOR_STATUS) is set. |      |         |

**Note:** The cursor color is handled the same as any pixel data. In 16 bit mode, only the lowest 5 bits of Red, 6 bits of Green and 5 bits of blue are used. In 8 bit mode, only the blue field is used as either the index into the CLUT or as an 8 bit grey scale value. If gamma correction / color lookup is enabled, the values are mapped through the CLUT.



# 10.5.27 Display Cursor Current Color 2 Register (DISPLAY\_CURSOR\_CUR\_COLOR\_2)

Address: 0ACh Size: 32 bits

This register indicates the current cursor color 2 that is in affect.

| BITS  | DESCRIPTION                                                                                   | TYPE | DEFAULT |
|-------|-----------------------------------------------------------------------------------------------|------|---------|
| 31:24 | RESERVED                                                                                      | RO   | -       |
| 23:16 | Cursor Current Red (CURSOR_CUR_RED_2)<br>This field indicates the current cursor color 2.     | RO   | 00h     |
| 15:8  | Cursor Current Green (CURSOR_CUR_GREEN_2)<br>This field indicates the current cursor color 2. | RO   | 00h     |
| 7:0   | Cursor Current Blue (CURSOR_CUR_BLUE_2)<br>This field indicates the current cursor color 2.   | RO   | 00h     |



# 10.5.28 Display Cursor Color 3 Register (DISPLAY\_CURSOR\_COLOR\_3)

Address: 0B0h Size: 32 bits

This register specifies cursor color 3 when using a 2 bpp cursor mode.

This register is double buffered. Writes to it are performed into a holding register. The register value will be used following the vertical blank signal only after a write cycle to the Display Cursor Position Register (DISPLAY\_CURSOR\_POSITION) (setting Cursor Trigger Armed (CURSOR\_TRIG)). Double buffering is not used if the display controller is stopped as indicated by the Display Controller Status (DC\_STS) bit in the Display Status Register (DISPLAY\_STATUS), in which case writes to this register have immediate affect.

| BITS  | DESCRIPTION                                                                                                                                         | TYPE | DEFAULT |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:24 | RESERVED                                                                                                                                            | RO   | -       |
| 23:16 | Cursor Red (CURSOR_RED_3)<br>The red portion of cursor color 3.                                                                                     | R/W  | 00h     |
|       | The current cursor color in affect can be checked via Display Cursor Current Color 3 Register (DISPLAY_CURSOR_CUR_COLOR_3).                         |      |         |
|       | This value normally should not be changed when Cursor Trigger Armed (CURSOR_TRIG) in Display Cursor Status Register (DISPLAY_CURSOR_STATUS) is set. |      |         |
| 15:8  | Cursor Green (CURSOR_GREEN_3)<br>The green portion of cursor color 3.                                                                               | R/W  | 00h     |
|       | The current cursor color in affect can be checked via Display Cursor Current Color 3 Register (DISPLAY_CURSOR_CUR_COLOR_3).                         |      |         |
|       | This value normally should not be changed when Cursor Trigger Armed (CURSOR_TRIG) in Display Cursor Status Register (DISPLAY_CURSOR_STATUS) is set. |      |         |
| 7:0   | Cursor Blue (CURSOR_BLUE_3)<br>The blue portion of cursor color 3.                                                                                  | R/W  | 00h     |
|       | The current cursor color in affect can be checked via Display Cursor Current Color 3 Register (DISPLAY_CURSOR_CUR_COLOR_3).                         |      |         |
|       | This value normally should not be changed when Cursor Trigger Armed (CURSOR_TRIG) in Display Cursor Status Register (DISPLAY_CURSOR_STATUS) is set. |      |         |

**Note:** The cursor color is handled the same as any pixel data. In 16 bit mode, only the lowest 5 bits of Red, 6 bits of Green and 5 bits of blue are used. In 8 bit mode, only the blue field is used as either the index into the CLUT or as an 8 bit grey scale value. If gamma correction / color lookup is enabled, the values are mapped through the CLUT.



# 10.5.29 Display Cursor Current Color 3 Register (DISPLAY\_CURSOR\_CUR\_COLOR\_3)

Address: 0B4h Size: 32 bits

This register indicates the current cursor color 3 that is in affect.

| BITS  | DESCRIPTION                                                                                   | TYPE | DEFAULT |
|-------|-----------------------------------------------------------------------------------------------|------|---------|
| 31:24 | RESERVED                                                                                      | RO   | -       |
| 23:16 | Cursor Current Red (CURSOR_CUR_RED_3)<br>This field indicates the current cursor color 3.     | RO   | 00h     |
| 15:8  | Cursor Current Green (CURSOR_CUR_GREEN_3)<br>This field indicates the current cursor color 3. | RO   | 00h     |
| 7:0   | Cursor Current Blue (CURSOR_CUR_BLUE_3)<br>This field indicates the current cursor color 3.   | RO   | 00h     |



## 10.5.30 Display Color Lookup Table (DISPLAY\_CLUT)

```
Address: 400h-7FCh Size: 32 bits
```

This is a 256 entry table. Each entry contains 10 bit Red, Green and Blue values and is used to map incoming pixel data to a color. The table must be initialized by S/W if color lookup / gamma correction is enabled. In 8 bit color mode, an entry is selected as a 3 color set. In 16 and 24 bit modes, different entries are selected for each color. The pixel clock must be running in order to access this table.

| BITS  | DESCRIPTION                                                                    | TYPE | DEFAULT   |
|-------|--------------------------------------------------------------------------------|------|-----------|
| 31:30 | RESERVED                                                                       | RO   | -         |
| 29:20 | <b>CLUT Red (RED)</b><br>The red color level associated with this entry.       | R/W  | undefined |
| 19:10 | <b>CLUT Green (GREEN)</b><br>The green color level associated with this entry. | R/W  | undefined |
| 9:0   | <b>CLUT Blue (BLUE)</b><br>The blue color level associated with this entry.    | R/W  | undefined |



## 11.1 Overview

Ҏ รกรc

The Graphics Engine module receives a stream of commands, along with parameters and data, over the USB bulk out endpoint and executes the commands writing the results into the Display Frame Buffer. The various commands range from simple memory write access to various decompression algorithms. The bulk out endpoint interface is by way of a FIFO. The Graphics Engine module contains Control and Status Registers (CSRs) which are used to configure parameters and to indicate various status, such as error status, current command sequence number, etc. For a summary description of the Graphics Engine and the commands it processes, refer to Section 2.2, "Graphics Engine (GPH)," on page 18 in Chapter 2, Overview.



Figure 11.1 Graphics Engine Block Diagram



# 11.2 FIFO (FCT) Interface

The FIFO (FCT) interface is used to read data from the USB endpoint. The FCT interface is shared amongst the various co-processors under the control of the Command Parser.

Unless otherwise noted, all multiple byte data fields are considered to be little endian (LSB in the lower byte).

# 11.3 Command Parser

When enabled via the Graphics Engine Enable (GE\_ENABLE) bit in Graphic Engine Control Register (GE\_CTRL), the Command Parser reads the command and length from the FIFO, checks the command for errors and, based on the command, either handles the command or invokes one of the co-processors.

When a command and it's length need to be passed to a co-processor, the Command Parser selects and invokes the co-processor and waits for a completion signal. The Pixel to QWORD Converter will also be selected via the associated multiplexer, if required, to process the command.

The command format is as follows:

- DWORD Command
- DWORD Length

The command format for the PAD command is as follows:

DWORD Command

The Length field is the length of the following message, in bytes, not counting the Command or Length fields or any end-align padding. All commands are DWORD (4 bytes) aligned and are end padded if needed to maintain alignment of the next command. The Length field is excluded for the PAD command.

The Command field consists of 4 byte fields as follows:

- BYTE the specific command
- BYTE the 1's complement of the command
- WORD sequence number

## 11.3.1 Error Checking and Handling

As each command arrives, the Command Parser checks for a correct ones complement, for an incrementing sequence number and (as described below) a correct length. The ones complement and incrementing sequence number can each be enabled / disabled via the Graphics Engine Command Ones Complement Enable (GE\_CMD\_ONECOMP\_EN) and the Graphics Engine Command Sequence Number Enable (GE\_CMD\_SEQ\_EN) bits in Graphic Engine Control Register (GE\_CTRL). The current incrementing sequence number can be initialized via Graphics Engine Initial Command Sequence Number (GE\_INIT\_CMD\_SEQ\_NUM) and read via Graphics Engine Next Command Sequence Number (GE\_NEXT\_CMD\_SEQ\_NUM).

There are also command-specific checks that are handled by the various co-processors (e.g. that the drawing area fits within the current resolution).

If a command fails any of the checks or if any of the command co-processors (including the commands processed by the Command Parser) experience an error, the Bulk Out Endpoint is stalled, and the Graphics Engine is stopped. Any and all, co-processors are deselected. The error code is stored in the Graphics Engine Error Status (GE\_ERROR\_STAT) register. The Graphics Engine is restarted by the host using the Graphics Engine Restart (GE\_RESTART) bit in Graphic Engine Control Register (GE\_CTRL). The host may need to first flush the endpoint FIFO by setting the FCT RX FIFO Reset (FCT\_RX\_RESET) bit of the FIFO Status Register (FIFO\_STATUS).



# 11.3.2 Aborting Command

A command (including the commands processed by the Command Parser) maybe aborted by setting the Graphics Engine Abort (GE\_ABORT) bit in Graphic Engine Control Register (GE\_CTRL). The Bulk Out Endpoint is stalled, and the Graphics Engine is stopped. Any and all, co-processors are deselected. The Graphics Engine is restarted by the host using the Graphics Engine Restart (GE\_RESTART) bit in Graphic Engine Control Register (GE\_CTRL). The host may need to first flush the endpoint FIFO by setting the FCT RX FIFO Reset (FCT\_RX\_RESET) bit of the FIFO Status Register (FIFO\_STATUS).

## **11.3.3 Graphics Engine Commands**

The following command values are defined (the command specifics are defined with each coprocessor):

| • | DRAW_RAW_RECTANGLE    | 0x01 |
|---|-----------------------|------|
| • | DRAW_FILLED_RECTANGLE | 0x02 |
| • | ROP_RECTANGLE         | 0x03 |
| • | ROP_RAW_RECTANGLE     | 0x04 |
| • | DIRECT_RAM_WRITE      | 0x08 |
| • | WRITE_CSR             | 0x10 |
| • | NOP                   | 0x11 |
| • | WAIT_FOR_EVENT        | 0x12 |
| • | PAD                   | 0x13 |
| • | DECOMP_HEXTILE        | 0x20 |
| • | DECOMP_JPEG           | 0x30 |
| • | BYPASS_JPEG           | 0x31 |
| • | DECOMP_JPEG_LS        | 0x40 |
|   |                       |      |

## 11.3.4 Command Parser Implemented Commands

The following command are handled directly by the Command Parser:

NOP

|   | 31 | 30 | 29 | 28  | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15  | 14  | 13   | 12   | 2 1 | 1 1( | ) 9 | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|----|----|----|-----|-----|----|----|----|----|----|----|----|----|----|----|-----|-----|-----|------|------|-----|------|-----|-----|---|---|---|---|---|---|---|---|
| 0 |    |    |    |     |     |    |    |    |    |    |    |    |    |    | C  | omr | nar | nd  |      |      |     |      |     |     |   |   |   |   |   |   |   |   |
| 1 |    |    |    |     |     |    |    |    |    |    |    |    |    |    |    | len | gth |     |      |      |     |      |     |     |   |   |   |   |   |   |   |   |
| 2 |    |    | Ŗ  | bad | din | g  |    |    |    |    |    |    |    |    |    |     | nur | nbe | er o | of o | clo | cks  | to  | wai | t |   |   |   |   |   |   |   |

- Length = 3
- 3 BYTES the number of clocks to wait (0 = reserved).
- BYTE padding

As implied, this command does nothing other than to wait a specified amount of time. The amount of time is the number of clocks specified plus whatever minimum time the command takes to execute (i.e. if a setting of 1 takes n+1 clocks, a setting of 2 should take n+2 clocks, etc.)

Before waiting, the length field is checked for a correct value.



### WAIT\_FOR\_EVENT

|   | 31 30 29 28 27 26 25 24 | 23 22 21 20 19 18 17 16 | 15 14 13 12 11 10 9 8          | 7 6 5 | 4 3      | 2 1 | 0 |
|---|-------------------------|-------------------------|--------------------------------|-------|----------|-----|---|
| 0 |                         | com                     | mand                           |       |          |     |   |
| 1 |                         | len                     | gth                            |       |          |     |   |
| 2 | OR mask                 | AND mask                | edge / level select bit<br>map | inve  | rt bit m | nap |   |

- Length = 4
- BYTE invert bit map (1 = invert)
- BYTE edge / level select bit map (1 = edge, 0 = level)
- BYTE AND signal mask (1 = enabled into AND function, 0 = signal has no affect on AND)
- BYTE OR signal mask (1 = enabled into OR function, 0 = signal has no affect on OR)

This command waits for the event specified.

Before waiting, the length field is checked for a correct value.

Each of 8 inputs are optionally inverted, optionally edge detected and then optionally ANDed then optionally ORed.

The AND/OR logic allows any signals to be ANDed and then ORed. Only one AND term and one OR term are supported. For example sig\_0 AND sig\_1 OR sig\_2 is supported but sig\_0 AND sig\_1 OR sig\_2 AND sig\_3 is not. The OR mask works by blocking the signal going to the OR term replacing it with a low. The AND mask works by blocking the signal going to the AND term replacing it with a high. However, If no signals are selected to be ANDed the output of the AND term is forced to zero. Also, although supported, it doesn't make logic sense to specify a signal to be both ANDed and ORed. For example sig\_0 AND sig\_1 OR sig\_0 is redundant.



Figure 11.2 Command Parser Wait for Event Logic



The signal inputs are:

- 0 Display Controller->Display Status Register (DISPLAY\_STATUS)->Frame Base Address Pending Count (FRAME\_BASE\_ADDR\_PENDING\_CNT)> 0
- 1 Display Controller->Vertical Blank as specified by the Display Vertical Blank Register (DISPLAY\_V\_BLANK)
- 2 Graphics Engine->Graphic Engine Command Status Register (GE\_CMD\_STATUS)->Graphics Engine Write Master State (GE\_WR\_MASTER\_STATE)
- 3 Display Controller->Display Status Register (DISPLAY\_STATUS)->Frame Base Address Queue Full (FRAME\_BASE\_ADDR\_QUEUE\_FULL)
- 4 Display Controller->Display Cursor Status Register (DISPLAY\_CURSOR\_STATUS))->Cursor Status (CURSOR\_STAT)
- 5 Display Controller->Display Cursor Status Register (DISPLAY\_CURSOR\_STATUS)->Cursor Trigger Armed (CURSOR\_TRIG)
- 6 Reserved
- 7 Reserved

#### WRITE\_CSR

|   | 31       30       29       28       27       26       25       24       23       22       21       20       19       18       17       16       15       14       13       12       11       10       9       8       7       6       5       4       3       2       1       0 |
|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | command                                                                                                                                                                                                                                                                         |
| 1 | length                                                                                                                                                                                                                                                                          |
| 2 | CSR byte address                                                                                                                                                                                                                                                                |
| 3 | CSR data                                                                                                                                                                                                                                                                        |

- Length = 8
- DWORD CSR byte address
- DWORD CSR data

This command writes the data to the addressed CSR.

Before writing, the length field is checked for a correct value.

PAD

|   | 3 | 1 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| C |   |      |    |    |    |    |    |    |    |    |    |    |    |    | СС | omr | nar | nd |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

This command is used to align subsequent commands to any DWORD boundary, if needed by the driver. Other than ones complement and sequence number checking, this command has no other affect.

# 11.4 Direct RAM Write Co-processor

The Direct RAM Write Co-processor takes a block of data with a starting address and writes the data into the Display Frame Buffer.



### DIRECT\_RAM\_WRITE

|          | 31 | 1 30 | ) 2 | 9 | 28 | 27 | 20 | 6 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17   | 16  | 15  | 14  | 13  | 3 1 | 2 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|----|------|-----|---|----|----|----|---|----|----|----|----|----|----|----|------|------|-----|-----|-----|-----|-----|---|----|----|---|---|---|---|---|---|---|---|---|---|
| 0        |    |      |     |   |    |    |    |   |    |    |    |    |    |    |    |      | С    | omi | nai | nd  |     |     |   |    |    |   |   |   |   |   |   |   |   |   |   |
| 1        |    |      |     |   |    |    |    |   |    |    |    |    |    |    |    |      |      | len | gth |     |     |     |   |    |    |   |   |   |   |   |   |   |   |   |   |
| 2        |    |      |     |   |    |    |    |   |    |    |    |    |    |    | S  | tart | ing  | by  | te  | add | Ire | ss  |   |    |    |   |   |   |   |   |   |   |   |   |   |
| 3        |    |      |     |   |    |    |    |   |    |    |    |    |    |    |    |      |      |     |     |     |     |     |   |    |    |   |   |   |   |   |   |   |   |   |   |
| 4        |    |      |     |   |    |    |    |   |    |    |    |    |    |    | da | ata  | arra | ay  | (se | e b | elc | w   | ) |    |    |   |   |   |   |   |   |   |   |   |   |
| 5<br>eto |    |      |     |   |    |    |    |   |    |    |    |    |    |    |    |      |      |     |     |     |     |     |   |    |    |   |   |   |   |   |   |   |   |   |   |

- Length = 4 + the number of bytes to be written + the number of pre-padding bytes (it does not count the number of post padding bytes)
- DWORD starting byte address
- DWORD first DWORD or pre-padding
- DWORD second DWORD or pre-padding
- DWORD third DWORD, etc.

All data is assumed QWORD byte lane aligned when it is read from the FCT. Pre-padding is performed by the host. Therefore no byte shifting is required. Up to 7 pre-pad bytes may exist. The command length will include these but the starting address prevents them from being written. The maximum number of post padding bytes is 3 and is used in order to maintain DWORD alignment of the next command. If the data ends on (or within) the first DWORD of a QWORD, there will not be a matching upper DWORD of 4 pad bytes.

## 11.4.1 Error Checking and Handling

Before writing into the Display Frame Buffer, the length field is checked for a correct value. It should be at least five plus the 3 lsbs of the starting address. For example, if the starting address is 0x12345673, there are 3 pre-pad bytes. Along with the 4 address bytes and at least one real; data byte, there should be at least 8 bytes.

In the event of an command error or an internal bus error, the command is aborted and an error result is returned to the Command Parser. The Direct RAM Write Co-processor then waits until it is deselected by the Command Parser.

### 11.4.1.1 Error Codes

The following command specific error codes are indicated in the Graphics Engine Error Type (GE\_ERROR\_TYPE) field in the Graphics Engine Command State (GE\_CMD\_STATE) register.

1 - Length field error

## 11.4.2 Aborting Command

In the event that the Direct RAM Write Co-processor is deselected by the Command Parser before the command is completed, the Co-processor will abort the current command and return to idle.

# 11.5 BLT Co-processor

The Block Transfer (BLT) Co-processor operates on un-compressed rectangle data and supports commands such as rectangle drawing and block copying. The BLT block takes source data (either a constant value or data from the USB endpoint or pixels from the display frame buffer) and uses it to



create pixel data which is written into the display frame buffer. Logical operations maybe performed on pixels read from the display frame buffer. The resulting rectangle is either filled solid (DRAW\_FILLED\_RECTANGLE), colored with the USB data (DRAW\_RAW\_RECTANGLE), a logic operation of the source rectangle and the USB constant (ROP\_RECTANGLE) or a logic operation of the source rectangle and the USB data (ROP\_RAW\_RECTANGLE). Basic rectangle copy is supported via ROP\_RECTANGLE. All commands support 8, 16 and 24 bpp modes, specified within the command. The destination and source frame base addresses as well as the horizontal and vertical resolutions are also specified within the command as required.

- **Note:** The horizontal resolution must be a multiple of 8 while using 24bpp or 16bpp with up-converting modes.
- **Note:** ROP\_RECTANGLE and ROP\_RAW\_RECTANGLE are limited to a maximum width of 2048 pixels.

| Γ | 3 | 31 3 | 30 | 29 | 2 | 8 27 | 7 20 | 6 | 25 | 24 | 23   | 22   | 21  | 20    | 19 | 18 | 17   | 16  | 15        | 14  | 13       | 12 | 11 | 10 | 9 | 8    | 7   | 6    | 5   | 4    | 3    | 2  | 1 | 0 |
|---|---|------|----|----|---|------|------|---|----|----|------|------|-----|-------|----|----|------|-----|-----------|-----|----------|----|----|----|---|------|-----|------|-----|------|------|----|---|---|
| 0 |   |      |    |    |   |      |      |   |    | 1  |      |      |     |       |    |    | С    | omr | mar       | nd  |          |    |    | 1  |   |      | 1   |      |     |      |      |    |   |   |
| 1 |   |      |    |    |   |      |      |   |    |    |      |      |     |       |    |    |      | len | gth       |     |          |    |    |    |   |      |     |      |     |      |      |    |   |   |
| 2 |   | u    | nu | se | d |      |      |   |    |    | up   | per  | lef | ft Y  |    |    |      |     | ι         | inu | sec      | ł  |    |    |   |      | up  | per  | lef | ťΧ   |      |    |   |   |
| 3 |   | u    | nu | se | d |      |      |   |    |    |      | hei  | ght | t     |    |    |      |     | ι         | inu | sec      | ł  |    |    |   |      |     | wi   | dth |      |      |    |   |   |
| 4 |   |      |    |    |   |      |      |   |    |    |      | fra  | me  | e ba  | se | ac | ldre | ess |           |     |          |    | 1  |    |   |      |     |      |     | ur   | nus  | ed |   |   |
| 5 |   | u    | nu | se | d |      |      |   |    | ve | rtic | al r | esc | oluti | on |    |      |     | col<br>mo | -   | uı<br>us |    |    |    | l | nori | zoi | ntal | res | solu | ıtio | n  |   |   |
| 6 |   |      |    |    |   |      |      |   |    |    |      |      |     |       |    | со | lor  | (se | e b       | elo | w)       |    | 1  |    |   |      |     |      |     |      |      |    |   |   |

### DRAW\_FILLED\_RECTANGLE

color mode = 24bpp

| 6 | unused | Red | Green | Blue |
|---|--------|-----|-------|------|
|   |        |     |       |      |

color mode = 16bpp

| 6 | unused | unused | Red | Green | Blue |
|---|--------|--------|-----|-------|------|
|---|--------|--------|-----|-------|------|

color mode = 8bpp

| 6 | unused | unused | unused | color |
|---|--------|--------|--------|-------|
|---|--------|--------|--------|-------|

- Length = 20
- WORD bits 15:12 unused / bits 11:0 upper left X (top left of frame is 0)
- WORD bits 15:12 unused / bits 11:0 upper left Y (top left of frame is 0)
- WORD bits 15:12 unused / bits 11:0 width
- WORD bits 15:12 unused / bits 11:0 height
- DWORD bits 31:7 frame base address in 128 byte increments / bits 6:0 unused
- WORD bits 15:14 color mode (11 = 16bpp with up-converting, 10 = 24bpp, 01 = 16bpp, 00 = 8bpp) / bits 13:12 unused / bits 11:0 horizontal resolution



**Note:**The horizontal resolution must be a multiple of 8 while using 24bpp or 16bpp with upconverting modes.

- WORD bits 15:12 unused / bits 11:0 vertical resolution
- The color DWORD is formatted depending on the color mode as follows: 24bpp: DWORD - 1 byte unused / 1 byte = Red / 1 byte = Green / 1 byte = Blue 16bpp: DWORD - 2 bytes unused / 2 bytes = RGB in 565 format 8bpp: DWORD - 3 bytes unused / 1 byte = color

#### DRAW\_RAW\_RECTANGLE

|          | 31  | 30  | 2  | 9 28 | 3 27 | 26 | 25 | 5 24 | 23    | 2  | 2 21   | 20    | 19 | 18 | 8 17 | 16   | 15       | 14  | 13       | 12   | 11 | 10 | 9 | 8    | 7   | 6    | 5   | 4   | 3    | 2  | 1 | 0 |
|----------|-----|-----|----|------|------|----|----|------|-------|----|--------|-------|----|----|------|------|----------|-----|----------|------|----|----|---|------|-----|------|-----|-----|------|----|---|---|
| 0        |     |     |    |      |      |    |    |      |       |    |        |       |    |    | C    | omr  | nar      | nd  |          |      |    |    |   |      |     |      |     |     |      |    |   |   |
| 1        |     |     |    |      |      |    |    |      |       |    |        |       |    |    |      | len  | gth      |     |          |      |    |    |   |      |     |      |     |     |      |    |   |   |
| 2        |     | unu | se | ed   |      |    |    |      | up    | pe | er lef | ťΥ    |    |    |      |      | ι        | ınu | sec      | ł    |    |    |   |      | up  | per  | lef | ťХ  | (    |    |   |   |
| 3        | dir | ur  | าน | sed  |      |    |    |      |       | he | eight  |       |    |    |      |      | lo       | gic | ор       | er   |    |    |   |      |     | wi   | dth |     |      |    |   |   |
| 4        |     |     |    |      |      |    |    |      |       | fr | rame   | e ba  | se | а  | ddre | ess  |          |     |          |      |    |    |   |      |     |      |     | u   | nus  | ed |   |   |
| 5        |     | unu | se | ed   |      |    |    | ve   | rtica | al | resc   | oluti | on |    |      |      | co<br>mc | -   | ur<br>us |      |    |    | ł | nori | zor | ntal | res | sol | utio | n  |   |   |
| 6        |     |     |    |      |      |    |    |      |       |    |        |       |    |    |      |      |          |     |          |      |    |    |   |      |     |      |     |     |      |    |   |   |
| 7        |     |     |    |      |      |    |    |      |       |    |        | pac   | ke | d  | pixe | l ar | ray      | (se | e l      | oelo | SW | )  |   |      |     |      |     |     |      |    |   |   |
| 8<br>etc |     |     |    |      |      |    |    |      |       |    |        |       |    |    |      |      |          |     |          |      |    |    |   |      |     |      |     |     |      |    |   |   |

- Length = 16 plus length of pixel color data (including padding) (width x BPP + row padding) x height)
- WORD bits 15:12 unused / bits 11:0 upper left X (top left of frame is 0)
- WORD bits 15:12 unused / bits 11:0 upper left Y (top left of frame is 0)
- WORD bits 15:12 logic operation / bits 11:0 width
- WORD bit 15 drawing direction (0=top down, 1=bottom up) / bits 14:12 unused / bits 11:0 height
- DWORD bits 31:7 frame base address in 128 byte increments / bits 6:0 unused
- WORD bits 15:14 color mode (11 = 16bpp with up-converting, 10 = 24bpp, 01 = 16bpp, 00 = 8bpp) / bits 13:12 unused / bits 11:0 horizontal resolution

**Note:**The horizontal resolution must be a multiple of 8 while using 24bpp or 16bpp with upconverting modes.

- WORD bits 15:12 unused / bits 11:0 vertical resolution
- The packed pixel array consists of one of more rows of pixels and is formatted depending on the color mode as follows:

24bpp: 3 BYTES per pixel padded to DWORD at end of each row 16bpp: 2 BYTES per pixel padded to DWORD at end of each row 8bpp: 1 BYTE per pixel padded to DWORD at end of each row



### **ROP\_RECTANGLE**

|   | 3 | 51 <b>3</b> 0 | 29                                                                 | 2 | 8 27 | 26 | 25 | 5 24 | 23    | 22   | 21   | 20    | 19   | 18 | 8 17 | 16  | 15  | 14   | 13  | 12 | 11 | 10   | 9  | 8   | 7    | 6   | 5    | 4     | 3    |      | 2 1 | 0 |
|---|---|---------------|--------------------------------------------------------------------|---|------|----|----|------|-------|------|------|-------|------|----|------|-----|-----|------|-----|----|----|------|----|-----|------|-----|------|-------|------|------|-----|---|
| 0 |   |               |                                                                    |   |      |    |    |      |       |      |      | 1     |      |    | С    | omr | ma  | nd   |     |    |    |      |    |     |      |     |      |       |      |      |     |   |
| 1 |   |               |                                                                    |   |      |    |    |      |       |      |      |       |      |    |      | len | gth | 1    |     |    |    |      |    |     |      |     |      |       |      |      |     |   |
| 2 |   | unı           | ise                                                                | d |      |    | de | esti | nati  | on   | upp  | ber   | left | Y  |      |     | I   | unu  | ise | d  |    |      | de | sti | nat  | ion | up   | pei   | · le | ft 2 | X   |   |
| 3 |   | unı           |                                                                    |   |      |    |    |      |       |      |      |       |      |    |      |     |     |      |     |    | w  | idth |    |     |      |     |      |       |      |      |     |   |
| 4 |   |               | destination frame base address       nused     vertical resolution |   |      |    |    |      |       |      |      |       |      |    |      |     |     | u    | nu  | se | t  |      |    |     |      |     |      |       |      |      |     |   |
| 5 |   | unı           | ise                                                                | d |      |    |    | ve   | ertic | al r | esc  | oluti | ion  |    |      |     |     |      | -   |    |    |      | ł  | nor | izo  | nta | l re | sol   | utio | on   |     |   |
| 6 |   | unu           | ise                                                                | d |      |    |    | sol  | urce  | e up | pe   | r le  | ft Y | ,  |      |     | I   | unu  | ise | d  |    |      |    | sol | urce | e u | рре  | er le | əft  | Х    |     |   |
| 7 |   |               |                                                                    |   |      |    |    |      | SO    | urce | e fr | am    | e b  | as | e a  | ddr | ess | ;    |     |    |    |      |    |     |      |     |      | u     | nu   | se   | b   |   |
| 8 |   |               |                                                                    |   |      |    |    |      |       |      |      |       |      | СС | olor | (se | e t | pelo | w)  |    |    |      |    |     |      |     |      |       |      |      |     |   |

color mode = 24bpp

| 8 | unused | Red | Green | Blue |
|---|--------|-----|-------|------|
|---|--------|-----|-------|------|

color mode = 16bpp

| 8 | unused | unused | Red | Green | Blue |
|---|--------|--------|-----|-------|------|
|---|--------|--------|-----|-------|------|

color mode = 8bpp

| 8 |
|---|
|---|

- Length = 28
- WORD bits 15:12 unused / bits 11:0 destination upper left X (top left of frame is 0)
- WORD bits 15:12 unused / bits 11:0 destination upper left Y (top left of frame is 0)
- WORD bits 15:12 logic operation / bits 11:0 width (the maximum width supported is 2048 pixels)
- WORD bits 15:12 unused / bits 11:0 height
- DWORD bits 31:7 destination frame base address in 128 byte increments / bits 6:0 unused
- WORD bits 15:14 color mode (11 = 16bpp with up-converting, 10 = 24bpp, 01 = 16bpp, 00 = 8bpp) / bits 13:12 unused / bits 11:0 horizontal resolution

**Note:**The horizontal resolution must be a multiple of 8 while using 24bpp or 16bpp with upconverting modes.

- WORD bits 15:12 unused / bits 11:0 vertical resolution
- WORD bits 15:12 unused / bits 11:0 source upper left X (top left of frame is 0)
- WORD bits 15:12 unused / bits 11:0 source upper left Y (top left of frame is 0)
- DWORD bits 31:7 source frame base address in 128 byte increments / bits 6:0 unused
- The color DWORD is formatted depending on the color mode as follows:
   24bpp: DWORD 1 byte unused / 1 byte = Red / 1 byte = Green / 1 byte = Blue
   16bpp: DWORD 2 bytes unused / 2 bytes = RGB in 565 format

8bpp: DWORD - 3 bytes unused / 1 byte = color



### **ROP\_RAW\_RECTANGLE**

|          | 3                                                      | 1 30                                        | 29  | 2 | 8 27 | 26 | 25 | 24  | 23   | 22   | 2  | 1 20  | 19    | 1   | 8 17  | 16               | 15  | 14   | 13  | 3 1 2 | 2 1 | 11 | 10 | 9 | 8   | 7   | 6   | Ę  | 5  | 4    | 3    | 2 | 1 | 0 |
|----------|--------------------------------------------------------|---------------------------------------------|-----|---|------|----|----|-----|------|------|----|-------|-------|-----|-------|------------------|-----|------|-----|-------|-----|----|----|---|-----|-----|-----|----|----|------|------|---|---|---|
| 0        |                                                        |                                             |     |   |      |    |    |     |      |      |    |       |       |     | C     | omi              | na  | nd   |     |       |     |    |    |   |     |     |     |    |    |      |      |   |   |   |
| 1        |                                                        |                                             |     |   |      |    |    |     |      |      |    |       |       |     |       | len              | gth | 1    |     |       |     |    |    |   |     |     |     |    |    |      |      |   |   |   |
| 2        |                                                        | unused destination upper left Y unused dest |     |   |      |    |    |     |      |      |    |       |       | sti | nat   | ion upper left X |     |      |     |       |     |    |    |   |     |     |     |    |    |      |      |   |   |   |
| 3        | log<br>ic<br>op<br>unused er height logic oper         |                                             |     |   |      |    |    |     |      |      |    |       |       |     | width |                  |     |      |     |       |     |    |    |   |     |     |     |    |    |      |      |   |   |   |
| 4        | destination frame base address                         |                                             |     |   |      |    |    |     |      |      |    |       |       |     |       | unused           |     |      |     |       |     |    |    |   |     |     |     |    |    |      |      |   |   |   |
| 5        | 5 unused vertical resolution color un-<br>mode used ho |                                             |     |   |      |    |    |     |      |      |    |       |       | nor | izo   | ntal resolution  |     |      |     |       |     |    |    |   |     |     |     |    |    |      |      |   |   |   |
| 6        |                                                        | unu                                         | sec | b |      |    |    | SOI | urce | e up | эр | er le | eft Y | ٢   |       |                  | 1   | uni  | Jse | d     |     |    |    |   | sol | urc | e u | pp | er | r le | ft ) | < |   |   |
| 7        | 7 source frame base address                            |                                             |     |   |      |    |    |     |      |      |    |       |       |     |       | unused           |     |      |     |       |     |    |    |   |     |     |     |    |    |      |      |   |   |   |
| 6        |                                                        |                                             |     |   |      |    |    |     |      |      |    |       |       |     |       |                  |     |      |     |       |     |    |    |   |     |     |     |    |    |      |      |   |   |   |
| 7        |                                                        |                                             |     |   |      |    |    |     |      |      |    | pa    | cke   | d   | pixe  | l ar             | ray | ' (s | ee  | be    | lo  | w) |    |   |     |     |     |    |    |      |      |   |   |   |
| 8<br>etc | ;                                                      |                                             |     |   |      |    |    |     |      |      |    |       |       |     |       |                  |     |      |     |       |     |    |    |   |     |     |     |    |    |      |      |   |   |   |

- Length = 24 plus length of pixel color data (including padding) (width x BPP + row padding) x height)
- WORD bits 15:12 unused / bits 11:0 destination upper left X (top left of frame is 0)
- WORD bits 15:12 unused / bits 11:0 destination upper left Y (top left of frame is 0)
- WORD bits 15:12 logic operation[3:0] / bits 11:0 width (the maximum width supported is 2048 pixels)
- WORD bits 15:13 unused / bit 12 logic operation[4] / bits 11:0 height
- DWORD bits 31:7 destination frame base address in 128 byte increments / bits 6:0 unused
- WORD bits 15:14 color mode (11 = 16bpp with up-converting, 10 = 24bpp, 01 = 16bpp, 00 = 8bpp) / bits 13:12 unused / bits 11:0 horizontal resolution

**Note:**The horizontal resolution must be a multiple of 8 while using 24bpp or 16bpp with upconverting modes.

- WORD bits 15:12 unused / bits 11:0 vertical resolution
- WORD bits 15:12 unused / bits 11:0 source upper left X (top left of frame is 0)
- WORD bits 15:12 unused / bits 11:0 source upper left Y (top left of frame is 0)
- DWORD bits 31:7 source frame base address in 128 byte increments / bits 6:0 unused
- The packed pixel array consists of one of more rows of pixels and is formatted depending on the color mode as follows:
   24bpp: 3 BYTES per pixel padded to DWORD at end of each row
   16bpp: 2 BYTES per pixel padded to DWORD at end of each row

8bpp: 1 BYTE per pixel padded to DWORD at end of each row



# 11.5.1 Error Checking and Handling

Before any pixels are drawn, error checking is performed.

The bottom right corner of the destination rectangle must be within the bounds of the frame. (Upper left X plus width must be less than or equal to the horizontal resolution. Upper left Y plus height must be less than or equal to the vertical resolution.) Note that this also checks that the top left corner is within bounds.

For the ROP\_RECTANGLE and ROP\_RAW\_RECTANGLE commands, the bottom right corner of the source rectangle must be within the bounds of the frame. (Source upper left X plus width must be less than or equal to the horizontal resolution. Source upper left Y plus height must be less than or equal to the vertical resolution.) Note that this also checks that the source top left corner is within bounds.

The height and width are checked for non-zero values. For the ROP\_RECTANGLE and ROP\_RAW\_RECTANGLE commands, the width is also checked for a maximum size of 2048 pixels.

The color mode is checked for a non-supported value.

The length field is checked for a correct value. For the DRAW\_FILLED\_RECTANGLE and ROP\_RECTANGLE commands, the length should be an exact match. For the DRAW\_RAW\_RECTANGLE and the ROP\_RAW\_RECTANGLE commands, the length should be at least the fixed portion (16 and 24 respectively) plus 4 (one pixel / pad).

Once the above checks have passed, length checking is done as the command is processed.

The co-processor will not read more data than indicated by the length field. An error is indicated if data runs out before the command is finished (the rectangle drawing reached the end X/Y coordinates).

Once the end X/Y coordinates are reached, there should not be any remaining data to be processed. The residual length should be zero. Note that in the event that the length field value is too large, it will be caught as an error. Also, the next command will most likely be caught as an error as well.

In the event of an command error or an error on the internal data path, the command is aborted and an error result is returned to the Command Parser. The BLT Co-processor then waits until it is deselected by the Command Parser.

### 11.5.1.1 Error Codes

The following command specific error codes are indicated in the Graphics Engine Error Type (GE\_ERROR\_TYPE) field in the Graphics Engine Command State (GE\_CMD\_STATE) register.

- 1 Length field error
- 2 Message length too short (ran out of data before command finished)
- 3 Message length too long (residual data length not zero or pre-fetch FIFOs not empty)
- 4 The color mode specified is not supported by the command
- 5 The height or width was set to zero or (for ROP\_RECTANGLE and ROP\_RAW\_RECTANGLE) the width was greater than 2048
- 6 Some or all of the destination is outside the frame buffer
- 7 Some or all of the source is outside the frame buffer

## 11.5.2 Aborting Command

In the event that the BLT Co-processor is deselected by the Command Parser before the command is completed, the Co-processor will abort the current command and return to idle.



## 11.5.3 Writing to Display Frame Buffer

As each pixel is created, it is written to an internal Pixel to QWORD Converter. The Pixel to QWORD Converter handles all issues associated with the display frame buffer access to permit this module to operate at the pixel level. The Pixel to QWORD Converter is given the color mode, horizontal resolution and frame base address, that was specified in the command. Based on the color mode, the appropriate number and combination of bits from the drawn pixel are selected. Based on the X and Y coordinates, horizontal resolution, color mode and frame base address, the correct memory address is calculated.

16bpp with up-converting mode is handle by the Pixel to QWORD Converter and the Pixel Retriever. The Pixel to QWORD Converter will convert the 16 bits of color (in 565 format) to 24 bits by right padding each color component as needed. The Pixel Retriever will convert the 24 bits of color from the display buffer to 16 bits by stripping off right bits as needed. Note that this will result in a loss of color resolution for operations such as a copy.

## 11.5.4 DRAW\_FILLED\_RECTANGLE

This command generates a solid filled rectangle. Pixels and their colors are generated from left to right and from top to bottom.

The color data within the command is a single DWORD which is interpreted based on the color mode, However this block needs just to pass 24 bits to the Pixel to QWORD Converter, which will select the appropriate bits.

This command operates at approximately one clock per pixel, assuming sufficient system memory bandwidth.

## 11.5.5 DRAW\_RAW\_RECTANGLE

This command generates a colored rectangle. Pixels and their colors are generated from left to right and either top to bottom or bottom to top. The drawing direction bit specifies if the rectangle is to be drawn top down or bottom up. In both cases, the rectangle is drawn left to right and the starting pixel parameter refers to the upper left corner of the rectangle.

The color data contained in the command consists of an array of pixels colors per row. The array is 1, 2 or 3 bytes (8, 16 or 24 bpp) and is padded at the end of each row to a DWORD boundary. Since the FCT interface is always read as DWORDs, each pixel must be extracted with any left over byte(s) used for the next pixel. In 8bpp mode, the lowest 8 bits represent the left most pixel. In 16bpp mode, the lowest 16 bits represent the left most pixel and the bit positions match the format in the display frame buffer. In 24bpp mode, three bytes are used per pixel, the lowest byte is the blue value, the middle byte is the green value and the left most byte is the red value, all matching the format in the display frame buffer. In 24bpp mode, a pixel might be split across two DWORDs.

The order of the row data matches the vertical direction specified in the command.

This command operates at approximately one clock per pixel, assuming sufficient USB and system memory bandwidth.



#### 11.5.5.1 Logic Operations

The logic operations supported are as follows. C is the color from the command.

| op<br>code | operation                                 |
|------------|-------------------------------------------|
| 0x0        | C (unconditional draw)                    |
| 0x1        | C if C is in-range (conditional draw)     |
| 0x2        | C if C is out-of-range (conditional draw) |
| 0x3-0xF    | reserved                                  |

Included in the logic operations is a conditional copy. Each pixel from the command data is compared to the chroma key value (Graphic Engine Chroma Key High Register (GE\_CHROMA\_KEY\_HIGH), Graphic Engine Chroma Key Low Register (GE\_CHROMA\_KEY\_LOW)) and checked if it is in-range or out-of-range. Depending on the logic operation specified (in-range or out-of-range), the pixel source pixel is conditionally written to the destination memory. The range checking is done for each color component of the source pixel and the results ANDed. A component can be disabled by setting the low value to 0 and the high value to 255. 16 bpp mode uses 5 bits of red and blue and 6 bits of green. 8 bpp mode uses only the blue value.

## 11.5.6 ROP\_RECTANGLE

This command reads a source rectangle, optionally performs a logic operation with the pixel data specified in the command and writes the rectangle into the display frame buffer. The source and destination can be the same, overlapping or independent areas. Different source and destination frame base addresses can be specified.

Maximum width is 2048 pixels. Top down or bottom up drawing is chosen based on the starting Y location of the source and destination.

#### 11.5.6.1 Logic Operations

The logic operations supported are as follows. S is the source rectangle and C is the constant color from the command.

| op<br>code | operation                                                                                                                    |
|------------|------------------------------------------------------------------------------------------------------------------------------|
| 0x0        | S (unconditional copy) - note that the command pixel data (C) is ignored but still present in the command                    |
| 0x1        | S if S is in-range (conditional copy) - note that the command pixel data (C) is ignored but still present in the command     |
| 0x2        | S if S is out-of-range (conditional copy) - note that the command pixel data (C) is ignored but still present in the command |
| 0x3-0x5    | reserved                                                                                                                     |
| 0x6        | C XOR S                                                                                                                      |
| 0x7        | C XNOR S                                                                                                                     |
| 0x8        | C AND S                                                                                                                      |
| 0x9        | ~C AND S                                                                                                                     |



| 0xA | C AND ~S  |
|-----|-----------|
| 0xB | ~C AND ~S |
| 0xC | C OR S    |
| 0xD | ~C OR S   |
| 0xE | C OR ~S   |
| 0xF | ~C OR ~S  |

The color data within the command is a single DWORD which is interpreted based on the color mode. Included in the logic operations is a conditional copy. Each pixel from the source rectangle is compared to the chroma key value (Graphic Engine Chroma Key High Register (GE\_CHROMA\_KEY\_HIGH), Graphic Engine Chroma Key Low Register (GE\_CHROMA\_KEY\_LOW)) and checked if it is in-range or out-of-range. Depending on the logic operation specified (in-range or out-of-range), the source pixel is conditionally written to the destination memory. The range checking is done for each color component of the source pixel and the results ANDed. A component can be disabled by setting the low value to 0 and the high value to 255. 16 bpp mode uses 5 bits of red and blue and 6 bits of green. 8 bpp mode uses only the blue value.

## 11.5.7 ROP\_RAW\_RECTANGLE

This command reads a source rectangle, optionally performs a logic operation with the pixel data specified in the command and writes the rectangle into the display frame buffer. The source and destination can be the same, overlapping, or independent areas. Different source and destination frame base addresses can be specified.

As with the ROP\_RECTANGLE command, the 2048 width limit also applies.

The color data consists of an array of pixels colors per row in the same format as the DRAW\_RAW\_RECTANGLE command.

Note the host S/W must ensure that the order of the rows of data must match the vertical direction that the BLT engine determines.

This command operates at approximately two clocks per pixel, assuming sufficient USB and system memory bandwidth.

#### 11.5.7.1 Logic Operations

The logic operations supported are as follows. S is the source rectangle and C is the color from the command.

| op<br>code | operation                                                   |
|------------|-------------------------------------------------------------|
| 0x0        | S if C != 0 (masked copy)                                   |
| 0x1        | S if S is in-range and C != 0 (masked conditional copy)     |
| 0x2        | S if S is out-of-range and C != 0 (masked conditional copy) |
| 0x3        | S if C is in-range (conditional copy)                       |
| 0x4        | S if C is out-of-range (conditional copy)                   |
| 0x5        | reserved                                                    |
| 0x6        | C XOR S                                                     |
| 0x7        | C XNOR S                                                    |



| 0x8     | C AND S                                                     |
|---------|-------------------------------------------------------------|
| 0x9     | ~C AND S                                                    |
| 0xA     | C AND ~S                                                    |
| 0xB     | ~C AND ~S                                                   |
| 0xC     | C OR S                                                      |
| 0xD     | ~C OR S                                                     |
| 0xE     | C OR ~S                                                     |
| 0xF     | ~C OR ~S                                                    |
| 0x10    | C if S != 0 (masked draw)                                   |
| 0x11    | C if C is in-range and S != 0 (masked conditional draw)     |
| 0x12    | C if C is out-of-range and S != 0 (masked conditional draw) |
| 0x13    | C if S is in-range (conditional draw)                       |
| 0x14    | C if S is out-of-range (conditional draw)                   |
| 0x15-1F | reserved                                                    |

Included in the logic operations are conditional copies and conditional draws. Chroma key matching and pixel masking are supported using both the source rectangle and command data. Either the source rectangle (conditional copy) or the command data (conditional draw) is written to the destination.

For chroma key matching (conditional copy/draw), each pixel (from the source rectangle or the command data) is compared to the chroma key value (Graphic Engine Chroma Key High Register (GE\_CHROMA\_KEY\_HIGH), Graphic Engine Chroma Key Low Register (GE\_CHROMA\_KEY\_LOW)) and checked if it is in-range or out-of-range. Depending on the logic operation specified (in-range or out-of-range), the pixel is conditionally written to the destination memory. The range checking is done for each color component of the source pixel (or command data) and the results ANDed. A component can be disabled by setting the low value to 0 and the high value to 255. 16 bpp mode uses 5 bits of red and blue and 6 bits of green. 8 bpp mode uses only the blue value.

For pixel masking (masked copy/draw), either the source rectangle or command data can used as a mask.

Masking and chroma key matching maybe combined (masked conditional copy/draw).

## 11.6 JPEG Co-processor

The JPEG Co-processor operates on a JPEG compressed rectangle image and supports various subsampling formats. The JPEG Co-processor block takes source data, consisting of header information and the compressed image organized in Minimum Coded Unit (MCU) sized rectangles, and uses it to create pixel data which is written into the display frame buffer. The destination frame base addresses, and image location, as well as the horizontal and vertical resolutions are specified within the command as required.

The JPEG image is specified as 24 bits in the YCbCr color space. Re-sampling of the sub-sampled Cb and Cr values is supported by linear interpolation. Color space conversion is then performed resulting in 24 bit RGB data. 16bpp mode is supported by down-converting the 24bit color.

A bypass mode is supported where the JPEG decompression is skipped. An un-compressed image, still organized as MCUs, is taken and converted to a rectangle using the remaining processes (re-sampling, color space conversion, etc.).



This command operates at approximately 2 clocks per pixel at 4:4:4, 1.4 clocks per pixel at 4:2:2 and 1 clocks per pixel at 4:2:0 sub-sampling, assuming sufficient USB and system memory bandwidth, a system clock of 167 MHz and a jpeg clock of 240-250MHz (or frequencies with a similar clock ratio).

Bypass mode operates at approximately 1 clock per pixel assuming sufficient USB and system memory bandwidth, a system clock of 167 MHz and a jpeg clock of 240-250MHz (or frequencies with a similar clock ratio). For HS operation, the system clock is set at 166.667 MHz and the jpeg clock is set at 240 MHz. for SS operation, the system clock is set at 167 MHz and the jpeg clock is set to 250 MHz. The Clock JPEG Source Select (CLK\_JPG\_SRC\_SEL) bit of the CPM Control Register (CPM\_CTL) is used to set the jpeg clock speed.

#### DECOMP\_JPEG

|          | 31       | 30  | 29        | 28 | 27 | 26 | 2 | 5 24 | 23   | 22   | 21  | 20    | 19  | 18 | 8 17  | 16  | 15       | 14  | 13       | 12 | 1 | 1 1 | 0 | 9 | 8   | 7   | 6    | 5   | 4    | 3     | 2  | 1 | 0 |
|----------|----------|-----|-----------|----|----|----|---|------|------|------|-----|-------|-----|----|-------|-----|----------|-----|----------|----|---|-----|---|---|-----|-----|------|-----|------|-------|----|---|---|
| 0        |          |     |           |    |    |    |   |      |      |      |     |       |     |    | C     | omr | nar      | nd  |          |    |   |     |   |   |     |     |      | ·   |      |       |    |   |   |
| 1        |          |     |           |    |    |    |   |      |      |      |     |       |     |    |       | len | gth      |     |          |    |   |     |   |   |     |     |      |     |      |       |    |   |   |
| 2        | ι        | Inu | sec       | ł  |    |    |   |      | up   | per  | lef | ťΥ    |     |    |       |     | ι        | ınu | sec      | ł  |   |     |   |   |     | up  | per  | lef | ťΧ   |       |    |   |   |
| 3        | ι        | unu | sec       | ł  |    |    |   |      |      | hei  | ght |       |     |    |       |     | ι        | ınu | sec      | ł  |   |     |   |   |     |     | wi   | dth |      |       |    |   |   |
| 4        |          |     |           |    |    |    |   |      |      | fra  | me  | e ba  | ise | а  | ddre  | ess |          |     |          |    |   |     |   |   |     |     |      |     | ur   | nus   | ed |   |   |
| 5        | ur<br>us |     | su<br>sai | -  |    |    |   | ve   | rtic | al r | esc | oluti | on  |    |       |     | co<br>mc | -   | ur<br>us |    |   |     |   | h | ori | zor | ntal | res | solu | itioi | ۱  |   |   |
| 6        |          |     |           |    |    |    |   |      |      |      |     |       |     |    |       |     |          |     |          |    |   |     |   |   |     |     |      |     |      |       |    |   |   |
| 7        |          |     |           |    |    |    |   |      |      |      | JP  | ΈG    | im  | na | ige ( | see | e be     | lov | v) /     | ра | d | din | ) |   |     |     |      |     |      |       |    |   |   |
| 8<br>etc |          |     |           |    |    |    |   |      |      |      |     |       |     |    |       |     |          |     |          |    |   |     |   |   |     |     |      |     |      |       |    |   |   |

- Length = 16 plus length of JPEG image
- WORD bits 15:12 unused / bits 11:0 upper left X (top left of frame is 0)
- WORD bits 15:12 unused / bits 11:0 upper left Y (top left of frame is 0)
- WORD bits 15:12 unused / bits 11:0 width
- WORD bits 15:12 unused / bits 11:0 height
- DWORD bits 31:7 frame base address in 128 byte increments / bits 6:0 unused
- WORD bits 15:14 color mode (11 = reserved, 10 = 24bpp, 01 = 16bpp, 00 = reserved) / bits 13:12 unused / bits 11:0 horizontal resolution

Note: The horizontal resolution must be a multiple of 8 while using 24bpp mode.

- WORD bits 15:14 unused / bits 13:12 sub-sampling mode (10 = 4:2:0, 01 = 4:2:2, 00 = 4:4:4) / bits 11:0 vertical resolution
- The JPEG image consisting of a sequence of segments each beginning with a marker. A segment may contain:
   Start of Image indication (SOI)
   Start of Frame indication (SOF<sub>0</sub> baseline DCT mode)
   Huffman table(s) (DHT)
   Quantization table(s) (DQT)
   The image data
   Restart interval (DRI) (not supported)
   Restart indication (RST<sub>m</sub>)
   Number of Lines (DNL)



Comments (COM) JPEG Extensions (JPG<sub>n</sub>) Application Specific (APP<sub>n</sub>) End of Image indication (EOI)

0 to 3 BYTES - padding

#### BYPASS\_JPEG

|          | 3 | s1 30       | 29        | 28 | 27 | 26 | 2 | 5 24 | 23   | 22   | 21  | 20    | 19  | 18  | 3 17 | 16  | 1   | 5 14          | 13  | 12        | 2 1 | 1 1 | 0   | 9  | 8    | 7   | 6    | 5   | 4    | 3     | 2  | 1 | 0 |
|----------|---|-------------|-----------|----|----|----|---|------|------|------|-----|-------|-----|-----|------|-----|-----|---------------|-----|-----------|-----|-----|-----|----|------|-----|------|-----|------|-------|----|---|---|
| 0        |   |             |           |    |    |    |   |      |      |      |     |       |     |     | С    | omi | ma  | and           |     |           | 1   |     |     |    |      |     | 1    |     | 1    |       |    |   |   |
| 1        |   |             |           |    |    |    |   |      |      |      |     |       |     |     |      | len | ngt | th            |     |           |     |     |     |    |      |     |      |     |      |       |    |   |   |
| 2        |   | unu         | iseo      | ł  |    |    |   |      | up   | per  | lef | t Y   |     |     |      |     |     | un            | lse | d         |     |     |     |    |      | up  | per  | lef | ťΧ   |       |    |   |   |
| 3        |   | unu         | ised      | t  |    |    |   |      |      | hei  | ght |       |     |     |      |     |     | un            | lse | d         |     |     |     |    |      |     | wi   | dth |      |       |    |   |   |
| 4        |   |             |           |    |    |    |   |      |      | fra  | me  | ba    | se  | a   | ddre | ess |     |               |     |           |     |     |     |    |      |     |      |     | ur   | nuse  | ed |   |   |
| 5        |   | un-<br>Jsed | su<br>sai | -  |    |    |   | ve   | rtic | al r | esc | oluti | on  |     |      |     | -   | color<br>node | -   | n-<br>sed |     |     |     | h  | nori | izo | ntal | res | solu | itioi | n  |   |   |
| 6        |   |             |           |    |    |    |   |      |      |      |     |       |     |     |      |     |     |               |     |           |     |     |     |    |      |     |      |     |      |       |    |   |   |
| 7        |   |             |           |    |    |    |   |      |      | ur   | -CO | mp    | res | sse | ed J | PE  | G   | ima           | ge  | (se       | ee  | be  | lo۱ | N) |      |     |      |     |      |       |    |   |   |
| 8<br>etc | ; |             |           |    |    |    |   |      |      |      |     |       |     |     |      |     |     |               |     |           |     |     |     |    |      |     |      |     |      |       |    |   |   |

- Length = 16 plus length of un-compressed JPEG image
- WORD bits 15:12 unused / bits 11:0 upper left X (top left of frame is 0)
- WORD bits 15:12 unused / bits 11:0 upper left Y (top left of frame is 0)
- WORD bits 15:12 unused / bits 11:0 width
- WORD bits 15:12 unused / bits 11:0 height
- DWORD bits 31:7 frame base address in 128 byte increments / bits 6:0 unused
- WORD bits 15:14 color mode (11 = reserved, 10 = 24bpp, 01 = 16bpp, 00 = reserved) / bits 13:12 unused / bits 11:0 horizontal resolution

Note: The horizontal resolution must be a multiple of 8 while using 24bpp mode.

- WORD bits 15:14 unused / bits 13:12 sub-sampling mode (10 = 4:2:0, 01 = 4:2:2, 00 = 4:4:4) / bits 11:0 vertical resolution
- The un-compressed JPEG image consists of repeated blocks formatted as follows (note that an integral number of blocks is included even if the bonding rectangle is smaller than the data clipping is performed on the bottom and right side as needed):

4:4:4: 8x8 array of Y values (64 bytes), 8x8 array of Cr values (64 bytes), 8x8 array of Cb values (64 bytes) - representing an 8x8 rectangle

4:2:2: two 8x8 arrays of Y values (left and right) (128 bytes), 8x8 array of Cr values (64 bytes), 8x8 array of Cb values (64 bytes) - representing a 16x8 rectangle. Interpolation of the Cr and Cb values is performed in the X direction.

4:2:0: four 8x8 arrays of Y values (top left, top right, bottom left and bottom right) (256 bytes), 8x8 array of Cr values (64 bytes), 8x8 array of Cb values (64 bytes) - representing a 16x16 rectangle. Interpolation of the Cr and Cb values is performed in the X and Y directions.



## 11.6.1 Error Checking and Handling

Before any pixels are drawn, error checking is performed

The bottom right corner of the drawn rectangle must be within the bounds of the frame. (Upper left X plus width must be less than or equal to the horizontal resolution. Upper left Y plus height must be less than or equal to the vertical resolution.) Note that this also checks that the top left corner is within bounds.

The height and width are checked for non-zero values.

The color mode is checked for non-supported value.

The length field is checked for a correct value. The length should be at least the fixed portion (16 bytes) plus 1 byte of image (even though 1 byte of image data is insufficient for any image, the length checking (described next) will catch those types of errors.

Once the above checks have passed, length checking is done as the command is processed.

The co-processor should not read more data than indicated by the length field. An error is indicated if data runs out before the command is finished (the rectangle drawing reached the end X/Y coordinates).

Once the end X/Y coordinates are reached, there should not be any remaining data to be processed. The residual length should be zero. Note that in the event that the length field value is too large, it will be caught as an error. Also, the next command will most likely be caught as an error as well.

Other error conditions that are handled are:

Image too big

Image too small

In the event of an command error or an error on the internal data path, the command is aborted and an error result is returned to the Command Parser. The JPEG Co-processor then waits until it is deselected by the Command Parser.

#### 11.6.1.1 Error codes

- 1 Length field error
- 2 Message length too short (ran out of data before command finished)
- 3 Message length too long (residual data length not zero or pre-fetch FIFOs not empty)
- 4 The color mode specified is not supported by the command
- 5 The height or width was set to zero
- 6 Some or all of the destination is outside the frame buffer
- 7 Image too big
- 8 Image too small

## 11.6.2 Aborting Command

In the event that the JPEG Co-processor is deselected by the Command Parser before the command is completed, the Co-processor should abort the current command and return to idle.

## 11.6.3 Block Diagram

The basic flow of the JPEG Co-processor is shown below.





Figure 11.1 JPEG Co-processor Block Diagram

## 11.6.4 FCT Reader / FIFO

This block reads data from the FCT interface and sends it to the Command Reader and Data Feeder blocks.

The total length of the JPEG command is provided by the Command Parser module. Once this block reads the appropriate amount of data, it stops requesting from the FCT.

## 11.6.5 Command Reader

This block reads data from the FIFO in the FCT Reader and extracts the upper left x, upper left y, width, height, horizontal and vertical resolutions, MCU sub-sampling mode (0=444, 1=422, 2=420), frame base address and color depth.

Command parameter error checking is done in this block.

Once the command header is read, this block instructs the Data Feeder block to move the JPEG image data.

#### 11.6.6 Data Feeder

This block reads data from the FIFO in the FCT Reader and sends it to the JPEG decoder. If processing the BYPASS\_JPEG command, data is sent directly to the YCbCr Interpolation and Conversion block.

Message length and image size error checking are done in this block as the data is fed.

#### 11.6.7 JPEG Decoder

The JPEG decoder offers the following features:

- Compatibility: 100 percent baseline ISO/IEC 10918-1 JPEG compliant
- 8-bit/channel pixel depths
- Support for JPEG header parsing
- Up to four programmable quantization tables
- Fully programmable Huffman tables (two AC and two DC)
- Fully programmable minimum coded unit (MCU)



Single-cycle Huffman decoding

## 11.6.8 YCbCr Interpolation and Conversion

This block receives the Y, Cb and Cr values from the JPEG Decoder or, for JPEG Bypass mode, directly from the Data Feeder and converts them into RGB data. The following video formats are supported: 4:4:4, 4:2:2, and 4:2:0.

#### 11.6.8.1 Writing to Display Frame Buffer

As each pixel is created, it is written to an internal Pixel to QWORD Converter. The Pixel to QWORD Converter handles all issues associated with the display frame buffer access to permit this module to operate at the pixel level. The Pixel to QWORD Converter is given the color mode, horizontal resolution and frame base address that was specified in the command. Based on the color mode, the appropriate number of bits from the drawn pixel are selected. Based on the X and Y coordinates, horizontal resolution, color mode and frame base address, the correct memory address is calculated.

Since JPEG images operate in the YCbCr color space, there is no direct support for 16bpp. In order to support 16bpp operation, the S/W driver will right pad the 5:6:5 RGB data into 8:8:8 format. Therefore when in 16bpp mode, this module strips the right most 3, 2 and 3 bits, respectively, from the 8:8:8 data RGB before sending it to the Pixel to QWORD Converter

## **11.7 Hextile Co-processor**

The Hextile Co-processor takes source data from the FCT, organized in tiles and sub-tiles, and uses it to create pixel data which is written into the display frame buffer. The destination frame base addresses, and image location, as well as the horizontal and vertical resolutions, are specified within the command, as required.

24bpp, 16bpp, 16bpp with up-converting and 8bpp modes are supported.

#### DECOMP\_HEXTILE

|          | 31 3 | 0  | 29  | 28 | 3 27 | 26 | 52 | 25 2 | 4 23  | 3 23 | 2 2 | 21   | 20   | 19   | 1  | 8 1 | 7   | 16  | 15  | 14        | 13           | 12       | 1  | 11  | 10 | 9 | 8    | 7   | 6    | 5    |    | 4    | 3   | 2  | 1 | 0 |
|----------|------|----|-----|----|------|----|----|------|-------|------|-----|------|------|------|----|-----|-----|-----|-----|-----------|--------------|----------|----|-----|----|---|------|-----|------|------|----|------|-----|----|---|---|
| 0        |      |    |     |    |      | 1  |    |      |       |      |     |      |      |      |    |     | со  | mr  | nar | nd        |              |          |    |     |    | 1 |      |     | 1    |      |    |      |     |    |   |   |
| 1        |      |    |     |    |      |    |    |      |       |      |     |      |      |      |    |     | I   | en  | gth |           |              |          |    |     |    |   |      |     |      |      |    |      |     |    |   |   |
| 2        | un   | us | sec | I  |      |    |    |      | up    | pe   | r∣  | left | tΥ   |      |    |     |     |     | l   | unu       | sec          | ł        |    |     |    |   |      | up  | per  | · le | ft | Х    |     |    |   |   |
| 3        | un   | us | sec | I  |      |    |    |      |       | he   | eig | ght  |      |      |    |     |     |     | I   | Jnu       | sec          | t        |    |     |    |   |      |     | wi   | dth  | 1  |      |     |    |   |   |
| 4        |      |    |     |    |      |    |    |      |       | fr   | ar  | ne   | ba   | ase  | а  | add | res | ss  |     |           |              |          | _  |     |    |   |      |     |      |      |    | นทเ  | ise | ed |   |   |
| 5        | un   | -u | sec | ł  |      |    |    | v    | ertic | al   | re  | eso  | luti | ion  |    |     |     |     |     | lor<br>de | u<br>us      | n-<br>ed |    |     |    | ł | nori | ZOI | ntal | re   | so | olut | ior | ı  |   |   |
| 6        |      |    |     |    |      |    |    |      |       |      |     |      |      |      |    |     |     |     |     |           |              |          | _  |     |    |   |      |     |      |      |    |      |     |    |   |   |
| 7        |      |    |     |    |      |    |    |      |       |      | ł   | He   | xtil | e ir | na | age | (   | see | e b | elo       | <b>v</b> ) / | / pa     | ac | ddi | ng |   |      |     |      |      |    |      |     |    |   |   |
| 8<br>etc |      |    |     |    |      |    |    |      |       |      |     |      |      |      |    |     |     |     |     |           |              |          |    |     |    |   |      |     |      |      |    |      |     |    |   |   |

- Length = 16 plus length of JPEG image
- WORD bits 15:12 unused / bits 11:0 upper left X (top left of frame is 0)
- WORD bits 15:12 unused / bits 11:0 upper left Y (top left of frame is 0)
- WORD bits 15:12 unused / bits 11:0 width
- WORD bits 15:12 unused / bits 11:0 height



- DWORD bits 31:7 frame base address in 128 byte increments / bits 6:0 unused
- WORD bits 15:14 color mode (11 = 16bpp with up-converting, 10 = 24bpp, 01 = 16bpp, 00 = 8bpp) / bits 13:12 unused / bits 11:0 horizontal resolution

**Note:**The horizontal resolution must be a multiple of 8 while using 24bpp or 16bpp with upconverting modes.

- WORD bits 15:12 unused / bits 11:0 vertical resolution
- The Hextile image, which consists of:

Subencoding type consisting of 1 byte with the following value definitions - 1 = Raw / 2 = BackgroundSpecified / 4 = ForegroundSpecified / 8 = AnySubrects / 16 = SubrectsColoured

Pixel array consisting of 256 pixels each with 1, 2 or 3 BYTES - only present if Raw bit set in subencoding type

Background pixel color consisting of 1, 2 or 3 bytes - only present if BackgroundSpecified bit set in subencoding type

Foreground pixel color consisting of 1, 2 or 3 bytes - only present if ForegroundSpecified bit set in subencoding type

Number of subrectangles consisting of 1 byte - only present if AnySubrects bit set in subencoding type

Subrectangle array consisting of "number of subrectangles" of the following array - only present if AnySubrects bit set in subencoding type:

- Subrectangle pixel color consisting of 1, 2 or 3 bytes only present if SubrectsColoured bit set in subencoding type
- Subrectangle x and y offsets consisting of 1 byte. The 4 msbs are the x value and the 4 lsbs are the y value
- Subrectangle width and height consisting of 1 byte. The 4 msbs specify the width minus one and the 4 lsbs specify the height minus one

The data stream starts at bits [7:0] of the DWORD from the FCT, followed by bits [15:8], then bits [23:16], then bits [31:24]. The fifth byte is at bits [7:0] in the next DWORD.

In 24bpp mode, when a pixel is encountered in the data stream, it is formatted with the blue byte first, followed by green, followed by red. For example, if the pixel started at bits [7:0], [7:0] would be blue, [15:8] would be green and [23:16] would be red. It is possible that the pixel is split across two DWORDs. For example, if the pixel started at bits [23:16], [23:16] would be blue, [31:24] would be green and [7:0] of the next DWORD would be red.

In 16bpp and 16bpp with up-converting modes, when a pixel is encountered in the data stream, it is formatted with the 5 blue bits first, followed by the 3 lsb green bits, followed by the 3 msb green bits in the next byte, followed by the 5 red bits. For example, if the pixel started at bits [15:8], [12:8] would be blue, [18:13] would be green and [23:19] would be red. It is possible that the pixel is split across two DWORDs. For example, if the pixel started at bits [31:24], [28:24] would be blue, [2:0] of the next DWORD along with [31:29] would be green and [7:3] of the next DWORD would be red. In 8bpp, each byte contains a full pixel.

• 0 to 3 BYTES - padding

## 11.7.1 Error Checking and Handling

Before any pixels are drawn, error checking is performed.

The bottom right corner of the drawn rectangle must be within the bounds of the frame. (Upper left X plus width must be less than or equal to the horizontal resolution. Upper left Y plus height must be



less than or equal to the vertical resolution.) Note that this also checks that the top left corner is within bounds.

The height and width are checked for non-zero values.

The color mode is checked for a non-supported value.

The length field is checked for a correct value. The length should be at least the fixed portion (16 bytes) plus 2 bytes of image.

As the command is processed, the image is checked for valid combinations of mask bits in the subencoding type byte, for valid foreground & background colors and for a valid number of subrectangles (if appropriate).

Length checking is also done as the command is processed.

The co-processor should not read more data than indicated by the length field. An error is indicated if data runs out before the command is finished (the rectangle drawing reached the end X/Y coordinates).

Once the end X/Y coordinates are reached, there should not be any remaining data to process. The residual length should be zero. Note that in the event that the length field value is too large, this will be caught as an error. Also, the next command will most likely be caught as an error as well.

In the event of an command error or an error on the internal data path, the command is aborted and an error result is returned to the Command Parser. The Hextile Co-processor then waits until it is deselected by the Command Parser.

#### 11.7.1.1 Error codes

- 1 Length field error (length less than 18)
- 2 Message length too short (ran out of data before command finished)
- 3 Message length too long (residual data length not zero or pre-fetch FIFOs not empty)
- 4 Reserved5 The height or width was set to zero
- 6 Some or all of the destination is outside the frame buffer
- 7 Tile with Raw mask set and with one or more of BackgroundSpecified, ForegroundSpecified, AnySubrects or SubrectsColoured masks also set
- 8 Tile with BackgroundSpecified mask not set and background has not yet been set for this command
- 9 Tile with ForegroundSpecified mask set but without AnySubrects mask set
- 0xA Tile with ForegroundSpecified mask set but SubrectsColoured mask also set
- 0xB Tile with AnySubrects mask set, both ForegroundSpecified and SubrectsColoured masks not set and foreground has not yet been set for this command
- 0xC Tile with SubrectsColoured mask set but without AnySubrects mask set
- 0xD Tile with AnySubrects but the number of subrectangles is 0

## 11.7.2 Aborting Command

In the event that the Hextile Co-processor is deselected by the Command Parser before the command is completed, the Hextile Co-processor will abort the current command and return to idle.

#### 11.7.3 Block Diagram

The basic flow of the Hextile Co-processor is shown below.





Figure 11.2 Hextile Co-processor Block Diagram

## 11.7.4 FCT Reader / FIFO

This block reads data from the FCT interface and sends it to the Hextile Stream Processor. The FCT Reader takes complete DWORDS from the FCT and presents 5 bytes to the Hextile Stream Processor. The Hextile Stream Processor can consume 1 to 5 bytes per cycle. Based on the number of bytes used, the remaining bytes are shifted and new bytes are added. The total length of the Hextile command is provided by the Command Parser module. Once this block reads the appropriate amount of data, it stops requesting from the FCT.

Command errors 1, 2 and 3 from Section 11.7.1.1 are checked for in this block.

#### 11.7.5 Hextile Stream Processor

The first function that this block performs is to extract the upper left x, upper left y, width, height, horizontal and vertical resolutions, frame base address and color depth from the command header. Command errors 5 and 6 from Section 11.7.1.1 are checked for in this block.

Following the command header parsing, the Hextile Stream Processor parses 16 x16 tiles and determines if clipping is required. Normally, the width and height of a tile is 16 x 16. However, it is likely that the total image size is not a multiple of 16. Therefore at the right and bottom edges, clipping is performed with the width and height adjusted as necessary.

#### 11.7.5.1 Tile Decoding

Tiles are decoded per the RFB (remote frame buffer) Protocol. The first byte is the subencoding type which contains Raw, BackgroundSpecified, ForegroundSpecified, AnySubrects and SubrectsColoured masks.

If the Raw bit is set:

256 pixels follow ordered from left to right, top to bottom. If this bit is set then the BackgroundSpecified, ForegroundSpecified, AnySubrects and SubrectsColoured bits must be zero.

- **Note:** The RFB Protocol states that the BackgroundSpecified, ForegroundSpecified, AnySubrects and SubrectsColoured bits are irrelevant for when the Raw bit is set. These requirements are more restrictive.
- If the BackgroundSpecified bit is set:
  - 1, 2 or 3 bytes (depending on the color mode) follow that specify the background color. All pixels in the tile are set to this color unless changed by a subsequent subtile.
- If the BackgroundSpecified bit is not set:

The background is the same as the previous tile. However the background pixel value may not be carried over if the previous tile was Raw.



If the ForegroundSpecified bit is set:

1, 2 or 3 bytes (depending on the color mode) follow that specify the foreground color to be used in subsequent subtiles. If this bit is set then the SubrectsColoured bit must be zero and the AnySubrects bit must be one.

If the ForegroundSpecified bit is not set:

The foreground is the same as the previous tile. However the foreground pixel value may not be carried over if the previous tile had the Raw or SubrectsColoured bits set.

If the AnySubrects bit is set:

1 byte follows specifying the number of subrectangles. The number of subrectangles must not be zero.

Following the "number of subrectangles" is an array of x, y, width, height and, optionally, pixel colors.

If the SubrectsColoured bit is set:

The subrectangle also includes (preceding the x, y, width and height) 1, 2 or 3 bytes (depending on the color mode) specifying the pixel color. If this bit is set then the ForegroundSpecified bit must be zero.

If the SubrectsColoured bit is not set:

All subrectangles receive the foreground color (either set above or carried over).

Subrectangle x and y offsets consisting of 1 byte. The 4 msbs are the x value and the 4 lsbs are the y value.

Subrectangle width and height consisting of 1 byte. The 4 msbs specify the width minus one and the 4 lsbs specify the height minus one.

If the AnySubrects bit is not set:

There are no subrectangles (the entire tile is solid background color). If this bit is not set, then the SubrectsColoured must be zero.

Command errors 7 through 0XD from Section 11.7.1.1 are checked for in this block.

#### 11.7.5.2 Writing to Display Frame Buffer

As each pixel is created, it is written to an internal Pixel to QWORD Converter. The Pixel to QWORD Converter handles all issues associated with the display frame buffer access to permit this module to operate at the pixel level. The Pixel to QWORD Converter is given the color mode, horizontal resolution and frame base address, that was specified in the command. Based on the color mode, the appropriate number and combinations of bits from the drawn pixel are selected. Based on the X and Y coordinates, horizontal resolution, color mode and frame base address, the correct memory address is calculated.

16bpp with up-converting mode is handle by the Pixel to QWORD Converter. It will convert the 16 bits of color (in 565 format) to 24 bits by right padding each color component as needed.

## 11.8 JPEG-LS Co-processor

The JPEG-LS Co-processor operates on a JPEG-LS compressed rectangle image. The JPEG-LS Coprocessor block takes source data, consisting of header information and the compressed image, and uses it to create pixel data which is written into the display frame buffer. The destination frame base addresses, and image location, as well as the horizontal and vertical resolutions, are specified within the command, as required.

The JPEG-LS image is specified in the RGB color space using three 8 bit components. 24bpp, 16bpp and 16bpp with up-converting modes are supported. 16bpp and 16bpp with up-converting modes use the upper 5 red, 6 green and 5 blue bits of the 24 bit RGB value.

The JPEG-LS decoder supports Regular and Run (constant color) modes.

Note that the maximum image width supported is 2048 pixels.



This command operates at approximately 3 clocks per pixel while decoding in regular mode and at approximately 1 clock per pixel while decoding in run mode, both assuming sufficient USB and system memory bandwidth.

#### DECOMP\_JPEG\_LS

|          | 3 | 1 30 | 29  | 2 | 28 27 | 26 | 25 | 24 | 23   | 22   | 2    | 1 20  | 19  | 1  | 8 17 | 16   | 15   | 14          | 13   | 12    | 1  | 1 ′ | 0   | 9 | 8   | 7    | ' ( | 6   | 5   | 4   | 3    | 2  | 1 | 0 |
|----------|---|------|-----|---|-------|----|----|----|------|------|------|-------|-----|----|------|------|------|-------------|------|-------|----|-----|-----|---|-----|------|-----|-----|-----|-----|------|----|---|---|
| 0        | 1 |      |     |   |       |    |    |    |      |      |      |       |     |    | C    | om   | ma   | nd          | 1    | 1     |    |     |     |   |     |      |     |     |     |     |      |    |   |   |
| 1        |   |      |     |   |       |    |    |    |      |      |      |       |     |    |      | ler  | ngth | 1           |      |       |    |     |     |   |     |      |     |     |     |     |      |    |   |   |
| 2        |   | unı  | Ise | d |       |    |    |    | up   | per  | · 10 | eft Y |     |    |      |      |      | unu         | ised | t     |    |     |     |   |     | u    | op  | er  | lef | t X |      |    |   |   |
| 3        |   | unı  | Ise | d |       |    |    |    |      | hei  | igl  | ht    |     |    |      |      |      | unu         | ised | b     |    |     |     |   |     |      | ۷   | vic | lth |     |      |    |   |   |
| 4        |   |      |     |   |       |    |    |    |      | fra  | an   | ne b  | ase | а  | ddr  | ess  |      |             |      |       |    |     |     |   |     |      |     |     |     | ur  | nus  | ed |   |   |
| 5        |   | un-  | use | d |       |    |    | ve | rtic | al r | e    | solut | ion |    |      |      |      | olor<br>ode | -    |       |    |     |     | ł | 101 | rizo | nta | al  | res | olu | itio | n  |   |   |
| 6        |   |      |     |   |       |    |    |    |      |      |      |       |     |    |      |      |      |             |      |       |    |     |     |   |     |      |     |     |     |     |      |    |   |   |
| 7        |   |      |     |   |       |    |    |    |      | J    | JΡ   | EG-   | LS  | in | nage | e (s | ee   | bel         | ow)  | ) / p | pa | dd  | ing | g |     |      |     |     |     |     |      |    |   |   |
| 8<br>etc | ; |      |     |   |       |    |    |    |      |      |      |       |     |    |      |      |      |             |      |       |    |     |     |   |     |      |     |     |     |     |      |    |   |   |

- Length = 16 plus length of JPEG image
- WORD bits 15:12 unused / bits 11:0 upper left X (top left of frame is 0)
- WORD bits 15:12 unused / bits 11:0 upper left Y (top left of frame is 0)
- WORD bits 15:12 unused / bits 11:0 width (the maximum width supported is 2048 pixels)
- WORD bits 15:12 unused / bits 11:0 height
- DWORD bits 31:7 frame base address in 128 byte increments / bits 6:0 unused
- WORD bits 15:14 color mode (11 = 16bpp with up-converting, 10 = 24bpp, 01 = 16bpp, 00 = reserved) / bits 13:12 unused / bits 11:0 horizontal resolution

**Note:**The horizontal resolution must be a multiple of 8 while using 24bpp or 16bpp with upconverting modes.

- WORD bits 15:12 unused / bits 11:0 vertical resolution
- The JPEG-LS image consisting of a sequence of markers and marker segments:
  - Start of Image (SOI) marker

Start of Frame (SOF<sub>55</sub>) marker and marker segment

Start of Scan (SOS) marker and marker segment

Image data segment - The compressed image data is always formatted as 24 bits per pixel. In 16bpp and 16bpp up-convert modes, the upper bits of each component are not used in which case the format is 3 unused, 5 bits red, 2 unused, 6 bits green, 3 unused, 5 bits blue). End of Image marker (EOI)

Note that the JPEG-LS specification also includes JPEG-LS preset parameters (LSE), Define Number of Lines (DNL), Define Restart Interval (DRI), Restart ( $RST_m$ ), Application (APP<sub>n</sub>) and Comment (COM) markers, however these are not supported.

• 0 to 3 BYTES - padding



## 11.8.1 Error Checking and Handling

Before any pixels are drawn, error checking is performed.

The bottom right corner of the drawn rectangle must be within the bounds of the frame. (Upper left X plus width must be less than or equal to the horizontal resolution. Upper left Y plus height must be less than or equal to the vertical resolution.) Note that this also checks that the top left corner is within bounds.

The height and width are checked for non-zero values. The width is also checked for a maximum size of 2048 pixels.

The color mode is checked for non-supported value.

The length field is checked for a correct value. The length should be at least the fixed portion (16 bytes) plus 1 byte of image (even though 1 byte of image data is insufficient for any image, the length checking (described next) will catch those types of errors.

As the command is processed, the image is checked for the correct sequence of markers and parameters. The order of markers and marker segments is: SOI, SOF, SOS. image data & EOF. The expected parameters are listed in Section 11.8.6.

Length checking is also done as the command is processed.

The co-processor should not read more data than indicated by the length field. An error is indicated if data runs out before the command is finished (the rectangle drawing reached the end X/Y coordinates).

Once the end X/Y coordinates are reached, there should not be any remaining data to process. The residual length should be zero. Note that in the event that the length field value is too large, this will be caught as an error. Also, the next command will most likely be caught as an error as well.

Checking is provided to detect end of Image mismatch - either when the EOI marker is missing or in the wrong spot. In the event of an command error or an error on the internal data path, the command is aborted and an error result is returned to the Command Parser. The JPEG-LS Co-processor then waits until it is deselected by the Command Parser.

#### 11.8.1.1 Error codes

- 1 Length field error
- 2 Message length too short (ran out of data before command finished)
- 3 Message length too long (residual data length not zero or pre-fetch FIFOs not empty)
- 4 The color mode specified is not supported by the command
- 5 The height or width was set to zero or the width was greater than 2048
- 6 Some or all of the destination is outside the frame buffer
- 7 End of Image mismatch (EOI marker missing or in the wrong spot)
- 8 Header mismatches (header fields mismatch expected values for LS sample interleaved mode or width/height does not match the drawing command header width/height)

#### 11.8.2 Aborting Command

In the event that the JPEG-LS Co-processor is deselected by the Command Parser before the command is completed, the JPEG-LS Co-processor should abort the current command and return to idle.



## 11.8.3 Block Diagram

The basic flow of the JPEG-LS Co-processor is shown below. Decoding is done in accordance with ISO/IEC International Standards 14495-1 and 10918-1.



Figure 11.3 JPEG-LS Co-processor Block Diagram

## 11.8.4 Command Reading

This block reads data from the FCT and extracts the upper left x, upper left y, width, height, horizontal and vertical resolutions, frame base address, and color depth.

Command parameter error checking is done in this block.

#### 11.8.5 Data Feeding

This block reads data from the FCT and sends it to either the Header Processor or the Data Segment Decoder. Bytes from the FCT are processed low byte (FCT bits 7-0) to high byte (FCT bits 24:31).

Message length and image size error checking are done in this block.

## 11.8.6 Header Processing

The Header Processor receives the JPEG-LS header from the Data Feeder and parses the various marker and marker segments. The markers and marker segments are checked for errors and the parameters are checked for their expected values.

It is expected that the following JPEG-LS marker and marker segments are used as specified and in the order specified.

- Start of Image (SOI 0xFFD8)
- Start of Frame (SOF<sub>55</sub> 0xFFF7) Frame header length (Lf) must be 0x0011 Sample precision (P) must be 0x08 Number of lines (Y) must equal that specified in the DECOMP\_JPEG\_LS command and must not be zero (DNL and LSE are not supported) Number of samples per line (X) must equal that specified in the DECOMP\_JPEG\_LS command and must not be zero (LSE is not supported)



Number of image components in frame (Nf) must equal 3 Component identifier 1 (C1) must equal 1 Horizontal sampling factor for component 1 (H<sub>1</sub>) must equal 1 Vertical sampling factor for component 1 (V<sub>1</sub>) must equal 1 Quantization table destination selector for component 1 (Tq1) must equal 0 Component identifier 2 (C2) must equal 2 Horizontal sampling factor for component 2 (H<sub>2</sub>) must equal 1 Vertical sampling factor for component 2 (V<sub>2</sub>) must equal 1 Quantization table destination selector for component 2 (Tq<sub>2</sub>) must equal 0 Component identifier 3 (C<sub>3</sub>) must equal 3 Horizontal sampling factor for component 3 (H<sub>3</sub>) must equal 1 Vertical sampling factor for component 3 (V<sub>3</sub>) must equal 1 Quantization table destination selector for component 3 (Tq<sub>3</sub>) must equal 0 Start of Scan (SOS - 0xFFDA) Scan header length (Ls) must be 0x000C Number of image components in scan (Ns) must equal 3 Scan component selector 1 (Cs1) must equal 1 Mapping table selector for component 1 (Tm<sub>1</sub>) must equal 0 Scan component selector 2 (Cs<sub>2</sub>) must equal 2 Mapping table selector for component 2 (Tm<sub>2</sub>) must equal 0 Scan component selector 3 (Cs<sub>3</sub>) must equal 3 Mapping table selector for component 3 (Tm<sub>3</sub>) must equal 0 NEAR parameter (NEAR) must equal 0 (lossless) ILV parameter (ILV) must equal 2 (sample interleaved scan) Successive approximation bit position high (Ah) must equal 0 (no meaning in lossless)

Successive approximation bit position low (AI) must equal 0 (no point transform)

- Image Data Segment
- End of Image (EOI 0xFFD9)

JPEG-LS preset parameters (LSE), Define Number of Lines (DNL), Define Restart Interval (DRI), Restart (RST<sub>m</sub>), Application (APP<sub>n</sub>) and Comment (COM) markers are not supported.

Since the LSE marker is not supported, the quantization threshold values (T1, T2 and T3) are fixed at 3, 7 and 21 respectively and the value of RESET is fixed at 64.

## 11.8.7 Data Segment Decoder

The Data Segment Decoder involves the following steps:

- Reading of neighbor pixels
- Context modeling and determining decode mode
- Regular mode decoding
   Pixel prediction
   Pixel prediction correction and clamping
   Golomb decoding
   Pixel reconstruction
   Context updating
- Run mode decoding Run length decode
   Run interrupt sample decode
   Golomb decoding
   Interrupt sample reconstruction
   Context updating



## 11.8.8 Writing to Display Frame Buffer

As each pixel is created, it is written to an internal Pixel to QWORD Converter. The Pixel to QWORD Converter handles all issues associated with the display frame buffer access to permit this module to operate at the pixel level. The Pixel to QWORD Converter is given the color mode, horizontal resolution and frame base address that was specified in the command. Based on the color mode, the appropriate number of bits from the drawn pixel are selected. Based on the X and Y coordinates, horizontal resolution, color mode, and frame base address, the correct memory address is calculated.

16bpp with up-converting mode is handle by the Pixel to QWORD Converter. It will convert the 16 bits of color (in 565 format) to 24 bits by right padding each color component as needed.

## 11.9 General Error Checking and Handling

In the event of any internal data path errors, the command being processed is aborted.

All holding registers, counters, etc are cleared when Graphics Engine Restart (GE\_RESTART) bit in Graphic Engine Control Register (GE\_CTRL) is set.

## **11.10 Pixel Retriever**

This block, when commanded, reads a block of pixels from the display frame buffer. When finished, the pixels can be read in sequential order. Up to 2K pixels can be stored.

## 11.10.1 Pixel Retrieving

The input to this block is by way of a command which specifies the frame base address, starting X/Y pixel (zero being the top left), number of pixels, horizontal resolution and color mode. The corresponding starting memory address is calculated and the display frame buffer memory is read.

As the display frame buffer is read, up to 2, 4, or 8 pixels (depending on the color mode) are extracted from each QWORD and are placed into shared scratch pad memory. Note that the first pixel may have any pixel alignment within the QWORD and it's position depends upon the starting X coordinate.

The pixels are stored in the scratch pad memory unpacked, with each pixel consuming a DWORD regardless of the color mode.

The scratch pad memory is a shared resource and is connected to this block during BLT commands.

## 11.10.2 Pixel Reading

Once the command is finished and all of the pixels have been read from the display frame buffer, the shared scratch pad memory acts as a read only FIFO. The first data is placed on the output. When it has been read, a read signal increments a pointer and the next pixel is presented. When the last pixel is read, the output becomes undefined.

In the event that a new command is issued before the last pixel has been read, the remaining pixels are discarded (the read pointer is set back to zero).

## 11.10.3 Pixel Color Data

When 16bpp with up-converting mode is indicated, the Pixel Retriever will convert the 24 bits of color from the display buffer to 16 bits by stripping off right bits as needed. Note that this will result in a loss of color resolution for operations such as a copy.

## 11.10.4 Error Checking and Handling

In the event of an error on the internal memory bus, the command is aborted



All holding registers, counters, etc are cleared when Graphics Engine Restart (GE\_RESTART) bit in Graphic Engine Control Register (GE\_CTRL) is set.

## 11.11 Pixel to QWORD Converter

This block receives pixels (X, Y and color) and calculates the memory address. It assembles multiple pixels into a QWORD worth of data and then writes the data into the system memory.

When pixels are received, they can be flagged as masked pixels. These are pixels that are not to be written into system memory.

The Pixel to QWORD Converter can be accessed by the various Graphic Engine co-processors. The access to the Pixel to QWORD Converter is statically enabled based on the Graphic Engine co-processor currently invoked.

#### 11.11.1 Memory Address

The memory address of a pixel is equal to  $((Y \times horizontal resolution + X) \times horizontal + frame base address. Bytes per pixel is either 1, 2 or 3 for 8bpp, 16bpp and 24bpp (and 16bpp with up-converting modes.) respectively.$ 

## 11.11.2 Pixel Color Data

Based on the color mode set by the selected co-processor, the correct bits and byte lanes of the color are used as the data to be written into memory.

When 16bpp with up-converting mode is indicated, the Pixel to QWORD Converter will convert the 16 bits of color (in 565 format) to 24 bits by right padding each color component as needed.

## 11.12 Control and Status Registers

| ADDRESS<br>OFFSET | REGISTER NAME (SYMBOL)                                               |
|-------------------|----------------------------------------------------------------------|
| 000h              | Graphic Engine Control Register (GE_CTRL)                            |
| 004h              | Graphic Engine Command Status Register (GE_CMD_STATUS)               |
| 008h              | Graphic Engine Command Info Register (GE_CMD_INFO)                   |
| 00Ch              | Graphic Engine Command Length Register (GE_CMD_LEN)                  |
| 010h              | Graphic Engine Command Offset Register (GE_CMD_OFFSET)               |
| 014h              | Graphic Engine Previous Command Info Register (GE_PREV_CMD_INFO)     |
| 018h              | Graphic Engine Previous Command Length Register (GE_PREV_CMD_LEN)    |
| 01Ch              | Graphic Engine Previous Command Offset Register (GE_PREV_CMD_OFFSET) |
| 020h              | Graphic Engine Chroma Key High Register (GE_CHROMA_KEY_HIGH)         |
| 024h              | Graphic Engine Chroma Key Low Register (GE_CHROMA_KEY_LOW)           |
|                   | Reserved                                                             |
| 028h – FFFh       | Reserved for future expansion                                        |

#### Table 11.1 Graphics Engine Control and Status Register Map



32 bits

## 11.12.1 Graphic Engine Control Register (GE\_CTRL)

Offset:

000h

Size:

This register is used to configure and control the Graphics Engine.

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | TYPE | DEFAULT |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:16 | Graphics Engine Initial Command Sequence Number<br>(GE_INIT_CMD_SEQ_NUM)<br>This field is used to initialize the expect sequence number of the next<br>command. It can be written at any point but only takes affect when the<br>Graphics Engine Restart (GE_RESTART) bit is set or when the Graphics<br>Engine Enable (GE_ENABLE) bit changes from low to high.                                                                                                                                                                                                                   | R/W  | 0000h   |
|       | This is used when the Graphics Engine Command Sequence Number<br>Enable (GE_CMD_SEQ_EN) bit is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |         |
| 15:5  | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | RO   | -       |
| 4     | Graphics Engine Command Ones Complement Enable<br>(GE_CMD_ONECOMP_EN)<br>When set, ones complement checking is performed by the Command Parser.                                                                                                                                                                                                                                                                                                                                                                                                                                    | R/W  | 0b      |
| 3     | Graphics Engine Command Sequence Number Enable<br>(GE_CMD_SEQ_EN)<br>When set, sequence number checking is performed by the Command<br>Parser.                                                                                                                                                                                                                                                                                                                                                                                                                                     | R/W  | Ob      |
| 2     | Graphics Engine Abort (GE_ABORT)<br>Write a 1 to abort an active command. This will cause an endpoint stall and<br>should be followed by setting the Graphics Engine Restart (GE_RESTART)<br>bit.<br>Note: This bit should not be set at the same time as the Graphics Engine                                                                                                                                                                                                                                                                                                      | SC   | Ob      |
|       | Restart (GE_RESTART) bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |         |
| 1     | <b>Graphics Engine Restart (GE_RESTART)</b><br>Write a 1 to restart the Graphics Engine in the event of an error that causes<br>an endpoint stall. This bit will also flush the Pixel Retriever and the Pixel to<br>QWORD Converter.                                                                                                                                                                                                                                                                                                                                               | SC   | 0b      |
|       | <b>Note:</b> This bit should not be set at the same time as the Graphics Engine Abort (GE_ABORT) bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |         |
|       | <b>Note:</b> This bit should not be set unless the Graphics Engine Command State (GE_CMD_STATE) field in Graphic Engine Command Status Register (GE_CMD_STATUS) indicates Stalled.                                                                                                                                                                                                                                                                                                                                                                                                 |      |         |
| 0     | <b>Graphics Engine Enable (GE_ENABLE)</b><br>When enabled, the Graphics Engine will execute commands. When<br>disabled, the current command will finish and once reaching IDLE, the<br>Graphics Engine will stop. If previously changed from enabled to disabled,<br>this bit should not be re-enabled unless the Graphics Engine Read Master<br>State (GE_RD_MASTER_STATE), Graphics Engine Write Master State<br>(GE_WR_MASTER_STATE) and Graphics Engine Command State<br>(GE_CMD_STATE) fields in Graphic Engine Command Status Register<br>(GE_CMD_STATUS) all indicate IDLE. | R/W  | Ob      |



## 11.12.2 Graphic Engine Command Status Register (GE\_CMD\_STATUS)

Offset:

004h

32 bits

Size:

This register indicates the current state of the Command Parser.

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                       | TYPE | DEFAULT |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:16 | Graphics Engine Next Command Sequence Number<br>(GE_NEXT_CMD_SEQ_NUM)<br>This field indicates the expect sequence number for the next command. It is<br>initialized from the Graphics Engine Initial Command Sequence Number<br>(GE_INIT_CMD_SEQ_NUM) field in Graphic Engine Control Register<br>(GE_CTRL) and is incremented at the completion of each command. | RO   | 0000h   |
| 15:12 | RESERVED                                                                                                                                                                                                                                                                                                                                                          | RO   | -       |
| 11:8  | <b>Graphics Engine Error Type (GE_ERROR_TYPE)</b><br>When the Graphics Engine Error Status (GE_ERROR_STAT) field indicates "bad command specific check", this field indicates the command check that failed. The command specific errors are listed in the respective command descriptions.                                                                       | RO   | 0000b   |
|       | This field is cleared when the Graphics Engine Restart (GE_RESTART) bit in Graphic Engine Control Register (GE_CTRL) is set.                                                                                                                                                                                                                                      |      |         |
| 7:4   | Graphics Engine Error Status (GE_ERROR_STAT)<br>When the Graphics Engine Command State (GE_CMD_STATE) field<br>indicates an error condition, this field indicates the reason for the error.                                                                                                                                                                       | RO   | 0000b   |
|       | This field is cleared when the Graphics Engine Restart (GE_RESTART) bit in Graphic Engine Control Register (GE_CTRL) is set.                                                                                                                                                                                                                                      |      |         |
|       | 1 = Invalid command value                                                                                                                                                                                                                                                                                                                                         |      |         |
|       | 2 = Invalid command value ones complement                                                                                                                                                                                                                                                                                                                         |      |         |
|       | 3 = Bad sequence number                                                                                                                                                                                                                                                                                                                                           |      |         |
|       | 4 = Bad command specific check                                                                                                                                                                                                                                                                                                                                    |      |         |
|       | 5 = Internal data path error 1                                                                                                                                                                                                                                                                                                                                    |      |         |
|       | 6 = Internal data path error 2                                                                                                                                                                                                                                                                                                                                    |      |         |
|       | 7 = Internal data path error 3                                                                                                                                                                                                                                                                                                                                    |      |         |
|       | 8 - 13 reserved                                                                                                                                                                                                                                                                                                                                                   |      |         |
|       | <ul> <li>14 = Graphics Engine Abort (GE_ABORT) bit was set while the Command<br/>Parser was waiting for a command (Graphics Engine Command State<br/>(GE_CMD_STATE) was equal to Idle)</li> </ul>                                                                                                                                                                 |      |         |
|       | <ul> <li>15 = Graphics Engine Abort (GE_ABORT) bit was set while a command<br/>was being executed (Graphics Engine Command State (GE_CMD_STATE)<br/>was equal to Executing</li> </ul>                                                                                                                                                                             |      |         |
| 3     | <ul> <li>Graphics Engine Read Master State (GE_RD_MASTER_STATE)<br/>Indicates the current state of the Read Command FIFO and internal read data path</li> <li>0 = Idle (no read commands pending and command FIFO empty)</li> <li>1 = Active</li> </ul>                                                                                                           | RO   | Ob      |



| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                   | TYPE | DEFAULT |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 2    | <ul> <li>Graphics Engine Write Master State (GE_WR_MASTER_STATE)<br/>Indicates the current state of the Pixel to QWORD Converter, Data and<br/>Command FIFOs and internal write data path.</li> <li>0 = Idle (no pixels being converted, no commands pending and command<br/>and data FIFOs empty)</li> </ul> | RO   | ОЬ      |
|      | ■ 1 = Active                                                                                                                                                                                                                                                                                                  |      |         |
|      | <b>Note:</b> When the Graphics Engine Command State (GE_CMD_STATE) field indicates Stalled, the Pixel to QWORD Converter and Data FIFO states are not taken into account.                                                                                                                                     |      |         |
| 1:0  | Graphics Engine Command State (GE_CMD_STATE)<br>Indicates the current state of the Command Parser.<br>• 0 = Idle                                                                                                                                                                                              | RO   | 00b     |
|      | <ul> <li>1 = Executing Command</li> <li>2 = Stalled (Errored)</li> </ul>                                                                                                                                                                                                                                      |      |         |



## 11.12.3 Graphic Engine Command Info Register (GE\_CMD\_INFO)

Offset: 008h Size:

32 bits

This register reflects the sequence number and command values of the current drawing command.

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                      | TYPE | DEFAULT |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:16 | <b>Graphics Engine Command Sequence Number (GE_CMD_SEQ_NUM)</b><br>Indicates the sequence number of the current command. This is valid even<br>if the Graphics Engine Command Sequence Number Enable<br>(GE_CMD_SEQ_EN) bit is cleared.                                                          | RO   | 0000h   |
|       | This field is cleared when the command completes.                                                                                                                                                                                                                                                |      |         |
|       | This field is cleared when the Graphics Engine Restart (GE_RESTART) bit<br>in Graphic Engine Control Register (GE_CTRL) is set or when the Graphics<br>Engine Enable (GE_ENABLE) bit in Graphic Engine Control Register<br>(GE_CTRL) changes from low to high.                                   |      |         |
| 15:8  | Graphics Engine Command Ones Complement<br>(GE_CMD_ONES_COMP)<br>The ones complement of the current command executed. See Graphics<br>Engine Commands for the command values. This is valid even if the<br>Graphics Engine Command Ones Complement Enable<br>(GE_CMD_ONECOMP_EN) bit is cleared. | RO   | 00h     |
|       | This field is cleared when the command completes.                                                                                                                                                                                                                                                |      |         |
|       | This field is cleared when the Graphics Engine Restart (GE_RESTART) bit<br>in Graphic Engine Control Register (GE_CTRL) is set or when the Graphics<br>Engine Enable (GE_ENABLE) bit in Graphic Engine Control Register<br>(GE_CTRL) changes from low to high.                                   |      |         |
| 7:0   | Graphics Engine Command (GE_CMD)<br>Indicates the current command executed. See Graphics Engine Commands<br>for the command values.                                                                                                                                                              | RO   | 00h     |
|       | This field is cleared when the command completes.                                                                                                                                                                                                                                                |      |         |
|       | This field is cleared when the Graphics Engine Restart (GE_RESTART) bit<br>in Graphic Engine Control Register (GE_CTRL) is set or when the Graphics<br>Engine Enable (GE_ENABLE) bit in Graphic Engine Control Register<br>(GE_CTRL) changes from low to high.                                   |      |         |



## 11.12.4 Graphic Engine Command Length Register (GE\_CMD\_LEN)

Address: 00Ch Size:

32 bits

This register reflects the length field of the current drawing command.

| BITS | DESCRIPTION                                                                                                                                                                                                                                                    | TYPE | DEFAULT   |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:0 | Graphics Engine Command Length (GE_CMD_LEN)<br>Indicates the length field of the current command.                                                                                                                                                              | RO   | 00000000h |
|      | This field is cleared when the command completes.                                                                                                                                                                                                              |      |           |
|      | This field is cleared when the Graphics Engine Restart (GE_RESTART) bit<br>in Graphic Engine Control Register (GE_CTRL) is set or when the Graphics<br>Engine Enable (GE_ENABLE) bit in Graphic Engine Control Register<br>(GE_CTRL) changes from low to high. |      |           |



## 11.12.5 Graphic Engine Command Offset Register (GE\_CMD\_OFFSET)

Offset: 010h Size:

32 bits

This register reflects the number of bytes (including the Command and Length fields) that have been read from the FCT for the current drawing command. It is incremented by four for each FCT read.

| BITS | DESCRIPTION                                                                                                                                                                                                                                                    | TYPE | DEFAULT   |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:0 | <b>Graphics Engine Command Offset (GE_CMD_OFFSET)</b><br>Indicates the number of bytes read from the FCT for the current command.<br>In the event of a command error, this field can be used to determine what<br>part of the command was in error.            | RO   | 00000000h |
|      | This field is cleared when the command completes.                                                                                                                                                                                                              |      |           |
|      | This field is cleared when the Graphics Engine Restart (GE_RESTART) bit<br>in Graphic Engine Control Register (GE_CTRL) is set or when the Graphics<br>Engine Enable (GE_ENABLE) bit in Graphic Engine Control Register<br>(GE_CTRL) changes from low to high. |      |           |



# 11.12.6 Graphic Engine Previous Command Info Register (GE\_PREV\_CMD\_INFO)

Offset: 014h Size: 32 bits

This register reflects the sequence number and command values of the last completed drawing command.

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                           | TYPE | DEFAULT |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:16 | Graphics Engine Previous Command Sequence Number<br>(GE_PREV_CMD_SEQ_NUM)<br>Indicates the sequence number of the last completed command. This is valid<br>even if the Graphics Engine Command Sequence Number Enable<br>(GE_CMD_SEQ_EN) bit is cleared.                                                              | RO   | 0000h   |
|       | This field is cleared when the Graphics Engine Restart (GE_RESTART) bit<br>in Graphic Engine Control Register (GE_CTRL) is set or when the Graphics<br>Engine Enable (GE_ENABLE) bit in Graphic Engine Control Register<br>(GE_CTRL) changes from low to high.                                                        |      |         |
| 15:8  | Graphics Engine Previous Command Ones Complement<br>(GE_PREV_CMD_ONES_COMP)<br>The ones complement of the last completed command executed. See<br>Graphics Engine Commands for the command values. This is valid even if<br>the Graphics Engine Command Ones Complement Enable<br>(GE_CMD_ONECOMP_EN) bit is cleared. | RO   | 00h     |
|       | This field is cleared when the Graphics Engine Restart (GE_RESTART) bit<br>in Graphic Engine Control Register (GE_CTRL) is set or when the Graphics<br>Engine Enable (GE_ENABLE) bit in Graphic Engine Control Register<br>(GE_CTRL) changes from low to high.                                                        |      |         |
| 7:0   | <b>Graphics Engine Previous Command (GE_PREV_CMD)</b><br>Indicates the last completed command executed. See Graphics Engine<br>Commands for the command values.                                                                                                                                                       | RO   | 00h     |
|       | This field is cleared when the Graphics Engine Restart (GE_RESTART) bit<br>in Graphic Engine Control Register (GE_CTRL) is set or when the Graphics<br>Engine Enable (GE_ENABLE) bit in Graphic Engine Control Register<br>(GE_CTRL) changes from low to high.                                                        |      |         |



# 11.12.7 Graphic Engine Previous Command Length Register (GE\_PREV\_CMD\_LEN)

018h

Offset:

Size: 32 bits

This register reflects the length field of the last completed drawing command.

| BITS | DESCRIPTION                                                                                                                                                                                                                                                    | TYPE | DEFAULT   |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:0 | Graphics Engine Previous Command Length (GE_PREV_CMD_LEN)<br>Indicates the length field of the last completed command.                                                                                                                                         | RO   | 00000000h |
|      | This field is cleared when the Graphics Engine Restart (GE_RESTART) bit<br>in Graphic Engine Control Register (GE_CTRL) is set or when the Graphics<br>Engine Enable (GE_ENABLE) bit in Graphic Engine Control Register<br>(GE_CTRL) changes from low to high. |      |           |



# 11.12.8 Graphic Engine Previous Command Offset Register (GE\_PREV\_CMD\_OFFSET)

Offset: 01Ch Size: 32 bits

This register reflects the number of bytes (including the Command and Length fields) that have been read from the for the last completed command. It is incremented by four for each FCT read.

| BITS | DESCRIPTION                                                                                                                                                                                                                                                    | TYPE | DEFAULT   |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:0 | <b>Graphics Engine Command Offset (GE_PREV_CMD_OFFSET)</b><br>Indicates the number of bytes read from the FCT for the last completed command.                                                                                                                  | RO   | 00000000h |
|      | This field is cleared when the Graphics Engine Restart (GE_RESTART) bit<br>in Graphic Engine Control Register (GE_CTRL) is set or when the Graphics<br>Engine Enable (GE_ENABLE) bit in Graphic Engine Control Register<br>(GE_CTRL) changes from low to high. |      |           |



## 11.12.9 Graphic Engine Chroma Key High Register (GE\_CHROMA\_KEY\_HIGH)

Offset: 020h Size: 32 bits

This register specifies the high compare values for chroma key operations.

A color match is true when it is less than or equal to the chroma high key and greater than or equal to the chroma low key. An single key value can be tested by setting the high and low values to the same value. Each color component is individually tested and the results ANDed, if enabled. In 24 bpp mode, all 8 bits of each component are used. In 16 bpp mode, the upper 5 bits of red and blue and the upper 6 bits of green are used. In 8 bpp mode, only the blue value is used.

| BITS  | DESCRIPTION                                                                                                                      | TYPE | DEFAULT |
|-------|----------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:24 | RESERVED                                                                                                                         | RO   | -       |
| 23:16 | Graphics Engine Chroma Key Red High<br>(GE_CHROMA_KEY_RED_HIGH)<br>This is the red component of the chroma key high value.       | RW   | 00h     |
| 15:8  | Graphics Engine Chroma Key Green High<br>(GE_CHROMA_KEY_GREEN_HIGH)<br>This is the green component of the chroma key high value. | RW   | 00h     |
| 7:0   | Graphics Engine Chroma Key Blue High<br>(GE_CHROMA_KEY_BLUE_HIGH)<br>This is the blue component of the chroma key high value.    | RW   | 00h     |



## 11.12.10 Graphic Engine Chroma Key Low Register (GE\_CHROMA\_KEY\_LOW)

Offset:

024h

Size:

32 bits

This register specifies the low compare values for chroma key operations.

| BITS  | DESCRIPTION                                                                                                                   | TYPE | DEFAULT |
|-------|-------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:24 | RESERVED                                                                                                                      | RO   | -       |
| 23:16 | Graphics Engine Chroma Key Red Low<br>(GE_CHROMA_KEY_RED_LOW)<br>This is the red component of the chroma key low value.       | RW   | 00h     |
| 15:8  | Graphics Engine Chroma Key Green Low<br>(GE_CHROMA_KEY_GREEN_LOW)<br>This is the green component of the chroma key low value. | RW   | 00h     |
| 7:0   | Graphics Engine Chroma Key Blue Low<br>(GE_CHROMA_KEY_BLUE_LOW)<br>This is the blue component of the chroma key low value.    | RW   | 00h     |



## 11.13 Error Recovery

## 11.13.1 USB 3-Strike Error Recovery

USB could have 3 errored transfers (3 strikes) which would cause the host to abort and stop further transfers. This is not the same as when the device initiates a STALL. From the device standpoint, it looks as if host just stopped sending data, there is no other error indication. It is the S/W driver responsibility to recover from this event

State of the H/W:

At the moment of the 3 strikes, the USB FIFOs (URXs and FCT - external to the Graphics Engine)

- 1 could be empty
- 2 could have an unfinished command (maybe header and a partial command body)
- 3 could have one of more whole commands
- 4 could have one of more whole commands and a partial command (header, partial body)
- 5 etc.

In the absence of a command related error, the USB FIFOs would eventually drain to empty. The interruption in the data stream could occur at various points.

- 1 cleanly between commands (the Command Parser is waiting for a new command). Graphics Engine Command State (GE\_CMD\_STATE) = Idle
- 2- in the command header of a new command (the Command Parser has read the command but is waiting for the length). Graphics Engine Command State (GE\_CMD\_STATE) = Idle
- 3 within the body of a command (the Command Parser has read the length and is waiting for the active co-processor to finish) Graphics Engine Command State (GE\_CMD\_STATE) = Active

Step 1 - The S/W driver may optionally wait until the FCT is empty (via a register external to the Graphics Engine) or until Graphics Engine Command State (GE\_CMD\_STATE) indicates Stall (a command related error could cause a Graphics Engine Stall with data remaining in the FIFO).

Step 2 - The S/W driver should set Graphics Engine Abort (GE\_ABORT) no matter what the above H/W condition. It is acceptable to abort an "in process" command.

- Graphics Engine Command State (GE\_CMD\_STATE) would then indicate Stall with Graphics Engine Error Status (GE\_ERROR\_STAT) would indicating either 14 or 15
- Graphic Engine Command Info Register (GE\_CMD\_INFO), Graphic Engine Command Length Register (GE\_CMD\_LEN) and Graphic Engine Command Offset Register (GE\_CMD\_OFFSET) would show the last command that was started or NULL (if Graphics Engine Error Status (GE\_ERROR\_STAT) = 14)
- Graphic Engine Previous Command Info Register (GE\_PREV\_CMD\_INFO), Graphic Engine Previous Command Length Register (GE\_PREV\_CMD\_LEN) and Graphic Engine Previous Command Offset Register (GE\_PREV\_CMD\_OFFSET) would show the last completed command

Step 3 - The S/W driver should wait until Graphics Engine Write Master State (GE\_WR\_MASTER\_STATE) and Graphics Engine Read Master State (GE\_RD\_MASTER\_STATE) indicate idle.

Step 4 - The S/W driver may optionally clear Graphics Engine Enable (GE\_ENABLE).

Step 5 - The S/W driver should flush the USB FIFO by setting the FCT RX FIFO Reset (FCT\_RX\_RESET) bit of the FIFO Status Register (FIFO\_STATUS). This should always be done just in case the Graphics Engine stalled due to command related error in step 1.

Step 6 - The S/W driver should perform a ClearFeature STALL for BULK EP on the host. This will resync the USB seq# and Data Toggle between the host and device.



Step 7 - The S/W driver should re-initialize the command sequence number via Graphics Engine Initial Command Sequence Number (GE\_INIT\_CMD\_SEQ\_NUM).

Note that the S/W driver should restart commands following the last successful command in order to avoid repeating any commands that have already been executed. This is especially important for Wait For Event commands which specify an event that might have already happened.

Step 8 - The S/W driver should set Graphics Engine Restart (GE\_RESTART).

Step 9 - The S/W driver should set Graphics Engine Enable (GE\_ENABLE) if it was cleared in step 4.

Step 10 - The S/W driver should restart USB transfers.



# Chapter 12 I<sup>2</sup>C Controller

## 12.1 I<sup>2</sup>C Controller Overview

The device includes a dedicated I<sup>2</sup>C controller with a simple two-wire master/slave serial interface. The I<sup>2</sup>C controller conforms to the Philips *I2C-Bus Specification*, consisting of a serial data line (I2CSDA), and a serial clock (I2CSCL). These wires carry information between the devices connected to the bus. The source/destination of the I2CSDA and I2CSCL signals are external pins, corresponding to two separate I<sup>2</sup>C channels. The setting of the I2C Interface Selection Register (I2C\_SEL) determines which set of external data and clock pins (I2CSDA0, I2CSCL0 or I2CSDA1, I2CSCL1), corresponding to the I<sup>2</sup>C channels, will be connected to the I2CSDA and I2CSCL signals. Please refer to Figure 12.1 I2C Block Diagram on page 250 for details.

Each device on the  $l^2C$  bus, including the UFX6000, is recognized by a unique address and can operate as either a transmitter or receiver, depending on the function of the device. The UFX6000 can be configured as a master, a slave, or both. When in master mode, it is the responsibility of the  $l^2C$  controller to generate the I2CSCL clock. Both slave and master devices are capable of being either a transmitter or receiver. Thus, four distinct modes are available: slave-receiver, slave-transmitter, master-receiver, and master-transmitter. These modes can be selected via the  $l^2C$  control and status registers (CSRs).

The I<sup>2</sup>C controller communicates at the I<sup>2</sup>C standard mode speed of 100 Kb/s. Because fast mode (400Kb/s) and high-speed mode (3.4Mb/s) devices are downward compatible with the standard mode speed of 100 Kb/s, they are able to communicate with the device's I<sup>2</sup>C controller on 100 Kb/s I<sup>2</sup>C bus systems. However, as noted in the *I2C-Bus Specification*, standard mode devices are not upward compatible and should not be incorporated in fast or high-speed mode I<sup>2</sup>C bus systems.

The  $l^2C$  controller supports multiple master arbitration. Any  $l^2C$  device can be attached to an  $l^2C$  bus and every device can talk with any master, passing information back and forth. There needs to be at least one master on the bus, but multiple masters are allowable by requiring each master to arbitrate for ownership. The  $l^2C$  controller also supports the 7-bit and 10-bit addressing modes of the  $l^2C$ specification. These modes can be configured independently for the slave and master via CSRs.

All functions of the  $I^2C$  are configurable via their respective CSRs and data to be transmitted or received via the  $I^2C$  interface is accessible here.

The  $I^2C$  controller contains many interruptible conditions that can be individually masked and cleared via their respective CSRs. When one or more interrupt conditions are met, a single interrupt output I2C\_INT is sent to the USB interrupt endpoint. The source of an interrupt can be determined via the interrupt status registers. The  $I^2C$  interrupts are explained in detail in Section 12.4.6, "Interrupt Operation".

For more information about the I<sup>2</sup>C specification, including addressing protocols, transmitting and receiving data protocols, multiple master arbitration and clock synchronization, refer to the Philips *I2C-Bus Specification*.



## 12.2 I<sup>2</sup>C Sub-Modules

A top level block diagram of the  $l^2C$  controller, including it's various sub-modules, is provided in Figure 12.1. The  $l^2C$  controller is responsible for the control and flow of data to/from the  $l^2C$  serial interface and the generation of interrupts based on configurable conditions. There are 5 main sub-modules of the  $l^2C$ ; the control block,  $l^2C$  mode logic,  $l^2C$  data control logic, clock generator, and interrupt controller. Detailed descriptions of each module's functions and various I/O signals are provided in the following sections.



Figure 12.1 I<sup>2</sup>C Block Diagram

## 12.2.1 Control Block

The control block consists of a slave controller and a bank of control and status registers. These registers are responsible for all  $I^2C$  related communication and configuration. Control and status signals from the control block are applied throughout the  $I^2C$  controller sub-modules. For a detailed description of each  $I^2C$  register, refer to Section 12.5, "I2C Register Descriptions".

## 12.2.2 Interrupt Controller

The interrupt controller block is used to generate an interrupt based upon various configurable conditions within the  $l^2C$  controller. The  $l^2C$  interrupt (I2C\_INT) indicates to the USB interrupt control endpoint that an interrupt condition occurred. The specific cause of the  $l^2C$  interrupt can be determined by reading the Masked Interrupt Status Register (I2C\_MIS).

Each interrupt can be individually enabled by setting the appropriate mask bit to 1 in the Interrupt Mask Register (I2C INTR MASK). Conditions that can be configured to generate interrupts include:

- I<sup>2</sup>C line special condition detection (START/RESTART, STOP, General Call)
- Rx/Tx conditions (read request, Rx acknowledge error, Tx abort)
- Rx/Tx FIFO buffer conditions (empty, full, threshold level)

Interrupts are clearable via their respective interrupt clear registers. Some interrupts are clearable via hardware only. For more information on how to configure and operate the I<sup>2</sup>C interrupts, refer to Section 12.4.6, "Interrupt Operation".



## 12.2.3 I<sup>2</sup>C Mode Logic

The I<sup>2</sup>C mode logic block is responsible for following the I<sup>2</sup>C protocol of both a slave and master device. This block contains two controllers, a master device controller and a slave device controller. The master controller is responsible for generating the I<sup>2</sup>C protocol for master transfers, while the slave controller follows the protocol for a slave and monitors the bus for an address match. The master and slave controllers are configured and enabled/disabled via the I<sup>2</sup>C CSRs. The I<sup>2</sup>C mode logic sends and receives the I<sup>2</sup>C data to/from the I<sup>2</sup>C data control logic block, where it is transported across the I2CSDA line.

## 12.2.4 I<sup>2</sup>C Data Control Logic

The I<sup>2</sup>C data control logic block is responsible for transporting the I<sup>2</sup>C data between the I2CSDA data line and the I2C mode logic slave and master controllers. The I<sup>2</sup>C data logic block contains two FIFO buffers, one for storing received data (RX FIFO) and one for storing data to be transmitted (TX FIFO). The RX FIFO is 8-bits wide and has a buffer depth of 16. The TX FIFO is 9-bits wide (1 extra bit for command type) and has a buffer depth of 16.

Shifting logic is also contained within this block. The Rx shift logic receives incoming serialized data from the I2CSDA line and converts it to byte format for loading into the RX FIFO. The Tx shift logic converts the TX FIFO byte formatted data into a serialized format for transmission over the I2CSDA line.

## 12.2.5 Clock Generator

The clock generator logic block controls and monitors the I2CSCL line and calculates the required timing to do the following:

- Generate the I2CSCL clock when configured as a master
- Check for bus idle
- Generate a START and STOP
- Setup the data and hold the data

The clock generator is configured via the I<sup>2</sup>C CSR's. For more information on configuring the I2CSCL clock, refer to Section 12.4.5, "I2CSCL Frequency Configuration".

## 12.3 I<sup>2</sup>C Terminology

The I<sup>2</sup>C specification contains its own unique set of specific terminology. The following terms are used throughout this chapter and are defined as follows:

## 12.3.1 I<sup>2</sup>C Bus Terms

The following terms relate to the role of the  $I^2C$  device and how it interacts with other  $I^2C$  devices on the bus.

**Transmitter** - A device that sends data to the bus. A transmitter can either be a device that initiates the data transmission to the bus (a master-transmitter) or responds to a request from the master to send data to the bus (a slave-transmitter).

**Receiver** - A device that receives data from the bus. A receiver can either be a device that receives data on its own request (a master-receiver) or in response to a request from the master (a slave receiver).

**Master** - The master initializes a transfer (START command), generates the clock signal (I2CSCL) and terminates the transfer (STOP command). A master can be either a transmitter or a receiver.

Slave - A device addressed by the master. A slave can be either a receiver or transmitter.



## 12.3.2 I2C Bus Transfer Terms

The following terms are specific to data transfers that occur to/from the  $\mathsf{I}^2\mathsf{C}$  bus.

**START (RESTART)** - Data transfer begins with a START or RESTART condition. The level of the SDA data line changes from high to low, while the SCL clock line remains high. When this occurs, the bus becomes busy.

**Note:** The RESTART condition of the I<sup>2</sup>C controller is the same behavior as the REPEAT START condition described in the Philips *I2C-Bus Specification*. START and RESTART conditions are functionally identical.

**STOP** - Data transfer is terminated by a STOP condition. This occurs when the level on the SDA data line passes from the low state to the high state, while the I2CSCL clock line remains high. When the data transfer has been terminated, the bus is free or idle once again. The bus stays busy if a RESTART is generated instead of a STOP condition.

## 12.4 I<sup>2</sup>C Operation

The following sections describe the operation of the  $I^2C$  controller:

- Slave Mode Operation
- Master Mode Operation
- Prioritizing Slave-Transmit Operation Over Master-Receiver Operation
- Disabling the I2C Controller
- I2CSCL Frequency Configuration
- Interrupt Operation

## 12.4.1 Slave Mode Operation

The following sections describe the initial configuration, slave-transmitter and slave-receiver operations.

#### 12.4.1.1 Initial Configuration

To use the I<sup>2</sup>C controller as a slave, perform the following steps:

- 1. Disable the I<sup>2</sup>C controller by writing a 0 to bit 0 of the I2C\_ENABLE register.
- Write to the I2C\_SAR register (bits 9:0) to set the slave address. This is the address to which the I<sup>2</sup>C controller responds.
- Write to the I2C\_CON register to specify which type of addressing is supported (7 or 10-bit by setting bit 3) and whether the I<sup>2</sup>C controller is in slave only (by writing a 0 to bit 6) or master slave mode (by writing a 0 to bit 6 and a 1 to bit 0).
- **Note:** Slaves and masters do not have to be programmed with the same type of addressing 7 or 10bit address. For instance, a slave can be programmed with 7-bit addressing and a master with 10-bit addressing, and vice versa.
- 4. Enable the I<sup>2</sup>C controller by writing a 1 in bit 0 of the I2C\_ENABLE register.

#### 12.4.1.2 Slave-Transmitter Operation for a Single Byte

When another  $I^2C$  master device on the bus addresses the  $I^2C$  and requests data, the  $I^2C$  controller acts as a slave transmitter and the following steps occur:

1. The other I<sup>2</sup>C master device initiates an I<sup>2</sup>C transfer with an address that matches the slave address in the I<sup>2</sup>C\_SAR register of the I<sup>2</sup>C controller.



- 2. The I<sup>2</sup>C controller acknowledges the sent address and recognizes the direction of the transfer to indicate that it is acting as a slave transmitter.
- 3. The I<sup>2</sup>C controller asserts the RD\_REQ interrupt (bit 5 of the I2C\_RIS register) and holds the I2CSCL line low. It is in a wait state until software responds.

If the RD\_REQ interrupt has been masked, due to the I2C\_INTR\_MASK[5] register (M\_RD\_REQ bit field) being cleared to 0, then it is recommended that a hardware and/or software timing routine be used to instruct the CPU to perform periodic reads of the I2C\_RIS register.

- a. Reads that indicate I2C\_RIS[5] (R\_RD\_REQ bit field) being set to 1 must be treated as the equivalent of the RD\_REQ interrupt being asserted.
- b. Software must then act to satisfy the I<sup>2</sup>C transfer.
- c. The timing interval used should be in the order of 10 times the I2CSCL clock period. For 100 kb/s, the clock period is 10µs. Therefore, a timing interval on the order of 100µs should be used.
- If there is any data remaining in the TX FIFO before receiving the read request, then the I<sup>2</sup>C controller asserts a TX\_ABRT interrupt (bit 6 of the I2C\_RIS register) to flush the old data from the TX FIFO.

If the TX\_ABRT interrupt has been masked, due to the I2C\_INTR\_MASK[6] register (M\_TX\_ABRT bit field) being set to 0, it is recommended to re-use the timing routine (described in the previous step), or a similar one, to read the I2C\_RIS register.

- a. Reads that indicate bit 6 (R\_TX\_ABRT) being set to 1 must be treated as the equivalent of the TX\_ABRT interrupt being asserted.
- b. There is no further action required from software.
- c. The timing interval used should be similar to that described in the previous step for the I2C\_RIS[5] register.
- 5. Software writes the I2C\_DATA\_CMD register with the data to be written (by writing a 0 in bit 8).
- 6. Software must clear the RD\_REQ and TX\_ABRT interrupts (bits 5 and 6, respectively) of the I2C\_RIS register before proceeding.

If the RD\_REQ and/or TX\_ABRT interrupts have been masked, then clearing of the I2C\_RIS register will have already been performed when either the R RD REQ or R TX ABRT bit has been read as 1.

- 7. The  $I^2C$  controller releases the I2CSCL and transmits the byte.
- 8. The master may hold the I<sup>2</sup>C bus by issuing a RESTART condition or release the bus by issuing a STOP condition.

#### 12.4.1.3 Slave-Receiver Operation for a Single Byte

When another  $I^2C$  master device on the bus addresses the  $I^2C$  controller and is sending data, the  $I^2C$  controller acts as a slave receiver and the following steps occur:

- 1. The other I<sup>2</sup>C master device initiates an I<sup>2</sup>C transfer with an address that matches the I<sup>2</sup>C controllers slave address in the I2C\_SAR register.
- 2. The I<sup>2</sup>C controller acknowledges the sent address and recognizes the direction of the transfer to indicate that the I<sup>2</sup>C controller is acting as a slave receiver.
- 3. The I<sup>2</sup>C controller receives the transmitted byte and places it in the receive buffer, assuming there is enough space.
- 4. The I<sup>2</sup>C controller asserts the RX\_FULL interrupt (I2C\_RIS[2] register).
- **Note:** For the RX\_FULL interrupt to operate correctly, when 1 byte is received, the I2C\_RX\_TL register must be written with and/or reset to a value of 0 before the Slave-Receiver operation begins.

If the RX\_FULL interrupt has been masked, due to setting I2C\_INTR\_MASK[2] register to 0 or setting I2C\_TX\_TL to a value larger than 0, then it is recommended that a timing routine (described in Section 12.4.1.2, "Slave-Transmitter Operation for a Single Byte") be implemented for periodic reads of the



I2C\_STATUS register. Reads of the I2C\_STATUS register, with bit 3 (RFNE) set at 1, must then be treated by software as the equivalent of the RX\_FULL interrupt being asserted.

- 5. Software may read the byte from the I2C\_DATA\_CMD register (bits 7:0).
- 6. The other master device may hold the I<sup>2</sup>C bus by issuing a RESTART condition or release the bus by issuing a STOP condition.

#### 12.4.1.4 Slave Bulk Transmit Mode

In the standard  $I^2C$  protocol, all transactions are single byte transactions and the programmer responds to a remote master read request by writing one byte into the slave's TX FIFO. When a slave (slavetransmitter) is issued a read request from the remote master (master-receiver), at a minimum there should be one entry placed into the slave-transmitter's TX FIFO. The  $I^2C$  controller is designed to handle more data in the TX FIFO so that subsequent read requests can take that data without raising an interrupt to get more data. Ultimately, this eliminates the possibility of significant latencies being incurred between raising the interrupt for data each time, had there been a restriction of having only one entry placed in the TX FIFO.

This mode only occurs when the I<sup>2</sup>C controller is acting as a slave-transmitter. If the slave-transmitter acknowledges the data sent by the remote master and there is no data in the slave's TX FIFO, the slave must hold the I2CSCL line low while it raises the read request interrupt (RD\_REQ) and waits for data to be populated in the TX FIFO before it can be sent to the master.

If the RD\_REQ interrupt is masked, due to bit 5 (M\_RD\_REQ) of the I2C\_INTR\_MASK register being set to 0, then it is recommended that a timing routine be used to activate periodic reads of the I2C\_RIS register. Reads of I2C\_RIS that return bit 5 (R\_RD\_REQ) set to 1, must be treated as the equivalent of the RD\_REQ interrupt referred to in this section. This timing routine is similar to that described in Section 12.4.1.2, "Slave-Transmitter Operation for a Single Byte".

The RD\_REQ interrupt is raised upon a read request, and like interrupts, must be cleared when exiting the interrupt service handling routine (ISR). The ISR should allow for the writing of 1 byte or more into the TX FIFO. During the transmission of these bytes to the master, if the master acknowledges the last byte, then the slave must re-raise the RD\_REQ because the master is looking for more data.

If the programmer knows in advance that the remote master is requesting a packet of n bytes, then when another master addresses the I<sup>2</sup>C controller and requests data, the TX FIFO can be written with n number bytes and the remote master receives it as a continuous stream of data. For example, the I<sup>2</sup>C slave controller continues to send data to the remote master as long as the remote master is acknowledging the data sent, and there is data available in the TX FIFO. There is no need to hold the I2CSCL line low or to issue RD\_REQ again.

If the remote master is to receive n bytes from the  $I^2C$  controller but the programmer wrote a number of bytes larger than n to the TX FIFO, when the slave finishes sending the requested n bytes, it clears the TX FIFO and ignores any excess bytes.

There is no interrupt to signify the clearing of the TX FIFO in this example. At the time an ACK/NACK is expected, if a NACK is received, then the remote master has all the data it wants. At this time, a flag is raised within the slave controller to clear the leftover data. The contents of the TX FIFO are cleared at that time. This prevents the master controller within the  $I^2C$  controller from thinking it has data to send when it does not.

#### 12.4.2 Master Mode Operation

The following sections describe the initial configuration and master transmit and receive operations.

#### 12.4.2.1 Initial Configuration

To use the I<sup>2</sup>C controller as a master, perform the following steps:

1. Disable the  $I^2C$  controller by writing 0 to the I2C\_ENABLE register.



- 2. Write to the I2C\_SAR register to set the slave address, which is the address to which the I<sup>2</sup>C controller responds.
- **Note:** Slaves and masters do not have to be programmed with the same type of addressing (7 or 10bit). For instance, a slave can be programmed with 7-bit addressing and a master with 10-bit addressing, and vice versa.
- Write to the I2C\_TAR register the address of the I<sup>2</sup>C device to be addressed (bits 9:0). This register also indicates whether a General Call or a START BYTE command is going to be performed by the I<sup>2</sup>C controller.
- 4. Enable the I<sup>2</sup>C controller by writing a 1 in bit 0 of the I2C\_ENABLE register.
- 5. Now write the transfer direction command bit (CMD) and the data to be sent into the I2C\_DATA\_CMD register. If the I2C\_DATA\_CMD register is written before the I<sup>2</sup>C controller is enabled, the data and commands are lost, as the buffers are kept cleared when the I<sup>2</sup>C controller is disabled. This step generates the START condition and the address byte. Once the I<sup>2</sup>C controller is enabled and there is data in the TX FIFO, the I<sup>2</sup>C controller starts reading the data.

#### 12.4.2.2 Master-Transmitter and Master-Receiver Operation

The I<sup>2</sup>C controller supports switching back and forth between reading and writing dynamically. To transmit data, write the data to be written to the lower byte of the Rx/Tx Data Buffer and Command Register (I2C\_DATA\_CMD). The CMD bit [8] should be written to 0 for write operations. Subsequently, a read command may be issued by writing "don't cares" to the lower byte of the I2C\_DATA\_CMD register, and a 1 should be written to the CMD bit. As data is transmitted and received, the transmit and receive buffer status bits and interrupts change. When the I<sup>2</sup>C controller is enabled by writing 1 in bit 0 of the I2C\_ENABLE register and there is data in the TX FIFO, a START is generated. When the TX FIFO becomes empty, a STOP is generated.

#### 12.4.3 Prioritizing Slave-Transmit Operation Over Master-Receiver Operation

In the event that the I2C\_DATA\_CMD register is written to in order to perform a master-receive operation (I2C\_DATA\_CMD[8] is set to 1) while a coincident I<sup>2</sup>C slave-transmit operation occurs in the I<sup>2</sup>C controller, the component's hardware treats the slave-transmit operation to be of a higher priority. In this type of scenario, the following occurs:

- 1. The I2C\_DATA\_CMD write (bit 8 set to 1) is ignored.
- 2. A TX\_ABRT interrupt (if not masked) is generated.
- 3. I2C\_TX\_ABRT\_SRC[15] (ABRT\_SLVRD\_INTX) is set to 1.
- 4. I2C\_RIS[6] (TX\_ABRT) is set to 1.
- 5. A RD\_REQ interrupt (if not masked) is generated.

To summarize, the write to the I2C\_DATA\_CMD is ignored, and I<sup>2</sup>C controller requires servicing as per any normal I<sup>2</sup>C Slave-Transmit operation. Note that due to the latter, the I<sup>2</sup>C controller forces I2CSCL low.

#### 12.4.4 Disabling the I<sup>2</sup>C Controller

To properly disable the I<sup>2</sup>C controller, follow these steps:

- 1. Define a timer interval equal to 10 times the I2CSCL clock period. For 100 kb/s, the clock period is 10µs. Therefore, a timing interval on the order of 100µs should be used.
- 2. Define a maximum time-out parameter, MAX\_T\_POLL\_COUNT, such that if any repeated polling operation exceeds this maximum value, an error is reported.
- 3. Execute a blocking thread/process/function that prevents any further I<sup>2</sup>C master transactions from being started by software, but allows any pending transfers to be completed.
- 4. Create a variable POLL\_COUNT and initialize it to zero.

- 5. Read the I2C\_ENABLE\_STATUS register and test the I2C\_EN bit (bit 0). Increment POLL\_COUNT by one. If POLL\_COUNT >= MAX\_T\_POLL\_COUNT, exit with the relevant error code. If I2C\_EN is 0, then the I<sup>2</sup>C controller is disabled and the routine may be exited with a relevant success code.
- 6. If I2C\_ENABLE\_STATUS[0] is 1, then sleep for the specified timer interval and proceed to the previous step.

#### 12.4.5 I2CSCL Frequency Configuration

When the I<sup>2</sup>C controller is configured as a master, the \*CNT registers must be set before any I<sup>2</sup>C bus transaction can take place to ensure proper I2CSCL clock timing. The \*CNT registers are:

- I2C\_SS\_SCL\_HCNT
- I2C\_SS\_SCL\_LCNT

Setting the I2C\_SS\_SCL\_LCNT register configures the number of I<sup>2</sup>C Clock cycles that are required for setting the low time of the I2CSCL clock. Setting the I2C\_SS\_SCL\_HCNT register configures the number of I<sup>2</sup>C Clock cycles that are required for setting the high time of the I2CSCL clock. The recommended values of I2C\_SS\_SCL\_HCNT and I2C\_SS\_SCL\_LCNT should be set for 100Kb/s standard speed communication at the frequency of the input I<sup>2</sup>C Clock, which is fixed at 2.08 MHz. The recommended values are stated in the text accompanying the definition of these registers.

**Note:** The count registers can be written only when the I<sup>2</sup>C interface has been disabled. This is accomplished by clearing bit 0 of the I2C\_ENABLE register. Writes at other times have no effect.

#### 12.4.6 Interrupt Operation

The I<sup>2</sup>C controller contains the ability to generate interrupts based on a variety of conditions within the I<sup>2</sup>C controller. The I<sup>2</sup>C interrupt (I2C\_INT) indicates to the interrupt control endpoint that an interrupt condition occurred. The specific cause of the I<sup>2</sup>C interrupt can be determined by reading the Masked Interrupt Status Register (I2C\_MIS).

Each interrupt can be individually enabled by setting the appropriate mask bit to 1 in the Interrupt Mask Register (I2C\_INTR\_MASK). At any time, the status of the interrupt mask can be read from I2C\_INTR\_MASK. Both the raw interrupt status (prior to masking) and the final interrupt status (after masking) can be read from the Raw Interrupt Status Register (I2C\_RIS) and the Masked Interrupt Status Register (I2C\_MIS) respectively. Conditions that can be configured to generate interrupts include:

- I<sup>2</sup>C line special condition detection (START/RESTART, STOP, General Call)
- Rx/Tx conditions (read request, Rx acknowledge error, Tx abort)
- Rx/Tx FIFO buffer conditions (empty, full, threshold level)

For a detailed explanation of each configurable interrupt source, refer to the Raw Interrupt Status Register (I2C\_RIS) in Section 12.5, "I2C Register Descriptions".

Upon detection of an interrupt event, as configured by in I2C\_INTR\_MASK, the I2C\_INT interrupt is generated. The I2C\_INT signal is sent to the USB interrupt endpoint for further processing. If the interrupt is software clearable, it can be cleared by reading it's corresponding interrupt clear register, or the Clear Interrupt Register (I2C\_CLR\_INTR) which clears all software interrupts. If the interrupt is clearable by hardware only, the interrupt will be cleared automatically when the interrupt bits are cleared by software, however some interrupt bits are cleared by hardware only. Table 12.1 shows how each I<sup>2</sup>C interrupt is cleared. For interrupts that are cleared by software, the corresponding clear interrupt registers that will clear the interrupt are listed. Interrupts that are cleared by hardware will be specified as such.



| INTERRUPT BIT FIELD | CLEARING METHOD                   |
|---------------------|-----------------------------------|
| GEN_CALL            | I2C_CLR_GEN_CALL or I2C_CLR_INTR  |
| START_DET           | I2C_CLR_START_DET or I2C_CLR_INTR |
| STOP_DET            | I2C_CLR_STOP_DET or I2C_CLR_INTR  |
| ACTIVITY            | I2C_CLR_ACTIVITY or Hardware      |
| RX_DONE             | I2C_CLR_RX_DONE or I2C_CLR_INTR   |
| TX_ABRT             | I2C_CLR_TX_ABRT or I2C_CLR_INTR   |
| RD_REQ              | I2C_CLR_RD_REQ or I2C_CLR_INTR    |
| TX_EMPTY            | Hardware                          |
| TX_OVER             | I2C_CLR_TX_OVER or I2C_CLR_INTR   |
| RX_FULL             | Hardware                          |
| RX_OVER             | I2C_CLR_RX_OVER or I2C_CLR_INTR   |
| RX_UNDER            | I2C_CLR_RX_UNDER or I2C_CLR_INTR  |

#### Table 12.1 Clearing Method of I2C Interrupts

- **Note:** Refer to bit 9 of the Transmit Abort Source Register (I2C\_TX\_ABRT\_SRC) for an exception to clearing the TX ABRT interrupt.
- **Note:** The ACTIVITY interrupt can be cleared via the Clear ACTIVITY Interrupt Register (I2C\_CLR\_ACTIVITY) but will also be automatically cleared by hardware when the I<sup>2</sup>C controller is disabled and there is no further activity on the bus.

## 12.5 I<sup>2</sup>C Register Descriptions

This section describes the various  $I^2C$  control and status registers. Some registers may be written only when the  $I^2C$  is disabled, as programmed by the I2C\_ENABLE register. Software should not disable the  $I^2C$  while it is active. If the  $I^2C$  is in the process of transmitting when it is disabled, it stops and deletes the contents of the transmit buffer after the current transfer is complete. In slave mode, the  $I^2C$  continues receiving until the remote master aborts the transfer, in which case the  $I^2C$  will then be disabled. Registers that cannot be written to when the  $I^2C$  is enabled are indicated in their descriptions.

Table 12.2 lists the control and status registers of the  $I^2C$  controller and their corresponding addresses. All  $I^2C$  control and status registers are reset to their default values on assertion of a chip-level reset.  $I^2C$  registers must be read and written using naturally aligned 32-bit transfers.

|                                                    | ADDRESS SYMBOL REGISTER NAME |                                  | REGISTER NAME                           |
|----------------------------------------------------|------------------------------|----------------------------------|-----------------------------------------|
| 1000h I2C_CONTROL Control Register, Section 12.5.1 |                              | Control Register, Section 12.5.1 |                                         |
| 1004h I2C_TAR                                      |                              | I2C_TAR                          | Target Address Register, Section 12.5.2 |
|                                                    | 1008h I2C_SAR                |                                  | Slave Address Register, Section 12.5.3  |
| 100Ch RESERVED Reserved for future expansion       |                              | Reserved for future expansion    |                                         |

#### Table 12.2 I<sup>2</sup>C Register Map



| ADDRESS       | SYMBOL            | REGISTER NAME                                          |
|---------------|-------------------|--------------------------------------------------------|
| 1010h         | I2C_DATA_CMD      | Rx/Tx Data Buffer and Command Register, Section 12.5.4 |
| 1014h         | I2C_SCL_HCNT      | SCL Clock High Count Register, Section 12.5.5          |
| 1018h         | I2C_SCL_LCNT      | SCL Clock Low Count Register, Section 12.5.6           |
| 101Ch - 1028h | RESERVED          | Reserved for future expansion                          |
| 102Ch         | I2C_MIS           | Masked Interrupt Status Register, Section 12.5.7       |
| 1030h         | I2C_INTR_MASK     | Interrupt Mask Register, Section 12.5.8                |
| 1034h         | I2C_RIS           | Raw Interrupt Status Register, Section 12.5.9          |
| 1038h         | I2C_RX_TL         | Receive FIFO Threshold Register, Section 12.5.10       |
| 103Ch         | I2C_TX_TL         | Transmit FIFO Threshold Register, Section 12.5.11      |
| 1040h         | I2C_CLR_INTR      | Clear Interrupt Register, Section 12.5.12              |
| 1044h         | I2C_CLR_RX_UNDER  | Clear RX_UNDER Interrupt Register, Section 12.5.13     |
| 1048h         | I2C_CLR_RX_OVER   | Clear RX_OVER Interrupt Register, Section 12.5.14      |
| 104Ch         | I2C_CLR_TX_OVER   | Clear TX_OVER Interrupt Register, Section 12.5.15      |
| 1050h         | I2C_CLR_RD_REQ    | Clear RD_REQ Interrupt Register, Section 12.5.16       |
| 1054h         | I2C_CLR_TX_ABRT   | Clear TX_ABRT Interrupt Register, Section 12.5.17      |
| 1058h         | I2C_CLR_RX_DONE   | Clear RX_DONE Interrupt Register, Section 12.5.18      |
| 105Ch         | I2C_CLR_ACTIVITY  | Clear ACTIVITY Interrupt Register, Section 12.5.19     |
| 1060h         | I2C_CLR_STOP_DET  | Clear STOP_DET Interrupt Register, Section 12.5.20     |
| 1064h         | I2C_CLR_START_DET | Clear START_DET Interrupt Register, Section 12.5.21    |
| 1068h         | I2C_CLR_GEN_CALL  | Clear GEN_CALL Interrupt Register, Section 12.5.22     |
| 106Ch         | I2C_ENABLE        | Enable Register, Section 12.5.23                       |
| 1070h         | I2C_STATUS        | Status Register, Section 12.5.24                       |
| 1074h         | I2C_TX_FLR        | Transmit FIFO Level Register, Section 12.5.25          |
| 1078h         | I2C_RX_FLR        | Receive FIFO Level Register, Section 12.5.26           |
| 107Ch         | RESERVED          | Reserved for future expansion                          |
| 1080h         | I2C_TX_ABRT_SRC   | Transmit Abort Source Register, Section 12.5.27        |
| 1084h - 1090h | RESERVED          | Reserved for future expansion                          |
| 1094h         | I2C_SDA_SETUP     | SDA Setup Register, Section 12.5.28                    |
| 1098h         | I2C_ACK_GEN_CALL  | ACK General Call Register, Section 12.5.29             |
| 109Ch         | I2C_ENABLE_STATUS | Enable Status Register, Section 12.5.30                |
| 10A0h - 10FCh | RESERVED          | Reserved for future expansion                          |
| 1100h         | I2C_ACCESS        | Access Module Register, Section 12.5.31                |

#### Table 12.2 I<sup>2</sup>C Register Map (continued)



| ADDRESS       | SYMBOL          | REGISTER NAME                                |
|---------------|-----------------|----------------------------------------------|
| 1104h         | I2C_PIN         | Pin Control Register, Section 12.5.32        |
| 1108h - 110Ch | RESERVED        | Reserved for future expansion                |
| 1110h         | I2C_SEQ_DATA_0  | Sequential Data 0 Register, Section 12.5.33  |
| 1114h         | I2C_SEQ_DATA_1  | Sequential Data 1 Register, Section 12.5.34  |
| 1118h         | I2C_SEQ_DATA_2  | Sequential Data 2 Register, Section 12.5.35  |
| 111Ch         | I2C_SEQ_DATA_3  | Sequential Data 3 Register, Section 12.5.36  |
| 1120h         | I2C_SEQ_DATA_4  | Sequential Data 4 Register, Section 12.5.37  |
| 1124h         | I2C_SEQ_DATA_5  | Sequential Data 5 Register, Section 12.5.38  |
| 1128h         | I2C_SEQ_DATA_6  | Sequential Data 6 Register, Section 12.5.39  |
| 112Ch         | I2C_SEQ_DATA_7  | Sequential Data 7 Register, Section 12.5.40  |
| 1130h         | I2C_SEQ_DATA_8  | Sequential Data 8 Register, Section 12.5.41  |
| 1134h         | I2C_SEQ_DATA_9  | Sequential Data 9 Register, Section 12.5.42  |
| 1138h         | I2C_SEQ_DATA_10 | Sequential Data 10 Register, Section 12.5.43 |
| 113Ch         | I2C_SEQ_DATA_11 | Sequential Data 11 Register, Section 12.5.44 |
| 1140h         | I2C_SEQ_DATA_12 | Sequential Data 12 Register, Section 12.5.45 |
| 1144h         | I2C_SEQ_DATA_13 | Sequential Data 13 Register, Section 12.5.46 |
| 1148h         | I2C_SEQ_DATA_14 | Sequential Data 14 Register, Section 12.5.47 |
| 114Ch         | I2C_SEQ_DATA_15 | Sequential Data 15 Register, Section 12.5.48 |

#### Table 12.2 I<sup>2</sup>C Register Map (continued)



### 12.5.1 Control Register (I2C\_CONTROL)

Offset: 0000h Size: 32 bits

This read/write register is responsible for enabling or disabling the master and slave modes as well as the selection of 7 or 10-bit addressing for each mode. The ability to send RESTART conditions when acting as a master is also selectable here. This register can be written only when the I<sup>2</sup>C interface has been disabled. This is accomplished by clearing bit 0 of the I2C ENABLE register.

See the bit descriptions below for additional information on these modes.

| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                            | TYPE | DEFAULT |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:7 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                               | RO   | -       |
| 6    | <b>Slave Mode (I2C_SLAVE_DISABLE)</b><br>This bit controls the enabling and disabling of the I <sup>2</sup> C slave mode. If this bit is set, the I <sup>2</sup> C functions only as a master and does not perform any action that requires a slave. The slave mode is enabled (set to 0) on reset by default. This bit needs only to be written after reset if slave mode is to be disabled.                                                          | R/W  | Ob      |
|      | 0: Slave enabled<br>1: Slave disabled                                                                                                                                                                                                                                                                                                                                                                                                                  |      |         |
| 5    | <b>RESTART Enable (I2C_RESTART_EN)</b><br>This bit determines whether RESTART conditions may be sent when acting<br>as a master.                                                                                                                                                                                                                                                                                                                       | R/W  | 1b      |
|      | 0: RESTART disabled<br>1: RESTART enabled                                                                                                                                                                                                                                                                                                                                                                                                              |      |         |
|      | <ul><li>When RESTART is disabled, the master is prohibited from performing the following functions:</li><li>Change direction within a transfer (split)</li></ul>                                                                                                                                                                                                                                                                                       |      |         |
|      | <ul> <li>Send a START byte</li> <li>Combined format transfers in 7 bit addressing medea</li> </ul>                                                                                                                                                                                                                                                                                                                                                     |      |         |
|      | <ul> <li>Combined format transfers in 7-bit addressing modes</li> <li>Read operation with a 10-bit address</li> </ul>                                                                                                                                                                                                                                                                                                                                  |      |         |
|      | <ul> <li>Send multiple bytes per transfer</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                   |      |         |
|      | By replacing RESTART conditions with a STOP and a subsequent START condition, split operations are broken down into multiple I <sup>2</sup> C transfers. If the above operations are performed, it will result in setting bit 6 (TX_ABRT) of the I2C_RIS register.                                                                                                                                                                                     |      |         |
|      | <b>Note:</b> Some older slaves do not support handling RESTART conditions.<br>However, RESTART conditions are used in several I <sup>2</sup> C operations.                                                                                                                                                                                                                                                                                             |      |         |
| 4    | <b>Master Address Mode (I2C_10BITADDR_MASTER)</b><br>This bit controls the addressing mode of the I <sup>2</sup> C when acting as a master.                                                                                                                                                                                                                                                                                                            | R/W  | 1b      |
|      | 0: 7-bit addressing<br>1: 10-bit addressing                                                                                                                                                                                                                                                                                                                                                                                                            |      |         |
| 3    | <b>Slave Address Mode (I2C_10BITADDR_SLAVE)</b><br>This bit controls the addressing mode of the I <sup>2</sup> C when acting as a slave. In<br>7-bit addressing mode, the I <sup>2</sup> C responds only to 7-bit addressing transfers<br>that match the lower 7 bits of the I2C_SAR register. In 10-bit addressing<br>mode, the I <sup>2</sup> C responds only to 10-bit addressing transfers that match the<br>full 10 bits of the I2C_SAR register. | R/W  | 1b      |
|      | 0: 7-bit addressing<br>1: 10-bit addressing                                                                                                                                                                                                                                                                                                                                                                                                            |      |         |



| BITS | DESCRIPTION                                                                                                                      | TYPE | DEFAULT |
|------|----------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 2:1  | Internal configuration only (INT_CFG_ONLY)<br>These bits must always be written as 01b.                                          | R/W  | 01b     |
| 0    | Master Mode (MASTER_MODE)This bit controls the enabling and disabling of the I2C master mode.0: Master disabled1: Master enabled | R/W  | 1b      |



#### 12.5.2 Target Address Register (I2C\_TAR)

| Offset: | 0004h | Size: | 32 bits |
|---------|-------|-------|---------|
|         |       |       |         |

This read/write register contains the target address for a master I<sup>2</sup>C transmission and controls whether a START byte or a General Call will be transmitted.

This register can be written only when the  $I^2C$  interface has been disabled. This is accomplished by clearing bit 0 of the I2C\_ENABLE register. Writes at other times have no effect.

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                         | TYPE | DEFAULT |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | RESERVED                                                                                                                                                                                                                                                                                                            | RO   | -       |
| 11    | <b>Special Command Selection (SPECIAL)</b><br>This bit indicates whether a General Call or START byte command will be<br>performed.                                                                                                                                                                                 | R/W  | 0b      |
|       | 0: Ignore bit 10 (GC_OR_START) and use I2C_TAR normally<br>1: Perform special I <sup>2</sup> C command as specified in GC_OR_START bit                                                                                                                                                                              |      |         |
| 10    | <b>General Call or START BYTE Selection (GC_OR_START)</b><br>If bit 11 (SPECIAL) is set to 1, this bit indicates whether a General Call or<br>START byte command is to be performed by the I <sup>2</sup> C.                                                                                                        | R/W  | Ob      |
|       | 0: General Call Address<br>After issuing a General Call, only writes may be performed. Attempting to<br>issue a read command results in setting bit 6 (TX_ABRT) of the I2C_RIS<br>register. The I <sup>2</sup> C remains in General Call mode until the SPECIAL bit is<br>cleared.                                  |      |         |
|       | 1: START byte                                                                                                                                                                                                                                                                                                       |      |         |
| 9:0   | <b>Target Address (I2C_TAR)</b><br>This field represents the target address for any master transaction. When transmitting a General Call, these bits are ignored. To generate a START byte, the CPU needs to write only once into this field.                                                                       | R/W  | 055h    |
|       | If the I2C_TAR and I2C_SAR are the same value, loopback exists.<br>However, the FIFOs are shared between the master and slave, so full<br>loopback is not feasible. Only one direction loopback mode is supported<br>(simplex), not duplex. A master cannot transmit to itself, it can transmit only<br>to a slave. |      |         |



#### 12.5.3 Slave Address Register (I2C\_SAR)

Offset: 0008h Size: 32 bits

This read/write register contains the slave address used for when the I<sup>2</sup>C is operating as a slave.

This register can be written only when the I<sup>2</sup>C interface has been disabled. This is accomplished by clearing bit 0 of the I2C\_ENABLE register. Writes at other times have no effect.

**Note:** The correct operation of the device is not guaranteed if I2C\_SAR or I2C\_TAR are programmed to the reserved address values of 00h, 07h, or 78h to 7Fh. Refer to the Philips *I2C\_Specifications* for a complete list of these reserved values.

| BITS  | DESCRIPTION                                                                                                                                                      | TYPE | DEFAULT |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:10 | RESERVED                                                                                                                                                         | RO   | -       |
| 9:0   | Slave Address (I2C_SAR)<br>This field represents the slave address of the I <sup>2</sup> C slave controller. For 7-bit<br>addressing, only I2C_SAR[6:0] is used. | R/W  | 055h    |



#### 12.5.4 Rx/Tx Data Buffer and Command Register (I2C\_DATA\_CMD)

Offset: 0010h Size: 32 bits

This read/write register is used to read or write the RX FIFO and TX FIFO respectively. The CPU should write to this register when filling the TX FIFO and read from this register when retrieving bytes from the RX FIFO. When writing, this register is has 9 valid bits comprised of the command bit and 8 data bits. When reading, the register only contains the 8 data bits.

| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                 | TYPE | DEFAULT |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:9 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                    | RO   | -       |
| 8    | <b>Command Bit (CMD)</b><br>This bit controls whether a read or a write is performed. This bit controls the direction only when the $I^2C$ is acting as a master, not a slave.                                                                                                                                                                                                                                                                              | R/W  | 0b      |
|      | 0: Write<br>1: Read                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |         |
|      | When a command is entered in the TX FIFO, this bit distinguishes the read<br>and write commands. In slave-receiver mode, this bit is a "don't care"<br>because writes to this register are not required. In slave-transmitter mode,<br>a 0 indicates that the CPU data written to the DAT field is to be transmitted.                                                                                                                                       |      |         |
|      | Attempting to perform a read operation after a General Call command has been sent will result in a TX_ABRT interrupt (bit 6 of the I2C_RIS register), unless the SPECIAL bit (bit 11 of the I2C_TAR register) has been cleared.                                                                                                                                                                                                                             |      |         |
|      | If a 1 is written to this bit after receiving a RD_REQ interrupt, then a TX_ABRT interrupt will occur.                                                                                                                                                                                                                                                                                                                                                      |      |         |
|      | <b>Note:</b> It is possible that while attempting a master I <sup>2</sup> C read transfer, a RD_REQ interrupt may have occurred simultaneously due to a remote I <sup>2</sup> C master addressing the I <sup>2</sup> C controller. In this type of scenario, the I <sup>2</sup> C controller ignores the I2C_DATA_CMD write, generates a TX_ABRT interrupt, and waits to service the RD_REQ interrupt. For more details, see Section 12.4, "I2C Operation". |      |         |
| 7:0  | <b>Tx/Rx Data (DAT)</b><br>This field contains the data to be transmitted or received on the $I^2C$ bus. If writing to this register to perform a read, bits 7:0 (DAT) are ignored by the $I^2C$ controller. However, when this register is read, this field will return the value of the data received on the $I^2C$ interface.                                                                                                                            | R/W  | 00h     |



### 12.5.5 SCL Clock High Count Register (I2C\_SCL\_HCNT)

Offset: 0014h Size: 32 bits

This read/write register sets the I2CSCL clock high-period count. The I2CSCL clock is based off the I<sup>2</sup>C Clock (2.08 MHz) from the clock factory. Based on this frequency, it is recommended that the high-period count value be set to 0009h. For more information on configuring the I2CSCL clock, refer to Section 12.4.5, "I2CSCL Frequency Configuration".

This register can be written only when the  $I^2C$  interface has been disabled. This is accomplished by clearing bit 0 of the I2C\_ENABLE register. Writes at other times have no effect.

| BITS  | DESCRIPTION                                                                                                               | TYPE | DEFAULT   |
|-------|---------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:16 | RESERVED                                                                                                                  | RO   | -         |
| 15:0  | I <sup>2</sup> C SCL High Count Value (I2C_SCL_HCNT)<br>This field sets the high-period count value for the I2CSCL clock. | R/W  | Note 12.1 |

**Note 12.1** While the default value of this field is 0008h, it is recommended that this field be set to 0009h for proper operation.



### 12.5.6 SCL Clock Low Count Register (I2C\_SCL\_LCNT)

Offset: 0018h Size: 32 bits

This read/write register sets the I2CSCL clock low-period count. The I2CSCL clock is based off the I<sup>2</sup>C Clock (2.08 MHz) from the clock factory. Based on this frequency, it is recommended that the low-period count value be set to 000Ah. For more information on configuring the I2CSCL clock, refer to Section 12.4.5, "I2CSCL Frequency Configuration".

This register can be written only when the  $I^2C$  interface has been disabled. This is accomplished by clearing bit 0 of the I2C\_ENABLE register. Writes at other times have no effect.

| BIT  | ГS | DESCRIPTION                                                                                                             | TYPE | DEFAULT   |
|------|----|-------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:′ | 16 | RESERVED                                                                                                                | RO   | -         |
| 15:  | :0 | I <sup>2</sup> C SCL Low Count Value (I2C_SCL_LCNT)<br>This field sets the low-period count value for the I2CSCL clock. | R/W  | Note 12.2 |

**Note 12.2** The default value and the recommended value of this field is 000Ah.



#### 12.5.7 Masked Interrupt Status Register (I2C\_MIS)

Offset: 002Ch Size: 32 bits

This read-only register indicates the masked interrupt status of the  $I^2C$  interrupts. The masked interrupt status is the status of each corresponding interrupt as masked by the Interrupt Mask Register (I2C\_INTR\_MASK). A bit value of 1 reflects that an interrupt trigger condition has been detected. A bit value of 0 indicates that the corresponding condition has not been met, or is masked. The unmasked raw versions of these bits are available in the I2C\_RIS register. An interrupt is cleared by reading the corresponding interrupt clear register, or the Clear Interrupt Register (I2C\_CLR\_INTR). For more information on configuring the I<sup>2</sup>C interrupts, refer to Section 12.4.6, "Interrupt Operation". At reset, all bits are cleared.

Note: See Raw Interrupt Status Register (I2C\_RIS) for a detailed description of each of these bits.

| BITS  | DESCRIPTION                                           | TYPE | DEFAULT |
|-------|-------------------------------------------------------|------|---------|
| 31:12 | RESERVED                                              | RO   | -       |
| 11    | General Call Masked Interrupt Status (R_GEN_CALL)     | RO   | 0b      |
| 10    | START Detection Masked Interrupt Status (R_START_DET) | RO   | 0b      |
| 9     | STOP Detection Masked Interrupt Status (R_STOP_DET)   | RO   | 0b      |
| 8     | Activity Masked Interrupt Status (R_ACTIVITY)         | RO   | 0b      |
| 7     | Receive Complete Masked Interrupt Status (R_RX_DONE)  | RO   | 0b      |
| 6     | Transmit Abort Masked Interrupt Status (R_TX_ABRT)    | RO   | 0b      |
| 5     | Read Request Masked Interrupt Status (R_RD_REQ)       | RO   | 0b      |
| 4     | TX FIFO Empty Masked Interrupt Status (R_TX_EMPTY)    | RO   | 0b      |
| 3     | TX FIFO Over Masked Interrupt Status (R_TX_OVER)      | RO   | 0b      |
| 2     | RX FIFO Full Masked Interrupt Status (R_RX_FULL)      | RO   | 0b      |
| 1     | RX FIFO Over Masked Interrupt Status (R_RX_OVER)      | RO   | 0b      |
| 0     | RX FIFO Under Masked Interrupt Status (R_RX_UNDER)    | RO   | 0b      |



#### 12.5.8 Interrupt Mask Register (I2C\_INTR\_MASK)

Offset: 0030h Size: 32 bits

This read/write register is responsible for masking the various  $I^2C$  interrupts. A value of 1 enables the corresponding interrupt for output to the I2C\_INT interrupt, while a value of 0 disables the corresponding interrupt. The bits of this register mask their corresponding interrupt status bits in the Masked Interrupt Status Register (I2C\_MIS). An interrupt is cleared by reading the corresponding interrupt clear register, or the Clear Interrupt Register (I2C\_CLR\_INTR). For more information on configuring the  $I^2C$  interrupts, refer to Section 12.4.6, "Interrupt Operation".

Note: See Raw Interrupt Status Register (I2C\_RIS) for a detailed description of each of these bits.

| BITS  | DESCRIPTION                                  | TYPE | DEFAULT |
|-------|----------------------------------------------|------|---------|
| 31:12 | RESERVED                                     | RO   | -       |
| 11    | General Call Interrupt Mask (M_GEN_CALL)     | R/W  | 1b      |
| 10    | START Detection Interrupt Mask (M_START_DET) | R/W  | 0b      |
| 9     | STOP Detection Interrupt Mask (M_STOP_DET)   | R/W  | 0b      |
| 8     | Activity Interrupt Mask (M_ACTIVITY)         | R/W  | 0b      |
| 7     | Receive Complete Interrupt Mask (M_RX_DONE)  | R/W  | 1b      |
| 6     | Transmit Abort Interrupt Mask (M_TX_ABRT)    | R/W  | 1b      |
| 5     | Read Request Interrupt Mask (M_RD_REQ)       | R/W  | 1b      |
| 4     | TX FIFO Empty Interrupt Mask (M_TX_EMPTY)    | R/W  | 1b      |
| 3     | TX FIFO Over Interrupt Mask (M_TX_OVER)      | R/W  | 1b      |
| 2     | RX FIFO Full Interrupt Mask (M_RX_FULL)      | R/W  | 1b      |
| 1     | RX FIFO Over Interrupt Mask (M_RX_OVER)      | R/W  | 1b      |
| 0     | RX FIFO Under Interrupt Mask (M_RX_UNDER)    | R/W  | 1b      |



#### 12.5.9 Raw Interrupt Status Register (I2C\_RIS)

Offset: 0034h Size: 32 bits

This read-only register indicates the raw interrupt status of the I<sup>2</sup>C interrupts. The raw interrupt status is the status of each corresponding interrupt regardless if it has been masked by the Interrupt Mask Register (I2C\_INTR\_MASK). A bit value of 1 reflects that an interrupt trigger condition has been detected. A bit value of 0 indicates that the corresponding condition has not been met. The masked versions of these bits are available in the Masked Interrupt Status Register (I2C\_MIS). An interrupt is cleared by reading the corresponding interrupt clear register, or the Clear Interrupt Register (I2C\_CLR\_INTR). For more information on configuring the I<sup>2</sup>C interrupts, refer to Section 12.4.6, "Interrupt Operation". At reset, all bits are cleared.

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | TYPE | DEFAULT |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:12 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | RO   | -       |
| 11    | <b>General Call Raw Interrupt Status (GEN_CALL)</b><br>This interrupt bit is set only when a General Call address is received and<br>is acknowledged. It stays set until it is cleared either by disabling the I <sup>2</sup> C<br>controller (set bit 0 of I2C_ENABLE = 0) or when the CPU reads bit 0 of<br>the I2C_CLR_GEN_CALL register. The I <sup>2</sup> C controller stores the received<br>data in the Rx buffer.                                                                                                                                                                   | RO   | Ob      |
| 10    | <ul> <li>START Detection Raw Interrupt Status (START_DET)         This interrupt bit indicates whether a START or RESTART condition has occurred on the I<sup>2</sup>C interface regardless of whether the I<sup>2</sup>C controller is operating in slave or master mode.     </li> <li>Note: There is no status bit for a RESTART condition because it is detected as a normal start condition. The I<sup>2</sup>C protocol does not care whether it is a START or RESTART because both conditions start from the IDLE state and send the message to all the slaves on the bus.</li> </ul> | RO   | Ob      |
| 9     | <b>STOP Detection Raw Interrupt Status (STOP_DET)</b><br>This interrupt bit indicates whether a STOP condition has occurred on the I <sup>2</sup> C interface regardless of whether the I <sup>2</sup> C controller is operating in slave or master mode.                                                                                                                                                                                                                                                                                                                                    | RO   | Ob      |
| 8     | Activity Raw Interrupt Status (ACTIVITY)<br>This bit captures I <sup>2</sup> C activity and stays set until it is cleared. There are four<br>ways to clear it:<br>• Disabling the I <sup>2</sup> C controller (set bit 0 of I2C_ENABLE = 0)<br>• Reading the I2C_CLR_ACTIVITY register<br>• Reading the I2C_CLR_INTR register<br>• Chip-level reset<br>Once this bit is set, it stays set unless one of the four methods is used to                                                                                                                                                          | RO   | Ob      |
|       | clear it. Even if the I <sup>2</sup> C controller is idle, it remains set until cleared, indicating that there was activity on the bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |         |
| 7     | <b>Receive Complete Raw Interrupt Status (RX_DONE)</b><br>When the I <sup>2</sup> C controller is acting as a slave transmitter, this bit is set to 1 if the master does not acknowledge a transmitted byte. Acknowledgement occurs on the last byte of the transmission, indicating that the transmission is done.                                                                                                                                                                                                                                                                          | RO   | Ob      |



| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | TYPE | DEFAULT |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 6    | <b>Transmit Abort Raw Interrupt Status (TX_ABRT)</b><br>This bit indicates if the I <sup>2</sup> C controller, acting as an I <sup>2</sup> C transmitter, is unable to complete the intended actions on the contents of the transmit FIFO. This situation can occur both as an I <sup>2</sup> C master or an I <sup>2</sup> C slave, and is referred to as a "transmit abort".                                                                                                                                                                                                                                                                                        | RO   | Ob      |
|      | When this bit is set to 1, the I2C_TX_ABRT_SRC register indicates the reason why the transmit abort has taken place.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |         |
|      | <b>Note:</b> The I <sup>2</sup> C controller flushes/empties all of its FIFOs (transmit and receive) whenever this bit is set to indicate the occurrence of a transmit abort.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |      |         |
| 5    | <b>Read Request Raw Interrupt Status (RD_REQ)</b><br>This bit is set to 1 when the I <sup>2</sup> C controller is acting as a slave and another<br>I <sup>2</sup> C master is attempting to read data from it. The I <sup>2</sup> C controller holds the<br>I <sup>2</sup> C bus in a wait state (I2CSCL=0) until this interrupt is serviced, which<br>means that the slave has been addressed by a remote master that is asking<br>for data to be transferred. The processor must respond to this interrupt and<br>then write the requested data to the I2C_DATA_CMD register. This interrupt<br>bit is cleared upon a read of bit 0 in the I2C_CLR_RD_REQ register. | RO   | Ob      |
| 4    | <b>TX FIFO Empty Raw Interrupt Status (TX_EMPTY)</b><br>This bit is set to 1 when the transmit buffer is at or below the threshold value set in the I2C_TX_TL register. It is automatically cleared by hardware when the buffer level goes above the threshold. When the I2C_ENABLE bit 0 is cleared, disabling the I <sup>2</sup> C controller, the TX FIFO is flushed and held in reset. In this case the TX FIFO appears as if it has no data within it, so this bit is set to 1, provided there is still activity in the master or slave controllers. When there is no longer activity, this interrupt bit is cleared.                                            | RO   | Ob      |
| 3    | <b>TX FIFO Over Raw Interrupt Status (TX_OVER)</b><br>This bit is set during a transmit if the transmit buffer is filled to the maximum TX FIFO buffer depth of 16 and the processor attempts to issue another I <sup>2</sup> C command by writing to the I2C_DATA_CMD register. When the I <sup>2</sup> C controller is disabled (I2C_ENABLE[0]=0), this bit keeps its level until the master or slave controllers activity is completed. When there is no longer activity, this interrupt bit is cleared.                                                                                                                                                           | RO   | ОЬ      |
| 2    | <b>RX FIFO Full Raw Interrupt Status (RX_FULL)</b><br>This bit is set when the receive buffer reaches or goes above the RX_TL threshold in the I2C_RX_TL register. It is automatically cleared by hardware when the buffer level returns below the threshold. If the I <sup>2</sup> C controller is disabled (I2C_ENABLE[0]=0), the RX FIFO is flushed and held in reset. therefore the RX FIFO is not full. Therefore, this bit is cleared once the I2C_ENABLE bit 0 is programmed with a 0, regardless of any I <sup>2</sup> C activity that continues.                                                                                                             | RO   | Ob      |
| 1    | <b>RX FIFO Over Raw Interrupt Status (RX_OVER)</b><br>This bit is set if the receive buffer is completely filled to the maximum RX<br>FIFO buffer depth of 16 and an additional byte is received from an external<br>I <sup>2</sup> C device. The I <sup>2</sup> C controller acknowledges this additional received byte,<br>but any data bytes received after the RX FIFO is full are lost. If the I <sup>2</sup> C<br>controller is disabled (I2C_ENABLE[0]=0), this bit keeps its level until the<br>master or slave controller activity is completed. When there is no longer<br>activity, this interrupt bit is cleared.                                         | RO   | Ob      |
| 0    | <b>RX FIFO Under Raw Interrupt Status (RX_UNDER)</b><br>This bit is set if the processor attempts to read the RX FIFO when it is<br>empty by reading from the I2C_DATA_CMD register. If the I <sup>2</sup> C controller is<br>disabled (I2C_ENABLE[0]=0), this bit keeps its level until the master or<br>slave controller activity is completed. When there is no longer activity, this<br>interrupt is cleared.                                                                                                                                                                                                                                                     | RO   | Ob      |



#### 12.5.10 Receive FIFO Threshold Register (I2C\_RX\_TL)

Offset: 0038h Size: 32 bits

This read/write register controls the level of entries (or above) into the RX FIFO that triggers the RX\_FULL interrupt (bit 2 of the I2C\_RIS register). The valid range is 0 to 15, since the total buffer depth of the RX FIFO is 16. A value of 0 will set the threshold for 1 entry, while a value of 15 will set the threshold for 16 entries. If an attempt is made to write a value larger than the depth of the buffer, the actual value set will be 15, the maximum depth of the buffer.

| BITS | DESCRIPTION                                                                                                                                    | TYPE | DEFAULT |
|------|------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:4 | RESERVED                                                                                                                                       | RO   | -       |
| 3:0  | <b>RX FIFO Threshold Level (RX_TL)</b><br>This field is used to set the level of entries into the RX FIFO that triggers the RX_FULL interrupt. | R/W  | 7h      |



### 12.5.11 Transmit FIFO Threshold Register (I2C\_TX\_TL)

Offset: 003Ch Size: 32 bits

This read/write register controls the level of entries (or below) into the TX FIFO that triggers the TX\_EMPTY interrupt (bit 4 of the I2C\_RIS register). The valid range is 0 to 15, since the total buffer depth of the TX FIFO is 16. A value of 0 will set the threshold for 1 entry, while a value of 15 will set the threshold for 16 entries. If an attempt is made to write a value larger than the depth of the buffer, the actual value set will be 15, the maximum depth of the buffer.

| BITS | DESCRIPTION                                                                                                                                     | TYPE | DEFAULT |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:4 | RESERVED                                                                                                                                        | RO   | -       |
| 3:0  | <b>TX FIFO Threshold Level (TX_TL)</b><br>This field is used to set the level of entries into the TX FIFO that triggers the TX_EMPTY interrupt. | R/W  | 7h      |



#### 12.5.12 Clear Interrupt Register (I2C\_CLR\_INTR)

```
Offset: 0040h Size: 32 bits
```

When read, this read-only register clears the combined interrupt I2C\_INT, all individual interrupts, and the I2C\_ABRT\_SRC register.

| BITS | DESCRIPTION                                                                                                                                                                                                                                      | TYPE | DEFAULT |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:1 | RESERVED                                                                                                                                                                                                                                         | RO   | -       |
| 0    | <b>Clear Interrupts (CLR_INTR)</b><br>When read, clears the combined interrupt I2C_INT, all individual interrupts,<br>and the I2C_TX_ABRT_SRC register.                                                                                          | RO   | Ob      |
|      | <b>Note:</b> This bit does not clear hardware clearable interrupts. Refer to bit 9 of the I2C_ABRT_SRC register for an exception to clearing I2C_TX_ABRT_SRC. Refer to Table 12.1 for a full list of hardware and software clearable interrupts. |      |         |



### 12.5.13 Clear RX\_UNDER Interrupt Register (I2C\_CLR\_RX\_UNDER)

Offset:

0044h

Size: 32 bits

When read, this read-only register clears the RX\_UNDER interrupt.

| BITS | DESCRIPTION                                                                                                                      | TYPE | DEFAULT |
|------|----------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:1 | RESERVED                                                                                                                         | RO   | -       |
| 0    | <b>Clear RX_UNDER Interrupt (CLR_RX_UNDER)</b><br>Read this bit to clear the RX_UNDER interrupt (bit 0) of the I2C_RIS register. | RO   | 0b      |



### 12.5.14 Clear RX\_OVER Interrupt Register (I2C\_CLR\_RX\_OVER)

Offset:

Size:

32 bits

When read, this read-only register clears the RX\_OVER interrupt.

0048h

| BITS | DESCRIPTION                                                                                                            | TYPE | DEFAULT |
|------|------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:1 | RESERVED                                                                                                               | RO   | -       |
| 0    | Clear RX_OVER Interrupt (CLR_RX_OVER)<br>Read this bit to clear the RX_OVER interrupt (bit 1) of the I2C_RIS register. | RO   | Ob      |



### 12.5.15 Clear TX\_OVER Interrupt Register (I2C\_CLR\_TX\_OVER)

Offset:

Size:

32 bits

When read, this read-only register clears the TX\_OVER interrupt.

004Ch

| BITS | DESCRIPTION                                                                                                            | TYPE | DEFAULT |
|------|------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:1 | RESERVED                                                                                                               | RO   | -       |
| 0    | Clear TX_OVER Interrupt (CLR_TX_OVER)<br>Read this bit to clear the TX_OVER interrupt (bit 3) of the I2C_RIS register. | RO   | 0b      |



### 12.5.16 Clear RD\_REQ Interrupt Register (I2C\_CLR\_RD\_REQ)

0050h

Offset:

Size:

32 bits

When read, this read-only register clears the RD\_REQ interrupt.

| BITS | DESCRIPTION                                                                                                                | TYPE | DEFAULT |
|------|----------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:1 | RESERVED                                                                                                                   | RO   | -       |
| 0    | <b>Clear RD_REQ Interrupt (CLR_RD_REQ)</b><br>Read this bit to clear the RD_REQ interrupt (bit 5) of the I2C_RIS register. | RO   | Ob      |



## 12.5.17 Clear TX\_ABRT Interrupt Register (I2C\_CLR\_TX\_ABRT)

Offset:

Size:

32 bits

When read, this read-only register clears the TX\_ABRT interrupt.

0054h

| BITS | DESCRIPTION                                                                                                                                                                                                                                               | TYPE | DEFAULT |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:1 | RESERVED                                                                                                                                                                                                                                                  | RO   | -       |
| 0    | <b>Clear TX_ABRT Interrupt (CLR_TX_ABRT)</b><br>Read this bit to clear the TX_ABRT interrupt (bit 6) of the I2C_RIS register, and the I2C_TX_ABRT_SRC register. Refer to bit 9 of the I2C_ABRT_SRC register for an exception to clearing I2C_TX_ABRT_SRC. | RO   | Ob      |



### 12.5.18 Clear RX\_DONE Interrupt Register (I2C\_CLR\_RX\_DONE)

Offset:

Size:

32 bits

When read, this read-only register clears the RX\_DONE interrupt.

0058h

| BITS | DESCRIPTION                                                                                                            | TYPE | DEFAULT |
|------|------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:1 | RESERVED                                                                                                               | RO   | -       |
| 0    | Clear RX_DONE Interrupt (CLR_RX_DONE)<br>Read this bit to clear the RX_DONE interrupt (bit 7) of the I2C_RIS register. | RO   | Ob      |



## 12.5.19 Clear ACTIVITY Interrupt Register (I2C\_CLR\_ACTIVITY)

Offset:

005Ch

32 bits

Size:

When read, this read-only register clears the ACTIVITY interrupt.

| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                        | TYPE | DEFAULT |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:1 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                           | RO   | -       |
| 0    | <b>Clear ACTIVITY Interrupt (CLR_ACTIVITY)</b><br>Reading this bit clears the ACTIVITY interrupt (bit 8) of the I2C_RIS register<br>if the I <sup>2</sup> C is no longer active. If the I <sup>2</sup> C controller is still active on the bus,<br>the ACTIVITY interrupt bit continues to be set. This bit is automatically<br>cleared by hardware if the I <sup>2</sup> C controller is disabled and there is no further<br>activity on the bus. | RO   | Ob      |



### 12.5.20 Clear STOP\_DET Interrupt Register (I2C\_CLR\_STOP\_DET)

Offset:

32 bits

When read, this read-only register clears the STOP\_DET interrupt.

0060h

| BITS | DESCRIPTION                                                                                                                      | TYPE | DEFAULT |
|------|----------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:1 | RESERVED                                                                                                                         | RO   | -       |
| 0    | <b>Clear STOP_DET Interrupt (CLR_STOP_DET)</b><br>Read this bit to clear the STOP_DET interrupt (bit 9) of the I2C_RIS register. | RO   | Ob      |

Size:



### 12.5.21 Clear START\_DET Interrupt Register (I2C\_CLR\_START\_DET)

Offset:

0064h

32 bits

Size:

When read, this read-only register clears the START\_DET interrupt.

| BITS | DESCRIPTION                                                                                                                          | TYPE | DEFAULT |
|------|--------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:1 | RESERVED                                                                                                                             | RO   | -       |
| 0    | <b>Clear START_DET Interrupt (CLR_START_DET)</b><br>Read this bit to clear the START_DET interrupt (bit 10) of the I2C_RIS register. | RO   | 0b      |



### 12.5.22 Clear GEN\_CALL Interrupt Register (I2C\_CLR\_GEN\_CALL)

Offset:

0068h

32 bits

Size:

When read, this read-only register clears the GEN\_CALL interrupt.

| BITS | DESCRIPTION                                                                                                                       | TYPE | DEFAULT |
|------|-----------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:1 | RESERVED                                                                                                                          | RO   | -       |
| 0    | <b>Clear GEN_CALL Interrupt (CLR_GEN_CALL)</b><br>Read this bit to clear the GEN_CALL interrupt (bit 11) of the I2C_RIS register. | RO   | Ob      |



# 12.5.23 I<sup>2</sup>C Enable Register (I2C\_ENABLE)

Offset:

006Ch

32 bits

Size:

This read/write register controls the enabling and disabling of the  $I^2C$  controller.

| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                      | TYPE | DEFAULT |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:1 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RO   | -       |
| 0    | I <sup>2</sup> C Enable (ENABLE)<br>This bit controls whether the I <sup>2</sup> C controller is enabled.                                                                                                                                                                                                                                                                                                                                                        | R/W  | 0b      |
|      | 0: Disables I <sup>2</sup> C controller (TX/RX FIFOs are held in erased state)<br>1: Enables I <sup>2</sup> C controller                                                                                                                                                                                                                                                                                                                                         |      |         |
|      | Software can disable the $I^2C$ controller while it is active. However, it is important that care be taken to ensure that it is disabled properly. A recommended procedure is described in Section 12.4.4, "Disabling the I2C Controller".                                                                                                                                                                                                                       |      |         |
|      | When the I <sup>2</sup> C controller is disabled, the following occurs:<br>The TX FIFO and RX FIFO get flushed.                                                                                                                                                                                                                                                                                                                                                  |      |         |
|      | <ul> <li>Status bits in the I2C_INTR_STAT register are still active until the I<sup>2</sup>C controller goes into IDLE state.</li> <li>If the I<sup>2</sup>C controller is transmitting, it stops as well as deletes the contents of the transmit buffer after the current transfer is complete. If the I<sup>2</sup>C controller is receiving, the current transfer is stopped at the end of the current byte and does not acknowledge the transfer.</li> </ul> |      |         |
|      | Note: There is a two clock cycle delay when enabling or disabling the ${\sf I}^2{\sf C}$ controller.                                                                                                                                                                                                                                                                                                                                                             |      |         |



#### 12.5.24 Status Register (I2C\_STATUS)

Offset: 0070h Size: 32 bits

This read-only register is used to indicate the current transfer and FIFO status. This register may be read at any time.

When the I<sup>2</sup>C controller is disabled (I2C\_ENABLE[0]=0):

- Bits 1 and 2 are set to 1
- Bits 3 and 4 are set to 0

When the I<sup>2</sup>C controller is disabled (I2C\_ENABLE[0]=0) and the master and slave controllers are idle:

Bits 5 and 6 are set to 0

Note: None of the bits in this register request an interrupt.

| BITS | DESCRIPTION                                                                                                                                                                                                                 | TYPE | DEFAULT |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:7 | RESERVED                                                                                                                                                                                                                    | RO   | -       |
| 6    | Slave Activity Status (SLV_ACTIVITY)<br>When the slave controller is not in the IDLE state, this bit is set.                                                                                                                | RO   | 0b      |
|      | 0: Slave controller is in IDLE state.<br>The slave portion of the I <sup>2</sup> C controller is not active.                                                                                                                |      |         |
|      | 1: Slave controller is not in IDLE state.<br>The slave portion of the I <sup>2</sup> C controller is active.                                                                                                                |      |         |
| 5    | Master Activity Status (MST_ACTIVITY)<br>When the master controller is not in the IDLE state, this bit is set.                                                                                                              |      | 0b      |
|      | 0: Master controller is in IDLE state. The master portion of the $I^2C$ controller is not active.                                                                                                                           |      |         |
|      | 1: Master controller is not in IDLE state.<br>The master portion of the I <sup>2</sup> C controller is active.                                                                                                              |      |         |
| 4    | <b>RX FIFO Full Status (RFF)</b><br>When the RX FIFO is completely full, this bit is set. When the RX FIFO contains one or more empty locations, this bit is cleared.                                                       |      | 0b      |
|      | 0: RX FIFO is not full<br>1: RX FIFO is full                                                                                                                                                                                |      |         |
| 3    | <b>RX FIFO Not Empty Status (RFNE)</b><br>This bit is set when the RX FIFO contains one or more entries and is<br>cleared when the RX FIFO is empty. This bit can be polled by software to<br>completely empty the RX FIFO. |      | 0b      |
|      | 0: RX FIFO is empty<br>1: RX FIFO is not empty                                                                                                                                                                              |      |         |
| 2    | <b>TX FIFO Empty Status (TFE)</b><br>When the TX FIFO is completely empty, this bit is set. When it contains one or more valid entries, this bit is cleared. This bit field does not request an interrupt.                  |      | 1b      |
|      | 0: TX FIFO is not empty<br>1: TX FIFO is empty                                                                                                                                                                              |      |         |



| BITS | DESCRIPTION                                                                                                                                                                                                                             | TYPE | DEFAULT |
|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 1    | <ul> <li>TX FIFO Not Full Status (TFNF)</li> <li>This bit is set when the TX FIFO contains one or more empty locations, and is cleared when the TX FIFO is full.</li> <li>0: TX FIFO is full</li> <li>1: TX FIFO is not full</li> </ul> |      | 1b      |
| 0    | I <sup>2</sup> C Activity Status (ACTIVITY)<br>0: No I <sup>2</sup> C activity detected<br>1: I <sup>2</sup> C activity detected                                                                                                        |      | Ob      |



#### 12.5.25 Transmit FIFO Level Register (I2C\_TXFLR)

Offset: 0074h

Size:

32 bits

This read-only register contains the number of valid data entries in the TX FIFO buffer. This register increments whenever data is placed into the TX FIFO and decrements when data is taken from the TX FIFO. It is cleared by the following conditions:

- The I<sup>2</sup>C controller is disabled (I2C\_ENABLE[0]=0)
- There is a transmit abort (TX\_ABRT bit is set in the I2C\_RIS register)
- The slave bulk transmit mode is aborted

| BITS | DESCRIPTION                                                                                          | TYPE | DEFAULT |
|------|------------------------------------------------------------------------------------------------------|------|---------|
| 31:5 | RESERVED                                                                                             | RO   | -       |
| 4:0  | <b>TX FIFO Level (TXFLR)</b><br>This field contains the number of valid data entries in the TX FIFO. | RO   | 0h      |



#### 12.5.26 Receive FIFO Level Register (I2C\_RXFLR)

Offset: 0078h Size: 32 bits

This read-only register contains the number of valid data entries in the RX FIFO buffer. This register increments whenever data is placed into the RX FIFO and decrements when data is taken from the RX FIFO. It is cleared by the following conditions:

- The I<sup>2</sup>C controller is disabled (I2C\_ENABLE[0]=0)
- There is a transmit abort caused by any of the events tracked in the I2C\_TX\_ABRT\_SRC register

| BITS | DESCRIPTION                                                                                          | TYPE | DEFAULT |
|------|------------------------------------------------------------------------------------------------------|------|---------|
| 31:5 | RESERVED                                                                                             | RO   | -       |
| 4:0  | <b>RX FIFO Level (RXFLR)</b><br>This field contains the number of valid data entries in the RX FIFO. | RO   | 0h      |



#### 12.5.27 Transmit Abort Source Register (I2C\_TX\_ABRT\_SRC)

Offset: 0080h Size: 32 bits

This read/write register contains 14 bits that indicate the source of the transmit abort interrupt (TX\_ABRT). Except for bit 9, this register is cleared whenever the I2C\_CLR\_TX\_ABRT register or the I2C\_CLR\_INTR register is read. To clear bit 9, the source of the ABRT\_SBYTE\_NORSTRT must be attended to; RESTART must be enabled (I2C\_CON [5]=1), the SPECIAL bit must be cleared (I2C\_TAR [11]), or the GC\_OR\_START bit must be cleared (I2C\_TAR[10]). Once the source of the ABRT\_SBYTE\_NORSTRT is attended to, this bit can be cleared in the same manner as other bits of this register. If the source of the ABRT\_SBYTE\_NORSTRT is not attended to before attempting to clear this bit, bit 9 clears for one cycle and is then re-asserted.

**Note:** As can be seen below, each bit description contains the additional field "I<sup>2</sup>C MODE" which contains the applicable I<sup>2</sup>C modes for each bit (master-transmitter, master-receiver, slave-transmitter, slave-receiver).

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                  | TYPE | DEFAULT | I <sup>2</sup> C MODE                                 |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|-------------------------------------------------------|
| 31:16 | RESERVED                                                                                                                                                                                                                                                                                                                                     | RO   | -       | -                                                     |
| 15    | <b>(ABRT_SLVRD_INTX)</b><br>This bit is set when the I <sup>2</sup> C controller responds to a slave<br>mode request for data to be transmitted to a remote master<br>and a 0 is written in CMD (bit 8) of the I2C_DATA_CMD<br>register.                                                                                                     | RO   | 0b      | Slave-<br>Transmitter                                 |
| 14    | (ABRT_SLV_ARBLOST)<br>This bit is set when the slave controller loses the bus while<br>transmitting data to a remote master.<br>I2C_TX_ABRT_SRC[12] is set at the same time.                                                                                                                                                                 | RO   | Ob      | Slave-<br>Transmitter                                 |
|       | <b>Note:</b> Even though the slave never "owns" the bus, something could go wrong on the bus. This is a fail safe check. For instance, during a data transmission at the low-to-high transition of I2CSCL, if what is on the data bus is not what is supposed to be transmitted, then the I <sup>2</sup> C controller no longer own the bus. |      |         |                                                       |
| 13    | (ABRT_SLVFLUSH_TXFIFO)<br>This bit is set when the slave has received a read command<br>and data exists in the TX FIFO. The slave issues a<br>TX_ABRT interrupt to flush the old data in the TX FIFO.                                                                                                                                        | RO   | 0b      | Slave-<br>Transmitter                                 |
| 12    | <ul> <li>(ARB_LOST)         This bit is set when the master has lost arbitration, or if I2C_TX_ABRT_SRC[14] is also set, then the slave transmitter has lost arbitration.         Note: I<sup>2</sup>C can be both a master and a slave at the same time.     </li> </ul>                                                                    | RO   | Ob      | Master-<br>Transmitter<br>or<br>Slave-<br>Transmitter |
| 11    | (ABRT_MASTER_DIS)<br>This bit is set when a master operation is attempted with the<br>master mode disabled.                                                                                                                                                                                                                                  | RO   | Ob      | Master-<br>Transmitter<br>or<br>Master-<br>Receiver   |
| 10    | (ABRT_10B_RD_NORSTRT)<br>This bit is set when the restart is disabled<br>(I2C_RESTART_EN bit (I2C_CON[5]) = 0) and the master<br>sends a read command in 10-bit addressing mode.                                                                                                                                                             | RO   | Ob      | Master-<br>Receiver                                   |



| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | TYPE | DEFAULT | I <sup>2</sup> C MODE                               |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|-----------------------------------------------------|
| 9    | (ABRT_SBYTE_NORSTRT)<br>This bit is set when the restart is disabled<br>(I2C_RESTART_EN bit (I2C_CON[5]) = 0) and a START<br>byte send is attempted.<br>To clear Bit 9, the source of the ABRT_SBYTE_NORSTRT<br>must be attended to; restart must be enabled<br>(I2C_CON[5]=1), the SPECIAL bit must be cleared<br>(I2C_TAR[11]), or the GC_OR_START bit must be cleared<br>(I2C_TAR[10]). Once the source of the<br>ABRT_SBYTE_NORSTRT is attended to, this bit can be<br>cleared in the same manner as other bits in this register. If<br>the source of the ABRT_SBYTE_NORSTRT is not attended<br>to before attempting to clear this bit, bit 9 clears for one<br>cycle and then gets re-asserted. | RO   | Ob      | Master-<br>Transmitter<br>or<br>Master-<br>Receiver |
| 8    | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO   | -       | -                                                   |
| 7    | (ABRT_SBYTE_ACKDET)<br>This bit is set when the master has sent a START byte and<br>the START byte was acknowledged (wrong behavior).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RO   | Ob      | Master-<br>Transmitter<br>or<br>Master-<br>Receiver |
| 6    | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO   | -       | -                                                   |
| 5    | <b>(ABRT_GCALL_READ)</b><br>This bit is set when in master mode a General Call is sent,<br>but the user programmed the byte following the General<br>Call to be a read from the bus (I2C_DATA_CMD[8] is set to<br>1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | RO   | Ob      | Master-<br>Transmitter                              |
| 4    | (ABRT_GCALL_NOACK)<br>This bit is set when in master mode a General Call is sent,<br>and no slave on the bus acknowledged the General Call.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RO   | 0b      | Master-<br>Transmitter                              |
| 3    | (ABRT_TXDATA_NOACK)<br>This master-mode only bit is set when the master has<br>received an acknowledgement for the address, but the sent<br>data byte(s) following the address did not receive an<br>acknowledgement from the remote slave(s)                                                                                                                                                                                                                                                                                                                                                                                                                                                        | RO   | 0b      | Master-<br>Transmitter                              |
| 2    | (ABRT_10ADDR2_NOACK)<br>This bit is set when the master is in 10-bit address mode<br>and the second address byte of the 10-bit address was not<br>acknowledged by any slave.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RO   | Ob      | Master-<br>Transmitter<br>or<br>Master-<br>Receiver |
| 1    | <b>(ABRT_10ADDR1_NOACK)</b><br>This bit is set when the master is in 10-bit address mode<br>and the first 10-bit address byte was not acknowledged by<br>any slave.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RO   | Ob      | Master-<br>Transmitter<br>or<br>Master-<br>Receiver |
| 0    | (ABRT_7B_ADDR_NOACK)<br>This bit is set when the master is in 7-bit addressing mode<br>and the address sent was not acknowledged by any slave.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | RO   | Ob      | Master-<br>Transmitter<br>or<br>Master-<br>Receiver |



#### 12.5.28 SDA Setup Register (I2C\_SDA\_SETUP)

Offset: 0094h Size: 32 bits

This read/write register controls the amount of time delay (in terms of number of  $I^2C$  clock periods) introduced in the rising edge of I2CSCL, relative to I2CSDA changing, when the  $I^2C$  controller services a read request in a slave-receiver operation. The relevant  $I^2C$  requirement is tSU;DAT (Note 4) as detailed in the Philips *I2C-Bus Specification*.

| BITS | DESCRIPTION                                                                                                                    | TYPE | DEFAULT |
|------|--------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:8 | RESERVED                                                                                                                       | RO   | -       |
| 7:0  | <b>SDA Setup Value (SDA_SETUP)</b><br>Controls the amount of delay (in clock periods) introduced in the rising edge of I2CSCL. | R/W  | 64h     |



## 12.5.29 ACK General Call Register (I2C\_ACK\_GEN\_CALL)

Offset: 0098h Size: 32 bits

This read/write register controls whether the I<sup>2</sup>C controller responds with an ACK or NACK when it receives an I<sup>2</sup>C General Call address.

| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                        | TYPE | DEFAULT |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:1 | RESERVED                                                                                                                                                                                                                                                                                                           | RO   | -       |
| 0    | <ul> <li>ACK General Call Enable (ACK_GEN_CALL)</li> <li>When set to 1, the I<sup>2</sup>C controller responds with an ACK when it receives a General Call. Otherwise, the I<sup>2</sup>C controller responds with a NACK.</li> <li>0: General Call ACK response</li> <li>1: General Call NACK response</li> </ul> | R/W  | 1b      |



#### 12.5.30 Enable Status Register (I2C\_ENABLE\_STATUS)

Offset: 009Ch Size: 32 bits

This read-only register is used to report the  $I^2C$  controller hardware status when the ENABLE bit of the I2C\_ENABLE register changes from 1 to 0 ( $I^2C$  controller disabled). Once ENABLE has been set to 1, bits [2:1] will be forced to 0.

| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | TYPE | DEFAULT |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:3 | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | RO   | -       |
| 2    | <b>Slave FIFO Filled and Flushed (SLV_FIFO_FF)</b><br>This bit indicates if a slave-receiver operation has been aborted with at least 1 data byte received from an I <sup>2</sup> C transfer due to the setting of I2C_ENABLE from 1 to 0.                                                                                                                                                                                                                                    | RO   | Ob      |
|      | When read as 1, the $I^2C$ controller is deemed to have been actively engaged in an aborted $I^2C$ transfer (with matching address) and the data phase of the $I^2C$ transfer has been entered, even though the first data byte has been responded with a NACK.                                                                                                                                                                                                               |      |         |
|      | When read as 0, the I <sup>2</sup> C controller is deemed to have been disabled without being actively involved in any slave-receiver transfer.                                                                                                                                                                                                                                                                                                                               |      |         |
|      | <b>Note:</b> The CPU can safely read this bit when I2C_EN (bit 0) is read as 0.                                                                                                                                                                                                                                                                                                                                                                                               |      |         |
| 1    | <b>Slave-Receiver Operation Aborted (SLV_RX_ABORTED)</b><br>This bit indicates if a potential or active slave-receiver operation has been<br>aborted due to the setting of the I2C_ENABLE register from 1 to 0. This bit<br>is set when the CPU writes a 0 to the I2C_ENABLE register while the I <sup>2</sup> C<br>controller is receiving the address byte of the slave-transmitter operation<br>from a remote master. This bit is tied to a slave-receiver operation only. | RO   | Ob      |
|      | When read as 1, the I <sup>2</sup> C controller is deemed to have forced a NACK during any part of an I <sup>2</sup> C transfer, irrespective of whether the I <sup>2</sup> C address matches the slave address set in the I2C_SAR register OR if the transfer is completed before I2C_ENABLE is set to 0 but has not taken effect.                                                                                                                                           |      |         |
|      | When read as 0, the I <sup>2</sup> C controller is deemed to have been disabled without actively involved in any slave-receiver transfer.                                                                                                                                                                                                                                                                                                                                     |      |         |
|      | <b>Note:</b> This bit does not reflect any master or slave transmit operation.<br>The CPU can safely read this bit when I2C_EN (bit 0) is read as 0.                                                                                                                                                                                                                                                                                                                          |      |         |
| 0    | <b>I<sup>2</sup>C Controller Enabled Status (I2C_EN)</b><br>This bit reflects the I <sup>2</sup> C controller status. When read as 1, the I <sup>2</sup> C controller is deemed to be actively involved in an I <sup>2</sup> C transfer, irrespective of whether being in an address or data phase for all master or slave modes. When read as 0, the I <sup>2</sup> C controller is deemed completely inactive.                                                              | RO   | Ob      |
|      | <b>Note:</b> The CPU can safely read this bit anytime. When this bit is read as 0, the CPU can safely read SLV_FIFO_FILLED_AND_FLUSHED (bit 2) and SLV_RX_ABORTED (bit 1).                                                                                                                                                                                                                                                                                                    |      |         |



#### 12.5.31 Access Module Register (I2C\_ACCESS)

Offset: 0100h Size: 32 bits

This register may be used in conjunction with the I2C\_SEQ\_DATA\_x registers for sequential reads/writes. The access module allows a user to perform complex I<sup>2</sup>C accesses via a single register. It can perform non-sequential accesses, where it writes an address, followed by either a read or write of data (via its I2C\_DATA field), or it can perform sequential accesses where it writes an address followed by 1 to 64-byte writes or reads of data (using the I2C\_SEQ\_DATA\_x registers). Once an access is complete, its status should be read and checked by the user. Note that when the I2C\_SEQ\_DATA\_x registers are employed in a sequential read/write, the LSB of the data being accessed is in the LSB of I2C\_SEQ\_DATA\_0, while the location of the MSB depends on the value of I2C\_ACCESS\_SIZE. When I2C\_ACCESS\_SIZE is 3Fh, the MSB of the data is in the MSB of I2C\_SEQ\_DATA\_15.

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | TYPE   | DEFAULT |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---------|
| 31    | <b>Busy (I2C_ACCESS_BUSY)</b><br>This bit must be set by software when initiating an I <sup>2</sup> C transfer. It is cleared<br>by the hardware on completion of the transfer. A new transfer must not be<br>attempted while this bit or the I2C_ACCESS_DONE bit is set. Once a<br>transfer is initiated via a write to this register, the State<br>(I2C_ACCESS_DONE) bit may be checked to determine that the transfer<br>has completed. Refer to Note 12.3 for further information. | R/W/SC | Ob      |
| 30    | <b>Reset (I2C_ACCESS_RST)</b><br>Writing 1 to this bit causes a soft reset of the I2C Access Module.                                                                                                                                                                                                                                                                                                                                                                                   | WO     | 0b      |
| 29    | <b>Error (I2C_ACCESS_ERROR)</b><br>When set, this bit indicates that an error occurred during the previous I <sup>2</sup> C access attempted using this register. Refer to Note 12.3 for further information.                                                                                                                                                                                                                                                                          | R/WC   | Ob      |
| 28    | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RO     | -       |
| 27    | State (I2C_ACCESS_DONE)<br>Access is complete when set.                                                                                                                                                                                                                                                                                                                                                                                                                                | R/WC   | 0b      |
| 26    | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RO     | -       |
| 25:20 | Size (I2C_ACCESS_SIZE)<br>The contents of this field specifies the number of bytes in a sequential<br>access.                                                                                                                                                                                                                                                                                                                                                                          | R/W    | 00h     |
| 19    | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RO     | -       |
| 18    | Skip Status (I2C_SKIP_STATUS)<br>This bit informs the hardware to skip the status check after address in read<br>operations.                                                                                                                                                                                                                                                                                                                                                           | R/W    | 0b      |
| 17    | <b>Sequential Access Enable (I2C_SEQ_ACCESS)</b><br>When set, this bit enables sequential access via the I2C_SEQ_DATA_x registers. When clear, a non-sequential access will be performed using the I2C_DATA field of this register.                                                                                                                                                                                                                                                    | R/W    | Ob      |
| 16    | Read/Write Select (I2C_READ_nWRITE)<br>When set, a read access will be performed. When cleared, a write will<br>occur.                                                                                                                                                                                                                                                                                                                                                                 | R/W    | 0b      |
| 15:8  | Address (I2C_ADDRESS)<br>This field specifies the address of the I <sup>2</sup> C access.                                                                                                                                                                                                                                                                                                                                                                                              | R/W    | 00h     |
| 7:0   | <b>Data (I2C_DATA)</b><br>This field is used to access read/write data for a non-sequential access.                                                                                                                                                                                                                                                                                                                                                                                    | R/W    | 00h     |



Note 12.3 The Error (I2C\_ACCESS\_ERROR) bit will not indicate an error when the video cable (VGA/HDMI/DVI) is unplugged and software attempts to read the EDID of the monitor. In this case, the State (I2C\_ACCESS\_DONE) bit is not set nor is the Busy (I2C\_ACCESS\_BUSY) bit cleared by hardware. Software should utilize a timer with a suitable timeout period to force reset of the I2C Access Module when a condition of this sort occurs. This issue only occurs when the Sequential Access Enable (I2C\_SEQ\_ACCESS) bit is set.



## 12.5.32 I2C Pin Control Register (I2C\_PIN)

Offset:

0104h

Size:

32 bits

| BITS | DESCRIPTION                               | TYPE | DEFAULT |
|------|-------------------------------------------|------|---------|
| 31:5 | RESERVED                                  | RO   | -       |
| 4    | I2C Clock pin output enable (I2C_CLK_OEN) | R/W  | 0b      |
| 3    | I2C Clock pin input value (I2C_CLK_IN)    | RO   | Х       |
| 2    | I2C Data pin output enable (I2C_DATA_OEN) | R/W  | 0b      |
| 1    | I2C Data pin input value (I2C_DATA_IN)    | RO   | Х       |
| 0    | I2C Raw pin control enable (I2C_RAW_EN)   | R/W  | 0b      |



#### 12.5.33 Sequential Data 0 Register (I2C\_SEQ\_DATA\_0)

Offset: 0110h Size: 32 bits

| BITS | DESCRIPTION                        | TYPE | DEFAULT    |
|------|------------------------------------|------|------------|
| 31:0 | SEQUENTIAL DATA 0 (I2C_SEQ_DATA_0) | R/W  | 0000_0000h |



## 12.5.34 Sequential Data 1 Register (I2C\_SEQ\_DATA\_1)

Offset: 0114h Size: 32 bits

| BITS | DESCRIPTION                        | TYPE | DEFAULT    |
|------|------------------------------------|------|------------|
| 31:0 | SEQUENTIAL DATA 1 (I2C_SEQ_DATA_1) | R/W  | 0000_0000h |



#### 12.5.35 Sequential Data 2 Register (I2C\_SEQ\_DATA\_2)

Offset: 0118h Size: 32 bits

| BITS | DESCRIPTION                        | TYPE | DEFAULT    |
|------|------------------------------------|------|------------|
| 31:0 | SEQUENTIAL DATA 2 (I2C_SEQ_DATA_2) | R/W  | 0000_0000h |



### 12.5.36 Sequential Data 3 Register (I2C\_SEQ\_DATA\_3)

Offset: 011Ch Size: 32 bits

| BITS | DESCRIPTION                        | TYPE | DEFAULT    |
|------|------------------------------------|------|------------|
| 31:0 | SEQUENTIAL DATA 3 (I2C_SEQ_DATA_3) | R/W  | 0000_0000h |



#### 12.5.37 Sequential Data 4 Register (I2C\_SEQ\_DATA\_4)

Offset: 0120h Size: 32 bits

| BITS | DESCRIPTION                        | TYPE | DEFAULT    |
|------|------------------------------------|------|------------|
| 31:0 | SEQUENTIAL DATA 4 (I2C_SEQ_DATA_4) | R/W  | 0000_0000h |



#### 12.5.38 Sequential Data 5 Register (I2C\_SEQ\_DATA\_5)

Offset: 0124h Size: 32 bits

| BITS | DESCRIPTION                        | TYPE | DEFAULT    |
|------|------------------------------------|------|------------|
| 31:0 | SEQUENTIAL DATA 5 (I2C_SEQ_DATA_5) | R/W  | 0000_0000h |



#### 12.5.39 Sequential Data 6 Register (I2C\_SEQ\_DATA\_6)

Offset: 0128h Size: 32 bits

| BITS | DESCRIPTION                        | TYPE | DEFAULT    |
|------|------------------------------------|------|------------|
| 31:0 | SEQUENTIAL DATA 6 (I2C_SEQ_DATA_6) | R/W  | 0000_0000h |



## 12.5.40 Sequential Data 7 Register (I2C\_SEQ\_DATA\_7)

Offset: 012Ch Size: 32 bits

| BITS | DESCRIPTION                        | TYPE | DEFAULT    |
|------|------------------------------------|------|------------|
| 31:0 | SEQUENTIAL DATA 7 (I2C_SEQ_DATA_7) | R/W  | 0000_0000h |



#### 12.5.41 Sequential Data 8 Register (I2C\_SEQ\_DATA\_8)

Offset: 0130h Size: 32 bits

| BITS | DESCRIPTION                        | TYPE | DEFAULT    |
|------|------------------------------------|------|------------|
| 31:0 | SEQUENTIAL DATA 8 (I2C_SEQ_DATA_8) | R/W  | 0000_0000h |



### 12.5.42 Sequential Data 9 Register (I2C\_SEQ\_DATA\_9)

Offset: 0134h Size: 32 bits

| BITS | DESCRIPTION                        | TYPE | DEFAULT    |
|------|------------------------------------|------|------------|
| 31:0 | SEQUENTIAL DATA 9 (I2C_SEQ_DATA_9) | R/W  | 0000_0000h |



#### 12.5.43 Sequential Data 10 Register (I2C\_SEQ\_DATA\_10)

| Offset: | 0138h | Size: | 32 bits |
|---------|-------|-------|---------|
|---------|-------|-------|---------|

| BITS | DESCRIPTION                          | TYPE | DEFAULT    |
|------|--------------------------------------|------|------------|
| 31:0 | SEQUENTIAL DATA 10 (I2C_SEQ_DATA_10) | R/W  | 0000_0000h |



### 12.5.44 Sequential Data 11 Register (I2C\_SEQ\_DATA\_11)

Offset: 013Ch Size: 32 bits

| BITS | DESCRIPTION                          | TYPE | DEFAULT    |
|------|--------------------------------------|------|------------|
| 31:0 | SEQUENTIAL DATA 11 (I2C_SEQ_DATA_11) | R/W  | 0000_0000h |



#### 12.5.45 Sequential Data 12 Register (I2C\_SEQ\_DATA\_12)

| Offset: | 0140h | Size: | 32 bits |
|---------|-------|-------|---------|
|---------|-------|-------|---------|

| BITS | DESCRIPTION                          | TYPE | DEFAULT    |
|------|--------------------------------------|------|------------|
| 31:0 | SEQUENTIAL DATA 12 (I2C_SEQ_DATA_12) | R/W  | 0000_0000h |



### 12.5.46 Sequential Data 13 Register (I2C\_SEQ\_DATA\_13)

Offset: 0144h Size: 32 bits

| BITS | DESCRIPTION                          | TYPE | DEFAULT    |
|------|--------------------------------------|------|------------|
| 31:0 | SEQUENTIAL DATA 13 (I2C_SEQ_DATA_13) | R/W  | 0000_0000h |



#### 12.5.47 Sequential Data 14 Register (I2C\_SEQ\_DATA\_14)

| Offset: | 0148h | Size: | 32 bits |
|---------|-------|-------|---------|
|---------|-------|-------|---------|

| BITS | DESCRIPTION                          | TYPE | DEFAULT    |
|------|--------------------------------------|------|------------|
| 31:0 | SEQUENTIAL DATA 14 (I2C_SEQ_DATA_14) | R/W  | 0000_0000h |



### 12.5.48 Sequential Data 15 Register (I2C\_SEQ\_DATA\_15)

Offset: 014Ch Size: 32 bits

| BITS | DESCRIPTION                          | TYPE | DEFAULT    |
|------|--------------------------------------|------|------------|
| 31:0 | SEQUENTIAL DATA 15 (I2C_SEQ_DATA_15) | R/W  | 0000_0000h |



# **Chapter 13 System Control**

#### 13.1 Overview

This section contains entities that control system hardware operation and whose Control and Status registers operate solely on clk\_xtal. As a result, these entities may be configured before the System PLL is operable.

#### 13.2 I2C Selection

I2C port selection is accomplished via the I2C Interface Select (I2C\_SEL) bit of the I2C Interface Selection Register (I2C\_SEL). When this bit is clear, the HDMI transmitter is connected to I2C Port 0 and the I2C Controller is connected to I2C Port 1. When the bit is set, the HDMI transmitter is connected to I2C Port 1, while the I2C Controller is connected to I2C Port 0.



Figure 13.1 I2C Interface Selection



# 13.3 Control and Status Registers

The System Control CSRs are capable of configuring various system settings. This block operates on clk\_xtal, therefore, its CSRs are available before the System PLL is enabled.

| ADDRESS       | SYMBOL   | REGISTER NAME                   |
|---------------|----------|---------------------------------|
| 3000h         | ID_REV   | Device ID Register              |
| 3004h         | FPGA_REV | FPGA Revision Register          |
| 3008h         | HW_CFG   | Hardware Configuration Register |
| 300Ch         | RESERVED | Reserved for future expansion   |
| 3010h         | I2C_SEL  | I2C Selection Register          |
| 3010h – 3FFFh | RESERVED | Reserved for future expansion   |

#### Table 13.1 System Control Register Map



## 13.3.1 Device ID (ID\_REV)

| Offset: |  |
|---------|--|
|         |  |

0000h

Size:

32 bits

BITSDESCRIPTIONTYPEDEFAULT31:16Device ID (ID)RO9D01h15:0Device Revision (REV)RONote 13.1

Note 13.1 Default value is dependent on device revision.



## 13.3.2 FPGA (FPGA\_REV)

Offset:

0004h

Size:

32 bits

| BITS  | DESCRIPTION              | TYPE | DEFAULT |
|-------|--------------------------|------|---------|
| 31:16 | RESERVED                 | RO   | -       |
| 15:0  | FPGA Revision (FPGA_REV) | RO   | 0000h   |



## 13.3.3 Hardware Configuration Register (HW\_CFG)

Offset:

0008h

Size:

32 bits

| BITS | DESCRIPTION                                                                                                                                                                                                                                                                          | TYPE | DEFAULT   |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:7 | RESERVED                                                                                                                                                                                                                                                                             | RO   | -         |
| 6    | <b>SW_MODE Polarity (SW_MODE_POL)</b><br>This bit selects the polarity of the nSW_MODE pin.                                                                                                                                                                                          | R/W  | Note 13.2 |
|      | 0 = Active low.<br>1 = Active high.                                                                                                                                                                                                                                                  |      |           |
|      | <b>Note:</b> This field is protected by Reset Protection (RST_PROTECT)                                                                                                                                                                                                               |      |           |
| 5    | Interrupt Pin Polarity (INT_POL)<br>This bit indicates the polarity of the INT pin. When set, the INT pin is active-<br>high. Otherwise it is active-low.                                                                                                                            | R/W  | Note 13.3 |
|      | <b>Note:</b> This field is protected by Reset Protection (RST_PROTECT).                                                                                                                                                                                                              |      |           |
| 4    | <b>EEPROM Emulation Enable (EEM)</b><br>This bit is used to select the source of descriptor information and<br>configuration flags when no EEPROM is present.                                                                                                                        | R/W  | Ob        |
|      | 0 = Use defaults as specified in Section 8.3, "EEPROM Defaults," on page 146.                                                                                                                                                                                                        |      |           |
|      | 1 = Use Descriptor RAM and Attributes Registers                                                                                                                                                                                                                                      |      |           |
|      | <b>Note:</b> This bit affects operation only when a EEPROM is not present. This bit has no effect when a EEPROM is present.                                                                                                                                                          |      |           |
|      | <b>Note:</b> This field is protected by Reset Protection (RST_PROTECT).                                                                                                                                                                                                              |      |           |
| 3    | <b>Reset Protection (RST_PROTECT)</b><br>Setting this bit protects select fields of certain registers from being affected by resets other than POR.                                                                                                                                  | R/W  | Ob        |
|      | <b>Note:</b> This field is protected by Reset Protection (RST_PROTECT).                                                                                                                                                                                                              |      |           |
| 2    | <b>EEPROM Time-out Control (ETC)</b><br>This bit controls the length of time used by the EEPOM controller to detect<br>a time-out.                                                                                                                                                   | R/W  | Ob        |
|      | 0 = Time-out occurs if no response received from EEPROM after 30 ms.<br>1 = Time-out occurs if no response received from EEPROM after 1.28 us.                                                                                                                                       |      |           |
| 1    | <b>Soft Reset (SRST)</b><br>Writing 1 generates a software initiated reset of the device. If an external Ethernet PHY is used, it will be reset as well.                                                                                                                             | SC   | Ob        |
|      | A software reset will result in the contents of the EEPROM being reloaded.<br>While the reset sequence is in progress, the USB PHY will be disconnected.<br>After the device has been reinitialized, it will take the PHY out of the<br>disconnect state and be visible to the Host. |      |           |
| 0    | Soft Lite Reset (LRST)<br>Writing 1 generates the lite software reset of the device.                                                                                                                                                                                                 | SC   | 0b        |
|      | A lite reset will not affect the UDC. Additionally, the contents of the EEPROM will not be reloaded. This reset will not cause the USB PHY to be disconnected. This bit clears after the reset sequence has completed.                                                               |      |           |



- Note 13.2 The default value of this field is determined by the value of the SW\_MODE Polarity (CFG0\_SW\_MODE\_POL) field of the Configuration Flags 0 contained within the EEPROM, if present. If no EEPROM is present, 0b is the default. A USB Reset or Lite Reset (LRST) will cause this field to be restored to the image value last loaded from EEPROM, or to be set to 0b if no EEPROM is present.
- Note 13.3 The default value of this bit is determined by the value of the Interrupt Pin Polarity (CFG0\_INT\_PIN\_POL) bit of Configuration Flags 0 contained within the EEPROM, if present. If no EEPROM is present, 0b is the default. A USB Reset or Lite Reset (LRST) will cause this field to be restored to the image value last loaded from EEPROM, or to be set to 0b if no EEPROM is present.



## 13.3.4 I2C Interface Selection Register (I2C\_SEL)

Offset:

0010h

Size:

32 bits

| BITS | DESCRIPTION                    | TYPE | DEFAULT |
|------|--------------------------------|------|---------|
| 31:1 | RESERVED                       | RO   | -       |
| 0    | I2C Interface Select (I2C_SEL) | R/W  | 0       |
|      | Controls I2C selection mux     |      |         |

See Section 13.2, "I2C Selection" for a description of the operation of this register.



# **Chapter 14 Miscellaneous**

#### 14.1 Overview

This section describes miscellaneous registers that are present in the device.

## 14.2 LED Configuration

The device supports an LED which can be configured to visually indicate the amount of USB Bulk Out data packet traffic it is handling. When the LED Enable (LED\_EN) bit of LED Configuration Register 0 (LED\_CFG0) is set, and the SW LED Control (SW\_LED\_CTRL) bit is clear, the LED is enabled for traffic indication. When LED Enable (LED\_EN) is cleared, the LED is disabled. When LED Enable (LED\_EN) and SW LED Control (SW\_LED\_CTRL) are both set, software is in control of the LED blinking and the amount of USB Bulk Out packet traffic has no effect on LED operation.

The following assumptions hold when determining the amount of USB Bulk Out data packet traffic:

- The total number of received bulk packets are counted.
- Only the size of the data stage is counted.

Figure 14.1illustrates how the initial state of the LED is determined. From the initial state, the transitions indicated in Figure 14.2 occur, depending on the events encountered during operation.

- **Note:** The operations illustrated in Figure 14.1 and Figure 14.2 are VALID ONLY WHEN SW LED Control (SW\_LED\_CTRL) IS CLEAR.
- **Note:** If I2S Enable (I2S\_EN) is set and I2SCLKALT1 is selected, then LED Enable (LED\_EN) must not be set, otherwise unpredictable results and untoward operation will result.





Figure 14.1 LED Initial State Determination





Figure 14.2 LED State Transitions



The LED Configuration Register 1 (LED\_CFG1) specifies the traffic rates for the LED fast and slow blink thresholds. The hardware will periodically check the traffic rate against these thresholds whenever the LED Enable (LED\_EN) bit of the LED Configuration Register 0 (LED\_CFG0) is set, and the state is LED\_Fast, LED\_Slow, or LED\_Solid. The Fast Blink Threshold (FAST\_THR) has precedence and is always checked first by the hardware. If the traffic rate is greater than the Fast Blink Threshold (FAST\_THR), then the LED is flashed at the rate dictated by the Fast Threshold Blink Time (FAST\_THR, then the LED Configuration Register 2 (LED\_CFG2). If the traffic rate does not exceed the Fast Blink Threshold (FAST\_THR), then the traffic rate exceeds the Slow Blink Threshold (SLOW\_THR). If the traffic rate exceeds the Slow Blink Time (SLOW\_THR), then the LED is flashed at the rate dictated by the Slow Threshold Blink Time (SLOW\_THR, BLINK) field in LED Configuration Register 2 (LED\_CFG2). LED\_Fast and LED\_Slow are the LED states entered when the corresponding blink threshold is exceeded. LED\_Solid is entered on any one of the following conditions:

- 1. When the LED is initially enabled.
- 2. On transitions from the SUSPEND state.
- 3. On a transition from LED\_Fast or LED\_Slow when the traffic fails to exceed the Fast Blink Threshold (FAST\_THR) and the Slow Blink Threshold (SLOW\_THR), respectively.
- 4. Whenever either threshold value contained in the LED Configuration Register 1 (LED\_CFG1) is altered by SW.
- 5. Whenever the contents of LED Configuration Register 2 (LED\_CFG2) is updated.

Upon entering the LED\_Solid state, traffic rate measurement and comparison with the thresholds commences.

One or both threshold checks may be disabled by writing the value FFFFh into threshold fields of LED Configuration Register 1 (LED\_CFG1). Whenever the LED is enabled and both threshold checks are disabled, the LED will remain in the LED\_SOLID state, with the LED being continuously illuminated.

**Note:** The default values for FAST\_THR and SLOW\_THR of FFFFh disable both threshold checks. In order to perform one or both of the threshold checks, and enable blinking according to the threshold met, set the threshold field corresponding to the desired check(s) to a value other than FFFFh.



## 14.3 Audio Configuration

#### 14.3.1 I2S Audio

Three registers are provided in this section for audio configuration when the I2S audio pathway is to be utilized. Note that only single channel I2S is supported. The Audio Configuration Register (AUDIO\_CFG) is used to enable the I2S audio pathway, select the pin on which the I2S clock input is present, and to enable I2S frequency measurement. The I2S Enable (I2S\_EN) bit of this register is set to enable usage of the I2S audio path. When I2S Enable (I2S\_EN) is set, the setting of the I2SCLK Select (I2SCLK\_SEL) bit determines the pin (I2SCLKALT0 or I2SCLKALT1) on which the I2S clock signal is connected. Since I2SCLKALT1 shares pin functionality with the LED signal, both I2S Enable (I2S\_EN) and LED Enable (LED\_EN), or enable GPIO24, may not be set at the same time, otherwise unpredictable results and untoward operation will result. Likewise it is not valid to enable single ended RGB mode, or GPIO0 enable, when using I2SCLKALT1.

**Note:** I2SCLKALT0 is used if single data rate RGB is required. Otherwise I2SCLKALT1 is used in the typical case.

Hardware dedicated to measuring the sampling rate of the CODEC and to determine when audio data starts/stops is enabled via the I2S Frequency Measurement Enable (I2S\_FREQ\_EN) bit of the Audio Configuration Register (AUDIO\_CFG). When this is set, the results of the measurements are available in the Audio Frequency 0 Register (AUDIO\_FREQ0) and Audio Frequency 1 Register (AUDIO\_FREQ1) 1 ms later and are subsequently updated every 1ms. No interrupt is available to signal software that a result is available. Software must poll the registers to obtain updated results. The Audio Frequency 0 Register (AUDIO\_FREQ0) provides measurements of the frequency at which the WS signal and I2S Clock toggle at. The units are transitions/ms. The I2S WS Frequency (WS\_FREQ) field toggles one clock cycle before the MSB of a new audio word, thus it provides an accurate metric for sampling audio frequency. I2S Clock Frequency (I2SCLK\_FREQ) contains the value of the frequency the I2S Clock toggles at. This field may be checked to determine that the clock signal is present.

The Audio Frequency 1 Register (AUDIO\_FREQ1) provides measurements of the frequency at which the MCLK pin and the I2SDATA pin toggle. They are useful in determining the presence of the MCLK signal and for determining when audio data starts/stops.

**Note:** An existing GPIO pin may be used to force the disconnect of the partner USB audio CODEC. It is suggested that GPIO30 be used, as it is available in all configurations of the part.

The results of the frequency measurements are used by the software to program the HDMI channel status CSRs appropriately.

#### 14.3.2 SDPIF Audio

When SPDIF audio is in use, the I2S Enable (I2S\_EN) bit of the Audio Configuration Register (AUDIO\_CFG) must be cleared. Minimum programming of the HDMI CSRs is required to facilitate operation in this mode.



# 14.4 Control and Status Registers

These CSRs are only accessibly after the System PLL is programmed and sys\_clk is available.

| ADDRESS       | SYMBOL       | REGISTER NAME                         |
|---------------|--------------|---------------------------------------|
| 8000h         | DP SEL       | Data Port Select Register             |
| 8004h         | DP CMD       | Data Port Command Register            |
| 8008h         | <br>DP_ADDR  | Data Port Address Register            |
| 800Ch         | <br>DP_DATA0 | Data Port Data Register 0             |
| 8010h         | DP_DATA1     | Data Port Data Register 1             |
| 8014h – 801Fh | RESERVED     | Reserved for future expansion         |
| 8020h         | FIFO_STATUS  | FIFO Status Register                  |
| 8024h         | VDAC_CFG     | Video DAC Configuration Register      |
| 8028h         | RGB_CFG      | RGB Configuration Register            |
| 802Ch         | EXT_RST_CFG  | External Reset Configuration Register |
| 8030h         | AUDIO_CFG    | Audio Configuration Register          |
| 8034h         | AUDIO_FREQ0  | Audio Frequency 0 Register            |
| 8038h         | AUDIO_FREQ1  | Audio Frequency 1 Register            |
| 803Ch – 803Fh | RESERVED     | Reserved for future expansion         |
| 8040h         | HDMI_CFG     | HDMI Configuration Register           |
| 8044h – 807Fh | RESERVED     | Reserved for future expansion         |
| 8080h         | LED_CFG0     | LED Configuration Register 0          |
| 8084h         | LED_CFG1     | LED Configuration Register 1          |
| 8088h         | LED_CFG2     | LED Configuration Register 2          |
| 808Ch – 809Fh | RESERVED     | Reserved for future expansion         |
| 80A0h         | GPIO_ENABLE  | GPIO Enable Register                  |
| 80A4h         | GPIO_BUF     | GPIO Buffer Type Register             |
| 80A8h         | GPIO_DIR     | GPIO Direction Register               |
| 80ACh         | GPIO_DATA    | GPIO Data Register                    |
| 80B0h – 80FFh | RESERVED     | Reserved for future expansion         |
| 8100h         | BOS_ATTR     | BOS Attributes Register               |
| 8104h         | RESERVED     | Reserved for future expansion         |
| 8108h         | HS_ATTR      | High Speed Attributes Register        |
| 810Ch         | FS_ATTR      | Full Speed Attributes Register        |
| 8110h         | STRNG_ATTR0  | String Attributes Register 0          |
| 8114h         | STRNG_ATTR1  | String Attributes Register 0          |
| 8118h – 8FFFh | RESERVED     | Reserved for future expansion         |

### Table 14.1 Miscellaneous Control and Status Register Map



## 14.4.1 Data Port Select Register (DP\_SEL)

Offset: 0000h Size: 32 bits

Before accessing the internal RAMs, the RAM Test Mode Enable (DP\_SEL\_TESTEN) bit must be set. It is not valid to use the RAM data port during run time.

The Data Port Select (DP\_SEL\_RSEL) field chooses which internal RAM to access.

The Data Port Ready (DP\_SEL\_DPRDY) bit indicates when the data port RAM access has completed. In the case of a read operation, this indicates when the read data has been stored in the DP\_DATA register.

Note: All writes to the Data Port Registers are ignored when the data port is busy.

| BITS  | DESCRIPTION                                                                                                                                                                                                                    | TYPE | DEFAULT |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31    | Data Port Ready (DP_SEL_DPRDY)                                                                                                                                                                                                 | RO   | 1b      |
|       | 0 = Data port is busy processing a transaction<br>1 = Data port is ready                                                                                                                                                       |      |         |
| 30    | Data Port Done (DP_DONE)<br>This bit asserts after the Data Port transaction successfully completes.                                                                                                                           | R/WC | Ob      |
| 29:24 | RESERVED                                                                                                                                                                                                                       | RO   | -       |
| 23:20 | <b>Transaction Response ID (DP_SEL_ID)</b><br>This field corresponds to the Data Port Command ID (DP_CMD_ID) written when the transaction was issued.                                                                          | RO   | 0       |
| 19:18 | RESERVED                                                                                                                                                                                                                       | RO   | -       |
| 17:16 | Transaction Response Status (DP_SEL_RESP)<br>AXI protocol response.                                                                                                                                                            | RO   | 0       |
|       | 00 = OKAY - Indicates if a normal access has been successful. Can also indicate an exclusive access failure.                                                                                                                   |      |         |
|       | 01 = EXOKAY - indicates that either the read or write portion of an exclusive access has been successful.                                                                                                                      |      |         |
|       | 10 = SLVERR - The access has reached the slave successfully, but the slave wishes to return an error condition to the originating master.                                                                                      |      |         |
|       | 11 = DECERR - Decode error - indicates that there is no slave at the transaction address.                                                                                                                                      |      |         |
| 15:10 | RESERVED                                                                                                                                                                                                                       | RO   | -       |
| 9:4   | Data Port Select (DP_SEL_RSEL)<br>Selects target of the dataport access. See Table 14.2 for mapping.                                                                                                                           | R/W  | 0       |
| 3:2   | RESERVED                                                                                                                                                                                                                       | RO   | -       |
| 1     | Auto Address Increment Enable (DP_SEL_AINC)<br>Determines whether or not the Data Port Address Register (DP_ADDR) is<br>incremented after a transaction completes.                                                             | R/W  | 0       |
|       | 0 = Address incrementing disabled<br>1 = After each transaction completes, the Data Port Address Register<br>(DP_ADDR) is automatically incremented depending on the transaction size<br>(incremented by 8 for DDR2 accesses). |      |         |



| BITS | DESCRIPTION                                                                                         | TYPE | DEFAULT |
|------|-----------------------------------------------------------------------------------------------------|------|---------|
| 0    | <b>RAM Test Mode Enable (DP_SEL_TESTEN)</b><br>When set, put all test accessible RAMs in test mode. | R/W  | 0       |

#### Table 14.2 Data Port Select Mapping Table

| DATA PORT<br>SELECT | DATA PORT TARGET   |
|---------------------|--------------------|
| 00h                 | DDR2 RAM           |
| 01h - 11h           | Reserved           |
| 12h                 | USB Descriptor RAM |
| 13h - 28h           | Reserved           |
| 29h                 | SSP PHY CSRs       |
| 2Ah                 | HDMI CSRs          |
| 2Bh - 3Fh           | Reserved           |



## 14.4.2 Data Port Command Register (DP\_CMD)

Offset: 0004h Size: 32 bits

This register commences the data port access. Writing a one to this register will enable a write access, while writing a zero will do a read access.

The address and data registers need to be configured appropriately for the desired read or write operation before accessing the register.

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                | TYPE | DEFAULT |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:17 | RESERVED                                                                                                                                                                                                                                                                   | RO   | -       |
| 16:8  | Byte Enables (DP_CMD_BE)<br>Byte Enables for a write command.                                                                                                                                                                                                              | R/W  | 0       |
| 7:4   | <b>Data Port Command ID (DP_CMD_ID)</b><br>This field may be used to write an identifier for the command. When the transaction is complete, the value of the Transaction Response ID (DP_SEL_ID) field in Data Port Select Register (DP_SEL) should agree with this field. | R/W  | 0       |
| 3:1   | RESERVED                                                                                                                                                                                                                                                                   | RO   | -       |
| 0     | Data Port Write Or Read (DP_CMD_WOR)<br>Selects operation. Writing to this bit initiates the data port access.                                                                                                                                                             | R/W  | 0       |
|       | 0 = Read operation<br>1 = Write operation                                                                                                                                                                                                                                  |      |         |



## 14.4.3 Data Port Address Register (DP\_ADDR)

Offset:

Size:

32 bits

Indicates the address to be used for the data port access.

0008h

| BITS  | DESCRIPTION                 | TYPE | DEFAULT   |
|-------|-----------------------------|------|-----------|
| 31:26 | RESERVED                    | RO   | -         |
| 25:0  | Data Port Address (DP_ADDR) | R/W  | 000_0000h |



## 14.4.4 Data Port Data 0 Register (DP\_DATA0)

Offset: 000Ch Size: 32 bits

The Data Port Data register holds the write data for a write access and the resultant read data for a read access.

Before reading this register for the result of a read operation, the Data Port Ready (DP\_SEL\_DPRDY) bit should be checked. The Data Port Ready (DP\_SEL\_DPRDY) bit must indicate the data port is ready. Otherwise, the read operation is still in progress.

| BITS | DESCRIPTION                      | TYPE | DEFAULT    |
|------|----------------------------------|------|------------|
| 31:0 | Data Port Data [31:0] (DP_DATA0) | R/W  | 0000_0000h |



## 14.4.5 Data Port Data 1 Register (DP\_DATA1)

Offset: 0010h Size: 32 bits

The Data Port Data register holds the write data for a write access and the resultant read data for a read access.

Before reading this register for the result of a read operation, the Data Port Ready (DP\_SEL\_DPRDY) bit should be checked. The Data Port Ready (DP\_SEL\_DPRDY) bit must indicate the data port is ready. Otherwise, the read operation is still in progress.

This register is required when accessing the DDR2 DRAM.

| BITS | DESCRIPTION                       | TYPE | DEFAULT    |
|------|-----------------------------------|------|------------|
| 31:0 | Data Port Data [63:32] (DP_DATA1) | R/W  | 0000_0000h |



## 14.4.6 FIFO Status Register (FIFO\_STATUS)

Offset:

```
0020h
```

```
Size:
```

| BITS  | DESCRIPTION                                                                                                                                                                                                                                    | TYPE | DEFAULT |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31    | FCT RX FIFO Reset (FCT_RX_RESET)<br>When set, the FCT RX FIFO pointers are reset. Any remnant data from the<br>FIFO stored in the datapath is also cleared.                                                                                    | SC   | 0b      |
| 30:16 | RESERVED                                                                                                                                                                                                                                       | RO   | -       |
| 15:0  | <b>RX Data FIFO Free Space (RXDFREE)</b><br>The amount of free space, in bytes, in the RX Data FIFO. The value returned<br>is rounded down to the nearest QWORD to take into account any payload<br>bytes that do not end on a QWORD boundary. | RO   | 4800h   |



# 14.4.7 Video DAC Configuration Register (VDAC\_CFG)

Offset:

0024h

```
Size:
```

| BITS | DESCRIPTION                                                | TYPE | DEFAULT |
|------|------------------------------------------------------------|------|---------|
| 31:8 | RESERVED                                                   | RO   | -       |
| 7    | Enable External Reference Current (BYP_IDAC)               | R/W  | 0b      |
| 6    | Enable 34 mA Output Full-Scale (EN_34)                     | R/W  | 0b      |
| 5    | Enable Analog Biasing Test Control 1 (EN_CTR1)             | R/W  | 0b      |
| 4    | Enable Analog Biasing Test Control 0 (EN_CTR0)             | R/W  | 0b      |
| 3    | RESERVED                                                   | RO   | -       |
| 2    | Enable DAC Channel 2 (EN_DAC2)<br>Powers up DAC Channel 2. | R/W  | 0b      |
| 1    | Enable DAC Channel 1 (EN_DAC1)<br>Powers up DAC Channel 1. | R/W  | 0b      |
| 0    | Enable DAC Channel 0 (EN_DAC0)<br>Powers up DAC Channel 0. | R/W  | 0b      |



# 14.4.8 RGB Configuration Register (RGB\_CFG)

Offset:

0028h

Size:

| BITS | DESCRIPTION                                                                                             | TYPE | DEFAULT |
|------|---------------------------------------------------------------------------------------------------------|------|---------|
| 31:2 | RESERVED                                                                                                | RO   | -       |
| 1    | VDAC Pad Enable (VDACPAD_EN)                                                                            | R/W  | 0b      |
|      | This bit disables the VDAC_HSYNC and VDAC_VSYNC pads when cleared.                                      |      |         |
| 0    | RGB Pad Enable (RGBPAD_EN)                                                                              | R/W  | 0b      |
|      | This bit disables the RGB pads (VDATA0 - VDATA23, RGB_VSYNC, RGB_HSYNC, nBLANK, and VCLK) when cleared. |      |         |



## 14.4.9 External Reset Configuration Register (EXT\_RST\_CFG)

002Ch

Offset:

32 bits

Size:

See Table 6.1, "Chip Level Resets" for additional description about this reset.

| BITS | DESCRIPTION                                                                                                                                                                                            | TYPE | DEFAULT   |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31:5 | RESERVED                                                                                                                                                                                               | RO   | -         |
| 4    | External Reset Force (EXT_RST_FORCE)<br>When set, the external reset is asserted. When clear, the external reset is<br>released.<br>Note: This function is a logical or with the Assert External Reset | R/W  | Ob        |
|      | (EXT_RST_AST).                                                                                                                                                                                         |      |           |
| 3:2  | External Reset Period (EXT_RST_PERIOD)<br>Defines the amount of time the nEXTRST pin is asserted.                                                                                                      | R/W  | 00b       |
|      | 00 = Assert reset for 50 us<br>01 = Assert reset for 1 ms<br>10 = Assert reset for 32 ms<br>11 = Assert reset for 128 ms                                                                               |      |           |
| 1    | Assert External Reset (EXT_RST_AST)<br>Asserts the external reset pin for the amount of time specified by<br>EXT_RST_PERIOD and clears after reset has completed.                                      | R/SC | 0b        |
| 0    | <b>External Reset Polarity (EXT_RST_POL)</b><br>Determines the polarity of the external reset pin (nEXTRST).                                                                                           | R/W  | Note 14.1 |
|      | 0 = active-low<br>1 = active-high                                                                                                                                                                      |      |           |
|      | <b>Note:</b> This field is protected by Reset Protection (RST_PROTECT).                                                                                                                                |      |           |

Note 14.1 The default value of this bit is determined by the value of the External Reset Polarity (CFG0\_EXT\_RST\_POL) bit of Configuration Flags 0 contained within the EEPROM, if present. If no EEPROM is present, 0b is the default. A USB Reset or Lite Reset (LRST) will cause this field to be restored to the image value last loaded from EEPROM, or to be set to 0b if no EEPROM is present.



## 14.4.10 Audio Configuration Register (AUDIO\_CFG)

0030h

Offset:

```
Size:
```

32 bits

| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                   | TYPE | DEFAULT |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31   | <b>LED 1 uS TESTMODE (LED_TEST_1US)</b><br>Setting this test bit causes the audio frequency counters to operate at 1uS intervals rather than 1 mS for testing purposes.                                                                                                                                                                                                       | R/W  | 0b      |
| 30:5 | RESERVED                                                                                                                                                                                                                                                                                                                                                                      | RO   | -       |
| 4    | <b>I2SCLK Select (I2SCLK_SEL)</b><br>When I2S Enable (I2S_EN) is set, this bit specifies the pin functioning as the I2SCLK input.                                                                                                                                                                                                                                             | R/W  | 0b      |
|      | 0 = I2SCLKALT0<br>1 = I2SCLKALT1                                                                                                                                                                                                                                                                                                                                              |      |         |
| 3:2  | RESERVED                                                                                                                                                                                                                                                                                                                                                                      | RO   | -       |
| 1    | <b>I2S Frequency Measurement Enable (I2S_FREQ_EN)</b><br>When set, the frequency that each of the I2S pins (WS,<br>I2SCLKALT0/I2SCLKALT1 (depending on setting of I2SCLK Select<br>(I2SCLK_SEL)), MCLK, and I2SDATA) toggles is measured. Once this bit is<br>set, it takes 1ms before a measurement is available. All subsequent<br>measurements are updated at a 1 ms rate. | R/W  | Ob      |
|      | Note: I2S Enable (I2S_EN) must be set in order for the measurement to be occur.                                                                                                                                                                                                                                                                                               |      |         |
| 0    | <b>I2S Enable (I2S_EN)</b><br>When this bit is set, I2S is enabled and the I2SCLK Select (I2SCLK_SEL) bit determines the I2SCLK input.                                                                                                                                                                                                                                        | R/W  | Ob      |

**Note:** If I2S Enable (I2S\_EN) is set and I2SCLKALT1 is selected, then LED Enable (LED\_EN) must not be set, otherwise unpredictable results and untoward operation will result.



## 14.4.11 Audio Frequency 0 Register (AUDIO\_FREQ0)

```
Offset: 0034h
```

```
Size:
```

| BITS  |                                                                                                                                                                                                      | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                | TYPE | DEFAULT |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:16 | Measur                                                                                                                                                                                               | <b>I2S WS Frequency (WS_FREQ)</b><br>Measures the frequency that the I2S WS pin toggles at. The units are transitions/ms.                                                                                                                                                                                                                                                                  |      | х       |
|       | Note:                                                                                                                                                                                                | The typical audio frequency supported will be 44.1 or 48 Khz. The WS_FREQ is the most appropriate option to determine the sample frequency, since it toggles one clock cycle before the MSB of a new audio word. The hardware only counts positive edges, therefore, the expected values for this field will be 43, 44, or 45 for the 44.1 KHz case and 47, 48, or 49 for the 48 KHz case. |      |         |
|       | Note:                                                                                                                                                                                                | I2S Enable (I2S_EN) and I2S Frequency Measurement Enable (I2S_FREQ_EN) bits must be set in order for the measurement to be taken.                                                                                                                                                                                                                                                          |      |         |
| 15:0  | <b>I2S Clock Frequency (I2SCLK_FREQ)</b><br>Measures the frequency that the I2SCLKALT0/I2SCLKALT1 (depending on setting of I2SCLK Select (I2SCLK_SEL)) pin toggles at. The units are transitions/ms. |                                                                                                                                                                                                                                                                                                                                                                                            | RO   | Х       |
|       | Note:                                                                                                                                                                                                | Only positive clock edges are counted.                                                                                                                                                                                                                                                                                                                                                     |      |         |
|       | Note:                                                                                                                                                                                                | I2S Enable (I2S_EN) and I2S Frequency Measurement Enable (I2S_FREQ_EN) bits must be set in order for the measurement to be taken.                                                                                                                                                                                                                                                          |      |         |



32 bits

## 14.4.12 Audio Frequency 1 Register (AUDIO\_FREQ1)

```
Offset: 0038h Size:
```

```
TYPE
BITS
                                        DESCRIPTION
                                                                                                       DEFAULT
         I2S MCLK Frequency (MCLK_FREQ)
Measures the frequency that the I2S MCLK pin toggles. The units are
31:16
                                                                                             RO
                                                                                                            Х
         transitions/ms.
         Note:
                  Only positive clock edges are counted.
         Note:
                  I2S Enable (I2S EN) and I2S Frequency Measurement Enable
                  (I2S FREQ EN) bits must be set in order for the measurement to
                  be taken.
         I2S Data Frequency (SD_FREQ)
Measures the frequency that the I2SDATA pin toggles. The units are
15:0
                                                                                             RO
                                                                                                            Х
         transitions/ms.
         Note:
                  Only positive clock edges are counted.
         Note:
                  I2S Enable (I2S_EN) and I2S Frequency Measurement Enable
                  (I2S FREQ EN) bits must be set in order for the measurement to
                  be taken.
```



# 14.4.13 HDMI Configuration Register (HDMI\_CFG)

Offset:

0040h

Size:

| BITS | DESCRIPTION                                                | TYPE | DEFAULT |
|------|------------------------------------------------------------|------|---------|
| 31:3 | RESERVED                                                   | RO   | -       |
| 2    | Reset HDMI Access Module (RST_HDMI_ACCESS)                 | R/SC | 0b      |
|      | Resets the HDMI Access Module.                             |      |         |
| 1    | Reset HDMI (RST_HDMI)                                      | R/SC | 0b      |
|      | Asserts hardware resets to HDMI controller for 1 us.       |      |         |
| 0    | Enable HDMI PHY (EN_HDMI)                                  | R/W  | 0b      |
|      | This register controls the power down pin of the HDMI PHY. |      |         |



## 14.4.14 LED Configuration Register 0 (LED\_CFG0)

0080h

Offset:

Size:

| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                                           | TYPE | DEFAULT   |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31   | <b>LED 1 uS TESTMODE (LED_TEST_1US)</b><br>Setting this test bit causes the LED to operate at 1uS intervals rather than 1 mS for testing purposes.                                                                                                                                                                                                    | R/W  | 0b        |
| 30:4 | RESERVED                                                                                                                                                                                                                                                                                                                                              | RO   | -         |
| 3    | <b>LED Buffer Type (LED_TYPE)</b><br>When set, the output buffer for the LED pin is configured as a push/pull<br>driver. When cleared, the LED signal is configured as an open-drain driver.                                                                                                                                                          | R/W  | Note 14.2 |
|      | <b>Note:</b> This field is protected by Reset Protection (RST_PROTECT).                                                                                                                                                                                                                                                                               |      |           |
| 2    | <b>LED Polarity (LED_POL)</b><br>When set, the LED pin is active high. When cleared, the pin is active low.                                                                                                                                                                                                                                           | R/W  | Note 14.3 |
|      | <b>Note:</b> This field is protected by Reset Protection (RST_PROTECT).                                                                                                                                                                                                                                                                               |      |           |
| 1    | SW LED Control (SW_LED_CTRL)<br>When asserted while LED Enable (LED_EN) is set, software controls LED<br>blinking. Hardware control of the blinking rate, as a function of traffic rate, is<br>disabled. The value of the Slow Threshold Blink Time (SLOW_THR_BLINK)<br>field of the LED Configuration Register 2 (LED_CFG2) controls the blink rate. | R/W  | Ob        |
|      | <b>Note:</b> If it is desired to utilize the LED as a non-blinking entity under software control, then LED Enable (LED_EN) must not be enabled and the LED pin should be programmed as a GPIO.                                                                                                                                                        |      |           |
| 0    | LED Enable (LED_EN)                                                                                                                                                                                                                                                                                                                                   | R/W  | Note 14.4 |
|      | When asserted, the LED is enabled.                                                                                                                                                                                                                                                                                                                    |      |           |
|      | <b>Note:</b> This field is protected by Reset Protection (RST_PROTECT).                                                                                                                                                                                                                                                                               |      |           |
|      | <b>Note:</b> If I2S Enable (I2S_EN) is set and I2SCLKALT1 is selected, then LED Enable (LED_EN) must not be set, otherwise unpredictable results and untoward operation will result.                                                                                                                                                                  |      |           |

- Note 14.2 The default value of this bit is determined by the value of the LED Buffer Type (CFG0\_LED\_TYPE) bit of Configuration Flags 0 contained within the EEPROM, if present. If no EEPROM is present, 0b is the default. A USB Reset or Lite Reset (LRST) will cause this field to be restored to the image value last loaded from EEPROM, or to be set to 0b if no EEPROM is present.
- Note 14.3 The default value of this bit is determined by the value of the LED Polarity (CFG0\_LED\_POL) bit of Configuration Flags 0 contained within the EEPROM, if present. If no EEPROM is present, 0b is the default. A USB Reset or Lite Reset (LRST) will cause this field to be restored to the image value last loaded from EEPROM, or to be set to 0b if no EEPROM is present.
- Note 14.4 The default value of this bit is determined by the value of the LED Enable (CFG0\_LED\_ENABLE) bit of Configuration Flags 0 contained within the EEPROM, if present. If no EEPROM is present, 1b is the default. A USB Reset or Lite Reset (LRST) will cause this field to be restored to the image value last loaded from EEPROM, or to be set to 1b if no EEPROM is present.



## 14.4.15 LED Configuration Register 1 (LED\_CFG1)

```
Offset: 0084h Size: 32 bits
```

This register specifies the traffic rates in units of 64 Bytes/mSec for the LED fast and slow blink thresholds. The hardware will periodically check the traffic rate against these thresholds whenever the LED Enable (LED\_EN) bit of the LED Configuration Register 0 (LED\_CFG0) is set and the SW LED Control (SW\_LED\_CTRL) bit is clear. The Fast Blink Threshold (FAST\_THR) has precedence and is always checked first by the hardware. If the traffic rate is greater than the Fast Blink Threshold (FAST\_THR), then the LED is flashed at the rate dictated by the Fast Threshold Blink Time (FAST\_THR\_BLINK) field in LED Configuration Register 2 (LED\_CFG2). If the traffic rate does not exceed the Fast Blink Threshold (FAST\_THR), then the traffic rate exceeds the Slow Blink Threshold (SLOW\_THR). If the traffic rate exceeds the Slow Blink Threshold (SLOW\_THR), then the LED is flashed at the rate dictated by the Slow Threshold Blink Time (SLOW\_THR\_BLINK) field in LED Configuration Register 2 (LED\_CFG2).

- **Note:** The default values for FAST\_THR and SLOW\_THR of FFFFh disable both threshold checks. In this case, the LED is steady on. In order to perform one or both of the threshold checks, set these fields to a value other than FFFFh.
- **Note:** The value of this register is not loaded from EEPROM or preserved across resets. Upon reset, in EEPROM emulation mode, the SW must check the LED Enable (LED\_EN) bit of the LED Configuration Register 0 (LED\_CFG0). If it is set, the SW must re-initialize the value of this register.
- **Note:** The 16-bit threshold field size and units of 64 Bytes/mSec allows for a traffic rate range of 512 Kbits/sec to 33 Gigabits/sec. The maximum value allowed here is approximately 10 times the expected maximum rate.
- **Note:** This register provides no functionality when LED blinking rate is under software control (LED Enable (LED\_EN) and SW LED Control (SW\_LED\_CTRL) both set).

| BITS  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | DESCRIPTION                                                                                                                                                                                                                                                                                                                          | TYPE | DEFAULT |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:16 | When the contract of the contr | checks are disabled, the LED will be steady on.                                                                                                                                                                                                                                                                                      | R/W  | FFFFh   |
|       | Note:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | This threshold has precedence.                                                                                                                                                                                                                                                                                                       |      |         |
|       | Note:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Units = 64-bytes/mSec                                                                                                                                                                                                                                                                                                                |      |         |
| 15:0  | When the second  | <b>link Threshold (SLOW_THR)</b><br>the LED is enabled for hardware traffic monitoring (LED Enable<br>N) set, SW LED Control (SW_LED_CTRL) clear), and the traffic rate<br>is this value, the hardware will blink the LED according to the Slow<br>old Blink Time (SLOW_THR_BLINK) specified in LED Configuration<br>r 2 (LED_CFG2). | R/W  | FFFFh   |
|       | Note:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | A value of FFFFh disables the threshold check. If both threshold checks are disabled, the LED will be steady on.                                                                                                                                                                                                                     |      |         |
|       | Note:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Units = 64-bytes/mSec                                                                                                                                                                                                                                                                                                                |      |         |



## 14.4.16 LED Configuration Register 2 (LED\_CFG2)

```
Offset: 0088h Size: 32 bits
```

This register specifies the parameters that control the blinking rate of the LED.

When hardware controls the blinking rate as a function of traffic (LED Enable (LED\_EN) set, SW LED Control (SW\_LED\_CTRL) clear) and the traffic rate exceeds the Slow Blink Threshold (SLOW\_THR) or the Fast Blink Threshold (FAST\_THR), the LED is cycled on and off repeatedly while either condition is in effect.

When software is in control of the blinking rate (LED Enable (LED\_EN) and SW LED Control (SW\_LED\_CTRL) both set), the LED is blinked at the rate specified by Slow Threshold Blink Time (SLOW\_THR\_BLINK).

**Note:** The value of this register is not loaded from EEPROM or preserved across resets. Upon reset, in EEPROM emulation mode, the SW must check the LED Enable (LED\_EN) bit of the LED Configuration Register 0 (LED\_CFG0). If it is set, the SW must re-initialize the value of this register.

| BITS  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                       | TYPE | DEFAULT |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|
| 31:16 | Fast Threshold Blink Time (FAST_THR_BLINK)<br>Controls the blinking rate when the traffic rate exceeds the Fast Blink<br>Threshold (FAST_THR) and hardware control of LED blinking is in effect.<br>Specifies the time, in mSec, to alternately turn the LED on, then off.                                                                                        | R/W  | 00h     |
| 15:0  | Slow Threshold Blink Time (SLOW_THR_BLINK)<br>Controls the blinking rate when the traffic rate exceeds the Slow Blink<br>Threshold (SLOW_THR) and hardware control of LED blinking is in effect.<br>Also controls the blinking rate when software control of LED blinking is in<br>effect. Specifies the time, in mSec, to alternately turn the LED on, then off. | R/W  | 00h     |



## 14.4.17 GPIO Enable Register (GPIO\_ENABLE)

Offset:

32 bits

Size:

Note: This register is protected by Reset Protection (RST\_PROTECT).

00A0h

| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | TYPE | DEFAULT   |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31   | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RO   | -         |
| 30:0 | <b>GPIO Enable 0-30 (nGPIOEN)</b><br>A '1' sets the associated pin to use the default function. When cleared low, the pin functions as a GPIO signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R/W  | Note 14.5 |
|      | nGPIOEN0 - bit 0<br>nGPIOEN1 - bit 1<br>nGPIOEN2 - bit 2<br>nGPIOEN3 - bit 3<br>nGPIOEN4 - bit 4<br>nGPIOEN5 - bit 5<br>nGPIOEN6 - bit 6<br>nGPIOEN7 - bit 7<br>nGPIOEN8 - bit 8<br>nGPIOEN10 - bit 10<br>nGPIOEN11 - bit 11<br>nGPIOEN11 - bit 12<br>nGPIOEN12 - bit 12<br>nGPIOEN13 - bit 13<br>nGPIOEN15 - bit 15<br>nGPIOEN16 - bit 16<br>nGPIOEN17 - bit 17<br>nGPIOEN18 - bit 18<br>nGPIOEN19 - bit 20<br>nGPIOEN20 - bit 20<br>nGPIOEN22 - bit 22<br>nGPIOEN23 - bit 23<br>nGPIOEN24 - bit 24<br>nGPIOEN25 - bit 25<br>nGPIOEN26 - bit 26<br>nGPIOEN27 - bit 27<br>nGPIOEN28 - bit 28<br>nGPIOEN29 - bit 29<br>nGPIOEN30 - bit 30<br>Note: These GPIOs are disabled after a reset. |      |           |



GPIO Enable Config Byte 0 (GPIOEN\_CFG0) GPIO Enable Config Byte 1 (GPIOEN\_CFG1) GPIO Enable Config Byte 2 (GPIOEN\_CFG2) GPIO Enable Config Byte 3 (GPIOEN\_CFG3)

If no EEPROM is present, 7FFF\_FFFh is the default. A USB Reset or Lite Reset (LRST) will cause this field to be restored to the image value last loaded from EEPROM, or to be set to 7FFF\_FFFh if no EEPROM is present.



## 14.4.18 GPIO Buffer Type Register (GPIO\_BUF)

Offset:

Size:

32 bits

Note: This register is protected by Reset Protection (RST\_PROTECT).

00A4h

| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                                      | TYPE | DEFAULT   |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31   | RESERVED                                                                                                                                                                                                                                                                                                                                         | RO   | -         |
| 30:0 | GPIO Buffer Type 0-30 (GPIOBUF)<br>When set, the output buffer for the corresponding GPIO signal is configured<br>as a push/pull driver. When cleared, the corresponding GPIO set configured<br>as an open-drain driver.<br>GPIOBUF0 - bit 0<br>GPIOBUF1 - bit 1<br>GPIOBUF2 - bit 2<br>GPIOBUF2 - bit 3<br>GPIOBUF4 - bit 4<br>CPIOBUF5 - bit 5 | R/W  | Note 14.6 |
|      | GPIOBUF5 - bit 5<br>GPIOBUF6 - bit 6<br>GPIOBUF7 - bit 7<br>GPIOBUF8 - bit 8<br>GPIOBUF9 - bit 9<br>GPIOBUF10 - bit 10<br>GPIOBUF11 - bit 11<br>GPIOBUF12 - bit 12<br>GPIOBUF13 - bit 13<br>GPIOBUF14 - bit 14<br>GPIOBUF15 - bit 15<br>GPIOBUF16 - bit 16<br>GPIOBUF17 - bit 17                                                                 |      |           |
|      | GPIOBUF17 - bit 17<br>GPIOBUF18 - bit 18<br>GPIOBUF20 - bit 20<br>GPIOBUF21 - bit 21<br>GPIOBUF22 - bit 22<br>GPIOBUF23 - bit 23<br>GPIOBUF24 - bit 24<br>GPIOBUF25 - bit 25<br>GPIOBUF26 - bit 26<br>GPIOBUF27 - bit 27<br>GPIOBUF28 - bit 28<br>GPIOBUF29 - bit 29<br>GPIOBUF30 - bit 30                                                       |      |           |

**Note 14.6** The default value of this register is determined by the value of the following fields within the EEPROM, if present:

GPIO Buffer Type Config Byte 0 (GPIOBUF\_CFG0) GPIO Buffer Type Config Byte 1 (GPIOBUF\_CFG1) GPIO Buffer Type Config Byte 2 (GPIOBUF\_CFG2) GPIO Buffer Type Config Byte 3 (GPIOBUF\_CFG3)

If no EEPROM is present, 0000\_0000h is the default. A USB Reset or Lite Reset (LRST) will cause this field to be restored to the image value last loaded from EEPROM, or to be set to 0000\_0000h if no EEPROM is present.



## 14.4.19 GPIO Direction Register (GPIO\_DIR)

Offset:

Size:

32 bits

Note: This register is protected by Reset Protection (RST\_PROTECT).

00A8h

| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | TYPE | DEFAULT   |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31   | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | RO   | -         |
| 30:0 | <b>GPIO Direction 0-30 (GPDIR)</b><br>When set, enables the corresponding GPIO as output. When cleared the GPIO is enabled as an input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R/W  | Note 14.7 |
|      | GPIODIR0 - bit 0         GPIODIR1 - bit 1         GPIODIR2 - bit 2         GPIODIR3 - bit 3         GPIODIR4 - bit 4         GPIODIR5 - bit 5         GPIODIR6 - bit 6         GPIODIR7 - bit 7         GPIODIR8 - bit 8         GPIODIR9 - bit 9         GPIODIR10 - bit 10         GPIODIR11 - bit 11         GPIODIR12 - bit 12         GPIODIR13 - bit 13         GPIODIR14 - bit 14         GPIODIR15 - bit 15         GPIODIR16 - bit 16         GPIODIR17 - bit 17         GPIODIR18 - bit 18         GPIODIR19 - bit 19         GPIODIR20 - bit 20         GPIODIR21 - bit 21         GPIODIR22 - bit 22         GPIODIR23 - bit 23         GPIODIR24 - bit 24         GPIODIR25 - bit 25         GPIODIR26 - bit 26         GPIODIR27 - bit 27         GPIODIR28 - bit 28         GPIODIR29 - bit 29         GPIODIR29 - bit 30 |      |           |

**Note 14.7** The default value of this register is determined by the value of the following fields within the EEPROM, if present:

GPIO Direction Config Byte 0 (GPIODIR\_CFG0) GPIO Direction Config Byte 1 (GPIODIR\_CFG1) GPIO Direction Config Byte 2 (GPIODIR\_CFG2) GPIO Direction Config Byte 3 (GPIODIR\_CFG3)

If no EEPROM is present, 0000\_0000h is the default. A USB Reset or Lite Reset (LRST) will cause this field to be restored to the image value last loaded from EEPROM, or to be set to 0000\_0000h if no EEPROM is present.



## 14.4.20 GPIO Data Register (GPIO\_DATA)

Offset: 00ACh Size: 32 bits

Note: This register is protected by Reset Protection (RST\_PROTECT).

| BITS | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                          | TYPE | DEFAULT   |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|
| 31   | RESERVED                                                                                                                                                                                                                                                                                                                                                                                                                                                             | RO   | -         |
| 30:0 | GPIO Data 0-30 (GPIOD)<br>When enabled as an output, the value written is reflected on GPIODx. When<br>read, GPIODx reflects the current state of the corresponding GPIO pin.<br>GPIOD1 - bit 0<br>GPIOD1 - bit 1<br>GPIOD2 - bit 2<br>GPIOD3 - bit 3<br>GPIOD4 - bit 4<br>GPIOD5 - bit 5<br>GPIOD6 - bit 6<br>GPIOD7 - bit 7                                                                                                                                        | R/W  | Note 14.8 |
|      | GPIOD8 - bit 8<br>GPIOD9 - bit 9<br>GPIOD10 - bit 10<br>GPIOD11 - bit 11<br>GPIOD12 - bit 12<br>GPIOD13 - bit 13<br>GPIOD14 - bit 14<br>GPIOD15 - bit 15<br>GPIOD16 - bit 16<br>GPIOD17 - bit 17<br>GPIOD18 - bit 18<br>GPIOD19 - bit 20<br>GPIOD20 - bit 20<br>GPIOD21 - bit 21<br>GPIOD22 - bit 22<br>GPIOD23 - bit 23<br>GPIOD24 - bit 24<br>GPIOD25 - bit 25<br>GPIOD26 - bit 26<br>GPIOD27 - bit 27<br>GPIOD28 - bit 28<br>GPIOD29 - bit 29<br>GPIOD30 - bit 30 |      |           |

**Note 14.8** When programmed as an outputs, the default value of enabled output bits of this register is determined by the value of the corresponding bits in the following fields within the EEPROM, if present:

GPIO Data Config Byte 0 (GPIOD\_CFG0) GPIO Data Config Byte 1 (GPIOD\_CFG1) GPIO Data Config Byte 2 (GPIOD\_CFG2) GPIO Data Config Byte 3 (GPIOD\_CFG3)

If no EEPROM is present, the pins are not enabled. A USB Reset or Lite Reset (LRST) will cause pins of this register to be disabled if no EEPROM is present, or, if programmed as outputs, to be restored to the image value last loaded from EEPROM.



## 14.4.21 BOS Attributes Register (BOS\_ATTR)

Offset: 0100h Size: 32 bits

This register sets the length values for BOS Block contents that have been loaded into Descriptor RAM via the Data Port registers. The Descriptor RAM images may be used, in conjunction with this register, to facilitate customized operation when no EEPROM is present.

- Note: If the block does not exist in Descriptor RAM, its size value must be written as 00h.
- **Note:** This register only affects system operation when an EEPROM is not present and the EEPROM Emulation Enable (EEM) bit indicates Descriptor RAM and the Attributes Registers are to be used for descriptor processing.
- **Note:** Writing to this register when an EEPROM is present is prohibited and will result in untoward operation and unexpected results.
- Note: Writing to this register in UFX6000 when LPM Enable (LPM\_ENABLE) is clear in the USB Configuration Register (USB\_CFG) is prohibited and will result in untoward operation and unexpected results.
- Note: This register is protected by Reset Protection (RST\_PROTECT).

| BITS | DESCRIPTION                               | TYPE | DEFAULT |
|------|-------------------------------------------|------|---------|
| 31:8 | RESERVED                                  | RO   | -       |
| 7:0  | BOS Block Size (BOS_BLOCK_SIZE) Note 14.9 | R/W  | 00h     |

**Note 14.9** In UFX6000 (LPM Enable (LPM\_ENABLE) set) this block may include Binary Object Store (BOS) Descriptor, USB 2.0 Extension Descriptor, and Container ID Descriptor.

In UFX7000, this block may include Binary Object Store (BOS) Descriptor, USB 2.0 Extension Descriptor, Super-Speed Device Capabilities Descriptor, and Container ID Descriptor.



## 14.4.22 HS Attributes Register (HS\_ATTR)

| Offset: | 0108h | Size: | 32 bits |
|---------|-------|-------|---------|
|         |       |       |         |

This register sets the length values for HS descriptors that have been loaded into Descriptor RAM via the Data Port registers. The HS Polling interval is also defined by a field within this register. The Descriptor RAM images may be used, in conjunction with this register, to facilitate customized operation when no EEPROM is present.

- Note: If a descriptor does not exist in Descriptor RAM, its size value must be written as 00h.
- **Note:** This register only affects system operation when an EEPROM is not present and the EEPROM Emulation Enable (EEM) bit indicates Descriptor RAM and the Attributes Registers are to be used for descriptor processing.
- **Note:** Writing to this register when an EEPROM is present is prohibited and will result in untoward operation and unexpected results.

| BITS  | DESCRIPTION                                                    | TYPE | DEFAULT |
|-------|----------------------------------------------------------------|------|---------|
| 31:24 | RESERVED                                                       | RO   | -       |
| 23:16 | HS Polling Interval (HS_POLL_INT)                              |      | 04h     |
| 15:8  | HS Device Descriptor Size (HS_DEV_DESC_SIZE) Note 14.10        |      | 00h     |
| 7:0   | HS Configuration Descriptor Size (HS_CFG_DESC_SIZE) Note 14.11 | R/W  | 00h     |

Note: This register is protected by Reset Protection (RST\_PROTECT).

**Note 14.10** The only legal values are 0 and 0x12h. Writing any other values will result in untoward behavior and unexpected results.

**Note 14.11** The only legal values are 0 and 0x12h. Writing any other values will result in untoward behavior and unexpected results.



## 14.4.23 FS Attributes Register (FS\_ATTR)

Offset: 010Ch Size: 32 bits

This register sets the length values for FS descriptors that have been loaded into Descriptor RAM via the Data Port registers. The FS Polling interval is also defined by a field within this register. The Descriptor RAM images may be used, in conjunction with this register, to facilitate customized operation when no EEPROM is present.

- Note: If a descriptor does not exist in Descriptor RAM, its size value must be written as 00h.
- **Note:** This register only affects system operation when an EEPROM is not present and the EEPROM Emulation Enable (EEM) bit indicates Descriptor RAM and the Attributes Registers are to be used for descriptor processing.
- **Note:** Writing to this register when an EEPROM is present is prohibited and will result in untoward operation and unexpected results.

| BITS  | DESCRIPTION                                                    | TYPE | DEFAULT |
|-------|----------------------------------------------------------------|------|---------|
| 31:24 | RESERVED                                                       |      | -       |
| 23:16 | FS Polling Interval (FS_POLL_INT)                              | R/W  | 01h     |
| 15:8  | FS Device Descriptor Size (FS_DEV_DESC_SIZE) Note 14.12        |      | 00h     |
| 7:0   | FS Configuration Descriptor Size (FS_CFG_DESC_SIZE) Note 14.13 | R/W  | 00h     |

Note: This register is protected by Reset Protection (RST\_PROTECT).

**Note 14.12** The only legal values are 0 and 0x12h. Writing any other values will result in untoward behavior and unexpected results.

**Note 14.13** The only legal values are 0 and 0x12h. Writing any other values will result in untoward behavior and unexpected results.



## 14.4.24 String Attributes Register 0 (STRNG\_ATTR0)

Offset: 0110h Size: 32 bits

This register sets the length values for the named string descriptors that have been loaded into Descriptor RAM via the Data Port registers. The Descriptor RAM images may be used, in conjunction with this register, to facilitate customized operation when no EEPROM is present.

- Note: If a descriptor does not exist in Descriptor RAM, its size value must be written as 00h.
- **Note:** This register only affects system operation when an EEPROM is not present and the EEPROM Emulation Enable (EEM) bit indicates Descriptor RAM and the Attributes Registers are to be used for descriptor processing.
- **Note:** Writing to this register when an EEPROM is present is prohibited and will result in untoward operation and unexpected results.

| BITS  | DESCRIPTION                                             | TYPE | DEFAULT |
|-------|---------------------------------------------------------|------|---------|
| 31:24 | Configuration String Descriptor Size (CFGSTR_DESC_SIZE) | R/W  | 00h     |
| 23:16 | Serial Number String Descriptor Size (SERSTR_DESC_SIZE) | R/W  | 00h     |
| 15:8  | Product Name String Descriptor Size (PRODSTR_DESC_SIZE) | R/W  | 00h     |
| 7:0   | Manufacturing String Descriptor Size (MANUF_DESC_SIZE)  | R/W  | 00h     |

Note: This register is protected by Reset Protection (RST PROTECT).



## 14.4.25 String Attributes Register 1 (STRNG\_ATTR1)

Offset: 0114h Size: 32 bits

This register sets the length values for the named string descriptors that have been loaded into Descriptor RAM via the Data Port registers. The Descriptor RAM images may be used, in conjunction with this register, to facilitate customized operation when no EEPROM is present.

- Note: If a descriptor does not exist in Descriptor RAM, its size value must be written as 00h.
- **Note:** This register only affects system operation when an EEPROM is not present and the EEPROM Emulation Enable (EEM) bit indicates Descriptor RAM and the Attributes Registers are to be used for descriptor processing.
- **Note:** Writing to this register when an EEPROM is present is prohibited and will result in untoward operation and unexpected results.

| Note: | This register is protected by | Reset Protection | (RST | PROTECT). |
|-------|-------------------------------|------------------|------|-----------|
|-------|-------------------------------|------------------|------|-----------|

| BITS | DESCRIPTION                                         |     | DEFAULT |
|------|-----------------------------------------------------|-----|---------|
| 31:8 | RESERVED                                            | RO  | -       |
| 7:0  | Interface String Descriptor Size (INTSTR_DESC_SIZE) | R/W | 00h     |



# **Chapter 15 Operational Characteristics**

## 15.1 Absolute Maximum Ratings\*

| +3.3V Supply Voltage (VDD33IO, VDD33USB, VDD33VDAC, SYSPLLP) (Note 15. | 1) 0V to +3.6V                   |
|------------------------------------------------------------------------|----------------------------------|
| +1.8V Supply Voltage (VDD18DDR) (Note 15.1)                            | 0V to +1.9V                      |
| +1.2V Supply Voltage (VDD12CORE, VDD12USBPLL, VDD12HDMI) (Note 15.1)   | 0V to +1.32V                     |
| Positive voltage on XI, with respect to ground                         |                                  |
| Positive voltage on XO, with respect to ground                         |                                  |
| Storage Temperature                                                    | 55°C to +150°C                   |
| Lead Temperature Range                                                 | . Refer to JEDEC Spec. J-STD-020 |
| HBM ESD Performance                                                    | JEDEC Class 2                    |
|                                                                        |                                  |

**Note 15.1** When powering this device from laboratory or system power supplies, it is important that the absolute maximum ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes on their outputs when AC power is switched on or off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists, it is suggested that a clamp circuit be used.

\*Stresses exceeding those listed in this section could cause permanent damage to the device. This is a stress rating only. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. Functional operation of the device at any condition exceeding those indicated in Section 15.2, "Operating Conditions\*\*", Section 15.5, "DC Specifications", or any other applicable section of this specification is not implied. Note, device signals are *NOT* 5 volt tolerant unless specified otherwise.

## 15.2 Operating Conditions\*\*

| +3.3V Supply Voltage (VDD33IO, VDD33USB, VDD33VDAC, SYSPLLP)+  | 3.3V +/- 5%                          |
|----------------------------------------------------------------|--------------------------------------|
| +1.8V Supply Voltage (VDD18DDR)                                | 1.8V +/- 5%                          |
| +1.2V Supply Voltage (VDD12CORE, VDD12USBPLL, VDD12HDMI)+      | 1.2V +/- 5%                          |
| Ambient Operating Temperature in Still Air (T <sub>A</sub> )0º | <sup>o</sup> C to +70 <sup>o</sup> C |
| Maximum Junction Temperature                                   | +110 <sup>o</sup> C                  |

\*\*Proper operation of the device is guaranteed only within the ranges specified in this section.



## **15.3** Package Thermal Specifications

| PARAMETER                  | SYMBOL          | VALUE | UNITS | COMMENTS                                          |
|----------------------------|-----------------|-------|-------|---------------------------------------------------|
| Thermal Resistance         | Θ <sub>JA</sub> | 28.7  | °C/W  | Measured in still air from the die to ambient air |
| Thermal Resistance         | Θ <sub>JC</sub> | 10.4  | °C/W  | Measured from the die to the case                 |
| Junction-to-Top-of-Package | $\Psi_{JT}$     | 0.38  | °C/W  | Measured in still air                             |

 Table 15.1 Package Thermal Parameters

Note: Thermal parameters are measured or estimated for devices in a multi-layer 2S2P PCB per JESD51.

## **15.4 Current Consumption**

This section details the current consumption of the device as measured during various modes of operation and power states. Current consumption values are provided for each power rail (+3.3V, +1.8V, +1.2V). Power dissipation is determined by temperature, supply voltage, and external source/sink requirements.

**Note:** All current consumption values were measured with power supplies at nominal voltages unless otherwise noted.

### 15.4.1 SUSPEND Power State

| PARAMETER                                                                     | TYPICAL | UNIT |
|-------------------------------------------------------------------------------|---------|------|
| +3.3V Supply Current (Device Only)<br>(VDD33IO, VDD33USB, VDD33VDAC, SYSPLLP) | 0.7     | mA   |
| +1.8V Supply Current (Device Only)<br>(VDD18DDR)                              | 0.0     | mA   |
| +1.2V Supply Current (Device Only)<br>(VDD12CORE, VDD12USBPLL, VDD12HDMI)     | 1.5     | mA   |

#### **Table 15.2 SUSPEND Supply Current**





## 15.4.2 Operational

#### 15.4.2.1 High-Speed

#### Table 15.3 Typical High-Speed Operational Supply Current (mA)

|                                                                             | S                       | TATIC IMAG              | E                       | FULL SCREEN VIDEO       |                         |                         |  |
|-----------------------------------------------------------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|--|
| PARAMETER                                                                   | 1280X1024<br>(DDR2-400) | 1600X1200<br>(DDR2-533) | 1920X1200<br>(DDR2-667) | 1280X1024<br>(DDR2-400) | 1600X1200<br>(DDR2-533) | 1920X1200<br>(DDR2-667) |  |
| Video DAC Interface Enabled                                                 |                         |                         |                         |                         |                         |                         |  |
| +3.3V Supply Current (Dev. Only)<br>(VDD33IO, VDD33USB, VDD33VDAC, SYSPLLP) | 77                      | 78                      | 79                      | 78                      | 78                      | 79                      |  |
| +1.8V Supply Current (Dev. Only)<br>(VDD18DDR)                              | 39                      | 45                      | 48                      | 58                      | 67                      | 75                      |  |
| +1.2V Supply Current (Dev. Only)<br>(VDD12CORE, VDD12USBPLL, VDD12HDMI)     | 181                     | 189                     | 192                     | 203                     | 215                     | 222                     |  |
| HDMI Interface Enabled (with audi                                           | 0)                      |                         |                         |                         |                         |                         |  |
| +3.3V Supply Current (Dev. Only)<br>(VDD33IO, VDD33USB, VDD33VDAC, SYSPLLP) | 5.0                     | 5.0                     | 5.0                     | 5.2                     | 5.2                     | 5.2                     |  |
| +1.8V Supply Current (Dev. Only)<br>(VDD18DDR)                              | 39                      | 45                      | 49                      | 60                      | 67                      | 76                      |  |
| +1.2V Supply Current (Dev. Only)<br>(VDD12CORE, VDD12USBPLL, VDD12HDMI)     | 201                     | 218                     | 218                     | 223                     | 242                     | 255                     |  |



# 15.5 DC Specifications

| PARAMETER                                                           | SYMBOL              | MIN                        | TYP              | MAX                        | UNITS | NOTES                  |  |  |
|---------------------------------------------------------------------|---------------------|----------------------------|------------------|----------------------------|-------|------------------------|--|--|
| IS Type Input Buffer                                                |                     |                            |                  |                            |       |                        |  |  |
| Low Input Level                                                     | $V_{ILI}$           | -0.3                       |                  |                            | V     |                        |  |  |
| High Input Level                                                    | V <sub>IHI</sub>    |                            |                  | 3.6                        | V     |                        |  |  |
| Negative-Going Threshold                                            | V <sub>ILT</sub>    | 1.01                       | 1.19             | 1.39                       | V     | Schmitt trigger        |  |  |
| Positive-Going Threshold                                            | V <sub>IHT</sub>    | 1.39                       | 1.59             | 1.8                        | V     | Schmitt trigger        |  |  |
| SchmittTrigger Hysteresis<br>(V <sub>IHT</sub> - V <sub>ILT</sub> ) | $V_{HYS}$           | 336                        | 399              | 485                        | mV    |                        |  |  |
| O8 Type Output Buffer                                               |                     |                            |                  |                            |       |                        |  |  |
| Low Output Level                                                    | V <sub>OL</sub>     |                            |                  | 0.4                        | V     | I <sub>OL</sub> = 8mA  |  |  |
| High Output Level                                                   | V <sub>OH</sub>     | VDD33IO - 0.4              |                  |                            | v     | I <sub>OH</sub> = -8mA |  |  |
| OD8 Type Output Buffer                                              |                     |                            |                  |                            |       |                        |  |  |
| Low Output Level                                                    | V <sub>OL</sub>     |                            |                  | 0.4                        | V     | I <sub>OL</sub> = 8mA  |  |  |
| RGB Type Output Buffer                                              |                     |                            |                  |                            |       |                        |  |  |
| Low Output Level                                                    | V <sub>OL</sub>     |                            |                  | 0.4                        | V     | I <sub>OL</sub> = 8mA  |  |  |
| High Output Level                                                   | V <sub>OH</sub>     | VDD33IO - 0.4              |                  |                            | V     | I <sub>OH</sub> = -8mA |  |  |
| DDR2I Type Input Buffer                                             |                     |                            |                  |                            |       | Note 15.2              |  |  |
| Termination Voltage                                                 | $V_{TT}$            | V <sub>REF</sub> - 0.04    | $V_{REF}$        | V <sub>REF</sub> + 0.04    | V     | Note 15.3              |  |  |
| Low Input Level (DC)                                                | V <sub>IL(dc)</sub> | -0.3                       |                  | V <sub>REF</sub> - 0.125   | V     | Note 15.3              |  |  |
| High Input Level (DC)                                               | V <sub>IH(dc)</sub> | V <sub>REF</sub> + 0.125   |                  | VDD18DDR + 0.3             | V     | Note 15.3              |  |  |
| Low Input Level (AC)                                                | V <sub>IL(ac)</sub> |                            |                  | V <sub>REF</sub> - 0.25    | V     | Note 15.3              |  |  |
| High Input Level (AC)                                               | V <sub>IH(ac)</sub> | V <sub>REF</sub> + 0.25    |                  |                            | V     | Note 15.3              |  |  |
| DDR2O Type Output Buffer                                            |                     |                            |                  |                            |       | Note 15.2              |  |  |
| Termination Voltage                                                 | V <sub>TT</sub>     | V <sub>REF</sub> - 0.04    | V <sub>REF</sub> | V <sub>REF</sub> + 0.04    | V     | Note 15.3              |  |  |
| Low Output Level (DC)                                               | V <sub>OL(dc)</sub> |                            |                  | 0.28                       | V     | Note 15.4              |  |  |
| High Output Level (DC)                                              | V <sub>OH(dc)</sub> | VDD18DDR(min) - 0.2        |                  |                            | v     | Note 15.5              |  |  |
| Low Output Level (AC)                                               | V <sub>OL(ac)</sub> |                            |                  | V <sub>TTmin</sub> - 0.603 | V     | Note 15.4              |  |  |
| High Output Level (AC)                                              | V <sub>OH(ac)</sub> | V <sub>TTmax</sub> + 0.603 |                  |                            | V     | Note 15.5              |  |  |
| ICLK Type Buffer (XI Input)                                         |                     |                            |                  |                            |       | Note 15.6              |  |  |
| Low Input Level                                                     | V <sub>ILI</sub>    | -0.3                       |                  | 0.5                        | V     |                        |  |  |
| High Input Level                                                    | V <sub>IHI</sub>    | 1.08                       |                  | 1.32                       | V     |                        |  |  |

#### Table 15.4 I/O Buffer Characteristics

Note 15.2 All values apply to both full-strength and half-strength operation unless otherwise stated.

Note 15.3  $V_{REF}$  equals DDRVREF[0:2].



**Note 15.4** I<sub>OL</sub> equals 13.4mA for full-strength operation and 6.7mA for half-strength operation.

**Note 15.5** I<sub>OH</sub> equals -13.4mA for full-strength operation and -6.7mA for half-strength operation.

**Note 15.6** XI can optionally be driven from a 25MHz single-ended clock oscillator.

| PARAMETER                        | SYMBOL | MIN | ТҮР  | ΜΑΧ    | UNITS |
|----------------------------------|--------|-----|------|--------|-------|
| Output Voltage                   | -      |     | 1.28 |        | V     |
| Output Current per Channel       | -      |     | 17   |        | mA    |
| Video DAC Resolution             | -      |     | 10   |        | bits  |
| Integral Non-linearity Error     | INL    |     |      | +/-2   | LSB   |
| Differential Non-linearity Error | DNL    |     |      | +/-0.5 | LSB   |

## **15.6 AC Specifications**

This section details the various AC timing specifications of the device.

- **Note:** The USB interface timing adheres to the USB 2.0 Specification. Refer to the Universal Serial Bus Revision 2.0 Specification for detailed USB timing information.
- **Note:** The DDR2 interface timing adheres to the JESD79-2E Specification. Refer to the JESD79-2E Specification for detailed DDR2 timing information.
- **Note:** The HDMI interface timing adheres to the HDMI 1.3 Specification. Refer to the HDMI 1.3 Specification for detailed HDMI timing information.
- **Note:** The S/PDIF interface timing adheres to the IEC 60958 2-channel PCM Specification. Refer to the IEC 60958 2-channel PCM Specification for detailed S/PDIF timing information.
- **Note:** The I<sup>2</sup>S interface timing adheres to the NXP I<sup>2</sup>S Bus Specification. Refer to the NXP I<sup>2</sup>S Bus Specification for detailed I<sup>2</sup>S timing information.
- **Note:** The I<sup>2</sup>C interface timing adheres to the NXP I<sup>2</sup>C-Bus Specification. Refer to the I<sup>2</sup>C-Bus Specification for detailed I<sup>2</sup>C timing information.



### 15.6.1 **Power Sequence Timing**

Power supplies must adhere to the following rules:

- All power supplies of the same voltage must be powered up/down together.
- There is no power-up sequencing requirement, however all power supplies must reach operational levels within the time periods specified in Table 15.6.
- There is no power-down sequencing or timing requirement, however the device must not be powered for an extended period of time without all supplies at operational levels.
- Following power-on, or if a power supply brownout occurs (i.e., one or more supplies drops below operational limits), a power-on reset must be executed once all power supplies reach operational levels. Refer to section Section 15.6.2, "Power-On Reset Timing," on page 358 for power-on reset requirements.
- With the exception of HPD, VBUS\_DET, I2CSDA[0:1], and I2CSCL[0:1], do not drive input signals without power supplied to the device.

Note: Violation of these specifications may damage the device.

Note: Power sequencing requirements are preliminary and subject to change.





#### Table 15.6 Power-On Timing Values

| SYMBOL           | DESCRIPTION               | MIN | ТҮР | МАХ | UNITS |
|------------------|---------------------------|-----|-----|-----|-------|
| t <sub>pon</sub> | Power supply turn on time | 0   |     | 25  | mS    |



## 15.6.2 Power-On Reset Timing

This diagram illustrates the nRESET timing requirements in relation to power-on. A hardware reset (nRESET assertion) is required following power-up. For proper operation, nRESET must be asserted for no less than  $t_{rstia}$ . The nRESET pin can be asserted at any time, but must not be deasserted before  $t_{purstd}$  after all external power supplies have reached operational levels.



Figure 15.1 nRESET Power-On Timing

| SYMBOL              | DESCRIPTION                                                         | MIN | ТҮР           | МАХ | UNITS |
|---------------------|---------------------------------------------------------------------|-----|---------------|-----|-------|
| t <sub>purstd</sub> | External power supplies at operational levels to nRESET deassertion | 25  | Note 15.<br>7 |     | mS    |
| t <sub>purstv</sub> | External power supplies at operational levels to nRESET valid       | 0   |               |     | nS    |
| t <sub>rstia</sub>  | nRESET input assertion time                                         | 100 |               |     | μS    |

#### Table 15.7 nRESET Power-On Timing Values

**Note:** nRESET deassertion must be monotonic.

**Note 15.7** For bus-powered applications, a typical value of 200 mS is recommended to allow time for connector mating. Permanently attached and/or self-powered applications do not require this longer reset time.



## 15.6.3 Reset Timing

Figure 15.1 illustrates the nRESET pin timing requirements. When used, nRESET must be asserted for no less than  $t_{rstia}$ .

**Note:** A hardware reset (nRESET assertion) is required following power-on. Refer to Section 15.6.2, "Power-On Reset Timing," on page 358 for additional information.





#### Table 15.8 nRESET Timing Values

| SYMBOL             | DESCRIPTION                 | MIN | ТҮР | МАХ | UNITS |
|--------------------|-----------------------------|-----|-----|-----|-------|
| t <sub>rstia</sub> | nRESET input assertion time | 1   |     |     | uS    |

## 15.6.4 Video DAC Timing

The following table specifies the Video DAC timing characteristics for the device. All values are measured with the Video DAC in 17mA full scale mode.

| PARAMETER                   | MIN | ТҮР  | МАХ | UNITS |
|-----------------------------|-----|------|-----|-------|
| Frequency                   | 25  |      | 200 | MHz   |
| Analog Output Delay         | 0.4 | 0.5  | 0.8 | nS    |
| Analog Output Rise Time     |     | 0.31 |     | nS    |
| Analog Output Fall Time     |     | 0.5  |     | nS    |
| Analog Output Settling Time |     | 0.7  |     | nS    |

#### Table 15.9 Video DAC - AC Characteristics



## 15.6.5 Digital RGB Timing

The following sub-sections specify the Digital RGB timing requirements for the device in DDR and SDR modes of operation.

#### 15.6.5.1 DDR Mode



| Figure 15.2 | <b>Digital RGB</b> | Timing - DDR | Node |
|-------------|--------------------|--------------|------|
|-------------|--------------------|--------------|------|

| Table 15.10 Digital | <b>RGB</b> Timing | Values - DDR | Mode |
|---------------------|-------------------|--------------|------|
|---------------------|-------------------|--------------|------|

| SYMBOL            | DESCRIPTION              | MIN | ТҮР | MAX | UNITS |
|-------------------|--------------------------|-----|-----|-----|-------|
| f <sub>vclk</sub> | VCLK Frequency           |     |     | 165 | MHz   |
| t <sub>vsu</sub>  | Video Setup Output Delay | 0.8 |     |     | nS    |
| t <sub>vhd</sub>  | Video Hold Output Delay  | 0.5 |     |     | nS    |

Note: RGB timing values are with respect to an equivalent test load of 5 pF.



#### 15.6.5.2 SDR Mode



Figure 15.3 Digital RGB Timing - SDR Mode

| Table 15.11 | <b>Digital RGB</b> | <b>Timing Values</b> | - SDR Mode |
|-------------|--------------------|----------------------|------------|
|-------------|--------------------|----------------------|------------|

| SYMBOL            | DESCRIPTION              | MIN | ТҮР | МАХ | UNITS |
|-------------------|--------------------------|-----|-----|-----|-------|
| f <sub>vclk</sub> | VCLK Frequency           |     |     | 165 | MHz   |
| t <sub>vsu</sub>  | Video Setup Output Delay | 2.5 |     |     | nS    |
| t <sub>vhd</sub>  | Video Hold Output Delay  | 1.5 |     |     | nS    |

Note: RGB timing values are with respect to an equivalent test load of 5 pF.



## 15.6.6 EEPROM Timing

The following specifies the EEPROM timing requirements for the device:



#### Figure 15.4 EEPROM Timing

| SYMBOL                | DESCRIPTION                            | MIN  | ТҮР | MAX  | UNITS |
|-----------------------|----------------------------------------|------|-----|------|-------|
| t <sub>ckcyc</sub>    | EECLK Cycle time                       | 1110 |     | 1130 | ns    |
| t <sub>ckh</sub>      | EECLK High time                        | 550  |     | 570  | ns    |
| t <sub>ckl</sub>      | EECLK Low time                         | 550  |     | 570  | ns    |
| t <sub>cshckh</sub>   | EECS high before rising edge of EECLK  | 1070 |     |      | ns    |
| t <sub>cklcsl</sub>   | EECLK falling edge to EECS low         | 30   |     |      | ns    |
| t <sub>dvckh</sub>    | EEDO valid before rising edge of EECLK | 550  |     |      | ns    |
| t <sub>ckhinvld</sub> | EEDO invalid after rising edge EECLK   | 550  |     |      | ns    |
| t <sub>dsckh</sub>    | EEDI setup to rising edge of EECLK     | 90   |     |      | ns    |
| t <sub>dhckh</sub>    | EEDI hold after rising edge of EECLK   | 0    |     |      | ns    |
| t <sub>ckldis</sub>   | EECLK low to data disable (OUTPUT)     | 580  |     |      | ns    |
| t <sub>cshdv</sub>    | EEDIO valid after EECS high (VERIFY)   |      |     | 600  | ns    |
| t <sub>dhcsl</sub>    | EEDIO hold after EECS low (VERIFY)     | 0    |     |      | ns    |
| t <sub>csl</sub>      | EECS low                               | 1070 |     |      | ns    |

#### Table 15.12 EEPROM Timing Values

Note: EEPROM timing values are with respect to an equivalent test load of 25 pF.



## 15.6.7 JTAG Timing

This section specifies the JTAG timing of the device.



#### Figure 15.5 JTAG Timing

#### Table 15.13 JTAG Timing Values

| SYMBOL               | DESCRIPTION                              | MIN                    | MAX                    | UNITS | NOTES |
|----------------------|------------------------------------------|------------------------|------------------------|-------|-------|
| t <sub>tckp</sub>    | TCK clock period                         | 66.67                  | 80                     | nS    |       |
| t <sub>tckhl</sub>   | TCK clock high/low time                  | t <sub>tckp</sub> *0.4 | t <sub>tckp</sub> *0.6 | nS    |       |
| t <sub>su</sub>      | TDI, TMS setup to TCK rising edge        | 10                     |                        | nS    |       |
| t <sub>h</sub>       | TDI, TMS hold from TCK rising edge       | 10                     |                        | nS    |       |
| t <sub>dov</sub>     | TDO output valid from TCK falling edge   |                        | 16                     | nS    |       |
| t <sub>doinvld</sub> | TDO output invalid from TCK falling edge | 0                      |                        | nS    |       |
| t <sub>trst</sub>    | nTRST assertion time                     | 10                     |                        | mS    |       |

Note: JTAG timing values are with respect to an equivalent test load of 25 pF.



# 15.7 Clock Circuit

The device can accept either a 25MHz crystal or a 25MHz single-ended clock oscillator (+/- 50ppm) input. If the single-ended clock oscillator method is implemented, XO should be left unconnected and XI should be driven with a nominal 0-1.2V clock signal. The input clock duty cycle is 40% minimum, 50% typical and 60% maximum.

It is recommended that a crystal utilizing matching parallel load capacitors be used for the crystal input/output signals (XI/XO). See Table 15.14 for the recommended crystal specifications.

| PARAMETER                     | SYMBOL                 | MIN | NOM       | MAX    | UNITS | NOTES      |
|-------------------------------|------------------------|-----|-----------|--------|-------|------------|
| Crystal Cut                   | AT, typ                |     |           |        |       |            |
| Crystal Oscillation Mode      | Fundamental Mode       |     |           |        |       |            |
| Crystal Calibration Mode      | Parallel Resonant Mode |     |           |        |       |            |
| Frequency                     | F <sub>fund</sub>      | -   | 25.000    | -      | MHz   |            |
| Frequency Tolerance @ 25°C    | F <sub>tol</sub>       | -   | -         | +/-50  | PPM   | Note 15.8  |
| Frequency Stability Over Temp | F <sub>temp</sub>      | -   | -         | +/-100 | PPM   | Note 15.8  |
| Frequency Deviation Over Time | F <sub>age</sub>       | -   | +/-3 to 5 | -      | PPM   | Note 15.9  |
| Total Allowable PPM Budget    |                        | -   | -         | +/-150 | PPM   |            |
| Shunt Capacitance             | CO                     | -   | 7 typ     | -      | pF    |            |
| Load Capacitance              | CL                     | -   | 20 typ    | -      | pF    |            |
| Drive Level                   | P <sub>W</sub>         | 300 | -         | -      | uW    |            |
| Equivalent Series Resistance  | R <sub>1</sub>         | -   | -         | 50     | Ohm   |            |
| Operating Temperature Range   |                        | 0   | -         | 70     | °C    |            |
| XI Pin Capacitance            |                        | -   | 3 typ     | -      | pF    | Note 15.10 |
| XO Pin Capacitance            |                        | -   | 3 typ     | -      | pF    | Note 15.10 |

| Table 15.14 Crystal Specifications | able 15.14 C | rystal Specifications |
|------------------------------------|--------------|-----------------------|
|------------------------------------|--------------|-----------------------|

- **Note 15.8** The maximum allowable values for Frequency Tolerance and Frequency Stability are application dependant.
- **Note 15.9** Frequency Deviation Over Time is also referred to as Aging.
- **Note 15.10** This number includes the pad, the bond wire and the lead frame. PCB capacitance is not included in this value. The XO/XI pin and PCB capacitance values are required to accurately calculate the value of the two external load capacitors. These two external load capacitors determine the accuracy of the 25.000 MHz frequency.



# **Chapter 16 Package Outline**

# 16.1 225-LFBGA Package







Figure 16.1 UFX6000 225-LFBGA Package Ball Detail



|     | MIN   | NOMINAL  | MAX   | REMARKS                      |  |
|-----|-------|----------|-------|------------------------------|--|
| Α   | -     | 1.30     | 1.40  | Overall Package Height       |  |
| A1  | 0.25  | -        | 0.40  | Standoff                     |  |
| A2  | 0.65  | 0.96     | -     | Package Body Thickness       |  |
| D/E | 12.90 | 13.00    | 13.10 | Overall Package Size         |  |
| b   | 0.40  | 0.45     | 0.50  | Ball Diameter                |  |
| b1  | 0.35  | 0.40     | 0.45  | Finished Solder Mask Opening |  |
| b2  | 0.45  | 0.50     | 0.55  | Finished Ball Pad Diameter   |  |
| е   |       | 0.80 BSC |       | Ball Pitch                   |  |
| CCC | -     | -        | 0.20  | Coplanarity                  |  |

#### Table 16.1 UFX6000 225-LFBGA Package Parameters

#### Notes:

- 1. All dimensions are in millimeters.
- 2. Dimension "b" is measured at the maximum ball diameter, parallel to primary datum "C".
- 3. Primary datum "C" (seating plane) is defined by the spherical crowns of the contact balls.
- 4. The ball A1 identifier may vary, but is always located within the zone indicated.
- 5. Dimension "A" does not include attached external features, such as heat sink or chip capacitors.
- 6. The package ball solderable surface is Solder-Mask-Defined (SMD) type.



| PCB LAND PATTERN DIMENSIONS |          |       |     |  |
|-----------------------------|----------|-------|-----|--|
| SYMBOL                      | MIN      | NOM   | MAX |  |
| D1/E1                       | -        | 11.20 | -   |  |
| e'                          | 0.80 BSC |       |     |  |

THE USER MAY MODIFY THE PCB LAND PATTERN & ROUTING DIMENSIONS, BASED ON THEIR EXPERIENCE AND/OR PROCESS CAPABILITY



| ROUTING DIMENSIONS |       |  |  |  |
|--------------------|-------|--|--|--|
| SYMBOL             | NOM   |  |  |  |
| Ø PAD              | 0.40  |  |  |  |
| ØSM                | 0.50  |  |  |  |
| L (Trace)          | 0.125 |  |  |  |
| SPACE              | 0.135 |  |  |  |
| SM-Space           | 0.09  |  |  |  |
| Ø VIA PAD          | 0.45  |  |  |  |
| Ø DRILL            | 0.25  |  |  |  |

#### Figure 16.2 UFX6000 225-LFBGA Recommended PCB Land Pattern



# **Chapter 17 Power Connections**

Figure 17.1 illustrates the power connections for UFX6000.



**Figure 17.1 Power Connections** 

Note: For additional power connection information, refer to the UFX6000 reference schematic.



# **Chapter 18 Databook Revision History**

#### Table 18.1 Customer Revision History

| <b>REVISION LEVEL &amp; DATE</b> | SECTION/FIGURE/ENTRY | CORRECTION      |
|----------------------------------|----------------------|-----------------|
| Rev. 1.0 (04-22-13)              | All                  | Initial Release |