

# **MT6219 GSM/GPRS Baseband Processor Data Sheet**

Revision 1.01

Feb 11, 2004

## Revision History

| Revision | Date         | Comments                                                              |
|----------|--------------|-----------------------------------------------------------------------|
| 1.00     | Feb 02, 2004 | First Release                                                         |
| 1.01     | Feb 11, 2004 | Analog Front-end Interface>AFE_AAC_CON register definition corrected. |

## TABLE OF CONTENTS

|                                                      |            |
|------------------------------------------------------|------------|
| <b>Revision History.....</b>                         | <b>2</b>   |
| <b>Preface.....</b>                                  | <b>5</b>   |
| <b>1. System Overview.....</b>                       | <b>6</b>   |
| 1.1 MODEM Features .....                             | 9          |
| 1.2 Multi-Media Features.....                        | 11         |
| 1.3 General Description .....                        | 13         |
| <b>2 Product Description.....</b>                    | <b>15</b>  |
| 2.1 Pin Outs.....                                    | 15         |
| 2.2 Pin Description.....                             | 18         |
| 2.3 Power Description.....                           | 26         |
| <b>3 Micro-Controller Unit Subsystem .....</b>       | <b>33</b>  |
| 3.1 Processor Core .....                             | 34         |
| 3.2 Memory Management .....                          | 34         |
| 3.3 Bus System.....                                  | 37         |
| 3.4 Direct Memory Access .....                       | 40         |
| 3.5 Interrupt Controller .....                       | 57         |
| 3.6 Internal Memory Interface .....                  | 70         |
| 3.7 External Memory Interface .....                  | 70         |
| <b>4 Microcontroller Peripherals .....</b>           | <b>80</b>  |
| 4.1 Pulse-Width Modulation Outputs.....              | 80         |
| 4.2 Alerter .....                                    | 82         |
| 4.3 SIM Interface .....                              | 85         |
| 4.4 Keypad Scanner .....                             | 94         |
| 4.5 General Purpose Inputs/Outputs .....             | 96         |
| 4.6 General Purpose Timer.....                       | 109        |
| 4.7 UART .....                                       | 112        |
| 4.8 IrDA Framer.....                                 | 126        |
| 4.9 Real Time Clock .....                            | 134        |
| 4.10 Auxiliary ADC Unit.....                         | 140        |
| 4.11 SCCB .....                                      | 143        |
| <b>5 Microcontroller Coprocessors .....</b>          | <b>147</b> |
| 5.1 Divider .....                                    | 147        |
| 5.2 CSD Accelerator .....                            | 149        |
| 5.3 FCS Codec .....                                  | 161        |
| <b>6 Multi-Media Subsystem .....</b>                 | <b>163</b> |
| 6.1 LCD Interface .....                              | 163        |
| 6.2 JPEG Decoder .....                               | 176        |
| 6.3 JPEG Encoder .....                               | 187        |
| 6.4 Image Resizer.....                               | 190        |
| 6.5 NAND FLASH interface .....                       | 209        |
| 6.6 USB Device Controller .....                      | 226        |
| 6.7 Memory Stick and SD Memory Card Controller ..... | 236        |
| 6.8 2D acceleration .....                            | 259        |
| 6.9 GIF Decoder.....                                 | 266        |
| 6.10 Camera Interface .....                          | 272        |
| 6.11 Image DMA .....                                 | 294        |
| 6.12 Image Engine .....                              | 315        |

|           |                                              |            |
|-----------|----------------------------------------------|------------|
| 6.13      | MPEG-4/H.263 Video CODEC .....               | 331        |
| <b>7</b>  | <b>Audio Front-end.....</b>                  | <b>348</b> |
| 7.1       | General Description .....                    | 348        |
| 7.2       | Register Definitions .....                   | 349        |
| 7.3       | Programming Guide .....                      | 351        |
| <b>8</b>  | <b>Radio Interface Control .....</b>         | <b>353</b> |
| 8.1       | Base-band Serial Interface .....             | 353        |
| 8.2       | Base-band Parallel Interface .....           | 358        |
| 8.3       | Automatic Power Control (APC) Unit .....     | 361        |
| 8.4       | Automatic Frequency Control (AFC) Unit ..... | 367        |
| <b>9</b>  | <b>Baseband Front End.....</b>               | <b>371</b> |
| 9.1       | Baseband Serial Ports.....                   | 372        |
| 9.2       | Downlink Path (RX Path) .....                | 374        |
| 9.3       | Uplink Path (TX Path) .....                  | 380        |
| 9.4       | Register Definitions Summary .....           | 382        |
| <b>10</b> | <b>Timing Generator .....</b>                | <b>384</b> |
| 10.1      | TDMA timer.....                              | 384        |
| 10.2      | Slow Clocking Unit.....                      | 391        |
| <b>11</b> | <b>Power, Clocks and Reset .....</b>         | <b>395</b> |
| 11.1      | B2PSI.....                                   | 395        |
| 11.2      | Clocks .....                                 | 397        |
| 11.3      | Reset Management.....                        | 400        |
| 11.4      | Software Power Down Control .....            | 404        |
| <b>12</b> | <b>Analog Front-end Interface .....</b>      | <b>408</b> |
| 12.1      | General Description .....                    | 408        |
| 12.2      | Register Definitions .....                   | 408        |

## Preface

### Acronym for Register Type

|            |                                                                                                                                                                                                        |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>R/W</b> | Capable of both read and write access                                                                                                                                                                  |
| <b>RO</b>  | Read only                                                                                                                                                                                              |
| <b>RC</b>  | Read only. After reading the register bank, each bit which is HIGH(1) will be cleared to LOW(0) automatically.                                                                                         |
| <b>WO</b>  | Write only                                                                                                                                                                                             |
| <b>W1S</b> | Write only. When writing data bits to register bank, each bit which is HIGH(1) will cause the corresponding bit to be set to 1. Data bits which are LOW(0) has no effect on the corresponding bit.     |
| <b>W1C</b> | Write only. When writing data bits to register bank, each bit which is HIGH(1) will cause the corresponding bit to be cleared to 0. Data bits which are LOW(0) has no effect on the corresponding bit. |

# 1. System Overview

The revolutionary MT6219 is a leading edge single-chip solution for GSM/GPRS mobile phones targeting the emerging applications in digital audio and video. Based on 32-bit ARM7EJ-S™ RISC processor, MT6219 not only features high performance GPRS Class 12 MODEM, but also provides comprehensive and advanced solutions for handheld multi-media.

Typical application is shown in **Figure 1**.

## Multi-media Subsystem

The MT6219 multi-media subsystem provides connection to CMOS image sensor and supports resolution up to 1.3M pixels. With its advanced image signal and data processing technology, MT6219 allows efficient processing of image and video data. It also has built-in JPEG CODEC and MPEG-4 CODEC, thus enabling real-time creation and playback of high-quality images and video. In addition to advanced image and video features, MT6219 also utilizes high resolution DAC, digital audio, and audio synthesis technology to provide superior audio features for all future multi-media needs.

In order to provide more flexibility and bandwidth for multi-media products, an additional 8-bit parallel interface is incorporated. This interface enables connection to LCD panels as well as connection to NAND flash devices to allow for multi-media data storage capabilities.

## External Memory Interface

Providing the greatest capacity for expansion, MT6219 supports up to 8 state-of-the-art devices through its 16-bit host interface. Devices such as burst/page mode Flash, page mode SRAM, Pseudo SRAM, Color/Parallel LCD, and multi-media companion chip are all supported through this interface. To minimize power consumption and ensure low noise, this interface is designed for flexible I/O voltage and allows lowering of supply voltage down to 1.8V. The driving strength is configurable for signal integrity adjustment. The data bus also employs retention technology to prevent the bus from floating during turn over.

## User Interface

To provide complete user interface, MT6219 brings together all the necessary peripheral blocks for multi-media GSM/GPRS phone. The peripheral blocks consists of the Keypad Scanner with the capability to detect multiple key presses, SIM Controller, Alerter, Real Time Clock, PWM, Serial LCD Controller, and General Purpose Programmable I/Os. For connectivity and data storage, the MT6219 supports UART, IrDA, USB 1.1 Slave and MMC/SD/MS/MS Pro. Furthermore, for large amount of data transfer, high performance DMA (Direct Memory Access) and hardware flow control are implemented, which greatly enhances the performance and reduces MCU processing load.

## Audio Interface

Using a highly integrated mixed-signal Audio Front-End, the MT6219 architecture allows for easy audio interfacing with direct connection to the audio transducers. The audio interface integrates D/A and A/D Converters for Voice band, as well as high resolution Stereo D/A Converters for Audio band. In addition, MT6219 also provides Stereo Input and Analog Mux. Overall, MT6219's audio features provide a rich platform for multi-media applications.

## Radio Interface

MT6219 integrates a mixed-signal Baseband front-end in order to provide a well-organized radio interface with flexibility for efficient customization. It contains gain and offset calibration mechanisms, and filters with programmable coefficients for comprehensive compatibility control on RF modules. This approach also allows the usage of a high resolution D/A Converter for controlling VCXO or crystal, thus reducing the need for expensive TCVCXO. MT6219 achieves great MODEM performance by utilizing 14-bit high resolution A/D Converter in the RF downlink path. Furthermore, to reduce the need for extra external current-driving component, the driving strength of some BPI outputs is designed to be configurable.

## Debug Function

The JTAG interface enables in-circuit debugging of software program with the ARM7EJ-S core. With this standardized debugging interface, the MT6219 provides developers with a wide set of options in choosing ARM development kits from different third party vendors.

#### Power Management

The MT6219 offers various low-power features to help reduce system power consumption. These features include Pause Mode of 32KHz clocking at Standby State, Power Down Mode for individual peripherals, and Processor Sleep Mode. In addition, MT6219 is also fabricated in advanced low leakage CMOS process, hence providing an overall ultra low leakage solution.

#### Package

The MT6219 device is offered in a 13mm×13mm, 293-ball, 0.65 mm pitch, TFBGA package.



Figure 1 Typical application of MT6219

## 1.1 MODEM Features

### ■ General

- Integrated voice-band, audio-band and base-band analog front ends
- TFBGA 13mm×13mm, 293-ball, 0.65 mm pitch package

### ■ MCU Subsystem

- ARM7EJ-S 32-bit RISC processor
- High performance multi-layer AMBA bus
- Java hardware acceleration for fast Java-based games and applets
- Operating frequency: 26/52 MHz
- Dedicated DMA bus
- 14 DMA channels
- 512K Bytes zero-wait-state on-chip SRAM
- On-chip boot ROM for Factory Flash Programming
- Watchdog timer for system crash recovery
- 2 sets of General Purpose Timer
- Circuit Switch Data coprocessor
- Division coprocessor

### ■ External Memory Interface

- Supports up to 8 external devices
- Supports 8-bit or 16-bit memory components with maximum size of up to 64M Bytes each
- Supports Flash and SRAM with Page Mode or Burst Mode
- Supports Pseudo SRAM
- Industry standard Parallel LCD Interface
- Supports multi-media companion chips with 8/16 bits data width
- Flexible I/O voltage of 1.8V ~ 2.8V for memory interface

- Configurable driving strength for memory interface

### ■ Audio and Modem CODEC

- Dial tone generation
- Voice Memo
- Noise Reduction
- Echo Suppression
- Advanced Sidetone Oscillation Reduction
- Digital sidetone generator with programmable gain
- Two programmable acoustic compensation filters
- GSM/GPRS quad vocoders for adaptive multirate (AMR), enhanced full rate (EFR), full rate (FR) and half rate (HR)
- GSM channel coding, equalization and A5/1 and A5/2 ciphering
- GPRS GEA and GEA2 ciphering
- Programmable GSM/GPRS Modem
- Packet Switched Data with CS1/CS2/CS3/CS4 coding schemes
- GSM Circuit Switch Data
- GPRS Class 12

### ■ User Interfaces

- 6-row × 7-column keypad controller with hardware scanner
- Supports multiple key presses for gaming
- SIM/USIM Controller with hardware T=0/T=1 protocol control
- 3 UARTs with hardware flow control and speed up to 921600 bps
- IrDA modulator/demodulator with hardware framer

- Real Time Clock (RTC) operating with a separate power supply
- Serial LCD Interface with 8/9 bit format support
- General Purpose I/Os (GPIOs)
- 2 Sets of Pulse Width Modulation (PWM) Output
- Alerter Output with Enhanced PWM or PDM
- Six external interrupt lines

#### ■ Audio Interface and Audio Front End

- Two microphone inputs sharing one low noise amplifier with programmable gain
- Two Voice power amplifiers with programmable gain
- 2<sup>nd</sup> order Sigma-Delta A/D Converter for voice uplink path
- D/A Converter for voice downlink path
- Supports half-duplex hands-free operation
- Compliant with GSM 03.50

#### ■ Radio Interface and Baseband Front End

- GMSK modulator with analog I and Q channel outputs
- 10-bit D/A Converter for uplink baseband I and Q signals
- 14-bit high resolution A/D Converter for downlink baseband I and Q signals
- Calibration mechanism of offset and gain mismatch for baseband A/D Converter and D/A Converter
- 10-bit D/A Converter for Automatic Power Control
- 13-bit high resolution D/A Converter for Automatic Frequency Control
- Programmable Radio RX filter
- 2 Channels Baseband Serial Interface (BSI) with 3-wire control

- 10-Pin Baseband Parallel Interface (BPI) with programmable driving strength
- Multi-band support

#### ■ Power Management

- Power Down Mode for analog and digital circuits
- Processor Sleep Mode
- Pause Mode of 32KHz clocking at Standby State
- 7-channel Auxiliary 10-bit A/D Converter for charger and battery monitoring and photo sensing

#### ■ Test and Debug

- Built-in digital and analog loop back modes for both Audio and Baseband Front-End
- DAI port complying with GSM Rec.11.10
- JTAG port for debugging embedded MCU

## 1.2 Multi-Media Features

### ■ LCD/NAND Flash Interface

- Dedicated 8-bit Parallel Interface, supports up to 3 external devices
- Hardware accelerated LCD Controller for display
- Dedicated LCD bus
- NAND Flash Controller for mass storages

### ■ LCD Controller

- Supports simultaneous connection to up to 2 parallel LCD and 1 serial LCD panels
- Supports format: RGB332, RGB444, RGB565, RGB666, RGB888
- Supports LCD panel maximum resolution up to 800x600 at 16bpp
- Supports hardware display rotation
- Capable of combining display memories with up to 4 blending layers

### ■ Image Signal Processor

- 8/10 bit Bayer format image input
- Capable of processing image of size up to 1.3M pixels
- Color Correction Matrix
- Gamma Correction
- Automatic Exposure Control
- Automatic White Balance Control
- Programmable AE/AWB windows
- Edge Enhancement Support
- Histogram Equalization Logic
- Horizontal and Vertical Sync Information on Separate Pin

### ■ JPEG Decoder

- ISO/IEC 10918-1 JPEG Baseline and Progressive modes

- Supports all possible YUV formats, including grayscale format
- Supports all DC/AC Huffman table parsing
- Supports all quantization table parsing
- Supports restart interval
- Supports SOS, DHT, DQT and DRI marker parsing
- IEEE Std 1180-1990 IDCT Standard Compliant
- Supports progressive image processing to minimize storage space requirement
- Supports reload-able DMA for VLD stream

### ■ JPEG Encoder

- ISO/IEC 10918-1 JPEG baseline mode
- ISO/IEC 10918-2 Compliance
- Supports YUV422 and grayscale formats
- Standard DC and AC Huffman tables
- Provides 4 levels of encode quality

### ■ Image Data Processing

- High throughput hardware Resizer capable of tailoring image to arbitrary size
- Horizontal scaling in averaging method
- Vertical scaling in bilinear method
- Simultaneous scaling for MPEG-4 encode and LCD display
- YUV and RGB color space conversion
- Pixel format transform
- Boundary padding
- Pixel processing: hue/saturation/intensity/color adjustment, Gamma correction and grayscale/invert/sepi-tone effects
- Programmable Spatial Filtering: Linear filter, Non-linear filter and Multi-pass artistic effects

- Hardware accelerated image editing
- **MPEG-4/H.263 CODEC**
  - Hardware Video CODEC
  - ISO/IEC 14496-2 simple profile:
    - decode @ level 0/1/2/3
    - encode @ level 0
  - Supported visual tools for decoder: I-VOP, P-VOP, AC/DC prediction, 4-MV, Unrestricted MV, Error Resilience, Short Header
  - Error Resilience for decoder: Slice Resynchronization, Data Partitioning, Reversible VLC
  - Supported visual tools for encoder: I-VOP, P-VOP, Half-pel, DC prediction, Unrestricted MV, Reversible VLC, Short Header
  - Supports encoding motion vector of range up to -64/+63.5 pixels
  - ITU-T H.263 profile 0 @ level 10
  - AAC/AMR/WB-AMR audio decode support
  - AMR/WB-AMR audio encode support
- **2D Accelerator**
  - Rectangle fill
  - BitBlt: multi-BitBlt without transform, 7 rotate, mirror (transparent) BitBlt
- Alpha blending
- Line drawing: normal line, dotted line
- Font caching: normal font, Italic font
- Supports 16-bpp RGB565 and 8-bpp index color modes
- Command queue with 32 levels
- **Audio CODEC**
  - Wavetable synthesis with up to 64 tones
  - Advanced wavetable synthesizer capable of generating simulated stereo
  - Wavetable including GM full set of 128 instruments and 47 sets of percussions
  - PCM Playback and Record
  - Digital Audio Playback
  - High resolution D/A Converters for Stereo Audio playback
  - Stereo analog input for stereo audio source
  - Analog mixers for Stereo Audio
  - Stereo to Mono Conversion
- **Connectivity**
  - Full-speed USB 1.1 Device
  - Multi Media Card/Secure Digital Memory Card/Memory Stick/Memory Stick Pro host controller

## 1.3 General Description

**Figure 2** details the block diagram of MT6219. Based on a dual-processor architecture, MT6219 integrates both an ARM7EJ-S core and a digital signal processor core. ARM7EJ-S is the main processor that is responsible for running high-level GSM/GPRS protocol software as well as multi-media applications. The digital signal processor handles the low-level MODEM as well as advanced audio functions. Except for some mixed-signal circuitries, the other building blocks in MT6219 are connected to either the microcontroller or the digital signal processor.

Specifically, MT6219 consists of the following subsystems:

- Microcontroller Unit (MCU) Subsystem - includes an ARM7EJ-S RISC processor and its accompanying memory management and interrupt handling logics.
- Digital Signal Processor (DSP) Subsystem - includes a DSP and its accompanying memory, memory controller, and interrupt controller.
- MCU/DSP Interface - where the MCU and the DSP exchange hardware and software information.
- Microcontroller Peripherals - includes all user interface modules and RF control interface modules.
- Microcontroller Coprocessors - runs computing-intensive processes in place of Microcontroller.
- DSP Peripherals - hardware accelerators for GSM/GPRS channel codec.
- Multi-media Subsystem - integrates several advanced accelerators to support multi-media applications.
- Voice Front End - the data path for converting analog speech from and to digital speech.
- Audio Front End - the data path for converting stereo audio from stereo audio source
- Baseband Front End - the data path for converting digital signal from and to analog signal of RF modules.
- Timing Generator - generates the control signals related to the TDMA frame timing.
- Power, Reset and Clock subsystem - manages the power, reset, and clock distribution inside MT6219.

Details of the individual subsystems and blocks are described in following Chapters.



Figure 2 MT6219 block diagram.

## 2 Product Description

### 2.1 Pin Outs

One type of package for this product, TFBGA 13mm\*13mm, 293-ball, 0.65 mm pitch Package, is offered.

Pin outs and the top view are illustrated in **Figure 3** for this package. Outline and dimension of package is illustrated in **Figure 4**, while the definition of package is shown in **Table 1**.

|   | 1         | 2           | 3         | 4         | 5         | 6         | 7             | 8             | 9         | 10         | 11         | 12            | 13         | 14        | 15        | 16        | 17        | 18        | 19        |        |
|---|-----------|-------------|-----------|-----------|-----------|-----------|---------------|---------------|-----------|------------|------------|---------------|------------|-----------|-----------|-----------|-----------|-----------|-----------|--------|
| A | NC        | SYSCL_K     | VSS33     | AFC_BYP   | AUXA_DIN6 | AUXA_DIN3 | AVDD_RFE      | BUPAI_N       | BDLAI_N   | AU_VI_N1_P | AGND_AFE   | AU_O_UT0_P    | AVSS_BUF   | AU_F_MINR | AU_M_OUTR | VSS33     | GPIO9     | GPIO8     | GPIO7     |        |
| B | XOUT      | AVDD_RTC    | AVDD_PLL  | AFC       | AUXA_DIN5 | AUXA_DIN2 | APC           | BUPAI_P       | BDLAI_P   | AU_VI_N1_N | AU_VR_EF_P | AU_O_UT0_N    | AVDD_BUF   | AU_F_MINL | AU_M_OUTL | VSS33     | GPIO7     | GPIO6     | VSS33     |        |
| C | BBWA KEUP | XIN         | AVSS_PLL  | AUXA_R_EF | AUXA_DIN4 | AUXA_DIN1 | AVSS_RFE      | BUPA_QN       | BDLA_QN   | AU_VI_N0_N | AU_VR_EF_N | AU_MI_CBIAS_P | AU_O_UT1_N | AU_M_BYP  | AVDD_MBUF | VDDK      | GPIO4     | DAIL_T    | DAC_IN    |        |
| D | VDDK      | VSS33       | TESTM_ODE | VDD33     | VSS33     | AUXA_DINO | AVDD_GSMRF_TX | BUPA_QP       | BDLA_QP   | AU_VI_N0_P | AVDD_AFE   | AU_MI_CBIAS_N | AU_O_UT1_P | AVSS_MBUF | ESDM_CK   | KROW1     | DAICLK    | DAIMOUT   | KROW0     |        |
| E | JTMS      | JTDI        | JTCK      | JTRST#    | IBOOT     | VDD33     | VSS33         | AVSS_GSMRF_TX | AGND_RFE  | AVSS_AFE   | VDD33      | VSS33         | VDD33      | VSS33     | VDD33     | KROW4     | KROW3     | KROW2     | VDD33     |        |
| F | VDD33     | BPI_B_US1   | BPI_B_US0 | JRTCK     | JTDO      | MPLL_OUT  | DPLL_OUT      |               |           |            |            |               |            |           |           | KCOL3     | KCOL2     | COL1      | KCOL0     | KROW5  |
| G | BPI_B_US6 | BPI_B_US5   | BPI_B_US4 | BPI_B_US3 | BPI_B_US2 | UPLL_OUT  |               |               |           |            |            |               |            |           |           | IRDA_TXD  | IRDA_RXD  | VSS33     | VDDK      |        |
| H | BSI_C_S0  | VSS33       | BPI_B_US9 | BPI_B_US8 | BPI_B_US7 |           |               | CMDA_T9       | CMPC_LK   | CMMC_LK    | CMHR_EF    | CMVR_EF       |            |           |           | URXD3     | UTXD3     | IRDA_RXD  | VSS33     | VDDK   |
| J | LSDA      | LSA0        | LSCK      | BSI_C_LK  | BSI_D_ATA |           |               | CMDA_T8       |           |            | CMRS_T     |               |            |           |           | NC        | UCTS1     | URTS1     | URXD2     | UTXD2  |
| K | VDD33     | LPC1#       | LSCE1#    | LSCE0#    | NC        |           |               | CMDA_T7       |           |            | CMPD_N     |               |            |           |           | SIMVC_C   | SIMSE_L   | SIMDA_TA  | URXD1     | UTXD1  |
| L | LWR#      | LPA0        | LRD#      | LRST#     | LPCE0#    |           |               | CMDA_T6       |           |            | CMDA_T0    |               |            |           |           | GPIO2     | GPIO3     | SIMCL_K   | SIMRS_T   | VDD33  |
| M | VDDK      | VSS33       | NLD5      | NLD6      | NLD7      |           |               | CMDA_T5       | CMDA_T4   | CMDA_T3    | CMDA_T2    | CMDA_T1       |            |           |           | NC        | MCPW_RON  | MCWP      | MCINS     | GPIO1  |
| N | NLD0      | NLD1        | NLD2      | NLD3      | NLD4      |           |               |               |           |            |            |               |            |           |           | MCDA_0    | MCDA_1    | MCDA_2    | MCDA_3    | MCCK   |
| P | NRE#      | NWE#        | NALE      | NCLE      | NRNB      |           |               |               |           |            |            |               |            |           |           | VDD33_USB | USB_DP    | USB_DM    | VSS33     | MCCM_0 |
| R | VDD33     | PWM2        | PWM1      | NCE#      | MIRQ      | EA14      | EA10          | EA7           | NC        | EA1        | NC         | ECS4#         | ECS0#      | ELB#      | ED1       | ED0       | MFIQ      | WATC_HDOG | VSS33_EMI |        |
| T | SRCL_KENA | SRCL_KENA_N | ALERT_ER  | EA18      | EA15      | EA11      | EA8           | EA4           | EA1       | EPDN#      | ECS5#      | ECS1#         | EUB#       | ED13      | ED11      | ED3       | VDD33_EMI | ED2       |           |        |
| U | SYSRS_T#  | GPIO0       | EINT1     | EA23      | EA19      | EA16      | EA12          | VSS33_EMI     | EA2       | EADV#      | ECS6#      | ECS2#         | ERD#       | ED14      | VSS33_EMI | ED8       | ED6       | ED4       |           |        |
| V | EINT0     | EINT3       | VSS33_EMI | EA22      | EA20      | VSS33_EMI | EA13          | VDD33_EMI     | EA6       | VSS33_EMI  | ECLK       | VSS33_EMI     | ECS3#      | VSS33_EMI | ED15      | VDDK      | ED9       | ED6       | VSS33_EMI |        |
| W | EINT2     | EA25        | EA24      | VDD33_EMI | EA21      | EA17      | VDD33_EMI     | EA9           | VDD33_EMI | EA3        | VDD33_EMI  | ECS7#         | VDD33_EMI  | EWR#      | VDD33_EMI | ED12      | ED10      | VDD33_EMI | ED7       |        |
|   | 1         | 2           | 3         | 4         | 5         | 6         | 7             | 8             | 9         | 10         | 11         | 12            | 13         | 14        | 15        | 16        | 17        | 18        | 19        |        |

Figure 3 Top View of MT6219 TFBGA 13mm\*13mm, 293-ball, 0.65 mm pitch Package



**Figure 4** Outlines and Dimension of TFBGA 13mm\*13mm, 293-ball, 0.65 mm pitch Package

| Body Size |         | Ball Count | Ball Pitch | Ball Dia. | Package Thk.    | Stand Off | Substrate Thk. |
|-----------|---------|------------|------------|-----------|-----------------|-----------|----------------|
| D<br>13   | E<br>13 | N<br>293   | e<br>0.65  | b<br>0.35 | A (Max.)<br>1.4 | A1<br>0.3 | C<br>0.36      |

**Table 1** Definition of TFBGA 13mm\*13mm, 293-ball, 0.65 mm pitch Package (Unit: mm)

## 2.2 Pin Description

| Ball<br>13X13                            | Name            | Dir | Description                                     | Mode0         | Mode1    | Mode2    | Mode3   | PU/<br>Rese<br>t<br>PD |
|------------------------------------------|-----------------|-----|-------------------------------------------------|---------------|----------|----------|---------|------------------------|
| <b>JTAG Port</b>                         |                 |     |                                                 |               |          |          |         |                        |
| E4                                       | <b>JTRST#</b>   | I   | JTAG test port reset input                      |               |          |          |         | PD Input               |
| E3                                       | <b>JTCK</b>     | I   | JTAG test port clock input                      |               |          |          |         | PU Input               |
| E2                                       | <b>JTDI</b>     | I   | JTAG test port data input                       |               |          |          |         | PU Input               |
| E1                                       | <b>JTMS</b>     | I   | JTAG test port mode switch                      |               |          |          |         | PU Input               |
| F5                                       | <b>JTDO</b>     | O   | JTAG test port data output                      |               |          |          |         | 0                      |
| F4                                       | <b>JRTCK</b>    | O   | JTAG test port returned clock output            |               |          |          |         | 0                      |
| <b>RF Parallel Control Unit</b>          |                 |     |                                                 |               |          |          |         |                        |
| F3                                       | <b>BPI_BUS0</b> | O   | RF hard-wire control bus 0                      |               |          |          |         | 0                      |
| F2                                       | <b>BPI_BUS1</b> | O   | RF hard-wire control bus 1                      |               |          |          |         | 0                      |
| G5                                       | <b>BPI_BUS2</b> | O   | RF hard-wire control bus 2                      |               |          |          |         | 0                      |
| G4                                       | <b>BPI_BUS3</b> | O   | RF hard-wire control bus 3                      |               |          |          |         | 0                      |
| G3                                       | <b>BPI_BUS4</b> | IO  | RF hard-wire control bus 4                      |               |          |          |         | Input                  |
| G2                                       | <b>BPI_BUS5</b> | IO  | RF hard-wire control bus 5                      |               |          |          |         | Input                  |
| G1                                       | <b>BPI_BUS6</b> | IO  | RF hard-wire control bus 6                      | <b>GPIO10</b> | BPI_BUS6 |          |         | PD Input               |
| H5                                       | <b>BPI_BUS7</b> | IO  | RF hard-wire control bus 7                      | <b>GPIO11</b> | BPI_BUS7 |          |         | PD Input               |
| H4                                       | <b>BPI_BUS8</b> | IO  | RF hard-wire control bus 4                      | <b>GPIO12</b> | BPI_BUS8 | 13MHz    | 32KHz   | PD Input               |
| H3                                       | <b>BPI_BUS9</b> | IO  | RF hard-wire control bus 5                      | <b>GPIO13</b> | BPI_BUS9 | BSI_CS1  |         | PD Input               |
| <b>RF Serial Control Unit</b>            |                 |     |                                                 |               |          |          |         |                        |
| H1                                       | <b>BSI_CS0</b>  | O   | RF 3-wire interface chip select 0               |               |          |          |         | 0                      |
| J5                                       | <b>BSI_DATA</b> | O   | RF 3-wire interface data output                 |               |          |          |         | 0                      |
| J4                                       | <b>BSI_CLK</b>  | O   | RF 3-wire interface clock output                |               |          |          |         | 0                      |
| <b>PWM Interface</b>                     |                 |     |                                                 |               |          |          |         |                        |
| R3                                       | PWM1            | IO  | Pulse width modulated signal 1                  | <b>GPIO21</b> | PWM1     | DSP_GPO0 | TBTXFS  | PD Input               |
| R2                                       | PWM2            | IO  | Pulse width modulated signal 2                  | <b>GPIO22</b> | PWM2     | DSP_GPO1 | TBRXEN  | PD Input               |
| T4                                       | ALERTER         | IO  | Pulse width modulated signal for buzzer         | <b>GPIO23</b> | ALERTER  | DSP_GPO2 | BTRXFS  | PD Input               |
| <b>Serial LCD/PM IC Interface</b>        |                 |     |                                                 |               |          |          |         |                        |
| J3                                       | LSCK            | IO  | Serial display interface data output            | <b>GPIO16</b> | LSCK     | TDMA_CK  | TBTXEN  | PD Input               |
| J2                                       | LSA0            | IO  | Serial display interface address output         | <b>GPIO17</b> | LSA0     | TDMA_D1  | TDTIRQ  | PD Input               |
| J1                                       | LSDA            | IO  | Serial display interface clock output           | <b>GPIO18</b> | LSDA     | TDMA_D0  | TCTIRQ2 | PD Input               |
| K4                                       | LSCE0#          | IO  | Serial display interface chip select 0 output   | <b>GPIO19</b> | LSCE0#   | TDMA_FS  | TCTIRQ1 | PU Input               |
| K3                                       | LSCE1#          | IO  | Serial display interface chip select 1 output   | <b>GPIO20</b> | LSCE1#   | LPCE2#   | TEVTVAL | PU Input               |
| <b>Parallel LCD/Nand-Flash Interface</b> |                 |     |                                                 |               |          |          |         |                        |
| K2                                       | LPCE1#          | IO  | Parallel display interface chip select 1 output | <b>GPIO24</b> | LPCE1#   | DSP_TID0 | MCU_TD0 | PU Input               |
| L5                                       | <b>LPCE0#</b>   | O   | Parallel display interface chip select 0 output |               |          |          |         | PU Input               |
| L4                                       | <b>LRST#</b>    | O   | Parallel display interface Reset Signal         |               |          |          |         | 1                      |
| L3                                       | <b>LRD#</b>     | O   | Parallel display interface Read Strobe          |               |          |          |         | 1                      |
| L2                                       | <b>LPA0</b>     | O   | Parallel display interface address output       |               |          |          |         | 1                      |
| L1                                       | <b>LWR#</b>     | O   | Parallel display interface Write Strobe         |               |          |          |         | 1                      |
| M5                                       | <b>NLD7</b>     | IO  | Parallel LCD/Nand-Flash Data 7                  |               |          |          |         | PD Input               |

|    |             |    |                                 |               |      |               |              |    |       |       |
|----|-------------|----|---------------------------------|---------------|------|---------------|--------------|----|-------|-------|
| M4 | <b>NLD6</b> | IO | Parallel LCD/Nand-Flash Data 6  |               |      |               |              |    | PD    | Input |
| M3 | <b>NLD5</b> | IO | Parallel LCD/Nand-Flash Data 5  |               |      |               |              |    | PD    | Input |
| N5 | <b>NLD4</b> | IO | Parallel LCD/Nand-Flash Data 4  |               |      |               |              |    | PD    | Input |
| N4 | <b>NLD3</b> | IO | Parallel LCD/Nand-Flash Data 3  |               |      |               |              |    | PD    | Input |
| N3 | <b>NLD2</b> | IO | Parallel LCD/Nand-Flash Data 2  |               |      |               |              |    | PD    | Input |
| N2 | <b>NLD1</b> | IO | Parallel LCD/Nand-Flash Data 1  |               |      |               |              |    | PD    | Input |
| N1 | <b>NLD0</b> | IO | Parallel LCD/Nand-Flash Data 0  |               |      |               |              |    | PD    | Input |
| P5 | NRNB        | IO | Nand-Flash Read/Busy Flag       | <b>GPIO25</b> | NRNB | DSP_TID1<br>1 | MCU_TID<br>1 | PU | Input |       |
| P4 | NCLE        | IO | Nand-Flash Command Latch Signal | <b>GPIO26</b> | NCLE | DSP_TID2      | MCU_TID<br>2 | PD | Input |       |
| P3 | NALE        | IO | Nand-Flash Address Latch Signal | <b>GPIO27</b> | NALE | DSP_TID3      | MCU_TID<br>3 | PD | Input |       |
| P2 | NWE#        | IO | Nand-Flash Write Strobe         | <b>GPIO28</b> | NWE# | DSP_TID4      | MCU_DID      | PU | Input |       |
| P1 | NRE#        | IO | Nand-Flash Read Strobe          | <b>GPIO29</b> | NRE# | DSP_TID5      | MCU_DF<br>S  | PU | Input |       |
| R4 | NCE#        | IO | Nand-Flash Chip select output   | <b>GPIO30</b> | NCE# | DSP_TID6      | MCU_DC<br>K  | PU | Input |       |

#### SIM Card Interface

|     |                |    |                               |               |        |  |  |    |       |  |
|-----|----------------|----|-------------------------------|---------------|--------|--|--|----|-------|--|
| L18 | <b>SIMRST</b>  | O  | SIM card reset output         |               |        |  |  |    | 0     |  |
| L17 | <b>SIMCLK</b>  | O  | SIM card clock output         |               |        |  |  |    | 0     |  |
| K15 | <b>SIMVCC</b>  | O  | SIM card supply power control |               |        |  |  |    | 0     |  |
| K16 | SIMSEL         | O  | SIM card supply power select  | <b>GPIO32</b> | SIMSEL |  |  | PD | Input |  |
| K17 | <b>SIMDATA</b> | IO | SIM card data input/output    |               |        |  |  |    | 0     |  |

#### Dedicated GPIO Interface

|     |              |    |                                 |              |         |              |              |    |       |  |
|-----|--------------|----|---------------------------------|--------------|---------|--------------|--------------|----|-------|--|
| U2  | <b>GPIO0</b> | IO | General purpose input/output 0  | <b>GPIO0</b> |         | DSP_GPO3     |              | PD | Input |  |
| M19 | <b>GPIO1</b> | IO | General purpose input/output 1  | <b>GPIO1</b> | DICK    |              |              | PD | Input |  |
| L15 | <b>GPIO2</b> | IO | General purpose input/output 2  | <b>GPIO2</b> | DID     |              |              | PD | Input |  |
| L16 | <b>GPIO3</b> | IO | General purpose input/output 3  | <b>GPIO3</b> | DIMS    |              |              | PD | Input |  |
| C17 | <b>GPIO4</b> | IO | General purpose input/output 4  | <b>GPIO4</b> | DSP_CLK | DSPLCK       | TRASD4       | PD | Input |  |
| A19 | <b>GPIO5</b> | IO | General purpose input/output 5  | <b>GPIO5</b> | AHB_CLK | DSPLD3       | TRASD3       | PD | Input |  |
| B18 | <b>GPIO6</b> | IO | General purpose input/output 6  | <b>GPIO6</b> | ARM_CLK | DSPLD2       | TRASD2       | PD | Input |  |
| B17 | <b>GPIO7</b> | IO | General purpose input/output 7  | <b>GPIO7</b> | SLOW_CK | DSPLD1       | TRASD1       | PD | Input |  |
| A18 | <b>GPIO8</b> | IO | General purpose input/output 19 | <b>GPIO8</b> | SCL     | DSPLD0       | TRASD0       | PD | Input |  |
| A17 | <b>GPIO9</b> | IO | General purpose input/output 21 | <b>GPIO9</b> | SDA     | DSPLSYN<br>C | TRARSY<br>NC | PD | Input |  |

#### Miscellaneous

|     |                       |    |                                         |               |                       |  |  |    |       |       |
|-----|-----------------------|----|-----------------------------------------|---------------|-----------------------|--|--|----|-------|-------|
| U1  | <b>SYSRST#</b>        | I  | System reset input active low           |               |                       |  |  |    |       | Input |
| R18 | <b>WATCHDOG<br/>#</b> | O  | Watchdog reset output                   |               |                       |  |  |    |       | 1     |
| T3  | <b>SRCLKENA<br/>N</b> | O  | External TCXO enable output active low  | <b>GPO1</b>   | <b>SRCLKEN<br/>AN</b> |  |  |    |       | 0     |
| T1  | <b>SRCLKENA</b>       | O  | External TCXO enable output active high | <b>GPO0</b>   | <b>SRCLKEN<br/>A</b>  |  |  |    |       | 1     |
| T2  | <b>SRCLKENAI</b>      | IO | External TCXO enable input              | <b>GPIO31</b> | <b>SRCLKEN<br/>AI</b> |  |  | PD | Input |       |
| E5  | <b>IBOOT</b>          | I  | Boot Device Configuration Input         |               |                       |  |  | PD | Input |       |

#### Keypad Interface

|     |              |   |                 |  |  |  |  |    |       |  |
|-----|--------------|---|-----------------|--|--|--|--|----|-------|--|
| G17 | <b>KCOL6</b> | I | Keypad column 6 |  |  |  |  | PU | Input |  |
| G18 | <b>KCOL5</b> | I | Keypad column 5 |  |  |  |  | PU | Input |  |

|     |              |   |                 |  |  |  |  |  |    |       |
|-----|--------------|---|-----------------|--|--|--|--|--|----|-------|
| G19 | <b>KCOL4</b> | I | Keypad column 4 |  |  |  |  |  | PU | Input |
| F15 | <b>KCOL3</b> | I | Keypad column 3 |  |  |  |  |  | PU | Input |
| F16 | <b>KCOL2</b> | I | Keypad column 2 |  |  |  |  |  | PU | Input |
| F17 | <b>KCOL1</b> | I | Keypad column 1 |  |  |  |  |  | PU | Input |
| F18 | <b>KCOL0</b> | I | Keypad column 0 |  |  |  |  |  | PU | Input |
| F19 | <b>KROW5</b> | O | Keypad row 5    |  |  |  |  |  | 0  |       |
| E16 | <b>KROW4</b> | O | Keypad row 4    |  |  |  |  |  | 0  |       |
| E17 | <b>KROW3</b> | O | Keypad row 3    |  |  |  |  |  | 0  |       |
| E18 | <b>KROW2</b> | O | Keypad row 2    |  |  |  |  |  | 0  |       |
| D16 | <b>KROW1</b> | O | Keypad row 1    |  |  |  |  |  | 0  |       |
| D19 | <b>KROW0</b> | O | Keypad row 0    |  |  |  |  |  | 0  |       |

**External Interrupt Interface**

|     |              |   |                      |               |      |       |       |  |    |       |
|-----|--------------|---|----------------------|---------------|------|-------|-------|--|----|-------|
| V1  | <b>EINT0</b> | I | External interrupt 0 |               |      |       |       |  | PU | Input |
| U3  | <b>EINT1</b> | I | External interrupt 1 |               |      |       |       |  | PU | Input |
| W1  | <b>EINT2</b> | I | External interrupt 2 |               |      |       |       |  | PU | Input |
| V2  | <b>EINT3</b> | I | External interrupt 3 |               |      |       |       |  | PU | Input |
| R5  | MIRQ         | I | Interrupt to MCU     | <b>GPIO41</b> | MIRQ | 13MHz | 32KHz |  | PU | Input |
| R17 | MFIQ         | I | Interrupt to MCU     | <b>GPIO42</b> | MFIQ |       |       |  | PU | Input |

**External Memory Interface**

|     |              |    |                                     |               |              |  |  |  |    |       |
|-----|--------------|----|-------------------------------------|---------------|--------------|--|--|--|----|-------|
| R16 | <b>ED0</b>   | IO | External memory data bus 0          |               |              |  |  |  |    | Input |
| R15 | <b>ED1</b>   | IO | External memory data bus 1          |               |              |  |  |  |    | Input |
| T19 | <b>ED2</b>   | IO | External memory data bus 2          |               |              |  |  |  |    | Input |
| T17 | <b>ED3</b>   | IO | External memory data bus 3          |               |              |  |  |  |    | Input |
| U19 | <b>ED4</b>   | IO | External memory data bus 4          |               |              |  |  |  |    | Input |
| U18 | <b>ED5</b>   | IO | External memory data bus 5          |               |              |  |  |  |    | Input |
| V18 | <b>ED6</b>   | IO | External memory data bus 6          |               |              |  |  |  |    | Input |
| W19 | <b>ED7</b>   | IO | External memory data bus 7          |               |              |  |  |  |    | Input |
| U17 | <b>ED8</b>   | IO | External memory data bus 8          |               |              |  |  |  |    | Input |
| V17 | <b>ED9</b>   | IO | External memory data bus 9          |               |              |  |  |  |    | Input |
| W17 | <b>ED10</b>  | IO | External memory data bus 10         |               |              |  |  |  |    | Input |
| T16 | <b>ED11</b>  | IO | External memory data bus 11         |               |              |  |  |  |    | Input |
| W16 | <b>ED12</b>  | IO | External memory data bus 12         |               |              |  |  |  |    | Input |
| T15 | <b>ED13</b>  | IO | External memory data bus 13         |               |              |  |  |  |    | Input |
| U15 | <b>ED14</b>  | IO | External memory data bus 14         |               |              |  |  |  |    | Input |
| V15 | <b>ED15</b>  | IO | External memory data bus 15         |               |              |  |  |  |    | Input |
| U14 | <b>ERD#</b>  | O  | External memory read strobe         |               |              |  |  |  |    | 1     |
| W14 | <b>EWR#</b>  | O  | External memory write strobe        |               |              |  |  |  |    | 1     |
| R13 | <b>ECS0#</b> | O  | External memory chip select 0       |               |              |  |  |  |    | 1     |
| T13 | <b>ECS1#</b> | O  | External memory chip select 1       |               |              |  |  |  |    | 1     |
| U13 | <b>ECS2#</b> | O  | External memory chip select 2       |               |              |  |  |  |    | 1     |
| V13 | <b>ECS3#</b> | O  | External memory chip select 3       |               |              |  |  |  |    | 1     |
| R12 | <b>ECS4#</b> | O  | External memory chip select 4       | <b>GPIO54</b> | ECS4#        |  |  |  | PU | 1     |
| T12 | <b>ECS5#</b> | O  | External memory chip select 5       | <b>GPIO53</b> | ECS5#        |  |  |  | PU | 1     |
| U12 | <b>ECS6#</b> | O  | External memory chip select 6       | <b>GPIO52</b> | ECS6#        |  |  |  | PU | 1     |
| W12 | <b>ECS7#</b> | O  | External memory chip select 7       | <b>GPIO40</b> | ECS7#        |  |  |  | PU | 1     |
| R14 | <b>ELB#</b>  | O  | External memory lower byte strobe   |               |              |  |  |  |    | 1     |
| T14 | <b>EUB#</b>  | O  | External memory upper byte strobe   |               |              |  |  |  |    | 1     |
| T11 | <b>EPDN#</b> | O  | Power Down Control Signal for PSRAM | <b>GPO2</b>   | <b>EPDN#</b> |  |  |  |    | 0     |



|     |              |   |                                           |             |      |       |       |   |
|-----|--------------|---|-------------------------------------------|-------------|------|-------|-------|---|
| U11 | <b>EADV#</b> | O | Address valid for burst mode flash memory |             |      |       |       | 1 |
| V11 | <b>ECLK</b>  | O | Clock for flash memory                    |             |      |       |       | 0 |
| R10 | <b>EA0</b>   | O | External memory address bus 0             |             |      |       |       | 0 |
| T10 | <b>EA1</b>   | O | External memory address bus 1             |             |      |       |       | 0 |
| U10 | <b>EA2</b>   | O | External memory address bus 2             |             |      |       |       | 0 |
| W10 | <b>EA3</b>   | O | External memory address bus 3             |             |      |       |       | 0 |
| T9  | <b>EA4</b>   | O | External memory address bus 4             |             |      |       |       | 0 |
| U9  | <b>EA5</b>   | O | External memory address bus 5             |             |      |       |       | 0 |
| V9  | <b>EA6</b>   | O | External memory address bus 6             |             |      |       |       | 0 |
| R8  | <b>EA7</b>   | O | External memory address bus 7             |             |      |       |       | 0 |
| T8  | <b>EA8</b>   | O | External memory address bus 8             |             |      |       |       | 0 |
| W8  | <b>EA9</b>   | O | External memory address bus 9             |             |      |       |       | 0 |
| R7  | <b>EA10</b>  | O | External memory address bus 10            |             |      |       |       | 0 |
| T7  | <b>EA11</b>  | O | External memory address bus 11            |             |      |       |       | 0 |
| U7  | <b>EA12</b>  | O | External memory address bus 12            |             |      |       |       | 0 |
| V7  | <b>EA13</b>  | O | External memory address bus 13            |             |      |       |       | 0 |
| R6  | <b>EA14</b>  | O | External memory address bus 14            |             |      |       |       | 0 |
| T6  | <b>EA15</b>  | O | External memory address bus 15            |             |      |       |       | 0 |
| U6  | <b>EA16</b>  | O | External memory address bus 16            |             |      |       |       | 0 |
| W6  | <b>EA17</b>  | O | External memory address bus 17            |             |      |       |       | 0 |
| T5  | <b>EA18</b>  | O | External memory address bus 18            |             |      |       |       | 0 |
| U5  | <b>EA19</b>  | O | External memory address bus 19            |             |      |       |       | 0 |
| V5  | <b>EA20</b>  | O | External memory address bus 20            |             |      |       |       | 0 |
| W5  | <b>EA21</b>  | O | External memory address bus 21            |             |      |       |       | 0 |
| V4  | <b>EA22</b>  | O | External memory address bus 22            |             |      |       |       | 0 |
| U4  | <b>EA23</b>  | O | External memory address bus 23            |             |      |       |       | 0 |
| W3  | EA24         | O | External memory address bus 24            | <b>GPO3</b> | EA24 |       |       | 0 |
| W2  | EA25         | O | External memory address bus 25            | <b>GPO4</b> | EA25 | 13MHz | 32KHz | 0 |

**USB Interface**

|     |               |    |                     |  |  |  |  |  |
|-----|---------------|----|---------------------|--|--|--|--|--|
| P16 | <b>USB_DP</b> | IO | USB D+ Input/Output |  |  |  |  |  |
| P17 | <b>USB_DM</b> | IO | USB D- Input/Output |  |  |  |  |  |

**Memory Card Interface**

|     |                |    |                                        |               |       |  |  |    |
|-----|----------------|----|----------------------------------------|---------------|-------|--|--|----|
| P19 | <b>MCCM0</b>   | IO | SD Command/MS Bus State Output         |               |       |  |  |    |
| N15 | <b>MCDA0</b>   | IO | SD Serial Data IO 0/MS Serial Data IO  |               |       |  |  |    |
| N16 | <b>MCDA1</b>   | IO | SD Serial Data IO 1                    |               |       |  |  |    |
| N17 | <b>MCDA2</b>   | IO | SD Serial Data IO 2                    |               |       |  |  |    |
| N18 | <b>MCDA3</b>   | IO | SD Serial Data IO 3                    |               |       |  |  |    |
| N19 | <b>MCCK</b>    | O  | SD Serial Clock/MS Serial Clock Output |               |       |  |  |    |
| M16 | <b>MCPWRON</b> | O  | SD Power On Control Output             |               |       |  |  |    |
| M17 | MCWP           | I  | SD Write Protect Input                 | <b>GPIO15</b> | MCWP  |  |  | PU |
| M18 | MCINS          | I  | SD Card Detect Input                   | <b>GPIO14</b> | MCINS |  |  | PU |

**UART Interface**

|     |              |    |                        |               |       |       |  |          |
|-----|--------------|----|------------------------|---------------|-------|-------|--|----------|
| K18 | <b>URXD1</b> | I  | UART 1 receive data    |               |       |       |  | PU Input |
| K19 | <b>UTXD1</b> | O  | UART 1 transmit data   |               |       |       |  | 1        |
| J16 | <b>UCTS1</b> | I  | UART 1 clear to send   |               |       |       |  | PU Input |
| J17 | <b>URTS1</b> | O  | UART 1 request to send |               |       |       |  | 1        |
| J18 | URXD2        | IO | UART 2 receive data    | <b>GPIO35</b> | URXD2 | UCTS3 |  | PU Input |



|                                |               |    |                                          |        |           |         |        |    |        |
|--------------------------------|---------------|----|------------------------------------------|--------|-----------|---------|--------|----|--------|
| J19                            | UTXD2         | IO | UART 2 transmit data                     | GPIO36 | UTXD2     | URTS3   |        | PU | Input  |
| H15                            | URXD3         | IO | UART 3 receive data                      | GPIO33 | URXD3     |         |        | PU | Input  |
| H16                            | UTXD3         | IO | UART 3 transmit data                     | GPIO34 | UTXD3     |         |        | PU | Input  |
| H17                            | IRDA_RXD      | IO | IrDA receive data                        | GPIO37 | IRDA_RXD  | URTS2   |        | PU | Input  |
| G15                            | IRDA_TXD      | IO | IrDA transmit data                       | GPIO38 | IRDA_TXD  | URTS2   |        | PU | Input  |
| G16                            | IRDA_PDN      | IO | IrDA Power Down Control                  | GPIO39 | IRDA_PDN  |         |        | PU | Input  |
| <b>Digital Audio Interface</b> |               |    |                                          |        |           |         |        |    |        |
| D17                            | DAICLK        | IO | DAI clock output                         | GPIO43 | DAICLK    | DSPLD7  | TRACLK | PU | Input  |
| D18                            | DAIPCMOUT     | IO | DAI pcm data out                         | GPIO44 | DAIPCMOUT | DSPLD6  | TRASYN | PD | Input  |
| C19                            | DAIPCMIN      | IO | DAI pcm data input                       | GPIO45 | DAIPCMIN  | DSPLD5  | TRASD7 | PU | Input  |
| C18                            | DAIRST        | IO | DAI reset signal input                   | GPIO47 | DAIRST    | DSPLD4  | TRASD6 | PU | Input  |
| B19                            | DAISYNC       | IO | DAI frame synchronization signal output  | GPIO46 | DAISYNC   | BFEPRBO | TRASD5 | PU | Input  |
| <b>CMOS Sensor Interface</b>   |               |    |                                          |        |           |         |        |    |        |
| J12                            | CMRST         | IO | CMOS sensor reset signal output          | GPIO48 | CMRST     |         |        | Z  | Input  |
| K12                            | CMPDN         | IO | CMOS sensor power down control           | GPIO49 | CMPDN     |         |        | Z  | Input  |
| H12                            | CMVREF        | I  | Sensor vertical reference signal input   |        |           |         |        |    | Input  |
| H11                            | CMHREF        | I  | Sensor horizontal reference signal input |        |           |         |        |    | Input  |
| H9                             | CMPCLK        | I  | CMOS sensor pixel clock input            |        |           |         |        |    | Input  |
| H10                            | CMMCLK        | O  | CMOS sensor master clock output          |        |           |         |        |    | Output |
| H8                             | CMDAT9        | I  | CMOS sensor data input 9                 |        |           |         |        |    | Input  |
| J8                             | CMDAT8        | I  | CMOS sensor data input 8                 |        |           |         |        |    | Input  |
| K8                             | CMDAT7        | I  | CMOS sensor data input 7                 |        |           |         |        |    | Input  |
| L8                             | CMDAT6        | I  | CMOS sensor data input 6                 |        |           |         |        |    | Input  |
| M8                             | CMDAT5        | I  | CMOS sensor data input 5                 |        |           |         |        |    | Input  |
| M9                             | CMDAT4        | I  | CMOS sensor data input 4                 |        |           |         |        |    | Input  |
| M10                            | CMDAT3        | I  | CMOS sensor data input 3                 |        |           |         |        |    | Input  |
| M11                            | CMDAT2        | I  | CMOS sensor data input 2                 |        |           |         |        |    | Input  |
| M12                            | CMDAT1        | IO | CMOS sensor data input 1                 | GPIO50 | CMDAT1    |         |        | PD | Input  |
| L12                            | CMDAT0        | IO | CMOS sensor data input 0                 | GPIO51 | CMDAT2    |         |        | PD | Input  |
| <b>Analog Interface</b>        |               |    |                                          |        |           |         |        |    |        |
| B15                            | AU_MOUL       |    | Audio analog output left channel         |        |           |         |        |    |        |
| A15                            | AU_MOUR       |    | Audio analog output right channel        |        |           |         |        |    |        |
| C14                            | AU_M_BYP      |    | Audio DAC bypass pin                     |        |           |         |        |    |        |
| B14                            | AU_FMINL      |    | FM radio analog input left channel       |        |           |         |        |    |        |
| A14                            | AU_FMINR      |    | FM radio analog input right channel      |        |           |         |        |    |        |
| D13                            | AU_OUT1_P     |    | Earphone 1 amplifier output (+)          |        |           |         |        |    |        |
| C13                            | AU_OUT1_N     |    | Earphone 1 amplifier output (-)          |        |           |         |        |    |        |
| B12                            | AU_OUT0_N     |    | Earphone 0 amplifier output (-)          |        |           |         |        |    |        |
| A12                            | AU_OUT0_P     |    | Earphone 0 amplifier output (+)          |        |           |         |        |    |        |
| C12                            | AU_MICBIA_S_P |    | Microphone bias supply (+)               |        |           |         |        |    |        |
| D12                            | AU_MICBIA_S_N |    | Microphone bias supply (-)               |        |           |         |        |    |        |



|                        |           |                                                    |                                           |  |  |  |  |   |
|------------------------|-----------|----------------------------------------------------|-------------------------------------------|--|--|--|--|---|
| C11                    | AU_VREF_N | Audio reference voltage (-)                        |                                           |  |  |  |  |   |
| B11                    | AU_VREF_P | Audio reference voltage (+)                        |                                           |  |  |  |  |   |
| D10                    | AU_VIN0_P | Microphone 0 amplifier input (+)                   |                                           |  |  |  |  |   |
| C10                    | AU_VIN0_N | Microphone 0 amplifier input (-)                   |                                           |  |  |  |  |   |
| B10                    | AU_VIN1_N | Microphone 1 amplifier input (-)                   |                                           |  |  |  |  |   |
| A10                    | AU_VIN1_P | Microphone 1 amplifier input (+)                   |                                           |  |  |  |  |   |
| D9                     | BDLAQP    | Quadrature input (Q+) baseband codec downlink      |                                           |  |  |  |  |   |
| C9                     | BDLAQN    | Quadrature input (Q-) baseband codec downlink      |                                           |  |  |  |  |   |
| A9                     | BDLAIN    | In-phase input (I+) baseband codec downlink        |                                           |  |  |  |  |   |
| B9                     | BDLAIP    | In-phase input (I-) baseband codec downlink        |                                           |  |  |  |  |   |
| B8                     | BUPAIP    | In-phase output (I+) baseband codec uplink         |                                           |  |  |  |  |   |
| A8                     | BUPAIN    | In-phase output (I-) baseband codec uplink         |                                           |  |  |  |  |   |
| C8                     | BUPAQN    | Quadrature output (Q+) baseband codec uplink       |                                           |  |  |  |  |   |
| D8                     | BUPAQP    | Quadrature output (Q-) baseband codec uplink       |                                           |  |  |  |  |   |
| B7                     | APC       | Automatic power control DAC output                 |                                           |  |  |  |  |   |
| D6                     | AUXADIN0  | Auxiliary ADC input 0                              |                                           |  |  |  |  |   |
| C6                     | AUXADIN1  | Auxiliary ADC input 1                              |                                           |  |  |  |  |   |
| B6                     | AUXADIN2  | Auxiliary ADC input 2                              |                                           |  |  |  |  |   |
| A6                     | AUXADIN3  | Auxiliary ADC input 3                              |                                           |  |  |  |  |   |
| C5                     | AUXADIN4  | Auxiliary ADC input 4                              |                                           |  |  |  |  |   |
| B5                     | AUXADIN5  | Auxiliary ADC input 5                              |                                           |  |  |  |  |   |
| A5                     | AUXADIN6  | Auxiliary ADC input 6                              |                                           |  |  |  |  |   |
| C4                     | AUX_REF   | Auxiliary ADC reference voltage input              |                                           |  |  |  |  |   |
| B4                     | AFC       | Automatic frequency control DAC output             |                                           |  |  |  |  |   |
| A4                     | AFC_BYP   | Automatic frequency control DAC bypass capacitance |                                           |  |  |  |  |   |
| <b>VCXO Interface</b>  |           |                                                    |                                           |  |  |  |  |   |
| A2                     | SYSCLK    | 13MHz or 26MHz system clock input                  |                                           |  |  |  |  |   |
| <b>RTC Interface</b>   |           |                                                    |                                           |  |  |  |  |   |
| C2                     | XIN       | 32.768 KHz crystal input                           |                                           |  |  |  |  |   |
| B1                     | XOUT      | 32.768 KHz crystal output                          |                                           |  |  |  |  |   |
| C1                     | BBWAKEUP  | O                                                  | Baseband power on/off control             |  |  |  |  | 1 |
| <b>Supply Voltages</b> |           |                                                    |                                           |  |  |  |  |   |
| D1                     | VDDK      |                                                    | Supply voltage of internal logic          |  |  |  |  |   |
| M1                     | VDDK      |                                                    | Supply voltage of internal logic          |  |  |  |  |   |
| V8                     | VDDK      |                                                    | Supply voltage of internal logic          |  |  |  |  |   |
| V16                    | VDDK      |                                                    | Supply voltage of internal logic          |  |  |  |  |   |
| H19                    | VDDK      |                                                    | Supply voltage of internal logic          |  |  |  |  |   |
| C16                    | VDDK      |                                                    | Supply voltage of internal logic          |  |  |  |  |   |
| W4                     | VDD33_EMI |                                                    | Supply voltage of memory interface driver |  |  |  |  |   |

|     |                  |                                                           |  |  |  |  |  |  |
|-----|------------------|-----------------------------------------------------------|--|--|--|--|--|--|
| W7  | <b>VDD33_EMI</b> | Supply voltage of memory interface driver                 |  |  |  |  |  |  |
| W9  | <b>VDD33_EMI</b> | Supply voltage of memory interface driver                 |  |  |  |  |  |  |
| W11 | <b>VDD33_EMI</b> | Supply voltage of memory interface driver                 |  |  |  |  |  |  |
| W13 | <b>VDD33_EMI</b> | Supply voltage of memory interface driver                 |  |  |  |  |  |  |
| W15 | <b>VDD33_EMI</b> | Supply voltage of memory interface driver                 |  |  |  |  |  |  |
| W18 | <b>VDD33_EMI</b> | Supply voltage of memory interface driver                 |  |  |  |  |  |  |
| T18 | <b>VDD33_EMI</b> | Supply voltage of memory interface driver                 |  |  |  |  |  |  |
| V3  | <b>VSS33_EMI</b> | Ground of memory interface driver                         |  |  |  |  |  |  |
| V6  | <b>VSS33_EMI</b> | Ground of memory interface driver                         |  |  |  |  |  |  |
| U8  | <b>VSS33_EMI</b> | Ground of memory interface driver                         |  |  |  |  |  |  |
| V10 | <b>VSS33_EMI</b> | Ground of memory interface driver                         |  |  |  |  |  |  |
| V12 | <b>VSS33_EMI</b> | Ground of memory interface driver                         |  |  |  |  |  |  |
| V14 | <b>VSS33_EMI</b> | Ground of memory interface driver                         |  |  |  |  |  |  |
| U16 | <b>VSS33_EMI</b> | Ground of memory interface driver                         |  |  |  |  |  |  |
| V19 | <b>VSS33_EMI</b> | Ground of memory interface driver                         |  |  |  |  |  |  |
| R19 | <b>VSS33_EMI</b> | Ground of memory interface driver                         |  |  |  |  |  |  |
| P15 | <b>VDD33_USB</b> | Supply voltage of drivers for USB                         |  |  |  |  |  |  |
| D4  | <b>VDD33</b>     | Supply voltage of drivers except memory interface and USB |  |  |  |  |  |  |
| F1  | <b>VDD33</b>     | Supply voltage of drivers except memory interface and USB |  |  |  |  |  |  |
| K1  | <b>VDD33</b>     | Supply voltage of drivers except memory interface and USB |  |  |  |  |  |  |
| R1  | <b>VDD33</b>     | Supply voltage of drivers except memory interface and USB |  |  |  |  |  |  |
| L19 | <b>VDD33</b>     | Supply voltage of drivers except memory interface and USB |  |  |  |  |  |  |
| E19 | <b>VDD33</b>     | Supply voltage of drivers except memory interface and USB |  |  |  |  |  |  |
| E15 | <b>VDD33</b>     | Supply voltage of drivers except memory interface and USB |  |  |  |  |  |  |
| E13 | <b>VDD33</b>     | Supply voltage of drivers except memory interface and USB |  |  |  |  |  |  |
| E11 | <b>VDD33</b>     | Supply voltage of drivers except memory interface and USB |  |  |  |  |  |  |
| E6  | <b>VDD33</b>     | Supply voltage of drivers except memory interface and USB |  |  |  |  |  |  |
| A3  | <b>VSS33</b>     | Ground of drivers except memory interface                 |  |  |  |  |  |  |
| D2  | <b>VSS33</b>     | Ground of drivers except memory interface                 |  |  |  |  |  |  |
| D5  | <b>VSS33</b>     | Ground of drivers except memory interface                 |  |  |  |  |  |  |
| H2  | <b>VSS33</b>     | Ground of drivers except memory interface                 |  |  |  |  |  |  |

|     |                        |                                                                  |  |  |  |  |  |  |
|-----|------------------------|------------------------------------------------------------------|--|--|--|--|--|--|
| M2  | <b>VSS33</b>           | Ground of drivers except memory interface                        |  |  |  |  |  |  |
| P18 | <b>VSS33</b>           | Ground of drivers except memory interface                        |  |  |  |  |  |  |
| H18 | <b>VSS33</b>           | Ground of drivers except memory interface                        |  |  |  |  |  |  |
| A16 | <b>VSS33</b>           | Ground of drivers except memory interface                        |  |  |  |  |  |  |
| B16 | <b>VSS33</b>           | Ground of drivers except memory interface                        |  |  |  |  |  |  |
| E14 | <b>VSS33</b>           | Ground of drivers except memory interface                        |  |  |  |  |  |  |
| E12 | <b>VSS33</b>           | Ground of drivers except memory interface                        |  |  |  |  |  |  |
| E7  | <b>VSS33</b>           | Ground of drivers except memory interface                        |  |  |  |  |  |  |
| B3  | <b>AVDD_PLL</b>        | Supply voltage for PLL                                           |  |  |  |  |  |  |
| C3  | <b>AVSS_PLL</b>        | Ground for PLL supply                                            |  |  |  |  |  |  |
| B2  | <b>AVDD_RTC</b>        | Supply voltage for Real Time Clock                               |  |  |  |  |  |  |
|     | <b>Analog Supplies</b> |                                                                  |  |  |  |  |  |  |
| C15 | <b>AVDD_MBUF</b>       | Supply Voltage for Audio band section                            |  |  |  |  |  |  |
| D14 | <b>AVSS_MBUF</b>       | GND for Audio band section                                       |  |  |  |  |  |  |
| B13 | <b>AVDD_BUF</b>        | Supply voltage for voice band transmit section                   |  |  |  |  |  |  |
| A13 | <b>AVSS_BUF</b>        | GND for voice band transmit section                              |  |  |  |  |  |  |
| D11 | <b>AVDD_AFE</b>        | Supply voltage for voice band receive section                    |  |  |  |  |  |  |
| A11 | <b>AGND_AFE</b>        | GND reference voltage for voice band section                     |  |  |  |  |  |  |
| E10 | <b>AVSS_AFE</b>        | GND for voice band receive section                               |  |  |  |  |  |  |
| E9  | <b>AGND_RFE</b>        | GND reference voltage for baseband section, APC, AFC and AUXADC  |  |  |  |  |  |  |
| E8  | <b>AVSS_GSMR_FTX</b>   | GND for baseband transmit section                                |  |  |  |  |  |  |
| D7  | <b>AVDD_GSM_RFTX</b>   | Supply voltage for baseband transmit section                     |  |  |  |  |  |  |
| C7  | <b>AVSS_RFE</b>        | GND for baseband receive section, APC, AFC and AUXADC            |  |  |  |  |  |  |
| A7  | <b>AVDD_RFE</b>        | Supply voltage for baseband receive section, APC, AFC and AUXADC |  |  |  |  |  |  |

 Table 2 Pin Descriptions (**Bolded** types are functions at reset)

## 2.3 Power Description

| Ball<br>13X13 | Name            | IO Supply | IO GND   | Core Supply | Core GND | Remark    |
|---------------|-----------------|-----------|----------|-------------|----------|-----------|
| B17           | GPIO7           | VDD33     | VSS33    | VDDK        | VSSK     |           |
| A18           | GPIO8           |           |          | VDDK        | VSSK     |           |
| A17           | GPIO9           |           |          | VDDK        | VSSK     |           |
| B16           | <b>VSS33</b>    |           |          |             |          |           |
| A16           | <b>VSS33</b>    |           |          |             |          |           |
| C16           | <b>VDDK</b>     |           |          |             |          | Typ. 1.2V |
| E15           | <b>VDD33</b>    |           |          |             |          | Typ. 2.8V |
| E14           | <b>VSS33</b>    |           |          |             |          |           |
| E13           | <b>VDD33</b>    |           |          |             |          | Typ. 2.8V |
| E12           | <b>VSS33</b>    |           |          |             |          |           |
| E11           | <b>VDD33</b>    |           |          |             |          | Typ. 2.8V |
| E7            | <b>VSS33</b>    |           |          |             |          |           |
| E6            | <b>VDD33</b>    |           |          |             |          | Typ. 2.8V |
| D5            | <b>VSS33</b>    |           |          |             |          |           |
| J12           | CMRST           | VDD33     | VSS33    | VDDK        | VSSK     |           |
| K12           | CMPDN           |           |          | VDDK        | VSSK     |           |
| H12           | CMVREF          |           |          | VDDK        | VSSK     |           |
| H11           | CMHREF          |           |          | VDDK        | VSSK     |           |
| H9            | CMPCLK          |           |          | VDDK        | VSSK     |           |
| H10           | CMMCLK          |           |          | VDDK        | VSSK     |           |
| D4            | <b>VDD33</b>    |           |          |             |          | Typ. 2.8V |
| H8            | CMDAT9          | VDD33     | VSS33    | VDDK        | VSSK     |           |
| J8            | CMDAT8          |           |          | VDDK        | VSSK     |           |
| K8            | CMDAT7          |           |          | VDDK        | VSSK     |           |
| L8            | CMDAT6          |           |          | VDDK        | VSSK     |           |
| M8            | CMDAT5          |           |          | VDDK        | VSSK     |           |
| M9            | CMDAT4          |           |          | VDDK        | VSSK     |           |
| M10           | CMDAT3          |           |          | VDDK        | VSSK     |           |
| M11           | CMDAT2          |           |          | VDDK        | VSSK     |           |
| M12           | CMDAT1          |           |          | VDDK        | VSSK     |           |
| L12           | CMDAT0          |           |          | VDDK        | VSSK     |           |
| A3            | <b>VSS33</b>    |           |          |             |          |           |
| B3            | <b>AVDD_PLL</b> |           |          |             |          | Typ. 2.8V |
| A2            | SYCLK           | AVDD_PLL  | AVSS_PLL | AVDD_PLL    | AVSS_PLL |           |
| C3            | <b>AVSS_PLL</b> |           |          |             |          |           |
| B2            | <b>AVDD_RTC</b> |           |          |             |          | Typ. 1.2V |
| B1            | XOUT            | AVDD_RTC  | VSS33    | AVDD_RTC    | VSS33    |           |
| C2            | XIN             | AVDD_RTC  | VSS33    | AVDD_RTC    | VSS33    |           |
| C1            | BBWAKEUP        | AVDD_RTC  | VSS33    | AVDD_RTC    | VSS33    |           |
| D2            | <b>VSS33</b>    |           |          |             |          |           |
| D3            | <b>TESTMODE</b> | VDD33     | VSS33    | VDDK        | VSSK     |           |
| D1            | <b>VDDK</b>     |           |          |             |          | Typ. 1.2V |
| E5            | IBOOT           | VDD33     | VSS33    | VDDK        | VSSK     |           |
| E4            | JTRST#          |           |          | VDDK        | VSSK     |           |

|    |              |       |       |      |      |           |
|----|--------------|-------|-------|------|------|-----------|
| E3 | JTCK         |       |       | VDDK | VSSK |           |
| E2 | JTDI         |       |       | VDDK | VSSK |           |
| E1 | JTMS         |       |       | VDDK | VSSK |           |
| F5 | JTDO         |       |       | VDDK | VSSK |           |
| F4 | JRTCK        |       |       | VDDK | VSSK |           |
| F3 | BPI_BUS0     |       |       | VDDK | VSSK |           |
| F2 | BPI_BUS1     |       |       | VDDK | VSSK |           |
| F1 | <b>VDD33</b> |       |       |      |      | Typ. 2.8V |
| G5 | BPI_BUS2     | VDD33 | VSS33 | VDDK | VSSK |           |
| G4 | BPI_BUS3     |       |       | VDDK | VSSK |           |
| G3 | BPI_BUS4     |       |       | VDDK | VSSK |           |
| G2 | BPI_BUS5     |       |       | VDDK | VSSK |           |
| G1 | BPI_BUS6     |       |       | VDDK | VSSK |           |
| H5 | BPI_BUS7     |       |       | VDDK | VSSK |           |
| H4 | BPI_BUS8     |       |       | VDDK | VSSK |           |
| H2 | <b>VSS33</b> |       |       |      |      |           |
| H3 | BPI_BUS9     | VDD33 | VSS33 | VDDK | VSSK |           |
| H1 | BSI_CS0      |       |       | VDDK | VSSK |           |
| J5 | BSI_DATA     |       |       | VDDK | VSSK |           |
| J4 | BSI_CLK      |       |       | VDDK | VSSK |           |
| J3 | LSCK         |       |       | VDDK | VSSK |           |
| J2 | LSA0         |       |       | VDDK | VSSK |           |
| J1 | LSDA         |       |       | VDDK | VSSK |           |
| K4 | LSCE0#       |       |       | VDDK | VSSK |           |
| K3 | LSCE1#       |       |       | VDDK | VSSK |           |
| K1 | <b>VDD33</b> |       |       |      |      | Typ. 2.8V |
| K2 | LPCIE1#      | VDD33 | VSS33 | VDDK | VSSK |           |
| L5 | LPCIE0#      |       |       | VDDK | VSSK |           |
| L4 | LRST#        |       |       | VDDK | VSSK |           |
| L3 | LRD#         |       |       | VDDK | VSSK |           |
| L2 | LPA0         |       |       | VDDK | VSSK |           |
| L1 | LWR#         |       |       | VDDK | VSSK |           |
| M5 | NLD7         |       |       | VDDK | VSSK |           |
| M4 | NLD6         |       |       | VDDK | VSSK |           |
| M3 | NLD5         |       |       | VDDK | VSSK |           |
| M2 | <b>VSS33</b> |       |       |      |      |           |
| M1 | <b>VDDK</b>  |       |       |      |      | Typ. 1.2V |
| N5 | NLD4         | VDD33 | VSS33 | VDDK | VSSK |           |
| N4 | NLD3         |       |       | VDDK | VSSK |           |
| N3 | NLD2         |       |       | VDDK | VSSK |           |
| N2 | NLD1         |       |       | VDDK | VSSK |           |
| N1 | NLD0         |       |       | VDDK | VSSK |           |
| P5 | NRNB         |       |       | VDDK | VSSK |           |
| P4 | NCLE         |       |       | VDDK | VSSK |           |
| P3 | NALE         |       |       | VDDK | VSSK |           |
| P2 | NEW#         |       |       | VDDK | VSSK |           |
| P1 | NRE#         |       |       | VDDK | VSSK |           |
| R4 | NCE#         |       |       | VDDK | VSSK |           |
| R1 | <b>VDD33</b> |       |       |      |      | Typ. 2.8V |

|     |                  |           |           |      |      |               |
|-----|------------------|-----------|-----------|------|------|---------------|
| R3  | PWM1             | VDD33     | VSS33     | VDDK | VSSK |               |
| R2  | PWM2             |           |           | VDDK | VSSK |               |
| T4  | ALERTER          |           |           | VDDK | VSSK |               |
| T1  | SRCLKENA         |           |           | VDDK | VSSK |               |
| T3  | SRCLKENAN        |           |           | VDDK | VSSK |               |
| T2  | SRCLKENAI        |           |           | VDDK | VSSK |               |
| U1  | SYRSRST#         |           |           | VDDK | VSSK |               |
| U2  | GPIO0            |           |           | VDDK | VSSK |               |
| V1  | EINT0            |           |           | VDDK | VSSK |               |
| U3  | EINT1            |           |           | VDDK | VSSK |               |
| W1  | EINT2            |           |           | VDDK | VSSK |               |
| V2  | EINT3            |           |           | VDDK | VSSK |               |
| V3  | <b>VSS33_EMI</b> |           |           |      |      |               |
| W2  | EA25             | VDD33_EMI | VSS33_EMI | VDDK | VSSK |               |
| W3  | EA24             |           |           | VDDK | VSSK |               |
| U4  | EA23             |           |           | VDDK | VSSK |               |
| V4  | EA22             |           |           | VDDK | VSSK |               |
| W4  | <b>VDD33_EMI</b> |           |           |      |      | Typ. 1.8~2.8V |
| R5  | MIRQ             | VDD33_EMI | VSS33_EMI | VDDK | VSSK |               |
| W5  | EA21             |           |           | VDDK | VSSK |               |
| V5  | EA20             |           |           | VDDK | VSSK |               |
| U5  | EA19             |           |           | VDDK | VSSK |               |
| T6  | EA18             |           |           | VDDK | VSSK |               |
| V6  | <b>VSS33_EMI</b> |           |           |      |      |               |
| W6  | EA17             | VDD33_EMI | VSS33_EMI | VDDK | VSSK |               |
| U6  | EA16             |           |           | VDDK | VSSK |               |
| T6  | EA15             |           |           | VDDK | VSSK |               |
| R6  | EA14             |           |           | VDDK | VSSK |               |
| W7  | <b>VDD33_EMI</b> |           |           |      |      | Typ. 1.8~2.8V |
| V7  | EA13             | VDD33_EMI | VSS33_EMI | VDDK | VSSK |               |
| U7  | EA12             |           |           | VDDK | VSSK |               |
| T7  | EA11             |           |           | VDDK | VSSK |               |
| R7  | EA10             |           |           | VDDK | VSSK |               |
| V8  | <b>VDDK</b>      |           |           |      |      | Typ. 1.2V     |
| U8  | <b>VSS33_EMI</b> |           |           |      |      |               |
| W8  | EA9              | VDD33_EMI | VSS33_EMI | VDDK | VSSK |               |
| T8  | EA8              |           |           | VDDK | VSSK |               |
| R8  | EA7              |           |           | VDDK | VSSK |               |
| V9  | EA6              |           |           | VDDK | VSSK |               |
| W9  | <b>VDD33_EMI</b> |           |           |      |      | Typ. 1.8~2.8V |
| U9  | EA5              | VDD33_EMI | VSS33_EMI | VDDK | VSSK |               |
| T9  | EA4              |           |           | VDDK | VSSK |               |
| W10 | EA3              |           |           | VDDK | VSSK |               |
| V10 | <b>VSS33_EMI</b> |           |           |      |      |               |
| U10 | EA2              | VDD33_EMI | VSS33_EMI | VDDK | VSSK |               |
| T10 | EA1              |           |           | VDDK | VSSK |               |
| R10 | EA0              |           |           | VDDK | VSSK |               |
| W11 | <b>VDD33_EMI</b> |           |           |      |      | Typ. 1.8~2.8V |

|     |                  |           |           |      |      |               |
|-----|------------------|-----------|-----------|------|------|---------------|
| U11 | EADV#            | VDD33_EMI | VSS33_EMI | VDDK | VSSK |               |
| V11 | ECLK             |           |           | VDDK | VSSK |               |
| T11 | EPDN#            |           |           | VDDK | VSSK |               |
| V12 | <b>VSS33_EMI</b> |           |           |      |      |               |
| W12 | ECS7#            | VDD33_EMI | VSS33_EMI | VDDK | VSSK |               |
| U12 | ECS6#            |           |           | VDDK | VSSK |               |
| T12 | ECS5#            |           |           | VDDK | VSSK |               |
| R12 | ECS4#            |           |           | VDDK | VSSK |               |
| W13 | <b>VDD33_EMI</b> |           |           |      |      | Typ. 1.8~2.8V |
| V13 | ECS3#            | VDD33_EMI | VSS33_EMI | VDDK | VSSK |               |
| U13 | ECS2#            |           |           | VDDK | VSSK |               |
| T13 | ECS1#            |           |           | VDDK | VSSK |               |
| R13 | ECS0#            |           |           | VDDK | VSSK |               |
| V14 | <b>VSS33_EMI</b> |           |           |      |      |               |
| W14 | EWR#             | VDD33_EMI | VSS33_EMI | VDDK | VSSK |               |
| U14 | ERD#             |           |           | VDDK | VSSK |               |
| T14 | EUB#             |           |           | VDDK | VSSK |               |
| R14 | ELB#             |           |           | VDDK | VSSK |               |
| W15 | <b>VDD33_EMI</b> |           |           |      |      | Typ. 1.8~2.8V |
| V15 | ED15             | VDD33_EMI | VSS33_EMI | VDDK | VSSK |               |
| U15 | ED14             |           |           | VDDK | VSSK |               |
| T15 | ED13             |           |           | VDDK | VSSK |               |
| W16 | ED12             |           |           | VDDK | VSSK |               |
| V16 | <b>VDDK</b>      |           |           |      |      | 1.2V          |
| U16 | <b>VSS33_EMI</b> |           |           |      |      |               |
| T16 | ED11             | VDD33_EMI | VSS33_EMI | VDDK | VSSK |               |
| W17 | ED10             |           |           | VDDK | VSSK |               |
| V17 | ED9              |           |           | VDDK | VSSK |               |
| W18 | <b>VDD33_EMI</b> |           |           |      |      | Typ. 1.8~2.8V |
| U17 | ED8              | VDD33_EMI | VSS33_EMI | VDDK | VSSK |               |
| W19 | ED7              |           |           | VDDK | VSSK |               |
| V18 | ED6              |           |           | VDDK | VSSK |               |
| V19 | <b>VSS33_EMI</b> |           |           |      |      |               |
| U18 | ED5              | VDD33_EMI | VSS33_EMI | VDDK | VSSK |               |
| U19 | ED4              |           |           | VDDK | VSSK |               |
| T17 | ED3              |           |           | VDDK | VSSK |               |
| T18 | <b>VDD33_EMI</b> |           |           |      |      | Typ. 1.8~2.8V |
| T19 | ED2              | VDD33_EMI | VSS33_EMI | VDDK | VSSK |               |
| R15 | ED1              |           |           | VDDK | VSSK |               |
| R16 | ED0              |           |           | VDDK | VSSK |               |
| R17 | MFIQ             |           |           | VDDK | VSSK |               |
| R18 | WATCHDOG         |           |           | VDDK | VSSK |               |
| R19 | <b>VSS33_EMI</b> |           |           |      |      |               |
| P15 | <b>VDD33_USB</b> |           |           |      |      | Typ. 3.3V     |
| P16 | USB_DP           | VDD33_USB | VSS33     | VDDK | VSSK |               |
| P17 | USB_DM           |           |           | VDDK | VSSK |               |
| P18 | <b>VSS33</b>     |           |           |      |      |               |
| P19 | MCCM0            | VDD33     | VSS33     | VDDK | VSSK |               |
| N15 | MCDA0            |           |           | VDDK | VSSK |               |

|     |              |       |       |      |      |           |
|-----|--------------|-------|-------|------|------|-----------|
| N16 | MCDA1        |       |       | VDDK | VSSK |           |
| N17 | MCDA2        |       |       | VDDK | VSSK |           |
| N18 | MCDA3        |       |       | VDDK | VSSK |           |
| N19 | MCCK         |       |       | VDDK | VSSK |           |
| M16 | MCPWRON      |       |       | VDDK | VSSK |           |
| M17 | MCWP         |       |       | VDDK | VSSK |           |
| M18 | MCINS        |       |       | VDDK | VSSK |           |
| M19 | GPIO1        |       |       | VDDK | VSSK |           |
| L15 | GPIO2        |       |       | VDDK | VSSK |           |
| L16 | GPIO3        |       |       | VDDK | VSSK |           |
| L19 | <b>VDD33</b> |       |       |      |      | Typ. 2.8V |
| L18 | SIMRST       | VDD33 | VSS33 | VDDK | VSSK |           |
| L17 | SIMCLK       |       |       | VDDK | VSSK |           |
| K15 | SIMVCC       |       |       | VDDK | VSSK |           |
| K16 | SIMSEL       |       |       | VDDK | VSSK |           |
| K17 | SIMDATA      |       |       | VDDK | VSSK |           |
| K18 | URXD1        |       |       | VDDK | VSSK |           |
| K19 | UTXD1        |       |       | VDDK | VSSK |           |
| J16 | UCTS1        |       |       | VDDK | VSSK |           |
| J17 | URTS1        |       |       | VDDK | VSSK |           |
| J18 | URXD2        |       |       | VDDK | VSSK |           |
| J19 | UTXD2        |       |       | VDDK | VSSK |           |
| H15 | URXD3        |       |       | VDDK | VSSK |           |
| H16 | UTXD3        |       |       | VDDK | VSSK |           |
| H19 | <b>VDDK</b>  |       |       | VDDK | VSSK | Typ. 1.2V |
| H18 | <b>VSS33</b> |       |       | VDDK | VSSK |           |
| H17 | IRDA_PDN     | VDD33 | VSS33 | VDDK | VSSK |           |
| G15 | IRDA_TXD     |       |       | VDDK | VSSK |           |
| G16 | IRDA_RXD     |       |       | VDDK | VSSK |           |
| G17 | KCOL6        |       |       | VDDK | VSSK |           |
| G18 | KCOL5        |       |       | VDDK | VSSK |           |
| G19 | KCOL4        |       |       | VDDK | VSSK |           |
| F15 | KCOL3        |       |       | VDDK | VSSK |           |
| F16 | KCOL2        |       |       | VDDK | VSSK |           |
| F17 | KCOL1        |       |       | VDDK | VSSK |           |
| F18 | KCOL0        |       |       | VDDK | VSSK |           |
| F19 | KROW5        |       |       | VDDK | VSSK |           |
| E16 | KROW4        |       |       | VDDK | VSSK |           |
| E17 | KROW3        |       |       | VDDK | VSSK |           |
| E18 | KROW2        |       |       | VDDK | VSSK |           |
| E19 | <b>VDD33</b> |       |       |      |      | Typ. 2.8V |
| D16 | KROW1        | VDD33 | VSS33 | VDDK | VSSK |           |
| D19 | KROW0        |       |       | VDDK | VSSK |           |
| D17 | DAICLK       |       |       | VDDK | VSSK |           |
| D18 | DAIPCMOUT    |       |       | VDDK | VSSK |           |
| C19 | DAIPCMIN     |       |       | VDDK | VSSK |           |
| C18 | DAIRST       |       |       | VDDK | VSSK |           |
| B19 | DAISYNC      |       |       | VDDK | VSSK |           |
| C17 | GPIO4        |       |       | VDDK | VSSK |           |

|     |                     |  |  |      |      |           |
|-----|---------------------|--|--|------|------|-----------|
| A19 | GPIO5               |  |  | VDDK | VSSK |           |
| A18 | GPIO6               |  |  | VDDK | VSSK |           |
| C15 | <b>AVDD_MBUF</b>    |  |  |      |      | Typ. 2.8V |
| B15 | AU_MOUTL            |  |  |      |      |           |
| A15 | AU_MOUTR            |  |  |      |      |           |
| D14 | <b>AVSS_MBUF</b>    |  |  |      |      |           |
| C14 | AU_M_BYP            |  |  |      |      |           |
| B14 | AU_FMINL            |  |  |      |      |           |
| A14 | AU_FMINR            |  |  |      |      |           |
| D13 | AU_OUT1_P           |  |  |      |      |           |
| C13 | AU_OUT1_N           |  |  |      |      |           |
| B12 | AU_OUT0_N           |  |  |      |      |           |
| B13 | <b>AVDD_BUF</b>     |  |  |      |      | Typ. 2.8V |
| A12 | AU_OUT0_P           |  |  |      |      |           |
| A13 | <b>AVSS_BUF</b>     |  |  |      |      |           |
| C12 | AU_MICBIAS_P        |  |  |      |      |           |
| D12 | AU_MICBIAS_N        |  |  |      |      |           |
| D11 | <b>AVDD_AFE</b>     |  |  |      |      | Typ. 2.8V |
| C11 | AU_VREF_N           |  |  |      |      |           |
| B11 | AU_VREF_P           |  |  |      |      |           |
| A11 | <b>AGND_AFE</b>     |  |  |      |      |           |
| D10 | AU_VIN0_P           |  |  |      |      |           |
| C10 | AU_VIN0_N           |  |  |      |      |           |
| B10 | AU_VIN1_N           |  |  |      |      |           |
| A10 | AU_VIN1_P           |  |  |      |      |           |
| E10 | <b>AVSS_AFE</b>     |  |  |      |      |           |
| D9  | BDLAQP              |  |  |      |      |           |
| C9  | BDLAQN              |  |  |      |      |           |
| E9  | <b>AGND_RFE</b>     |  |  |      |      |           |
| A9  | BDLAIN              |  |  |      |      |           |
| B9  | BDLAIP              |  |  |      |      |           |
| E8  | <b>AVSS_GSMRFTX</b> |  |  |      |      |           |
| B8  | BUPAIP              |  |  |      |      |           |
| A8  | BUPAIN              |  |  |      |      |           |
| D7  | <b>AVDD_GSMRFTX</b> |  |  |      |      | Typ. 2.8V |
| C8  | BUPAQN              |  |  |      |      |           |
| D8  | BUPAQP              |  |  |      |      |           |
| C7  | <b>AVSS_RFE</b>     |  |  |      |      |           |
| B7  | APC                 |  |  |      |      |           |
| A7  | <b>AVDD_RFE</b>     |  |  |      |      | Typ. 2.8V |
| D6  | AUXADIN0            |  |  |      |      |           |
| C6  | AUXADIN1            |  |  |      |      |           |
| B6  | AUXADIN2            |  |  |      |      |           |
| A6  | AUXADIN3            |  |  |      |      |           |
| C5  | AUXADIN4            |  |  |      |      |           |
| B5  | AUXADIN5            |  |  |      |      |           |
| A5  | AUXADIN6            |  |  |      |      |           |
| C4  | AUX_REF             |  |  |      |      |           |
| B4  | AFC                 |  |  |      |      |           |

|    |         |  |  |  |  |  |  |
|----|---------|--|--|--|--|--|--|
| A4 | AFC_BYP |  |  |  |  |  |  |
|    |         |  |  |  |  |  |  |

**Table 3** Power Descriptions

MTK Confidential Release for Techfaith

### 3 Micro-Controller Unit Subsystem

**Figure 5** illustrates the block diagram of the Micro-Controller Unit Subsystem in MT6219. The subsystem utilizes a main 32-bit ARM7EJ-S RISC processor, which plays the role of the main bus master controlling the whole subsystem. The processor communicates with all the other on-chip modules via the two-level system buses: AHB Bus and APB Bus. All bus transactions originate from bus masters, while slaves can only respond to requests from bus masters. Before data transfer can be established, bus master must ask for bus ownership. This is accomplished by request-grant handshaking protocol between masters and arbiters.

Two levels of bus hierarchy are designed to provide optimum usage for different performance requirements. Specifically, AHB Bus, the main system bus, is tailored toward high-speed requirements and provides 32-bit data path with multiplex scheme for bus interconnections. The APB bus, on the other hand, is designed to reduce interface complexity for lower data transfer rate, and so it is isolated from high bandwidth AHB Bus by APB Bridge. It supports 16-bit addressing and both 16-bit and 32-bit data paths. APB Bus is also optimized for minimal power consumption by employing gated-clock scheme.

During operation, if the target slave is located on the AHB Bus, the transaction is conducted directly on AHB Bus. However, if the target slave is a peripheral and is attached to the APB bus, then the transaction is conducted between AHB and APB bus through the use of APB Bridge.

The MT6219 MCU subsystem supports only memory addressing method, therefore all components are mapped onto MCU 32-bit address space. A Memory Management Unit is employed to allow for a central decode scheme. It generates appropriate selection signals for each memory-addressed modules on the AHB Bus.

In order to off-load the processor core, a DMA Controller is designated to act as a master and share the bus resources on AHB Bus to perform fast data movement between modules. This controller provides fourteen DMA channels.

The Interrupt Controller provides a software interface to manipulate interrupt events. It can handle up to 32 interrupt sources asserted at the same time. In general, it generates 2 levels of interrupt requests, FIQ and IRQ, to the processor.

A 512K Byte SRAM is provided as system memory for high-speed data access. For factory programming purposes, a Boot ROM module is also integrated. These two modules use the same Internal Memory Controller to connect to AHB Bus.

External Memory Interface supports both 8-bit and 16-bit devices. Since AHB Bus is 32-bit wide, all the data transfer will be converted into several 8-bit or 16-bit cycles depending on the data width of the target device. Note that, this interface supports both synchronous and asynchronous components, such as Flash, SRAM and parallel LCD. This interface supports also page and burst mode type of Flash.



**Figure 5** Block Diagram of the Micro-Controller Unit Subsystem in MT6219

## 3.1 Processor Core

### 3.1.1 General Description

The Micro-Controller Unit Subsystem in MT6219 uses the 32-bit ARM7EJ-S RISC processor that is based on the Von Neumann architecture with a single 32-bit data bus carrying both instructions and data. The memory interface of ARM7EJ-S is totally compliant to AMBA based bus system, which allows direct connection to the AHB Bus.

## 3.2 Memory Management

### 3.2.1 General Description

The processor core of MT6219 supports only memory addressing method for instruction fetch and data access. It manages a 32-bit address space that has addressing capability up to 4GB. System RAM, System ROM, Registers, MCU Peripherals and external components are all mapped onto such 32-bit address space, as depicted in **Figure 6**.

|                               |                           |              |
|-------------------------------|---------------------------|--------------|
| MCU 32-bit Addressing Space   | Reserved                  |              |
| 9FFF_FFFh<br> <br>9000_0000h  | 9800_0000h                | Reserved     |
|                               | 9000_0000h                | Virtual FIFO |
| 8FFF_FFFFh<br> <br>8000_0000h | APB Peripherals           |              |
| 7FFF_FFFFh<br> <br>7000_0000h | 7800_0000h                | LCD          |
|                               | 7000_0000h                | USB          |
| 6FFF_FFFFh<br> <br>5000_0000h | MCU-DSP Interface         |              |
| 4FFF_FFFFh<br> <br>4000_0000h | Internal Memory           |              |
| 3FFF_FFFFh<br> <br>0000_0000h | External Memroy           |              |
|                               | EA[25:0] Addressing Space |              |

**Figure 6** The Memory Layout of MT6219

The address space is organized into blocks with size of 256M Bytes each. Memory blocks 0-97FFFFFFh are defined and currently dedicated to specific functions, while the others are reserved for future usage. The block number is uniquely selected by address line A31-A28 of the internal system bus.

### 3.2.1.1 External Access

To allow external access, the MT6219 outputs 26 bits (A25-A0) of address lines along with 8 selection signals that correspond to associated memory blocks. That is, MT6219 can support up to 8 MCU addressable external components. The data width of internal system bus is fixed at 32-bit wide, while the data width of the external components can be either 8 or 16 bit.

Since devices are usually available with varied operating grades, adaptive configurations for different applications are needed. MT6219 provides software programmable registers to configure their wait-states to adapt to different operating conditions.

### 3.2.1.2 Memory Re-mapping Mechanism

To permit more flexible system configuration, a memory re-mapping mechanism is provided. It allows software program to swap BANK0 (ECS0#) and BANK1 (ECS1#) dynamically. Whenever the bit value of RM0 in register EMI\_REMAP is changed, these two banks will be swapped accordingly. Furthermore, it allows system to boot in different sequences as detailed in 3.2.1.3 Boot Sequence.

### 3.2.1.3 Boot Sequence

Since the ARM7EJ-S core always starts to fetch instructions from the lowest memory address at 00000000h after system has been reset, it is designed to have a dynamic mapping architecture capable of associating Boot Code, external Flash or external SRAM with the memory block 0000\_0000h – 07ff\_ffffh.

By default, the Boot Code is mapped onto 0000\_0000h – 07ff\_ffffh while the state of IBOOT is “0”. But, this configuration can be changed by altering the state of IBOOT before system reset, or by programming bit value of RM1 in register EMI\_REMAP directly.

MT6219 system provides two kinds of boot up scheme:

- Start up system of running codes from Boot Code for factory programming
- Start up system of running codes from external FLASH or ROM device for normal operation

#### 3.2.1.3.1 Boot Code

The Boot Code is placed together with Memory Re-Mapping Mechanism in External Memory Controller and comprises of just two words of instructions as shown below. There is a jump instruction that leads the processor to run the code starting at address of 48000000h where the System ROM is placed.

| ADDRESS   | BINARY CODE | ASSEMBLY    |
|-----------|-------------|-------------|
| 00000000h | E51FF004h   | LDR PC, 0x4 |
| 00000004h | 48000000h   | (DATA)      |

#### 3.2.1.3.2 Factory Programming

The configuration for factory programming is shown in **Figure 7**. Usually the Factory Programming Host connects with MT6219 via the UART interface. In order to have it work properly, the system should boot up from Boot Code. That is, IBOOT should be tied to GND. The download speed can be up to 921K bps while MCU is running at 26MHz.

After the system has reset, the Boot Code will guide the processor to run the Factory Programming software placed in System ROM. Then, MT6219 will start and continue to poll the UART1 port until valid information is detected. The first information received on the UART1 will be used to configure the chip for factory programming. The Flash downloader program is then transferred into System RAM or external SRAM.

Further information will be detailed in MT6219 Software Programming Specification.



**Figure 7** System configuration required for factory programming

### 3.2.1.4 Little Endian Mode

The MT6219 system always treats 32-bit words of memory in Little Endian format. In Little Endian mode, the lowest numbered byte in a word is stored in the least significant position, and the highest numbered byte in the most significant position. Byte 0 of the memory system is therefore connected to data lines 7 through 0.

## 3.3 Bus System

### 3.3.1 General Description

Two levels of bus hierarchy are employed in the Micro-Controller Unit Subsystem of MT6219. As depicted in **Figure 5**, AHB Bus and APB Bus serve as system backbone and peripheral buses, while an APB bridge connects these two buses. Both AHB and APB Buses operate at the same clock rate as processor core.

The APB Bridge is the only bus master residing on the APB bus. All APB slaves are mapped onto memory block MB8 in MCU 32-bit addressing space. A central address decoder is implemented inside the bridge to generate select signals for individual peripherals. In addition, since the base address of each APB slave has been associated with select signals, the address bus on APB will contain only the value of offset address.

The maximum address space that can be allocated to a single APB slave is 32KB, i.e. 16-bit address lines. The width of the data bus is mainly constrained to 16-bit in order to minimize the design complexity and power consumption while some uses 32-bit data bus to accommodate more bandwidth. In the case where an APB slave needs large amount of transfers, the device driver can also request DMA channels to conduct a burst of data transfer. The base address and data width of each peripheral are listed in **Table 4**.

| Base Address | Description                                                       | Data Width | Software Base ID |
|--------------|-------------------------------------------------------------------|------------|------------------|
| 8000_0000h   | Configuration Registers<br>(Clock, Power Down, Version and Reset) | 16         | CONFG Base       |
| 8001_0000h   | External Memory Interface                                         | 16         | EMI Base         |
| 8002_0000h   | Interrupt Controller                                              | 32         | CIRQ Base        |
| 8003_0000h   | DMA Controller                                                    | 32         | DMA Base         |

|            |                                    |    |              |
|------------|------------------------------------|----|--------------|
| 8004_0000h | Reset Generation Unit              | 16 | RGU Base     |
| 8005_0000h | Reserved                           |    |              |
| 8006_0000h | GPRS Cipher Unit                   | 32 | GCU Base     |
| 8007_0000h | Software Debug                     | 16 | SWDBG Base   |
| 8008_0000h | MCU Tracer                         | 32 | TRC Base     |
| 8009_0000h | NAND Flash Interface               | 32 | NFI Base     |
| 800a_0000h | Serial Camera Control Bus          | 16 | SCCB Base    |
| 8010_0000h | General Purpose Timer              | 16 | GPT Base     |
| 8011_0000h | Keypad Scanner                     | 16 | KP Base      |
| 8012_0000h | General Purpose Inputs/Outputs     | 16 | GPIO Base    |
| 8013_0000h | UART 1                             | 16 | UART1 Base   |
| 8014_0000h | SIM Interface                      | 16 | SIM Base     |
| 8015_0000h | Pulse-Width Modulation Outputs     | 16 | PWM Base     |
| 8016_0000h | Alerter Interface                  | 16 | ALTER Base   |
| 8017_0000h | Reserved                           |    |              |
| 8018_0000h | UART 2                             | 16 | UART2 Base   |
| 8019_0000h | Reserved                           |    |              |
| 801a_0000h | IrDA                               | 16 | IRDA Base    |
| 801b_0000h | UART 3                             | 16 | UART3 Base   |
| 801c_0000h | Base-Band to PMIC Serial Interface | 16 | B2PSI Base   |
| 8020_0000h | TDMA Timer                         | 16 | TDMA Base    |
| 8021_0000h | Real Time Clock                    | 16 | RTC Base     |
| 8022_0000h | Base-Band Serial Interface         | 32 | BSI Base     |
| 8023_0000h | Base-Band Parallel Interface       | 16 | BPI Base     |
| 8024_0000h | Automatic Frequency Control Unit   | 16 | AFC Base     |
| 8025_0000h | Automatic Power Control Unit       | 32 | APC Base     |
| 8026_0000h | Frame Check Sequence               | 16 | FCS Base     |
| 8027_0000h | Auxiliary ADC Unit                 | 16 | AUXADC Base  |
| 8028_0000h | Divider/Modulus Coprocessor        | 32 | DIVIDER Base |
| 8029_0000h | CSD Format Conversion Coprocessor  | 32 | CSD_ACC Base |
| 802a_0000h | MS/SD Controller                   | 32 | MSDC Base    |
| 8030_0000h | MCU-DSP Shared Register            | 16 | SHARE Base   |
| 8031_0000h | DSP Patch Unit                     | 16 | PATCH Base   |
| 8040_0000h | Audio Front End                    | 16 | AFE Base     |
| 8041_0000h | Base-Band Front End                | 16 | BFE Base     |
| 8050_0000h | Analog Chip Interface Controller   | 16 | MIXED Base   |
| 8060_0000h | JPEG Decoder                       | 32 | JPEG Base    |
| 8061_0000h | Resizer                            | 32 | RESZ Base    |
| 8062_0000h | Camera Interface                   | 32 | CAM Base     |

|            |                  |    |             |
|------------|------------------|----|-------------|
| 8063_0000h | Image Engine     | 32 | IMG Base    |
| 8064_0000h | Reserved         |    |             |
| 8065_0000h | GIF Decoder      | 32 | GIFDEC Base |
| 8066_0000h | 2D Command Queue | 32 | GCMQ Base   |
| 8067_0000h | 2D Accelerator   | 32 | G2D Base    |
| 8068_0000h | MPEG4 Codec      | 32 | MP4 Base    |
| 8069_0000h | Image DMA        | 32 | IMGDMA Base |

**Table 4** Register Base Addresses for MCU Peripherals

| REGISTER ADDRESS | REGISTER NAME             | SYNONYM |
|------------------|---------------------------|---------|
| CONFG + 0000h    | Hardware Version Register | HW_VER  |
| CONFG + 0004h    | Firmware Version Register | FW_VER  |
| CONFG + 0008h    | Hardware Code Register    | HW_CODE |
| CONFG + 0404h    | APB Bus Control Register  | APB_CON |

**Table 5** APB Bridge Register Map

### 3.3.2 Register Definitions

#### CONFG+0000h Hardware Version Register

#### HW\_VERSION

| Bit   | 15          | 14 | 13            | 12 | 11            | 10 | 9 | 8           | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------------|----|---------------|----|---------------|----|---|-------------|---|---|---|---|---|---|---|---|
| Name  | <b>EXTP</b> |    | <b>MAJREV</b> |    | <b>MINREV</b> |    |   | <b>HFIX</b> |   |   |   |   |   |   |   |   |
| Type  | RO          |    | RO            |    | RO            |    |   | RO          |   |   |   |   |   |   |   |   |
| Reset | 8           |    | A             |    | 0             |    |   | 0           |   |   |   |   |   |   |   |   |

This register is useful for software program to determine the hardware version of the chip. It will have a new value whenever each metal fix or major step is performed. All these values are incremented by a step of 1.

**HFIX** Iteration to fix a hardware bug, in case of some layer mask fixed

**MINREV** Minor Revision of the chip, in case of all layer masks changed

**MAJREV** Major Revision of the chip

**EXTP** This field shows the existence of Hardware Code Register that presents the Hardware ID while the value is other than zero.

#### CONFG+0004h Firmware Version Register

#### FW\_VERSION

| Bit   | 15          | 14 | 13            | 12 | 11            | 10 | 9 | 8           | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------------|----|---------------|----|---------------|----|---|-------------|---|---|---|---|---|---|---|---|
| Name  | <b>EXTP</b> |    | <b>MAJREV</b> |    | <b>MINREV</b> |    |   | <b>FFIX</b> |   |   |   |   |   |   |   |   |
| Type  | RO          |    | RO            |    | RO            |    |   | RO          |   |   |   |   |   |   |   |   |
| Reset | 8           |    | A             |    | 0             |    |   | 0           |   |   |   |   |   |   |   |   |

This register is useful for software program to determine the Firmware ROM version that is included in this chip. All these values are incremented by a step of 1.

**FFIX** Iteration to fix a firmware bug

**MINREV** Minor Revision of the firmware

**MAJREV** Major Revision of the firmware

**EXTP** This field shows the existence of Hardware Code Register that presents the Hardware ID when the value is other than zero.

### CONFIG+0008h Hardware Code Register

| Bit   | 15 | 14 | 13 | 12           | 11 | 10 | 9            | 8 | 7 | 6            | 5 | 4 | 3            | 2 | 1 | 0 | HW_CODE |
|-------|----|----|----|--------------|----|----|--------------|---|---|--------------|---|---|--------------|---|---|---|---------|
| Name  |    |    |    | <b>CODE3</b> |    |    | <b>CODE2</b> |   |   | <b>CODE1</b> |   |   | <b>CODE0</b> |   |   |   |         |
| Type  |    |    |    | RO           |    |    | RO           |   |   | RO           |   |   | RO           |   |   |   |         |
| Reset |    |    |    | 6            |    |    | 2            |   |   | 1            |   |   | 9            |   |   |   |         |

This register presents the Hardware ID.

**CODE** This version of chip is coded as 6219h.

### CONFIG+0404h APB Bus Control Register

| Bit   | 15 | 14 | 13 | 12           | 11 | 10 | 9            | 8            | 7            | 6            | 5            | 4 | 3            | 2 | 1            | 0            | APB_CON      |              |              |
|-------|----|----|----|--------------|----|----|--------------|--------------|--------------|--------------|--------------|---|--------------|---|--------------|--------------|--------------|--------------|--------------|
| Name  |    |    |    | <b>APBW6</b> |    |    | <b>APBW4</b> | <b>APBW3</b> | <b>APBW2</b> | <b>APBW1</b> | <b>APBW0</b> |   | <b>APBR6</b> |   | <b>APBR4</b> | <b>APBR3</b> | <b>APBR2</b> | <b>APBR1</b> | <b>APBR0</b> |
| Type  |    |    |    | R/W          |    |    | R/W          | R/W          | R/W          | R/W          | R/W          |   | R/W          |   | R/W          | R/W          | R/W          | R/W          |              |
| Reset |    |    |    | 0            |    |    | 0            | 0            | 0            | 0            | 0            |   | 1            |   | 1            | 1            | 1            | 1            |              |

This register is used to control the timing of Read Cycle and Write Cycle on APB Bus. Note that APB Bridge 5 is different from other bridges. The access time is varied, and access is not completed until acknowledge signal from APB slave is asserted.

**APBR0-APBR6** Read Access Time on APB Bus

- 0** 1-Cycle Access
- 1** 2-Cycle Access

**APBW0-APBW6** Write Access Time on APB Bus

- 0** 1-Cycle Access
- 1** 2-Cycle Access

## 3.4 Direct Memory Access

### 3.4.1 General Description

A generic DMA Controller is placed on Layer 2 AHB Bus to support fast data transfers, and also to off-load the processor. With this controller, specific devices on AHB or APB buses can benefit greatly from quick completion of data movement from or to memory module such as Internal System RAM or External SRAM. Such Generic DMA Controller can also be used to connect any two devices other than memory module as long as they can be addressed in memory space.



**Figure 8** Variety Data Paths of DMA Transfers

Up to fourteen channels of simultaneous data transfer are supported. Each channel has a similar set of registers to be configured to different scheme as desired. If more than fourteen devices are requesting the DMA resources at the same time, software based arbitration should be employed. Once the service candidate is decided, the responsible device driver should configure the Generic DMA Controller properly in order to conduct DMA transfers. Both Interrupt and Polling based schemes in handling the completion event are supported. The block diagram of such generic DMA Controller is illustrated in **Figure 9**.



**Figure 9** Block Diagram of Direct memory Access Module

### 3.4.1.1 Full-Size & Half-Size DMA Channels

There are three types of DMA channels in the DMA controller. The first one is called full-size DMA channel, the second one is called half-size DMA channel, and the last one is Virtual FIFO DMA. Channel 1 to 3 are full-size DMA channels, channel 4 to 10 are half-size ones, and channel 11 to 14 are Virtual FIFO DMAs. The difference between the first two types of DMA channels is that both source and destination address are programmable in full-size DMA channels, but only one side of address can be programmed in half-size DMA channel. In half-size channels, only either the source or destination address can be programmed, while the addresses of the other side is preset. Which preset address is used depends on the setting of MAS in DMA Channel Control Register. Please refer to Register Definition section for more detail.

### 3.4.1.2 Ring Buffer & Double Buffer Memory Data Movement

DMA channel 1-10 support ring-buffer and double-buffer memory data movement. This can be achieved by programming DMA\_WPPT and DMA\_WPTO, as well as setting WPEN in DMA\_CON register to enable. **Figure 10** illustrates how this function works. Once transfer counter reaches the value of WPPT, next address will jump to WPTO address after completing data transfer of WPPT. Note that only one side can be configured as ring-buffer or double-buffer memory, and this is controlled by WPSD in DMA\_CON register.



**Figure 10** Ring Buffer and double Buffer Memory Data Movement

### 3.4.1.3 Unaligned Word Access

The address of word access on AHB bus must be aligned to word boundary, or the 2 LSB will be truncated to 00b. If programmers do not notice this, it may cause incorrect data fetch. In the case where data is to be moved from unaligned addresses to aligned addresses, the word is usually first split into four bytes and then moved by byte. This causes four read and four write transfers on the bus.

To improve bus efficiency, unaligned-word access is provided in DMA 4-10. While this function is enabled, DMAs move data from unaligned address to aligned address by executing four continuous byte-read access and one word-write access. This reduces three transfers on the bus.



Figure 11 unaligned word accesses

#### 3.4.1.4 Virtual FIFO DMA

Virtual FIFO DMA is used to ease UART control. The difference between the Virtual FIFO DMAs and the ordinary DMAs is that Virtual FIFO DMA contains additional FIFO controller. The read and write pointer are kept in the Virtual FIFO DMA. During READ from the FIFO, the read pointer points to the address of the next data. During WRITE to the fifo, the write pointer moves to the next address. If the FIFO is empty, FIFO read will not be allowed. Similarly, data will not be written into the FIFO if the FIFO is full. Due to requirement of UART flow control, an alert length shall be programmed. Once the FIFO Space is less than this value, an alert signal will be issued to enable UART flow control. What kind of flow control will be performed depends on the setting in UART.

Each Virtual FIFO DMA can be programmed as RX or TX FIFO. This depends on the setting of DIR in DMA\_CON register. If DIR is "0"(READ), it means TX FIFO. On the other hand, if DIR is "1"(WRITE), the Virtual FIFO DMA is specified as a RX FIFO.

Virtual FIFO DMA provides an interrupt to MCU. This interrupt is to inform MCU that there are data in the FIFO, and the amount of data is over or under the value defined in DMA\_COUNT register. With this, MCU does not need to poll DMA to know when it needs to remove the data from FIFO or put data into FIFO.

Note that Virtual FIFO DMAs cannot be used as generic DMAs, i.e. DMA1-10.



Figure 12 Virtual FIFO DMA

| DMA number | Address of Virtual FIFO Access Port | Associated UART        |
|------------|-------------------------------------|------------------------|
| DMA11      | 7800_0000h                          | UART1 RX / ALL UART TX |
| DMA12      | 7800_0100h                          | UART2 RX / ALL UART TX |
| DMA13      | 7800_0200h                          | UART3 RX / ALL UART TX |
| DMA14      | 7800_0300h                          | ALL UART TX            |

**Table 6** Virtual FIFO Access Port

| DMA number | Type         | Ring Buffer | Two Buffer | Burst Mode | Unaligned Word Access |
|------------|--------------|-------------|------------|------------|-----------------------|
| DMA1       | Full Size    | •           | •          | •          |                       |
| DMA2       | Full Size    | •           | •          | •          |                       |
| DMA3       | Full Size    | •           | •          | •          |                       |
| DMA4       | Half Size    | •           | •          | •          | •                     |
| DMA5       | Half Size    | •           | •          | •          | •                     |
| DMA6       | Half Size    | •           | •          | •          | •                     |
| DMA7       | Half Size    | •           | •          | •          | •                     |
| DMA8       | Half Size    | •           | •          | •          | •                     |
| DMA9       | Half Size    | •           | •          | •          | •                     |
| DMA10      | Half Size    | •           | •          | •          | •                     |
| DMA11      | Virtual FIFO | •           |            |            |                       |
| DMA12      | Virtual FIFO | •           |            |            |                       |
| DMA13      | Virtual FIFO | •           |            |            |                       |
| DMA14      | Virtual FIFO | •           |            |            |                       |

**Table 7** Function list of DMA channels

| REGISTER ADDRESS | REGISTER NAME                                      | SYNONYM      |
|------------------|----------------------------------------------------|--------------|
| DMA + 0000h      | DMA Global Status Register                         | DMA_GLBSTA   |
| DMA + 0100h      | DMA Channel 1 Source Address Register              | DMA1_SRC     |
| DMA + 0104h      | DMA Channel 1 Destination Address Register         | DMA1_DST     |
| DMA + 0108h      | DMA Channel 1 Wrap Point Address Register          | DMA1_WPPT    |
| DMA + 010Ch      | DMA Channel 1 Wrap To Address Register             | DMA1_WPTO    |
| DMA + 0110h      | DMA Channel 1 Transfer Count Register              | DMA1_COUNT   |
| DMA + 0114h      | DMA Channel 1 Control Register                     | DMA1_CON     |
| DMA + 0118h      | DMA Channel 1 Start Register                       | DMA1_START   |
| DMA + 011Ch      | DMA Channel 1 Interrupt Status Register            | DMA1_INTSTA  |
| DMA + 0120h      | DMA Channel 1 Interrupt Acknowledge Register       | DMA1_ACKINT  |
| DMA + 0124h      | DMA Channel 1 Remaining Length of Current Transfer | DMA1_RLCT    |
| DMA + 0128h      | DMA Channel 1 Bandwidth Limiter Register           | DMA1_LIMITER |
| DMA + 0200h      | DMA Channel 2 Source Address Register              | DMA2_SRC     |
| DMA + 0204h      | DMA Channel 2 Destination Address Register         | DMA2_DST     |

|             |                                                    |              |
|-------------|----------------------------------------------------|--------------|
| DMA + 0208h | DMA Channel 2 Wrap Point Address Register          | DMA2_WPPT    |
| DMA + 020Ch | DMA Channel 2 Wrap To Address Register             | DMA2_WPTO    |
| DMA + 0210h | DMA Channel 2 Transfer Count Register              | DMA2_COUNT   |
| DMA + 0214h | DMA Channel 2 Control Register                     | DMA2_CON     |
| DMA + 0218h | DMA Channel 2 Start Register                       | DMA2_START   |
| DMA + 021Ch | DMA Channel 2 Interrupt Status Register            | DMA2_INTSTA  |
| DMA + 0220h | DMA Channel 2 Interrupt Acknowledge Register       | DMA2_ACKINT  |
| DMA + 0224h | DMA Channel 2 Remaining Length of Current Transfer | DMA2_RLCT    |
| DMA + 0228h | DMA Channel 2 Bandwidth Limiter Register           | DMA2_LIMITER |
| DMA + 0300h | DMA Channel 3 Source Address Register              | DMA3_SRC     |
| DMA + 0304h | DMA Channel 3 Destination Address Register         | DMA3_DST     |
| DMA + 0308h | DMA Channel 3 Wrap Point Address Register          | DMA3_WPPT    |
| DMA + 030Ch | DMA Channel 3 Wrap To Address Register             | DMA3_WPTO    |
| DMA + 0310h | DMA Channel 3 Transfer Count Register              | DMA3_COUNT   |
| DMA + 0314h | DMA Channel 3 Control Register                     | DMA3_CON     |
| DMA + 0318h | DMA Channel 3 Start Register                       | DMA3_START   |
| DMA + 031Ch | DMA Channel 3 Interrupt Status Register            | DMA3_INTSTA  |
| DMA + 0320h | DMA Channel 3 Interrupt Acknowledge Register       | DMA3_ACKINT  |
| DMA + 0324h | DMA Channel 3 Remaining Length of Current Transfer | DMA3_RLCT    |
| DMA + 0328h | DMA Channel 3 Bandwidth Limiter Register           | DMA3_LIMITER |
| DMA + 0408h | DMA Channel 4 Wrap Point Address Register          | DMA4_WPPT    |
| DMA + 040Ch | DMA Channel 4 Wrap To Address Register             | DMA4_WPTO    |
| DMA + 0410h | DMA Channel 4 Transfer Count Register              | DMA4_COUNT   |
| DMA + 0414h | DMA Channel 4 Control Register                     | DMA4_CON     |
| DMA + 0418h | DMA Channel 4 Start Register                       | DMA4_START   |
| DMA + 041Ch | DMA Channel 4 Interrupt Status Register            | DMA4_INTSTA  |
| DMA + 0420h | DMA Channel 4 Interrupt Acknowledge Register       | DMA4_ACKINT  |
| DMA + 0424h | DMA Channel 4 Remaining Length of Current Transfer | DMA4_RLCT    |
| DMA + 0428h | DMA Channel 4 Bandwidth Limiter Register           | DMA4_LIMITER |
| DMA + 042Ch | DMA Channel 4 Programmable Address Register        | DMA4_PGMADDR |
| DMA + 0508h | DMA Channel 5 Wrap Point Address Register          | DMA5_WPPT    |
| DMA + 050Ch | DMA Channel 5 Wrap To Address Register             | DMA5_WPTO    |
| DMA + 0510h | DMA Channel 5 Transfer Count Register              | DMA5_COUNT   |
| DMA + 0514h | DMA Channel 5 Control Register                     | DMA5_CON     |
| DMA + 0518h | DMA Channel 5 Start Register                       | DMA5_START   |
| DMA + 051Ch | DMA Channel 5 Interrupt Status Register            | DMA5_INTSTA  |
| DMA + 0520h | DMA Channel 5 Interrupt Acknowledge Register       | DMA5_ACKINT  |
| DMA + 0524h | DMA Channel 5 Remaining Length of Current Transfer | DMA5_RLCT    |
| DMA + 0528h | DMA Channel 5 Bandwidth Limiter Register           | DMA5_LIMITER |

|             |                                                    |              |
|-------------|----------------------------------------------------|--------------|
| DMA + 052Ch | DMA Channel 5 Programmable Address Register        | DMA5_PGMADDR |
| DMA + 0608h | DMA Channel 6 Wrap Point Address Register          | DMA6_WPPT    |
| DMA + 060Ch | DMA Channel 6 Wrap To Address Register             | DMA6_WPTO    |
| DMA + 0610h | DMA Channel 6 Transfer Count Register              | DMA6_COUNT   |
| DMA + 0614h | DMA Channel 6 Control Register                     | DMA6_CON     |
| DMA + 0618h | DMA Channel 6 Start Register                       | DMA6_START   |
| DMA + 061Ch | DMA Channel 6 Interrupt Status Register            | DMA6_INTSTA  |
| DMA + 0620h | DMA Channel 6 Interrupt Acknowledge Register       | DMA6_ACKINT  |
| DMA + 0624h | DMA Channel 6 Remaining Length of Current Transfer | DMA6_RLCT    |
| DMA + 0628h | DMA Channel 6 Bandwidth Limiter Register           | DMA6_LIMITER |
| DMA + 062Ch | DMA Channel 6 Programmable Address Register        | DMA6_PGMADDR |
| DMA + 0708h | DMA Channel 7 Wrap Point Address Register          | DMA7_WPPT    |
| DMA + 070Ch | DMA Channel 7 Wrap To Address Register             | DMA7_WPTO    |
| DMA + 0710h | DMA Channel 7 Transfer Count Register              | DMA7_COUNT   |
| DMA + 0714h | DMA Channel 7 Control Register                     | DMA7_CON     |
| DMA + 0718h | DMA Channel 7 Start Register                       | DMA7_START   |
| DMA + 071Ch | DMA Channel 7 Interrupt Status Register            | DMA7_INTSTA  |
| DMA + 0720h | DMA Channel 7 Interrupt Acknowledge Register       | DMA7_ACKINT  |
| DMA + 0724h | DMA Channel 7 Remaining Length of Current Transfer | DMA7_RLCT    |
| DMA + 0728h | DMA Channel 7 Bandwidth Limiter Register           | DMA7_LIMITER |
| DMA + 072Ch | DMA Channel 7 Programmable Address Register        | DMA7_PGMADDR |
| DMA + 0808h | DMA Channel 8 Wrap Point Address Register          | DMA8_WPPT    |
| DMA + 080Ch | DMA Channel 8 Wrap To Address Register             | DMA8_WPTO    |
| DMA + 0810h | DMA Channel 8 Transfer Count Register              | DMA8_COUNT   |
| DMA + 0814h | DMA Channel 8 Control Register                     | DMA8_CON     |
| DMA + 0818h | DMA Channel 8 Start Register                       | DMA8_START   |
| DMA + 081Ch | DMA Channel 8 Interrupt Status Register            | DMA8_INTSTA  |
| DMA + 0820h | DMA Channel 8 Interrupt Acknowledge Register       | DMA8_ACKINT  |
| DMA + 0824h | DMA Channel 8 Remaining Length of Current Transfer | DMA8_RLCT    |
| DMA + 0828h | DMA Channel 8 Bandwidth Limiter Register           | DMA8_LIMITER |
| DMA + 082Ch | DMA Channel 8 Programmable Address Register        | DMA8_PGMADDR |
| DMA + 0908h | DMA Channel 9 Wrap Point Address Register          | DMA9_WPPT    |
| DMA + 090Ch | DMA Channel 9 Wrap To Address Register             | DMA9_WPTO    |
| DMA + 0910h | DMA Channel 9 Transfer Count Register              | DMA9_COUNT   |
| DMA + 0914h | DMA Channel 9 Control Register                     | DMA9_CON     |
| DMA + 0918h | DMA Channel 9 Start Register                       | DMA9_START   |
| DMA + 091Ch | DMA Channel 9 Interrupt Status Register            | DMA9_INTSTA  |
| DMA + 0920h | DMA Channel 9 Interrupt Acknowledge Register       | DMA9_ACKINT  |
| DMA + 0924h | DMA Channel 9 Remaining Length of Current Transfer | DMA9_RLCT    |

|             |                                                     |               |
|-------------|-----------------------------------------------------|---------------|
| DMA + 0928h | DMA Channel 9 Bandwidth Limiter Register            | DMA9_LIMITER  |
| DMA + 092Ch | DMA Channel 9 Programmable Address Register         | DMA9_PGMADDR  |
| DMA + 0A08h | DMA Channel 10 Wrap Point Address Register          | DMA10_WPPT    |
| DMA + 0A0Ch | DMA Channel 10 Wrap To Address Register             | DMA10_WPTO    |
| DMA + 0A10h | DMA Channel 10 Transfer Count Register              | DMA10_COUNT   |
| DMA + 0A14h | DMA Channel 10 Control Register                     | DMA10_CON     |
| DMA + 0A18h | DMA Channel 10 Start Register                       | DMA10_START   |
| DMA + 0A1Ch | DMA Channel 10 Interrupt Status Register            | DMA10_INTSTA  |
| DMA + 0A20h | DMA Channel 10 Interrupt Acknowledge Register       | DMA10_ACKINT  |
| DMA + 0A24h | DMA Channel 10 Remaining Length of Current Transfer | DMA10_RLCT    |
| DMA + 0A28h | DMA Channel 10 Bandwidth Limiter Register           | DMA10_LIMITER |
| DMA + 0A2Ch | DMA Channel 10 Programmable Address Register        | DMA10_PGMADDR |
| DMA + 0B10h | DMA Channel 11 Transfer Count Register              | DMA11_COUNT   |
| DMA + 0B14h | DMA Channel 11 Control Register                     | DMA11_CON     |
| DMA + 0B18h | DMA Channel 11 Start Register                       | DMA11_START   |
| DMA + 0B1Ch | DMA Channel 11 Interrupt Status Register            | DMA11_INTSTA  |
| DMA + 0B20h | DMA Channel 11 Interrupt Acknowledge Register       | DMA11_ACKINT  |
| DMA + 0B28h | DMA Channel 11 Bandwidth Limiter Register           | DMA11_LIMITER |
| DMA + 0B2Ch | DMA Channel 11 Programmable Address Register        | DMA11_PGMADDR |
| DMA + 0B30h | DMA Channel 11 Write Pointer                        | DMA11_WRPTR   |
| DMA + 0B34h | DMA Channel 11 Read Pointer                         | DMA11_RDPTR   |
| DMA + 0B38h | DMA Channel 11 FIFO Count                           | DMA11_FFCNT   |
| DMA + 0B3Ch | DMA Channel 11 FIFO Status                          | DMA11_FFSTA   |
| DMA + 0B40h | DMA Channel 11 Alert Length                         | DMA11_ALTLEN  |
| DMA + 0B44h | DMA Channel 11 FIFO Size                            | DMA11_FFSIZE  |
| DMA + 0C10h | DMA Channel 12 Transfer Count Register              | DMA12_COUNT   |
| DMA + 0C14h | DMA Channel 12 Control Register                     | DMA12_CON     |
| DMA + 0C18h | DMA Channel 12 Start Register                       | DMA12_START   |
| DMA + 0C1Ch | DMA Channel 12 Interrupt Status Register            | DMA12_INTSTA  |
| DMA + 0C20h | DMA Channel 12 Interrupt Acknowledge Register       | DMA12_ACKINT  |
| DMA + 0C28h | DMA Channel 12 Bandwidth Limiter Register           | DMA12_LIMITER |
| DMA + 0C2Ch | DMA Channel 12 Programmable Address Register        | DMA12_PGMADDR |
| DMA + 0C30h | DMA Channel 12 Write Pointer                        | DMA12_WRPTR   |
| DMA + 0C34h | DMA Channel 12 Read Pointer                         | DMA12_RDPTR   |
| DMA + 0C38h | DMA Channel 12 FIFO Count                           | DMA12_FFCNT   |
| DMA + 0C3Ch | DMA Channel 12 FIFO Status                          | DMA12_FFSTA   |
| DMA + 0C40h | DMA Channel 12 Alert Length                         | DMA12_ALTLEN  |
| DMA + 0C44h | DMA Channel 12 FIFO Size                            | DMA12_FFSIZE  |
| DMA + 0D10h | DMA Channel 13 Transfer Count Register              | DMA13_COUNT   |

|             |                                               |               |
|-------------|-----------------------------------------------|---------------|
| DMA + 0D14h | DMA Channel 13 Control Register               | DMA13_CON     |
| DMA + 0D18h | DMA Channel 13 Start Register                 | DMA13_START   |
| DMA + 0D1Ch | DMA Channel 13 Interrupt Status Register      | DMA13_INTSTA  |
| DMA + 0D20h | DMA Channel 13 Interrupt Acknowledge Register | DMA13_ACKINT  |
| DMA + 0D28h | DMA Channel 13 Bandwidth Limiter Register     | DMA13_LIMITER |
| DMA + 0D2Ch | DMA Channel 13 Programmable Address Register  | DMA13_PGMADDR |
| DMA + 0D30h | DMA Channel 13 Write Pointer                  | DMA13_WRPTR   |
| DMA + 0D34h | DMA Channel 13 Read Pointer                   | DMA13_RDPTR   |
| DMA + 0D38h | DMA Channel 13 FIFO Count                     | DMA13_FFCNT   |
| DMA + 0D3Ch | DMA Channel 13 FIFO Status                    | DMA13_FFSTA   |
| DMA + 0D40h | DMA Channel 13 Alert Length                   | DMA13_ALTLEN  |
| DMA + 0D44h | DMA Channel 13 FIFO Size                      | DMA13_FFSIZE  |
| DMA + 0E10h | DMA Channel 14 Transfer Count Register        | DMA14_COUNT   |
| DMA + 0E14h | DMA Channel 14 Control Register               | DMA14_CON     |
| DMA + 0E18h | DMA Channel 14 Start Register                 | DMA14_START   |
| DMA + 0E1Ch | DMA Channel 14 Interrupt Status Register      | DMA14_INTSTA  |
| DMA + 0E20h | DMA Channel 14 Interrupt Acknowledge Register | DMA14_ACKINT  |
| DMA + 0E28h | DMA Channel 14 Bandwidth Limiter Register     | DMA14_LIMITER |
| DMA + 0E2Ch | DMA Channel 14 Programmable Address Register  | DMA14_PGMADDR |
| DMA + 0E30h | DMA Channel 14 Write Pointer                  | DMA14_WRPTR   |
| DMA + 0E34h | DMA Channel 14 Read Pointer                   | DMA14_RDPTR   |
| DMA + 0E38h | DMA Channel 14 FIFO Count                     | DMA14_FFCNT   |
| DMA + 0E3Ch | DMA Channel 14 FIFO Status                    | DMA14_FFSTA   |
| DMA + 0E40h | DMA Channel 14 Alert Length                   | DMA14_ALTLEN  |
| DMA + 0E44h | DMA Channel 14 FIFO Size                      | DMA14_FFSIZE  |
|             |                                               |               |

**Table 8 DMA Controller Register Map**

### 3.4.2 Register Definitions

Registers programming tips,

- Start registers shall be cleared, when associated channels are being programmed.
- PGMADDR, i.e. programmable address, only exists in half-size DMA channels. If DIR in Control Register is high, PGMADDR represents Destination Address. Conversely, If DIR in Control Register is low, PGMADDR represents Source Address.
- Functions of ring-buffer & double-buffer memory data movement can be activated in either source side or destination side by programming DMA\_WPPT & and DMA\_WPTO, as well as setting WPEN in DMA\_CON register high. WPSD in DMA\_CON register determines the activated side.

**DMA+0000h DMA Global Status Register**
**DMA\_GLBSTA**

| Bit   | 31  | 30   | 29  | 28   | 27   | 26        | 25   | 24        | 23   | 22        | 21   | 20        | 19   | 18        | 17  | 16   |
|-------|-----|------|-----|------|------|-----------|------|-----------|------|-----------|------|-----------|------|-----------|-----|------|
| Name  |     |      |     |      | IT14 | RUN1<br>4 | IT13 | RUN1<br>3 | IT12 | RUN1<br>2 | IT11 | RUN1<br>1 | IT10 | RUN1<br>0 | IT9 | RUN9 |
| Type  |     |      |     |      | RO   | RO        | RO  | RO   |
| Reset |     |      |     |      | 0    | 0         | 0    | 0         | 0    | 0         | 0    | 0         | 0    | 0         | 0   | 0    |
| Bit   | 15  | 14   | 13  | 12   | 11   | 10        | 9    | 8         | 7    | 6         | 5    | 4         | 3    | 2         | 1   | 0    |
| Name  | IT8 | RUN8 | IT7 | RUN7 | IT6  | RUN6      | IT5  | RUN5      | IT4  | RUN4      | IT3  | RUN3      | IT2  | RUN2      | IT1 | RUN1 |
| Type  | RO  | RO   | RO  | RO   | RO   | RO        | RO   | RO        | RO   | RO        | RO   | RO        | RO   | RO        | RO  | RO   |
| Reset | 0   | 0    | 0   | 0    | 0    | 0         | 0    | 0         | 0    | 0         | 0    | 0         | 0    | 0         | 0   | 0    |

This register helps software program being well aware of the global status of DMA channels.

**RUN<sub>n</sub>** DMA channel n status

- 0 Channel n is stopped or has completed the transfer already.
- 1 Channel n is currently running.

**IT<sub>n</sub>** Interrupt status for channel n

- 0 No interrupt is generated.
- 1 An interrupt is pending and waiting for service.

**DMA+0n00h DMA Channel n Source Address Register**
**DMA<sub>n</sub>\_SRC**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The above registers contain the base or current source address that the DMA channel is currently operating on. Writing to this register specifies the base address of transfer source for a DMA channel. Before programming these registers, the software program should make sure that STR in DMA<sub>n</sub>\_START is set to '0', that is, the DMA channel is stopped and disabled completely. Otherwise, the DMA channel may run out of order. Reading this register returns the address value that the DMA is reading from.

Note that n is from 1 to 3.

**SRC** SRC[31:0] specifies the base or current address of transfer source for a DMA channel, i.e. channel 1, 2 or 3

**WRITE** base address of transfer source

**READ** the address DMA is reading from

**DMA+0n04h DMA Channel n Destination Address Register**
**DMA<sub>n</sub>\_DST**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The above registers contain the base or current destination address that the DMA channel is currently operating on.. Writing to this register specifies the base address of the transfer destination for a DMA channel. Before programming these registers, the software should make sure that STR in DMA<sub>n</sub>\_START is set to ‘0’, that is, the DMA channel is stopped and disabled completely. Otherwise, the DMA channel may run out of order. Reading this register returns the address value that the DMA is writing to.

Note that n is from 1 to 3.

**DST** DST[31:0] specifies the base or current address of transfer destination for a DMA channel, i.e. channel 1, 2 or 3.

**WRITE** base address of transfer destination

**READ** the address DMA is writing to

### DMA+0n08h DMA Channel n Wrap Point Count Register

| Bit        | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit        | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| WPPT[15:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| R/W        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

### DMA<sub>n</sub>\_WPPT

The above registers are to specify the address of the jump point of a given DMA transfer to support ring buffer or double buffer style memory accesses. To enable this function, two control bits, WPEN and WPSD, in DMA control register should be programmed. See the following register description for more details. If the address counter in the DMA engine matches this value, an address jump will occurs, and the next address will be the address specified in DMA<sub>n</sub>\_WPTO. Before programming these registers, the software should make sure that STR in DMA<sub>n</sub>\_START is set to ‘0’, that is the DMA channel is stopped and disabled completely. Otherwise, the DMA channel may run out of order. To enable this function, WPEN in DMA\_CON should be set.

Note that n is from 1 to 10.

**WPPT** WPPT[15:0] specifies the amount of the transfer count from start to jumping point for a DMA channel, i.e. channel 1 – 10.

**WRITE** the address of the jump point.

**READ** the same as what you fill in.

### DMA+0n0Ch DMA Channel n Wrap To Address Register

### DMA<sub>n</sub>\_WPTO

| Bit         | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| WPTO[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 0           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| WPTO[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 0           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The above registers are to specify the address of the jump destination of a given DMA transfer to support ring buffer or double buffer style memory accesses. To enable this function, two control bit, WPEN and WPSD, in DMA control register should be programmed. See the following register description for more details. Before programming these registers, the software should make sure that STR in DMA<sub>n</sub>\_START is set to ‘0’, that is the DMA channel is stopped and disabled

completely. Otherwise, the DMA channel may run out of order. To enable this function, WPEN in DMA\_CON should be set.

Note that n is from 1 to 10.

**WPTO** WPTO[31:0] specifies the address of the jump point for a DMA channel, i.e. channel 1 – 10.

**WRITE** the address of the jump destination.

**READ** the same as what you fill in.

### DMA+0n10h DMA Channel n Transfer Count Register DMAAn\_COUNT

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0   |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | LEN |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0   |

This register specifies the amount of total transfer count that the DMA channel is required to perform. Upon completion, the DMA channel generates an interrupt request to the processor while ITEN in DMAAn\_CON is set as ‘1’. Note that the total size of data being transferred by a DMA channel is determined by LEN together with the SIZE in DMAAn\_CON, i.e. LEN x SIZE.

For virtual FIFO DMA, this register is used to configure the RX threshold and TX threshold. Interrupt is triggered while FIFO count >= RX threshold in RX path or FIFO count =< TX threshold in TX path. Note that ITEN bit in DMA\_CON register shall be set, or no interrupt will be issued.

Note that n is from 1 to 14.

**LEN** The amount of total transfer count

### DMA+0n14h DMA Channel n Control Register DMAAn\_CON

| Bit   | 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17    | 16  |      |      |      |      |
|-------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|-----|------|------|------|------|
| Name  |      |    |    |    |    |    |    |    |    |    |    |    |    |    |       | DIR | WPEN | WPSD |      |      |
| Type  |      |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W   | R/W | R/W  |      |      |      |
| Reset |      |    |    |    |    |    |    |    |    |    |    |    |    |    | 0     | 0   | 0    |      |      |      |
| Bit   | 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1     | 0   |      |      |      |      |
| Name  | ITEN |    |    |    |    |    |    |    |    |    |    |    |    |    | BURST | B2W | DRQ  | DINC | SINC | SIZE |
| Type  | R/W  |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W   | R/W | R/W  | R/W  | R/W  |      |
| Reset | 0    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0     | 0   | 0    | 0    | 0    |      |

This register contains all the available control schemes for a DMA channel that is ready for software programmer to configure with. Note that all these fields cannot be changed while DMA transfer is in progress or unexpected situation may occur.

Note that n is from 1 to 14.

**SIZE** Data size within the confine of a bus cycle per transfer

These bits confines the data transfer size between source and destination to the specified value for individual bus cycle. The size is in terms of byte and has maximum value of 4 bytes. It is mainly decided by the data width of a DMA master.

**00** Byte transfer/1 byte

- 01** Half-word transfer/2 bytes
  - 10** Word transfer/4 bytes
  - 11** Reserved
- SINC** Incremental source address. Source addresses increase every transfer. If the setting of SIZE is Byte, Source addresses increase by 1 every single transfer. If Half-Word, increase by 2; and if Word, increase by 4.
- 0** Disable
  - 1** Enable
- DINC** Incremental destination address. Destination addresses increase every transfer. If the setting of SIZE is Byte, Destination addresses increase by 1 every single transfer. If Half-Word, increase by 2; and if Word, increase by 4.
- 0** Disable
  - 1** Enable
- DREQ** Throttle and handshake control for DMA transfer
- 0** No throttle control during DMA transfer or transfers occurred only between memories
  - 1** Hardware handshake management
    - The DMA master is able to throttle down the transfer rate by way of request-grant handshake.
- B2W** Word to Byte or Byte to Word transfer for the applications of transferring non-word-aligned-address data to word-aligned-address data. Note that BURST shall be set to 4-beat/8-beat/16-beat burst while enabling this function, and the SIZE shall be set to Byte.  
**NO effect on channel 1 – 3 & 11 - 14.**
- 0** Disable
  - 1** Enable
- BURST** Transfer Type. Burst-type transfers have better bus efficiency. Mass data movement is recommended to use this kind of transfer. However, note that burst-type transfer will not stop until all of the beats in a burst are completed or transfer length is reached. FIFO threshold of peripherals shall be configured carefully while you use it to move data from/to the peripherals.
- What transfer type can be used is restricted by the SIZE. If SIZE is 00b, i.e. byte transfer, all of the four transfer types can be used. If SIZE is 01b, i.e. half-word transfer, 16-beat incrementing burst cannot be used. If SIZE is 10b, i.e. byte transfer, only single and 4-beat incrementing burst can be used.
- NO effect on channel 11 - 14.**
- 000** Single
  - 001** Reserved
  - 010** 4-beat incrementing burst
  - 011** Reserved
  - 100** 8-beat incrementing burst
  - 101** Reserved
  - 110** 16-beat incrementing burst
  - 111** Reserved
- ITEM** DMA transfer completion interrupt enable.
- 0** Disable
  - 1** Enable
- WPSD** The side using address-wrapping function. Only one side of a DMA channel can activate address-wrapping function at a time.  
**NO effect on channel 11 - 14.**
- 0** address-wrapping on source

**1** address-wrapping on destination

**WPEN** Address-wrapping for ring buffer. The next address of DMA jumps to WRAP TO address when current address matches WRAP POINT count.

**NO effect on channel 11 - 14.**

**0** Disable

**1** Enable

**DIR** the directions of DMA transfer for half-size and Virtual FIFO DMA channels, i.e. channel 4 – 14. The direction is from the perspective of the DMA masters. WRITE means read from master and then write to the address specified in DMA\_PGMADDR, and vice versa.

**NO effect on channel 1 - 3.**

**0** Read

**1** Write

**MAS** Master selection. Specifies which master occupies this DMA channel. Once assigned to certain master, corresponding DREQ and DACK will be connected. For half-size and Virtual FIFO DMA channels, i.e. channel 4 – 14, a predefined address will be assigned as well.

**00000** SIM

**00001** MSDC

**00010** IrDA TX

**00011** IrDA RX

**00100** USB1 Write

**00101** USB1 Read

**00110** USB2 Write

**00111** USB2 Read

**01000** UART1 TX

**01001** UART1 RX

**01010** UART2 TX

**01011** UART2 RX

**01100** UART3 TX

**01101** UART3 RX

**01110** DSP-DMA

**01111** NFI TX

**10000** NFI RX

**OTHERS** Reserved

**DMA+0x18h DMA Channel n Start Register DMA<sub>n</sub>\_START**

| Bit   | 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | STR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

This register controls the activity of a DMA channel. Note that prior to setting STR to “1”, all the configurations should be done by giving proper value to the registers. Note also that once the STR is set to “1”, the hardware will not clear it

automatically no matter if the DMA channel accomplishes the DMA transfer or not. Put in another way, the value of **STR** stay as “1” regardless of the completion of DMA transfer. Therefore, the software program should be sure to clear **STR** to “0” before restarting another DMA transfer.

Note that n is from 1 to 14.

**STR** Start control for a DMA channel

0 The DMA channel is stopped

1 The DMA channel is started and running

#### DMA+0n1Ch DMA Channel n Interrupt Status Register

#### DMA<sub>n</sub>\_INTSTA

|       |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>INT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

This register shows the interrupt status of a DMA channel. It has the same value as DMA\_GLBSTA.

Note that n is from 1 to 14.

**INT** Interrupt Status for DMA Channel

0 No interrupt request is generated.

1 One interrupt request is pending and waiting for service

#### DMA+0n20h DMA Channel n Interrupt Acknowledge Register

#### DMA<sub>n</sub>\_ACKINT

|       |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>ACK</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

This register is used to acknowledge the current interrupt request associated with the completion event of a DMA channel by software program. Note that this is a write-only register, and any read to it will return a value of “0”.

Note that n is from 1 to 14.

**ACK** Interrupt acknowledge for the DMA channel

0 No effect

1 Interrupt request is acknowledged and should be relinquished.

#### DMA+0n24h DMA Channel n Remaining Length of Current Transfer

#### DMA<sub>n</sub>\_RLCT

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

|       |      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------|------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Name  | RLCT |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type  | RO   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset | 0    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

This register is to reflect the left amount of the transfer.

Note that n is from 1 to 10

### DMA+0n28h DMA Bandwidth limiter Register

### DMA<sub>n</sub>\_LIMITER

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17      | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1       | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | LIMITER |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W     |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0       |    |

This register is to suppress the Bus utilization of the DMA channel. The value is from 0 to 255. 0 means no limitation, and 255 means totally banned. The value between 0 and 255 means certain DMA can have permission to use AHB every (4 X n) AHB clock cycles.

Note that it is not recommended to limit the Bus utilization of the DMA channels because this will increase the latency of response to the masters, and the transfer rate will decrease as well. Before using it, programmer must make sure that masters have some protective mechanism to avoid entering into the wrong states.

Note that n is from 1 to 14.

**LIMITER** from 0 to 255. 0 means no limitation, 255 means totally banned, and others means Bus access permission every (4 X n) AHB clock.

### DMA+0n2Ch DMA Channel n Programmable Address Register

### DMA<sub>n</sub>\_PGMADD

R

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16             |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | PGMADDR[31:16] |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W            |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0              |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0              |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | PGMADDR[15:0]  |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W            |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0              |

The above registers specify the address for a half-size DMA channel. This address represents source address if DIR in DMA\_CON is set to 0, and represents destination address if DIR in DMA\_CON is set to 1. Before being able to program these register, the software should make sure that STR in DMA<sub>n</sub>\_START is set to '0', that is the DMA channel is stopped and disabled completely. Otherwise, the DMA channel may run out of order.

Note that n is from 4 to 14.

**PGMADDR PGMADDR[31:0]** specifies the addresses for a half-size or a Virtual FIFO DMA channel, i.e. channel 4 – 14.

**WRITE** the address of the jump destination.

**READ** the current address of the transfer

**DMA+0n30h DMA Channel n Virtual FIFO Write Pointer Register DMAAn\_WRPTR**

| Bit  | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name | <b>WRPTR[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | RO                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>WRPTR[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | RO                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Note that n is from 11 to 14.

**WRPTR** Virtual FIFO Write Pointer.

**DMA+0n34h DMA Channel n Virtual FIFO Read Pointer Register DMAAn\_RDPTR**

| Bit  | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name | <b>RDPTR[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | RO                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>RDPTR[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | RO                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Note that n is from 11 to 14.

**RDPTR** Virtual FIFO Read Pointer.

**DMA+0n38h DMA Channel n Virtual FIFO Data Count Register DMAAn\_FFCNT**

| Bit  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>FFCNT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | RO           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Note that n is from 11 to 14.

**FFCNT** To display the number of data stored in FIFO. 0 means FIFO empty, and FIFO is full if FFCNT is equal to FFsize.  
FFsize.

**DMA+0n3Ch DMA Channel n Virtual FIFO Status Register DMAAn\_FFSTA**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**EMPTY** To indicate FIFO is empty.

0 Not Empty

1 Empty

**ALT** To indicate FIFO Count is larger than ALTLEN. DMA will issue alert signal to UART to enable UART flow control.

0 Not reach alert region

1 Reach alert region.

### DMA+0n40h DMA Channel n Virtual FIFO Alert Length Register DMA<sub>n</sub>\_ALTLEN

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18     | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2      | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    | ALTLEN |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    | 0      |    |    |

Note that n is from 11 to 14.

**ALTLEN** specifies the Alert Length of Virtual FIFO DMA. Once remaining FIFO space is less than ALTLEN, an alert signal will issued to UART to enable flow control. Normally, ALTLEN shall be larger than 16 for UART application.

### DMA+0n44h DMA Channel n Virtual FIFO Size Register DMA<sub>n</sub>\_FFSIZE

|       |    |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    | FFSIZE |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    | R/W    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    | 0      |    |    |    |    |    |    |    |

Note that n is from 11 to 14.

**FFSIZE** specifies the FIFO Size of Virtual FIFO DMA.

## 3.5 Interrupt Controller

### 3.5.1 General Description

**Figure 13** outlines the major functionality of the MCU Interrupt Controller. The interrupt controller processes all interrupt sources coming from external lines and internal MCU peripherals. Since ARM7EJ-S core supports two levels of interrupt latency, this controller will generate two request signals: FIQ for fast, low latency interrupt request and IRQ for more general interrupts with lower priority.



**Figure 13** Block Diagram of the Interrupt Controller

One and only one of the interrupt sources can be assigned to FIQ Controller and have the highest priority in requesting timing critical service. All the others should share the same IRQ signal by connecting them to IRQ Controller. The IRQ Controller manages up 32 interrupt lines of IRQ0 to IRQ31 with fixed priority in descending order.

The Interrupt Controller provides a simple software interface by mean of registers to manipulate the interrupt request shared system. IRQ Selection Registers and FIQ Selection Register determine the source priority and connecting relation among sources and interrupt lines. IRQ Source Status Register allows software program to identify the source of interrupt that generates the interrupt request. IRQ Mask Register provides software to mask out undesired sources some time. End of Interrupt Register permits software program to indicate the controller that a certain interrupt service routine has been finished.

Binary coded version of IRQ Source Status Register is also made available for software program to helpfully identify the interrupt source. Note that while using this register, the controller also needs to use the corresponding binary coded version of End of Interrupt Register for response.

The essential Interrupt Table of ARM7EJ-S core is shown as **Table 9**.

| Address   | Description  |
|-----------|--------------|
| 00000000h | System Reset |
| 00000018h | IRQ          |
| 0000001Ch | FIQ          |

**Table 9** Interrupt Table of ARM7EJ-S

### 3.5.1.1 Interrupt Source Masking

Interrupt controller provides the function of Interrupt Source Masking by the way of programming MASK register. Any of them can be masked individually.

However, because of the bus latency, the masking takes effect a minimal of 3 clock cycles later. In this time, the to-be-masked interrupts could come in and generate an IRQ pulse to MCU, and then disappear immediately. This IRQ forces MCU to go into Interrupt Service Routine and poll the Status Register (IRQ\_STA or IRQ\_STA2), but the register will show there is no interrupt. This may cause MCU malfunction.

There are two ways for programmers to protect their software.

1. Return from ISR (Interrupt Service Routine) immediately while the Status register shows no interrupt.
2. Set I bit of MCU before performing Interrupt Masking, and then clear it after Interrupt Masking done.

Both can avoid the problem, but it is always recommended to use the first method list above.

### 3.5.1.2 External Interrupt

This interrupt controller also integrates an External Interrupt Controller that can support up to 4 interrupt requests coming from external sources, the EINT0–3 as shown in **Figure 14**, and 4 WakeUp interrupt requests, i.e. EINT4–7, coming from peripherals used to inform system to resume system clock.

The four external interrupts can be used for different kind of applications, mainly for event detections: detection of hands-free connection, detection of hood opening, detection of battery charger connection.

Since the external event may be unstable in a certain period, de-bounce mechanism is introduced to ensure the correct functionality. The circuitry is mainly used to verify that the input signal remains stable for a programmable number of periods of the clock. When this condition is satisfied, for the appearance or the disappearance of the input, the output of the de-bounce logic will change to the desired state. Note that, because it uses the 32KHz slow clock for doing de-bounce process, the parameter of de-bounce period and de-bounce enable take effect no sooner than one 32KHz clock cycle (~31.25us) after software program sets them. However, the polarities of EINTs are clocking with system clock. Any changes on it will take effect immediately. Note also that this External Interrupt Controller handles only level sensitive type of interrupt sources.



**Figure 14** Block diagram of External Interrupt Controller

| REGISTER ADDRESS | REGISTER NAME                    | SYNONYM       |
|------------------|----------------------------------|---------------|
| CIRQ + 0000h     | IRQ Selection 0 Register         | IRQ_SEL0      |
| CIRQ + 0004h     | IRQ Selection 1 Register         | IRQ_SEL1      |
| CIRQ + 0008h     | IRQ Selection 2 Register         | IRQ_SEL2      |
| CIRQ + 000Ch     | IRQ Selection 3 Register         | IRQ_SEL3      |
| CIRQ + 0010h     | IRQ Selection 4 Register         | IRQ_SEL4      |
| CIRQ + 0014h     | IRQ Selection 5 Register         | IRQ_SEL5      |
| CIRQ + 0018h     | FIQ Selection Register           | FIQ_SEL       |
| CIRQ + 001Ch     | IRQ Mask Register                | IRQ_MASK      |
| CIRQ + 0020h     | IRQ Mask Disable Register        | IRQ_MASK_DIS  |
| CIRQ + 0024h     | IRQ Mask Enable Register         | IRQ_MASK_EN   |
| CIRQ + 0028h     | IRQ Status Register              | IRQ_STA       |
| CIRQ + 002Ch     | IRQ End of Interrupt Register    | IRQ_EOI       |
| CIRQ + 0030h     | IRQ Sensitive Register           | IRQ_SENS      |
| CIRQ + 0034h     | IRQ Software Interrupt Register  | IRQ_SOFT      |
| CIRQ + 0038h     | FIQ Control Register             | FIQ_CON       |
| CIRQ + 003Ch     | FIQ End of Interrupt Register    | FIQ_EOI       |
| CIRQ + 0040h     | Binary Coded Value of IRQ_STATUS | IRQ_STA2      |
| CIRQ + 0044h     | Binary Coded Value of IRQ_EOI    | IRQ_EOI2      |
| CIRQ + 0100h     | EINT Status Register             | EINT_STA      |
| CIRQ + 0104h     | EINT Mask Register               | EINT_MASK     |
| CIRQ + 0108h     | EINT Mask Disable Register       | EINT_MASK_DIS |
| CIRQ + 010Ch     | EINT Mask Enable Register        | EINT_MASK_EN  |

|              |                                     |             |
|--------------|-------------------------------------|-------------|
| CIRQ + 0110h | EINT Interrupt Acknowledge Register | EINT_INTACK |
| CIRQ + 0114h | EINT Sensitive Register             | EINT_SENS   |
| CIRQ + 0120h | EINT0 De-bounce Control Register    | EINT0_CON   |
| CIRQ + 0130h | EINT1 De-bounce Control Register    | EINT1_CON   |
| CIRQ + 0140h | EINT2 De-bounce Control Register    | EINT2_CON   |
| CIRQ + 0150h | EINT3 De-bounce Control Register    | EINT3_CON   |
| CIRQ + 0160h | EINT4 De-bounce Control Register    | EINT4_CON   |
| CIRQ + 0170h | EINT5 De-bounce Control Register    | EINT5_CON   |
| CIRQ + 0180h | EINT6 De-bounce Control Register    | EINT6_CON   |
| CIRQ + 0190h | EINT7 De-bounce Control Register    | EINT7_CON   |

Table 10 Interrupt Controller Register Map

### 3.5.2 Register Definitions

#### CIRQ+0000h IRQ Selection 0 Register

**IRQ\_SEL0**

| Bit   | 31 | 30 | 29 | 28   | 27   | 26 | 25 | 24 | 23   | 22   | 21 | 20 | 19 | 18   | 17   | 16 |
|-------|----|----|----|------|------|----|----|----|------|------|----|----|----|------|------|----|
| Name  |    |    |    |      | IRQ5 |    |    |    |      | IRQ4 |    |    |    |      | IRQ3 |    |
| Type  |    |    |    |      | R/W  |    |    |    |      | R/W  |    |    |    |      | R/W  |    |
| Reset |    |    |    |      | 5    |    |    |    |      | 4    |    |    |    |      | 3    |    |
| Bit   | 15 | 14 | 13 | 12   | 11   | 10 | 9  | 8  | 7    | 6    | 5  | 4  | 3  | 2    | 1    | 0  |
| Name  |    |    |    | IRQ2 |      |    |    |    | IRQ1 |      |    |    |    | IRQ0 |      |    |
| Type  |    |    |    | R/W  |      |    |    |    | R/W  |      |    |    |    | R/W  |      |    |
| Reset |    |    |    | 2    |      |    |    |    | 1    |      |    |    |    | 0    |      |    |

#### CIRQ+0004h IRQ Selection 1 Register

**IRQ\_SEL1**

| Bit   | 31 | 30 | 29 | 28   | 27   | 26 | 25 | 24 | 23   | 22   | 21 | 20 | 19 | 18   | 17   | 16 |
|-------|----|----|----|------|------|----|----|----|------|------|----|----|----|------|------|----|
| Name  |    |    |    |      | IRQB |    |    |    |      | IRQA |    |    |    |      | IRQ9 |    |
| Type  |    |    |    |      | R/W  |    |    |    |      | R/W  |    |    |    |      | R/W  |    |
| Reset |    |    |    |      | B    |    |    |    |      | A    |    |    |    |      | 9    |    |
| Bit   | 15 | 14 | 13 | 12   | 11   | 10 | 9  | 8  | 7    | 6    | 5  | 4  | 3  | 2    | 1    | 0  |
| Name  |    |    |    | IRQ8 |      |    |    |    | IRQ7 |      |    |    |    | IRQ6 |      |    |
| Type  |    |    |    | R/W  |      |    |    |    | R/W  |      |    |    |    | R/W  |      |    |
| Reset |    |    |    | 8    |      |    |    |    | 7    |      |    |    |    | 6    |      |    |

#### CIRQ+0008h IRQ Selection 2 Register

**IRQ\_SEL2**

| Bit   | 31 | 30 | 29 | 28   | 27    | 26 | 25 | 24 | 23   | 22    | 21 | 20 | 19 | 18   | 17   | 16 |
|-------|----|----|----|------|-------|----|----|----|------|-------|----|----|----|------|------|----|
| Name  |    |    |    |      | IRQ11 |    |    |    |      | IRQ10 |    |    |    |      | IRQF |    |
| Type  |    |    |    |      | R/W   |    |    |    |      | R/W   |    |    |    |      | R/W  |    |
| Reset |    |    |    |      | 11    |    |    |    |      | 10    |    |    |    |      | F    |    |
| Bit   | 15 | 14 | 13 | 12   | 11    | 10 | 9  | 8  | 7    | 6     | 5  | 4  | 3  | 2    | 1    | 0  |
| Name  |    |    |    | IRQE |       |    |    |    | IRQD |       |    |    |    | IRQC |      |    |
| Type  |    |    |    | R/W  |       |    |    |    | R/W  |       |    |    |    | R/W  |      |    |
| Reset |    |    |    | E    |       |    |    |    | D    |       |    |    |    | C    |      |    |

#### CIRQ+000Ch IRQ Selection 3 Register

**IRQ\_SEL3**

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

| Name  |    |    | IRQ17 |    |    |    | IRQ16 |   |   |   | IRQ15 |   |   |   |   |   |
|-------|----|----|-------|----|----|----|-------|---|---|---|-------|---|---|---|---|---|
| Type  |    |    | R/W   |    |    |    | R/W   |   |   |   | R/W   |   |   |   |   |   |
| Reset |    |    | 17    |    |    |    | 16    |   |   |   | 15    |   |   |   |   |   |
| Bit   | 15 | 14 | 13    | 12 | 11 | 10 | 9     | 8 | 7 | 6 | 5     | 4 | 3 | 2 | 1 | 0 |
| Name  |    |    | IRQ14 |    |    |    | IRQ13 |   |   |   | IRQ12 |   |   |   |   |   |
| Type  |    |    | R/W   |    |    |    | R/W   |   |   |   | R/W   |   |   |   |   |   |
| Reset |    |    | 14    |    |    |    | 13    |   |   |   | 12    |   |   |   |   |   |

**CIRQ+0010h IRQ Selection 4 Register**
**IRQ\_SEL4**

| Bit   | 31 | 30 | 29    | 28 | 27 | 26 | 25    | 24 | 23 | 22 | 21    | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|-------|----|----|----|-------|----|----|----|-------|----|----|----|----|----|
| Name  |    |    | IRQ1D |    |    |    | IRQ1C |    |    |    | IRQ1B |    |    |    |    |    |
| Type  |    |    | R/W   |    |    |    | R/W   |    |    |    | R/W   |    |    |    |    |    |
| Reset |    |    | 1D    |    |    |    | 1C    |    |    |    | 1B    |    |    |    |    |    |
| Bit   | 15 | 14 | 13    | 12 | 11 | 10 | 9     | 8  | 7  | 6  | 5     | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    | IRQ1A |    |    |    | IRQ19 |    |    |    | IRQ18 |    |    |    |    |    |
| Type  |    |    | R/W   |    |    |    | R/W   |    |    |    | R/W   |    |    |    |    |    |
| Reset |    |    | 1A    |    |    |    | 19    |    |    |    | 18    |    |    |    |    |    |

**CIRQ+0014h IRQ Selection 5 Register**
**IRQ\_SEL5**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25    | 24 | 23 | 22 | 21    | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|-------|----|----|----|-------|----|----|----|----|----|
| Name  |    |    |    |    |    |    |       |    |    |    |       |    |    |    |    |    |
| Type  |    |    |    |    |    |    |       |    |    |    |       |    |    |    |    |    |
| Reset |    |    |    |    |    |    |       |    |    |    |       |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8  | 7  | 6  | 5     | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    | IRQ1F |    |    |    | IRQ1E |    |    |    |    |    |
| Type  |    |    |    |    |    |    | R/W   |    |    |    | R/W   |    |    |    |    |    |
| Reset |    |    |    |    |    |    | 1F    |    |    |    | 1E    |    |    |    |    |    |

**CIRQ+0018h FIQ Selection Register**
**FIQ\_SEL**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3   | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    | FIQ |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    | R/W |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    | 0   |    |    |    |

The IRQ/FIQ Selection Registers provide system designers with a flexible routing scheme to make various mappings of priority among interrupt sources possible. It allows the interrupt sources to be mapped onto interrupt requests of either FIQ or IRQ. While only one interrupt source can be assigned to FIQ, the other ones should share IRQ by mapping them onto IRQ0 to IRQ1F, which are connected to IRQ controller. The priority of IRQ0-IRQ1F is fixed, i.e. IRQ0 > IRQ1 > IRQ2 > ... > IRQ1E > IRQ1F. During the software configuration process, the Interrupt Source Code of desired interrupt source should be written into source field of the corresponding IRQ\_SEL0-IRQ\_SEL4/FIQ\_SEL. 5-bit Interrupt Source Codes for all interrupt sources are fixed and defined in **Table 11**.

| Interrupt Source | Interrupt Source Code |
|------------------|-----------------------|
| GPI_FIQ          | 00000                 |
| TDMA_CTIRQ1      | 00001                 |
| TDMA_CTIRQ2      | 00010                 |

|              |       |
|--------------|-------|
| DSP2CPU      | 00011 |
| SIM          | 00100 |
| DMA          | 00101 |
| TDMA         | 00110 |
| UART1        | 00111 |
| KeyPad       | 01000 |
| UART2        | 01001 |
| GPTimer      | 01010 |
| EINT         | 01011 |
| USB          | 01100 |
| MSDC         | 01101 |
| RTC          | 01110 |
| IrDA         | 01111 |
| LCD          | 10000 |
| UART3        | 10001 |
| GPI_IRQ      | 10010 |
| WDT          | 10011 |
| JPEG         | 10100 |
| Resizer      | 10101 |
| NFI          | 10110 |
| B2PSI        | 10111 |
| Image DMA    | 11000 |
| GIF          | 11001 |
| Reserved     | 11010 |
| SCCB         | 11011 |
| G2D          | 11100 |
| Image Engine | 11101 |
| CAM          | 11110 |
| MPEG4        | 11111 |

**Table 11** Interrupt Source Code for Interrupt Sources

**FIQ, IRQ0-1F** The 5-bit content of this field would be the Interrupt Source Code shown in **Table 11** indicating that the certain interrupt source uses the associated interrupt line to generate fast interrupt requests.

### CIRQ+001Ch IRQ Mask Register

### IRQ\_MASK

| Bit   | 31    | 30    | 29    | 28    | 27    | 26    | 25    | 24    | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name  | IRQ1F | IRQ1E | IRQ1D | IRQ1C | IRQ1B | IRQ1A | IRQ19 | IRQ18 | IRQ17 | IRQ16 | IRQ15 | IRQ14 | IRQ13 | IRQ12 | IRQ11 | IRQ10 |
| Type  | R/W   |
| Reset | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| Bit   | 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| Name  | IRQF  | IRQE  | IRQD  | IRQC  | IRQB  | IRQA  | IRQ9  | IRQ8  | IRQ7  | IRQ6  | IRQ5  | IRQ4  | IRQ3  | IRQ2  | IRQ1  | IRQ0  |
| Type  | R/W   |
| Reset | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |

This register contains mask bit for each interrupt line in IRQ Controller. It allows each interrupt source of IRQ0 to IRQ1F to be disabled or masked out separately under software control. After System Reset, all bit values will be set to '1' to indicate that interrupt requests are prohibited.

**IRQ0-1F** Mask Control for the Associated Interrupt Source in IRQ Controller

- 0** Interrupt is enabled
- 1** Interrupt is disabled

**CIRQ+0020h** **IRQ Mask Clear Register**

**IRQ\_MASK\_CL**  
**R**

| Bit  | 31           | 30           | 29           | 28           | 27           | 26           | 25           | 24           | 23           | 22           | 21           | 20           | 19           | 18           | 17           | 16           |
|------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
| Name | <b>IRQ1F</b> | <b>IRQ1E</b> | <b>IRQ1D</b> | <b>IRQ1C</b> | <b>IRQ1B</b> | <b>IRQ1A</b> | <b>IRQ19</b> | <b>IRQ18</b> | <b>IRQ17</b> | <b>IRQ16</b> | <b>IRQ15</b> | <b>IRQ14</b> | <b>IRQ13</b> | <b>IRQ12</b> | <b>IRQ11</b> | <b>IRQ10</b> |
| Type | W1C          |
| Bit  | 15           | 14           | 13           | 12           | 11           | 10           | 9            | 8            | 7            | 6            | 5            | 4            | 3            | 2            | 1            | 0            |
| Name | <b>IRQF</b>  | <b>IRQE</b>  | <b>IRQD</b>  | <b>IRQC</b>  | <b>IRQB</b>  | <b>IRQA</b>  | <b>IRQ9</b>  | <b>IRQ8</b>  | <b>IRQ7</b>  | <b>IRQ6</b>  | <b>IRQ5</b>  | <b>IRQ4</b>  | <b>IRQ3</b>  | <b>IRQ2</b>  | <b>IRQ1</b>  | <b>IRQ0</b>  |
| Type | W1C          |

This register is used to clear bits in the IRQ Mask Register. When writing to this register, the data bits that are high will cause the corresponding bits in the IRQ Mask Register to be cleared. Data bits that are low have no effect on the corresponding bits in the IRQ Mask Register

**IRQ0-1F** Clear corresponding bits in IRQ Mask Register.

- 0** no effect
- 1** Disable corresponding MASK bit

**CIRQ+0024h** **IRQ Mask SET Register**

**IRQ\_MASK\_SET**

| Bit  | 31           | 30           | 29           | 28           | 27           | 26           | 25           | 24           | 23           | 22           | 21           | 20           | 19           | 18           | 17           | 16           |
|------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
| Name | <b>IRQ1F</b> | <b>IRQ1E</b> | <b>IRQ1D</b> | <b>IRQ1C</b> | <b>IRQ1B</b> | <b>IRQ1A</b> | <b>IRQ19</b> | <b>IRQ18</b> | <b>IRQ17</b> | <b>IRQ16</b> | <b>IRQ15</b> | <b>IRQ14</b> | <b>IRQ13</b> | <b>IRQ12</b> | <b>IRQ11</b> | <b>IRQ10</b> |
| Type | W1S          |
| Bit  | 15           | 14           | 13           | 12           | 11           | 10           | 9            | 8            | 7            | 6            | 5            | 4            | 3            | 2            | 1            | 0            |
| Name | <b>IRQF</b>  | <b>IRQE</b>  | <b>IRQD</b>  | <b>IRQC</b>  | <b>IRQB</b>  | <b>IRQA</b>  | <b>IRQ9</b>  | <b>IRQ8</b>  | <b>IRQ7</b>  | <b>IRQ6</b>  | <b>IRQ5</b>  | <b>IRQ4</b>  | <b>IRQ3</b>  | <b>IRQ2</b>  | <b>IRQ1</b>  | <b>IRQ0</b>  |
| Type | W1S          |

This register is used to set bits in the IRQ Mask Register. When writing to this register, the data bits that are high will cause the corresponding bits in the IRQ Mask Register to be set. Data bits that are low have no effect on the corresponding bits in the IRQ Mask Register

**IRQ0-1F** Set corresponding bits in IRQ Mask Register.

- 0** no effect
- 1** Enable corresponding MASK bit

**CIRQ+0028h** **IRQ Source Status Register**

**IRQ\_STA**

| Bit   | 31           | 30           | 29           | 28           | 27           | 26           | 25           | 24           | 23           | 22           | 21           | 20           | 19           | 18           | 17           | 16           |
|-------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
| Name  | <b>IRQ1F</b> | <b>IRQ1E</b> | <b>IRQ1D</b> | <b>IRQ1C</b> | <b>IRQ1B</b> | <b>IRQ1A</b> | <b>IRQ19</b> | <b>IRQ18</b> | <b>IRQ17</b> | <b>IRQ16</b> | <b>IRQ15</b> | <b>IRQ14</b> | <b>IRQ13</b> | <b>IRQ12</b> | <b>IRQ11</b> | <b>IRQ10</b> |
| Type  | RC           |
| Reset | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            |
| Bit   | 15           | 14           | 13           | 12           | 11           | 10           | 9            | 8            | 7            | 6            | 5            | 4            | 3            | 2            | 1            | 0            |
| Name  | <b>IRQF</b>  | <b>IRQE</b>  | <b>IRQD</b>  | <b>IRQC</b>  | <b>IRQB</b>  | <b>IRQA</b>  | <b>IRQ9</b>  | <b>IRQ8</b>  | <b>IRQ7</b>  | <b>IRQ6</b>  | <b>IRQ5</b>  | <b>IRQ4</b>  | <b>IRQ3</b>  | <b>IRQ2</b>  | <b>IRQ1</b>  | <b>IRQ0</b>  |
| Type  | RC           |
| Reset | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            |

This Register allows software to poll which interrupt line generates the IRQ interrupt request. A bit set to '1' indicates a corresponding active interrupt line. Only one flag is active at a time. The IRQ\_STA is type of READ-Clear, write access will have no effect to the content.

**IRQ0-1F** Interrupt Indication for the Associated Interrupt Source

- 0** The associated interrupt source is non-active
- 1** The associated interrupt source is asserted

**CIRQ+002Ch** IRQ End of Interrupt Register

**IRQ\_EOI**

| Bit   | 31           | 30           | 29           | 28           | 27           | 26           | 25           | 24           | 23           | 22           | 21           | 20           | 19           | 18           | 17           | 16           |
|-------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
| Name  | <b>IRQ1F</b> | <b>IRQ1E</b> | <b>IRQ1D</b> | <b>IRQ1C</b> | <b>IRQ1B</b> | <b>IRQ1A</b> | <b>IRQ19</b> | <b>IRQ18</b> | <b>IRQ17</b> | <b>IRQ16</b> | <b>IRQ15</b> | <b>IRQ14</b> | <b>IRQ13</b> | <b>IRQ12</b> | <b>IRQ11</b> | <b>IRQ10</b> |
| Type  | WO           |
| Reset | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            |
| Bit   | 15           | 14           | 13           | 12           | 11           | 10           | 9            | 8            | 7            | 6            | 5            | 4            | 3            | 2            | 1            | 0            |
| Name  | <b>IRQF</b>  | <b>IRQE</b>  | <b>IRQD</b>  | <b>IRQC</b>  | <b>IRQB</b>  | <b>IRQA</b>  | <b>IRQ9</b>  | <b>IRQ8</b>  | <b>IRQ7</b>  | <b>IRQ6</b>  | <b>IRQ5</b>  | <b>IRQ4</b>  | <b>IRQ3</b>  | <b>IRQ2</b>  | <b>IRQ1</b>  | <b>IRQ0</b>  |
| Type  | WO           |
| Reset | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            |

This register provides a mean for software to relinquish and refresh the Interrupt Controller. Writing a '1' to the specific bit position will result in an End of Interrupt Command internally to the corresponding interrupt line.

**IRQ0-1F** End of Interrupt Command for the Associated Interrupt Line

- 0** No service is currently in progress or pending
- 1** Interrupt request is in-service

**CIRQ+0030h** IRQ Sensitive Register

**IRQ\_SENS**

| Bit   | 31           | 30           | 29           | 28           | 27           | 26           | 25           | 24           | 23           | 22           | 21           | 20           | 19           | 18           | 17           | 16           |
|-------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
| Name  | <b>IRQ1F</b> | <b>IRQ1E</b> | <b>IRQ1D</b> | <b>IRQ1C</b> | <b>IRQ1B</b> | <b>IRQ1A</b> | <b>IRQ19</b> | <b>IRQ18</b> | <b>IRQ17</b> | <b>IRQ16</b> | <b>IRQ15</b> | <b>IRQ14</b> | <b>IRQ13</b> | <b>IRQ12</b> | <b>IRQ11</b> | <b>IRQ10</b> |
| Type  | R/W          |
| Reset | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            |
| Bit   | 15           | 14           | 13           | 12           | 11           | 10           | 9            | 8            | 7            | 6            | 5            | 4            | 3            | 2            | 1            | 0            |
| Name  | <b>IRQF</b>  | <b>IRQE</b>  | <b>IRQD</b>  | <b>IRQC</b>  | <b>IRQB</b>  | <b>IRQA</b>  | <b>IRQ9</b>  | <b>IRQ8</b>  | <b>IRQ7</b>  | <b>IRQ6</b>  | <b>IRQ5</b>  | <b>IRQ4</b>  | <b>IRQ3</b>  | <b>IRQ2</b>  | <b>IRQ1</b>  | <b>IRQ0</b>  |
| Type  | R/W          |
| Reset | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            |

All interrupt lines of IRQ Controller, IRQ0-IRQ1F can be programmed as either edge or level sensitive. By default, all the interrupt lines are edge sensitive and should be active LOW. Once a interrupt line is programmed as edge sensitive, an interrupt request is triggered only at the falling edge of interrupt line, and the next interrupt will not be taken until the EOI command is given. However, level sensitive interrupt triggering is according to the signal level of the interrupt line. Once the interrupt line become from High to Low, an interrupt request is triggered, and another interrupt request will be triggered if the signal level remain Low after EOI command. Please note that in edge sensitive mode, even if the signal level remains Low after EOI command, another interrupt request will not be triggered. This is because edge sensitive interrupt is only triggered at the falling edge.

**IRQ0-1F** Sensitive Type of the Associated Interrupt Source

- 0** Edge sensitivity with active LOW
- 1** Level sensitivity with active LOW

**CIRQ+0034h** IRQ Software Interrupt Register

**IRQ\_SOFT**

| Bit  | 31           | 30           | 29           | 28           | 27           | 26           | 25           | 24           | 23           | 22           | 21           | 20           | 19           | 18           | 17           | 16           |
|------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
| Name | <b>IRQ1F</b> | <b>IRQ1E</b> | <b>IRQ1D</b> | <b>IRQ1C</b> | <b>IRQ1B</b> | <b>IRQ1A</b> | <b>IRQ19</b> | <b>IRQ18</b> | <b>IRQ17</b> | <b>IRQ16</b> | <b>IRQ15</b> | <b>IRQ14</b> | <b>IRQ13</b> | <b>IRQ12</b> | <b>IRQ11</b> | <b>IRQ10</b> |

| Type  | R/W         | R/W |
|-------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-----|
| Reset | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0   |
| Bit   | 15          | 14          | 13          | 12          | 11          | 10          | 9           | 8           | 7           | 6           | 5           | 4           | 3           | 2           | 1           | 0           |     |
| Name  | <b>IRQF</b> | <b>IRQE</b> | <b>IRQD</b> | <b>IRQC</b> | <b>IRQB</b> | <b>IRQA</b> | <b>IRQ9</b> | <b>IRQ8</b> | <b>IRQ7</b> | <b>IRQ6</b> | <b>IRQ5</b> | <b>IRQ4</b> | <b>IRQ3</b> | <b>IRQ2</b> | <b>IRQ1</b> | <b>IRQ0</b> |     |
| Type  | R/W         | R/W |
| Reset | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0   |

Setting “1” to the specific bit position generates a software interrupt for corresponding Interrupt Line before mask. This register is used for debug purpose.

**IRQ0-IRQ1F** Software Interrupt

### CIRQ+0038h FIQ Control Register

**FIQ\_CON**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17          | 16          |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|-------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |             |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |             |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |             |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1           | 0           |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SENS</b> | <b>MASK</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W         | R/W         |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0           | 1           |

This register provides a mean for software program to control the FIQ Controller.

**MASK** Mask Control for the FIQ Interrupt Source

**0** Interrupt is enabled

**1** Interrupt is disabled

**SENS** Sensitive Type of the FIQ Interrupt Source

**0** Edge sensitivity with active LOW

**1** Level sensitivity with active LOW

### CIRQ+003Ch FIQ End of Interrupt Register

**FIQ\_EOI**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17         | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1          | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>EOI</b> |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | WO         |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0          |    |

This register provides a mean for software to relinquish and refresh the FIQ Controller. Writing a ‘1’ to the specific bit position will result in an End of Interrupt Command internally to the corresponding interrupt line.

**EOI** End of Interrupt Command

### CIRQ+0040h Binary Coded Value of IRQ\_STATUS

**IRQ\_STA2**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23          | 22 | 21 | 20 | 19 | 18         | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|-------------|----|----|----|----|------------|----|----|
| Name  |    |    |    |    |    |    |    |    |             |    |    |    |    |            |    |    |
| Type  |    |    |    |    |    |    |    |    |             |    |    |    |    |            |    |    |
| Reset |    |    |    |    |    |    |    |    |             |    |    |    |    |            |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7           | 6  | 5  | 4  | 3  | 2          | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    | <b>NOIR</b> |    |    |    |    | <b>STS</b> |    |    |

|       |  |  |  |  |  |    |  |  |  |  |  |    |
|-------|--|--|--|--|--|----|--|--|--|--|--|----|
| Type  |  |  |  |  |  | RO |  |  |  |  |  | RC |
| Reset |  |  |  |  |  | 0  |  |  |  |  |  | 0  |

This Register is a binary coded version of IRQ\_STA. It is used for software program to poll and see which interrupt line generated the IRQ interrupt request in a much easier way. Any read to it has the same result as reading IRQ\_STA. The IRQ\_STA2 is also READ-ONLY, write access has no effect to the content. Note that, IRQ\_STA2 should be coupled with IRQ\_EOI2 while using it.

**STS** Binary Coded Value of IRQ\_STA

**NOIRQ** Indicating if there is an IRQ or not. If there is no IRQ, this bit will be high, and the value of STS should be 0\_0000b.

### CIRQ+0044h Binary Coded Value of IRQ\_EOI

### IRQ\_EOI2

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2   | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    | EOI |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    | WO  |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    | 0   |    |    |

This register is a binary coded version of IRQ\_EOI. It provides an easier way for software program to relinquish and refresh the Interrupt Controller. Writing a specific code will result in an End of Interrupt Command internally to the corresponding interrupt line. Note that, IRQ\_EOI2 should be coupled with IRQ\_STA2 while using it.

**EOI** Binary Coded Value of IRQ\_EOI

### CIRQ+0100h EINT Interrupt Status Register

### EINT\_STA

|       |    |    |    |    |    |    |    |    |       |       |       |       |       |       |       |       |
|-------|----|----|----|----|----|----|----|----|-------|-------|-------|-------|-------|-------|-------|-------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
| Name  |    |    |    |    |    |    |    |    |       |       |       |       |       |       |       |       |
| Type  |    |    |    |    |    |    |    |    |       |       |       |       |       |       |       |       |
| Reset |    |    |    |    |    |    |    |    |       |       |       |       |       |       |       |       |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| Name  |    |    |    |    |    |    |    |    | EINT7 | EINT6 | EINT5 | EINT4 | EINT3 | EINT2 | EINT1 | EINT0 |
| Type  |    |    |    |    |    |    |    |    | RO    |
| Reset |    |    |    |    |    |    |    |    | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

This register keeps up with current status of which EINT Source generated the interrupt request. If EINT sources are set to edge sensitive, EINT\_IRQ will be de-asserted while this register is read.

**EINT0-EINT7** Interrupt Status

- 0 No Interrupt Request is generated
- 1 Interrupt Request is pending

### CIRQ+0104h EINT Interrupt Mask Register

### EINT\_MASK

|       |    |    |    |    |    |    |    |    |       |       |       |       |       |       |       |       |
|-------|----|----|----|----|----|----|----|----|-------|-------|-------|-------|-------|-------|-------|-------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
| Name  |    |    |    |    |    |    |    |    |       |       |       |       |       |       |       |       |
| Type  |    |    |    |    |    |    |    |    |       |       |       |       |       |       |       |       |
| Reset |    |    |    |    |    |    |    |    |       |       |       |       |       |       |       |       |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| Name  |    |    |    |    |    |    |    |    | EINT7 | EINT6 | EINT5 | EINT4 | EINT3 | EINT2 | EINT1 | EINT0 |
| Type  |    |    |    |    |    |    |    |    | R/W   |

|       |  |  |  |  |  |  |  |  |   |   |   |   |   |   |   |   |
|-------|--|--|--|--|--|--|--|--|---|---|---|---|---|---|---|---|
| Reset |  |  |  |  |  |  |  |  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|-------|--|--|--|--|--|--|--|--|---|---|---|---|---|---|---|---|

This register controls whether if EINT Source is allowed to generate interrupt request. Setting a “1” to the specific bit position prohibits the External Interrupt Line to active accordingly.

#### EINT0-EINT7 Interrupt Mask

- 0 Interrupt Request is enabled
- 1 Interrupt Request is disabled

#### CIRQ+0108h EINT Interrupt Mask Clear Register

EINT\_MASK\_CL  
R

|      |    |    |    |    |    |    |    |    |       |       |       |       |       |       |       |       |
|------|----|----|----|----|----|----|----|----|-------|-------|-------|-------|-------|-------|-------|-------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
| Name |    |    |    |    |    |    |    |    |       |       |       |       |       |       |       |       |
| Type |    |    |    |    |    |    |    |    |       |       |       |       |       |       |       |       |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| Name |    |    |    |    |    |    |    |    | EINT7 | EINT6 | EINT5 | EINT4 | EINT3 | EINT2 | EINT1 | EINT0 |
| Type |    |    |    |    |    |    |    |    | W1C   |

This register is used to individually clear mask bit. Only the bits set to 1 are in effect, and these mask bits will set to 0. Otherwise mask bits keep original value.

#### EINT0-EINT7 Disable Mask for the Associated External Interrupt Source

- 0 no effect
- 1 Disable corresponding MASK bit

#### CIRQ+010Ch EINT Interrupt Mask Set Register

EINT\_MASK\_SE  
T

|      |    |    |    |    |    |    |    |    |       |       |       |       |       |       |       |       |
|------|----|----|----|----|----|----|----|----|-------|-------|-------|-------|-------|-------|-------|-------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
| Name |    |    |    |    |    |    |    |    |       |       |       |       |       |       |       |       |
| Type |    |    |    |    |    |    |    |    |       |       |       |       |       |       |       |       |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| Name |    |    |    |    |    |    |    |    | EINT7 | EINT6 | EINT5 | EINT4 | EINT3 | EINT2 | EINT1 | EINT0 |
| Type |    |    |    |    |    |    |    |    | W1S   |

This register is used to individually set mask bit. Only the bits set to 1 are in effect, and these mask bits will set to 1. Otherwise mask bits keep original value.

#### EINT0-EINT7 Disable Mask for the Associated External Interrupt Source

- 0 no effect
- 1 Enable corresponding MASK bit

#### CIRQ+0110h EINT Interrupt Acknowledge Register

EINT\_INTACK

|       |    |    |    |    |    |    |    |    |       |       |       |       |       |       |       |       |
|-------|----|----|----|----|----|----|----|----|-------|-------|-------|-------|-------|-------|-------|-------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
| Name  |    |    |    |    |    |    |    |    |       |       |       |       |       |       |       |       |
| Type  |    |    |    |    |    |    |    |    |       |       |       |       |       |       |       |       |
| Reset |    |    |    |    |    |    |    |    |       |       |       |       |       |       |       |       |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| Name  |    |    |    |    |    |    |    |    | EINT7 | EINT6 | EINT5 | EINT4 | EINT3 | EINT2 | EINT1 | EINT0 |
| Type  |    |    |    |    |    |    |    |    | WO    |
| Reset |    |    |    |    |    |    |    |    | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

Writing "1" to the specific bit position means to acknowledge the interrupt request correspondingly to the External Interrupt Line source.

**EINT0-EINT7** Interrupt Acknowledge

- 0** No effect
- 1** Interrupt Request is acknowledged

**CIRQ+0114h EINT Sensitive Register**
**EINT\_SENS**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19           | 18           | 17           | 16           |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|--------------|--------------|--------------|--------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |              |              |              |              |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |              |              |              |              |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |              |              |              |              |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3            | 2            | 1            | 0            |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    | <b>EINT3</b> | <b>EINT2</b> | <b>EINT1</b> | <b>EINT0</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    | R/W          | R/W          | R/W          | R/W          |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    | 1            | 1            | 1            | 1            |

Sensitivity type of external interrupt source. Only EINT0 – 3 need to be specified. EINT4 – 7 are always edge sensitive.

**EINT0-3** Sensitive Type of the Associated External Interrupt Source

- 0** Edge sensitivity with active LOW
- 1** Level sensitivity with active LOW

**CIRQ+01m0h EINTn De-bounce Control Register**
**EINTn\_CON**

| Bit   | 31        | 30 | 29 | 28 | 27         | 26 | 25 | 24 | 23 | 22 | 21         | 20 | 19 | 18 | 17 | 16 |
|-------|-----------|----|----|----|------------|----|----|----|----|----|------------|----|----|----|----|----|
| Name  |           |    |    |    |            |    |    |    |    |    |            |    |    |    |    |    |
| Type  |           |    |    |    |            |    |    |    |    |    |            |    |    |    |    |    |
| Reset |           |    |    |    |            |    |    |    |    |    |            |    |    |    |    |    |
| Bit   | 15        | 14 | 13 | 12 | 11         | 10 | 9  | 8  | 7  | 6  | 5          | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>EN</b> |    |    |    | <b>POL</b> |    |    |    |    |    | <b>CNT</b> |    |    |    |    |    |
| Type  | R/W       |    |    |    | R/W        |    |    |    |    |    | R/W        |    |    |    |    |    |
| Reset | 0         |    |    |    | 0          |    |    |    |    |    | 0          |    |    |    |    |    |

These registers control the de-bounce logic for external interrupt sources in order to minimize the possibility of false activations. EINT4 – 7 have no de-bounce mechanism. Therefore only bit POL is used.

Note that n is from 0 to 7, and m is n plus 2.

**CNT** De-bounce Duration in terms of numbers of 32KHz clock cycles

**POL** Activation Type of the EINT Source

- 0** Negative polarity
- 1** Positive polarity

**EN** De-bounce Control Circuit

- 0** Disable
- 1** Enable

## 3.6 Internal Memory Interface

### 3.6.1 System RAM

MT6219 provides four 128K Byte size of on-chip memory modules acting as System RAM for data access with zero latency. Such module is composed of four high speed synchronous SRAMs with AHB Slave Interface connected to the system backbone AHB Bus, as shown in **Figure 15**. The synchronous SRAM operates at the same clock as the AHB Bus and is organized as 32-bit wide with 4 byte-write signals capable for byte operations.

### 3.6.2 System ROM

The System ROM is primarily used to store software program for Factory Programming. However, due to its advantageous zero latency performance, some of the timing critical codes are also placed in this area. This module is composed of high-speed VIA ROM with AHB Slave Interface connected to system backbone AHB Bus, as shown in **Figure 15**. It operates at the same clock as AHB Bus and is organized as 32-bit wide.



**Figure 15** Block Diagram of Internal

Memory Controller

## 3.7 External Memory Interface

### 3.7.1 General Description

MT6219 incorporates a powerful and flexible memory controller, External Memory Interface, to connect with a variety of memory components. This controller provides generic access schemes to asynchronous/synchronous types of memory devices, such as Flash Memory and SRAM. It can simultaneously support up to 8 memory banks BANK0-BANK7 with maximum size of 64MB each.

Since most of the target asynchronous components have similar AC requirements, it is desirable to have a generic configuration scheme to interface them. This way, software program can treat different components by simply specifying certain predefined parameters. All these parameters are based on cycle time of system clock. The interface definition based on such asynchronous/synchronous scheme is listed in **Table 12**. Note that, this interface always operates data in Little Endian format for all types of accesses.

Page/Burst mode Flash is supported for those applications required to run EIP (execution in place).

| Signal Name | Type | Description                           |
|-------------|------|---------------------------------------|
| EA[25:0]    | O    | Address Bus                           |
| ED[15:0]    | I/O  | Data Bus                              |
| EWR#        | O    | Write Enable Strobe                   |
| ERD#        | O    | Read Enable Strobe                    |
| ELB#        | O    | Lower Byte Strobe                     |
| EUB#        | O    | Upper Byte Strobe                     |
| ECS# [7:0]  | O    | BANK0~BANK7 Selection Signal          |
| EPDN        | O    | Pseudo SRAM Power Down Control Signal |
| ECLK        | O    | Burst Mode Flash Clock Signal         |
| EADV#       | O    | Burst Mode Flash Address Latch Signal |

Table 12 External Memory Interface of MT6219s for Asynchronous/Synchronous Type Components

This controller can also handle parallel type of LCD. 8080 type of control method is supported. The interface definition is detailed in **Table 13**.

| Bus Type    | ECS# | EA25 | ERD# | EWR# | ED[15:0] |
|-------------|------|------|------|------|----------|
| 8080 series | CS#  | A0   | RD#  | WR#  | D[15:0]  |

Table 13 Configuration for LCD Parallel Interface

| REGISTER ADDRESS | REGISTER NAME                                 | SYNONYM      |
|------------------|-----------------------------------------------|--------------|
| EMI + 0000h      | EMI Control Register for BANK0                | EMI_CONA     |
| EMI + 0008h      | EMI Control Register for BANK1                | EMI_CONB     |
| EMI + 0010h      | EMI Control Register for BANK2                | EMI_CONC     |
| EMI + 0018h      | EMI Control Register for BANK3                | EMI_COND     |
| EMI + 0020h      | EMI Control Register for BANK4                | EMI_CONE     |
| EMI + 0028h      | EMI Control Register for BANK5                | EMI_CONF     |
| EMI + 0030h      | EMI Control Register for BANK6                | EMI_CONG     |
| EMI + 0038h      | EMI Control Register for BANK7                | EMI_CONH     |
| EMI + 0040h      | EMI Remap Control Register                    | EMI_REMAP    |
| EMI + 0044h      | EMI General Control Register                  | EMI_GEN      |
| EMI + 0050h      | Code Cache and Code Prefetch Control Register | PREFETCH_CON |
| EMI + 0060h      | EMI Patch Enable Register                     | EMI_PATCHEN  |
| EMI + 0064h      | EMI Patch 0 Address Register                  | EMI_PADDRO   |

|             |                                  |            |
|-------------|----------------------------------|------------|
| EMI + 006Ch | EMI Patch 0 Instruction Register | EMI_PDATA0 |
| EMI + 0074h | EMI Patch 1 Address Register     | EMI_PADDR1 |
| EMI + 007Ch | EMI Patch 1 Instruction Register | EMI_PDATA1 |

Table 14 External Memory Interface Register Map

### 3.7.2 Register Definitions

#### EMI+0000h EMI Control Register for BANK0

| Bit   | 31   | 30   | 29   | 28 | 27  | 26 | 25  | 24    | 23 | 22 | 21 | 20   | 19 | 18     | 17    | 16 | EMI_CONA |
|-------|------|------|------|----|-----|----|-----|-------|----|----|----|------|----|--------|-------|----|----------|
| Name  | C2WS | C2WH | C2RS |    |     |    | ADV |       |    |    |    | PRLT |    | BMOD E | PMODE |    |          |
| Type  | R/W  | R/W  | R/W  |    |     |    | R/W |       |    |    |    | R/W  |    | R/W    | R/W   |    |          |
| Reset | 0    | 0    | 0    |    |     |    | 1   |       |    |    |    | 0    |    | 0      | 0     | 0  |          |
| Bit   | 15   | 14   | 13   | 12 | 11  | 10 | 9   | 8     | 7  | 6  | 5  | 4    | 3  | 2      | 1     | 0  |          |
| Name  | DW   | RBLN |      |    | WST |    |     | PSIZE |    |    |    | RLT  |    |        |       |    |          |
| Type  | R/W  | R/W  |      |    | R/W |    |     | R/W   |    |    |    | R/W  |    |        |       |    |          |
| Reset | 0    | 1    |      |    | 0   |    |     | 0     |    |    |    | 7    |    |        |       |    |          |

#### EMI+0008h EMI Control Register for BANK1

| Bit   | 31   | 30   | 29   | 28 | 27  | 26 | 25  | 24    | 23 | 22 | 21 | 20   | 19 | 18     | 17    | 16 | EMI_CONB |
|-------|------|------|------|----|-----|----|-----|-------|----|----|----|------|----|--------|-------|----|----------|
| Name  | C2WS | C2WH | C2RS |    |     |    | ADV |       |    |    |    | PRLT |    | BMOD E | PMODE |    |          |
| Type  | R/W  | R/W  | R/W  |    |     |    | R/W |       |    |    |    | R/W  |    | R/W    | R/W   |    |          |
| Reset | 0    | 0    | 0    |    |     |    | 1   |       |    |    |    | 0    |    | 0      | 0     | 0  |          |
| Bit   | 15   | 14   | 13   | 12 | 11  | 10 | 9   | 8     | 7  | 6  | 5  | 4    | 3  | 2      | 1     | 0  |          |
| Name  | DW   | RBLN |      |    | WST |    |     | PSIZE |    |    |    | RLT  |    |        |       |    |          |
| Type  | R/W  | R/W  |      |    | R/W |    |     | R/W   |    |    |    | R/W  |    |        |       |    |          |
| Reset | 0    | 1    |      |    | 0   |    |     | 0     |    |    |    | 7    |    |        |       |    |          |

#### EMI+0010h EMI Control Register for BANK2

| Bit   | 31   | 30   | 29   | 28 | 27  | 26 | 25  | 24    | 23 | 22 | 21 | 20   | 19 | 18     | 17    | 16 | EMI_CONC |
|-------|------|------|------|----|-----|----|-----|-------|----|----|----|------|----|--------|-------|----|----------|
| Name  | C2WS | C2WH | C2RS |    |     |    | ADV |       |    |    |    | PRLT |    | BMOD E | PMODE |    |          |
| Type  | R/W  | R/W  | R/W  |    |     |    | R/W |       |    |    |    | R/W  |    | R/W    | R/W   |    |          |
| Reset | 0    | 0    | 0    |    |     |    | 1   |       |    |    |    | 0    |    | 0      | 0     | 0  |          |
| Bit   | 15   | 14   | 13   | 12 | 11  | 10 | 9   | 8     | 7  | 6  | 5  | 4    | 3  | 2      | 1     | 0  |          |
| Name  | DW   | RBLN |      |    | WST |    |     | PSIZE |    |    |    | RLT  |    |        |       |    |          |
| Type  | R/W  | R/W  |      |    | R/W |    |     | R/W   |    |    |    | R/W  |    |        |       |    |          |
| Reset | 0    | 1    |      |    | 0   |    |     | 0     |    |    |    | 7    |    |        |       |    |          |

#### EMI+0018h EMI Control Register for BANK3

| Bit   | 31   | 30   | 29   | 28 | 27  | 26 | 25  | 24    | 23 | 22 | 21 | 20   | 19 | 18     | 17    | 16 | EMI_COND |
|-------|------|------|------|----|-----|----|-----|-------|----|----|----|------|----|--------|-------|----|----------|
| Name  | C2WS | C2WH | C2RS |    |     |    | ADV |       |    |    |    | PRLT |    | BMOD E | PMODE |    |          |
| Type  | R/W  | R/W  | R/W  |    |     |    | R/W |       |    |    |    | R/W  |    | R/W    | R/W   |    |          |
| Reset | 0    | 0    | 0    |    |     |    | 1   |       |    |    |    | 0    |    | 0      | 0     | 0  |          |
| Bit   | 15   | 14   | 13   | 12 | 11  | 10 | 9   | 8     | 7  | 6  | 5  | 4    | 3  | 2      | 1     | 0  |          |
| Name  | DW   | RBLN |      |    | WST |    |     | PSIZE |    |    |    | RLT  |    |        |       |    |          |
| Type  | R/W  | R/W  |      |    | R/W |    |     | R/W   |    |    |    | R/W  |    |        |       |    |          |
| Reset | 0    | 1    |      |    | 0   |    |     | 0     |    |    |    | 7    |    |        |       |    |          |

|       |     |     |  |     |  |     |  |     |  |     |  |     |  |
|-------|-----|-----|--|-----|--|-----|--|-----|--|-----|--|-----|--|
| Type  | R/W | R/W |  |
| Reset | 0   | 1   |  | 0   |  | 0   |  | 7   |  |     |  |     |  |

**EMI+0020h EMI Control Register for BANK4**
**EMI\_CONE**

| Bit   | 31   | 30   | 29   | 28 | 27   | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19   | 18 | 17   | 16    |
|-------|------|------|------|----|------|----|----|----|-------|----|----|----|------|----|------|-------|
| Name  | C2WS |      | C2WH |    | C2RS |    |    |    | ADV   |    |    |    | PRLT |    | BMOD | PMODE |
| Type  | R/W  |      | R/W  |    | R/W  |    |    |    | R/W   |    |    |    | R/W  |    | R/W  | R/W   |
| Reset | 0    |      | 0    |    | 0    |    |    |    | 1     |    |    |    | 0    |    | 0    | 0     |
| Bit   | 15   | 14   | 13   | 12 | 11   | 10 | 9  | 8  | 7     | 6  | 5  | 4  | 3    | 2  | 1    | 0     |
| Name  | DW   | RBLN |      |    | WST  |    |    |    | PSIZE |    |    |    | RLT  |    |      |       |
| Type  | R/W  | R/W  |      |    | R/W  |    |    |    | R/W   |    |    |    | R/W  |    |      |       |
| Reset | 0    | 1    |      |    | 0    |    |    |    | 0     |    |    |    | 7    |    |      |       |

**EMI+0028h EMI Control Register for BANK5**
**EMI\_CONF**

| Bit   | 31   | 30   | 29   | 28 | 27   | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19   | 18 | 17   | 16    |
|-------|------|------|------|----|------|----|----|----|-------|----|----|----|------|----|------|-------|
| Name  | C2WS |      | C2WH |    | C2RS |    |    |    | ADV   |    |    |    | PRLT |    | BMOD | PMODE |
| Type  | R/W  |      | R/W  |    | R/W  |    |    |    | R/W   |    |    |    | R/W  |    | R/W  | R/W   |
| Reset | 0    |      | 0    |    | 0    |    |    |    | 1     |    |    |    | 0    |    | 0    | 0     |
| Bit   | 15   | 14   | 13   | 12 | 11   | 10 | 9  | 8  | 7     | 6  | 5  | 4  | 3    | 2  | 1    | 0     |
| Name  | DW   | RBLN |      |    | WST  |    |    |    | PSIZE |    |    |    | RLT  |    |      |       |
| Type  | R/W  | R/W  |      |    | R/W  |    |    |    | R/W   |    |    |    | R/W  |    |      |       |
| Reset | 0    | 1    |      |    | 0    |    |    |    | 0     |    |    |    | 7    |    |      |       |

**EMI+0030h EMI Control Register for BANK6**
**EMI\_CONG**

| Bit   | 31   | 30   | 29   | 28 | 27   | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19   | 18 | 17   | 16    |
|-------|------|------|------|----|------|----|----|----|-------|----|----|----|------|----|------|-------|
| Name  | C2WS |      | C2WH |    | C2RS |    |    |    | ADV   |    |    |    | PRLT |    | BMOD | PMODE |
| Type  | R/W  |      | R/W  |    | R/W  |    |    |    | R/W   |    |    |    | R/W  |    | R/W  | R/W   |
| Reset | 0    |      | 0    |    | 0    |    |    |    | 1     |    |    |    | 0    |    | 0    | 0     |
| Bit   | 15   | 14   | 13   | 12 | 11   | 10 | 9  | 8  | 7     | 6  | 5  | 4  | 3    | 2  | 1    | 0     |
| Name  | DW   | RBLN |      |    | WST  |    |    |    | PSIZE |    |    |    | RLT  |    |      |       |
| Type  | R/W  | R/W  |      |    | R/W  |    |    |    | R/W   |    |    |    | R/W  |    |      |       |
| Reset | 0    | 1    |      |    | 0    |    |    |    | 0     |    |    |    | 7    |    |      |       |

**EMI+0038h EMI Control Register for BANK7**
**EMI\_CONH**

| Bit   | 31   | 30   | 29   | 28 | 27   | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19   | 18 | 17   | 16    |
|-------|------|------|------|----|------|----|----|----|-------|----|----|----|------|----|------|-------|
| Name  | C2WS |      | C2WH |    | C2RS |    |    |    | ADV   |    |    |    | PRLT |    | BMOD | PMODE |
| Type  | R/W  |      | R/W  |    | R/W  |    |    |    | R/W   |    |    |    | R/W  |    | R/W  | R/W   |
| Reset | 0    |      | 0    |    | 0    |    |    |    | 1     |    |    |    | 0    |    | 0    | 0     |
| Bit   | 15   | 14   | 13   | 12 | 11   | 10 | 9  | 8  | 7     | 6  | 5  | 4  | 3    | 2  | 1    | 0     |
| Name  | DW   | RBLN |      |    | WST  |    |    |    | PSIZE |    |    |    | RLT  |    |      |       |
| Type  | R/W  | R/W  |      |    | R/W  |    |    |    | R/W   |    |    |    | R/W  |    |      |       |
| Reset | 0    | 1    |      |    | 0    |    |    |    | 0     |    |    |    | 7    |    |      |       |

For each bank (BANK0-BANK7), there is a dedicated control register in connection with the associated bank controller. These registers have the timing parameters that help the controller to convert memory access into proper timing waveform. Note that, except for parameters ADV, BMODE, PMODE, DW and RBLN, all the other parameters specified explicitly are based on bus clock speed in terms of cycle count.

**RLT** Read Latency Time

Specifying the number of wait-states to insert in bus transfer to requesting agent. Such parameter should be chosen carefully to meet the common parameter tACC (access time) for device in read operation. Example is shown below.

**Figure 16** Read Wait State Timing Diagram

| Access Time     | Read Latency Time in 52 MHz unit |
|-----------------|----------------------------------|
| 65 ns ~ 70 ns   | 4                                |
| 85 ns ~ 90 ns   | 5                                |
| 110 ns ~ 120 ns | 6                                |

**Table 15** Reference value of Read Latency Time for variant memory devices**PMODE** Page Mode Control

If target device supports page mode operations, the Page Mode Control can be enabled. Read in Page Mode is determined by set of parameters: PRLT and PSIZE.

- 0** disable page mode operation
- 1** enable page mode operation

**BMODE** Burst Mode Control

If target device supports burst mode operations, the Burst Mode Control can be enabled. Read in Burst Mode is determined by set of parameters: PRLT and PSIZE.

- 0** disable burst mode operation
- 1** enable burst mode operation

**PRLT** Read Latency Within the Same Page or in Burst Mode Operation

Since page/burst mode operation only help to eliminate read latency in subsequent burst within the same page, it does not matter what the initial latency is at all. Thus, it should still adopt RLT parameter for initial read or read between different pages even if PMODE or BMODE is set “1”.

- 000** zero wait state
- 001** one wait state
- 010** two wait state
- 011** three wait state
- 100** four wait state

**101** five wait state

**110** six wait state

**111** seven wait state

**PSIZE** Page/Burst Size for Page/Burst Mode Operation

These bit positions describe the page/burst size that the Page/Burst Mode enabled device will use.

**000** 8 byte, EA[22:3] remains the same

**001** 16 byte, EA[22:4] remains the same

**010** 32 byte, EA[22:5] remains the same

**011** 64 byte, EA[22:6] remains the same

**100~110** reserved for future use

**111** continuous sequential burst

**WST** Write Wait State

Specifying the parameters to extend adequate setup and hold time for target component in write operation. Those parameters also effectively insert wait-states in bus transfer to requesting agent. Example is shown in **Figure 17** and **Table 16**.



**Figure 17** Write Wait State Timing Diagram

| Write Pulse Width<br>(Write Data Setup Time) | Write Wait State in 52 MHz unit |
|----------------------------------------------|---------------------------------|
| 65 ns ~ 70 ns                                | 3                               |
| 85 ns ~ 90 ns                                | 4                               |
| 110 ns ~ 120 ns                              | 5                               |

**Table 16** Reference value of Write Wait State for variant memory devices

**RBLN** Read Byte Lane Enable

**0** all byte lanes held high during system reads

**1** all byte lanes held low during system reads

**DW** Data Width

Since the data width of internal system bus is fixed as 32-bit wide, any access to external components may be converted into more than one cycle, depending on transfer size and the parameter DW for the specific component. In general, this bit position of certain component is cleared to '0' upon system reset and is programmed during the

system initialization process prior to beginning access to it. Note that, dynamically changing this parameter will cause unexpected result.

**0** 16-bit device

**1** 8-bit device

**C2WS** Chip Select to Write Strobe Setup Time

**C2WH** Chip Select to Write Strobe Hold Time

**C2RS** Chip Select to Read Strobe Setup Time

**ADV** Address valid signal for burst mode flash memory

**0** ADV is 1T signal for flash memory address latch

**1** Keep ADV low during flash memory write access

### EMI+0040h EMI Re-map Control Register

### EMI\_REMAP

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2          | 1          | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|------------|------------|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>RM1</b> | <b>RMO</b> |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | R/W        | R/W        |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | IBOO<br>T  | 0          |   |

This register accomplishes the Memory Re-mapping Mechanism. Basically, it provides the kernel software program or system designer the capability to change memory configuration dynamically. Three kinds of configuration are permitted.

**RM[1:0]** Re-mapping control for Boot Code, BANK0 and BANK1, refer to **Table 17**.

| RM[1:0] | Address 00000000h – 07fffffh | Address 08000000h – 0fffffh |
|---------|------------------------------|-----------------------------|
| 00      | Boot Code                    | BANK1                       |
| 01      | BANK1                        | BANK0                       |
| 10      | BANK0                        | BANK1                       |
| 11      | BANK1                        | BANK0                       |

**Table 17** Memory Map Configuration

### EMI+0044h EMI General Control Register

### EMI\_GEN

| Bit   | 31                | 30            | 29          | 28          | 27          | 26                | 25          | 24                | 23          | 22          | 21          | 20          | 19          | 18           | 17          | 16          |
|-------|-------------------|---------------|-------------|-------------|-------------|-------------------|-------------|-------------------|-------------|-------------|-------------|-------------|-------------|--------------|-------------|-------------|
| Name  | <b>CKSR</b>       | <b>CKE2</b>   | <b>CKE4</b> | <b>CKE8</b> | <b>CSR</b>  | <b>CSE2</b>       | <b>CSE4</b> | <b>CSE8</b>       | <b>EASR</b> | <b>EAE2</b> | <b>EAE4</b> | <b>EAE8</b> | <b>EDSR</b> | <b>EDE2</b>  | <b>EDE4</b> | <b>EDE8</b> |
| Type  | R/W               | R/W           | R/W         | R/W         | R/W         | R/W               | R/W         | R/W               | R/W         | R/W         | R/W         | R/W         | R/W         | R/W          | R/W         | R/W         |
| Reset | 1                 | 1             | 0           | 0           | 0           | 0                 | 0           | 0                 | 1           | 1           | 0           | 0           | 0           | 0            | 0           | 0           |
| Bit   | 15                | 14            | 13          | 12          | 11          | 10                | 9           | 8                 | 7           | 6           | 5           | 4           | 3           | 2            | 1           | 0           |
| Name  | <b>PRCE<br/>N</b> | <b>PRCCNT</b> |             |             | <b>BANK</b> | <b>BURS<br/>T</b> | <b>EDA</b>  | <b>FLUS<br/>H</b> |             | <b>PDNE</b> | <b>CKE</b>  |             |             | <b>CKDLY</b> |             |             |
| Type  | R/W               | R/W           |             |             | R/W         | R/W               | R/W         | R/W               |             | R/W         | R/W         |             |             | R/W          |             |             |
| Reset | 0                 | 0             |             |             | 1           | 1                 | 1           | 1                 |             | 0           | 0           |             |             | 0            |             |             |

This register is the general control that can alter the behavior of all bank controllers according to specific features below.

**PRCEN** Enable Dummy Cycle Insertion for Pseudo SRAM Write Protection

**0** Disable

**1** Enable

**PRCCNT** Pseudo SRAM Dummy Cycle Insertion Count. This field defines the maximum number of continuous write operations is allowed for this Pseudo SRAM device. Once the number is reached, a dummy cycle will be inserted to this interface.

**BANK** Inter-Bank Turnaround Cycle Insertion

- 0 Disable
- 1 Enable

**BURST** Dummy Cycle Insertion Control between Two Burst Accesses

- 0 Disable
- 1 Enable

**EDA** ED[15:0] Activity

- 0 Drive ED Bus only on write access
- 1 Always drive ED Bus except for read access

**FLUSH** Instruction Cache Write Flush Control

**PDNE** Pseudo SRAM Power Down Mode Control

**CKE** Burst Mode Flash Clock Enable Control

**CKDLY** Burst Mode Flash Clock Delay Control

**CKSR** Pin ECLK Through Rate Control

**CKEn** Pin ECLK Driving Strength Control

**CSR** Pin ECS# Through Rate Control

**CSEN** Pin ECS# Driving Strength Control

**EASR** Pin EA[25:0] Through Rate Control

**EAE<sub>n</sub>** Pin EA[25:0] Driving Strength Control

**EDSR** Pin ED[15:0], EWR#, ERD#, ELB# and EUB# Through Rate Control

**EDEn** Pin ED[15:0], EWR#, ERD#, ELB# and EUB# Driving Strength Control

### EMI+0050h Code Cache and Code Prefetch Control Register

PREFETCH\_CO  
N

| Bit   | 31         | 30         | 29         | 28         | 27         | 26         | 25         | 24         | 23 | 22 | 21 | 20 | 19 | 18          | 17           | 16          |
|-------|------------|------------|------------|------------|------------|------------|------------|------------|----|----|----|----|----|-------------|--------------|-------------|
| Name  | <b>DB7</b> | <b>DB6</b> | <b>DB5</b> | <b>DB4</b> | <b>DB3</b> | <b>DB2</b> | <b>DB1</b> | <b>DB0</b> |    |    |    |    |    | <b>DWRP</b> | <b>DPRE</b>  | <b>DCAC</b> |
| Type  | R/W        |    |    |    |    |    | 8           | F            | H           |
| Reset | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          |    |    |    |    |    | 0           | 0            | 0           |
| Bit   | 15         | 14         | 13         | 12         | 11         | 10         | 9          | 8          | 7  | 6  | 5  | 4  | 3  | 2           | 1            | 0           |
| Name  | <b>IB7</b> | <b>IB6</b> | <b>IB5</b> | <b>IB4</b> | <b>IB3</b> | <b>IB2</b> | <b>IB1</b> | <b>IB0</b> |    |    |    |    |    | <b>IWRP</b> | <b>IPREF</b> | <b>ICAC</b> |
| Type  | R/W        |    |    |    |    |    | 8           | H            | H           |
| Reset | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          |    |    |    |    |    | 0           | 0            | 0           |

This register is used to control the functions of Code/Data Cache and Code/Data Prefetch. The Code/Data Cache is a low latency memory that can store up to 16 most recently used instruction codes/data. When an instruction/data fetch hits the one in the code/data cache, not only can the access time be minimized, but also the signaling to off chip ROM or Flash can be relieved. In addition, it can also store up to 16 prefetched instruction codes/data when the Code/Data Prefetch function is enabled. The Code/Data Prefetch is a sophisticated controller that can predict and fetch the instruction codes/data in advance based on previous code/data fetching sequence. As the Code/Data Prefetch always performs the fetch during the period that the EMI interface is in IDLE state, the bandwidth to off chip memory could be fully utilized. If the instruction/data fetch hits one of the prefetched codes/data, the access time can be minimized and the overall system performance can be enhanced.

**xWRP8** Prefetch Size

**0** 8 bytes

**1** 16 bytes

**xBn** Prefetchable/Cacheable Area

These bit positions determine the prefetchable and cacheable banks in which the instruction/data could be cached or prefetched.

**xPREF** Prefetch Enable

**xCACH** Cache Enable

### EMI+0060h EMI Patch Enable Register

### EMI\_PATCHEN

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2          | 1          | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|------------|------------|-----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>EN1</b> | <b>EN0</b> |     |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |            | R/W        | R/W |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |            | 0          | 0   |

**ENn** Patch Enable

### EMI+0064h EMI Patch Address 0 Register

### EMI\_PADD0

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18           | 17  | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|-----|----|
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>PADD0</b> |     |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |              | R/W |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2            | 1   | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>PADD0</b> |     |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |              | R/W |    |

**PADD0** Patch 0 Address

### EMI+006Ch EMI Patch Instruction 0 Register

### EMI\_PDAT0

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18           | 17  | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|-----|----|
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>PDAT0</b> |     |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |              | R/W |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2            | 1   | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>PDAT0</b> |     |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |              | R/W |    |

**PDAT0** Patch 0 Instruction

### EMI+0074h EMI Patch Address 1 Register

### EMI\_PADD1

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18           | 17  | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|-----|----|
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>PADD1</b> |     |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |              | R/W |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2            | 1   | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>PADD1</b> |     |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |              | R/W |    |

**PADD1** Patch 1 Address

### EMI+007Ch EMI Patch Instruction 1 Register

### EMI\_PDAT1

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18           | 17  | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|-----|----|
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>PDAT1</b> |     |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |              | R/W |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2            | 1   | 0  |



|      |              |
|------|--------------|
| Name | <b>PDAT1</b> |
| Type | R/W          |

**PDAT1** Patch 1 Instruction

## 4 Microcontroller Peripherals

Microcontroller (MCU) Peripherals are devices that are under direct control of the Microcontroller. Most of them are attached to the Advanced Peripheral Bus (APB) of the MCU subsystem, and serve as APB slaves. Each MCU peripheral has to be accessed as a memory-mapped I/O device; that is, the MCU or the DMA bus master read from or write to specific peripheral by issuing memory-addressed transactions.

### 4.1 Pulse-Width Modulation Outputs

#### 4.1.1 General Description

Two generic pulse-width modulators are implemented to generate pulse sequences with programmable frequency and duty cycle for LCD backlight or charging purpose. The duration of the PWM output signal is Low as long as the internal counter value is greater than or equal to the threshold value. The waveform is shown in **Figure 18**.



**Figure 18** PWM waveform

The frequency and volume of PWM output signal are determined by these registers: PWM\_COUNT, PWM\_THRES, PWM\_CON. POWERDOWN (pdn\_pwm) signal is applied to power-down the PWM module. When PWM is deactivated (POWERDOWN=1), the output will be in Low state.

The output PWM frequency is determined

by:  $\frac{CLK}{(PWM\_CON + 1) \times 2 \times (PWM\_COUNT + 1)}$  CLK = 13000000 when CLKSEL = 1, CLK = 32000 when CLKSEL = 0

The output PWM duty cycle is determined by:  $\frac{PWM\_THRES}{PWM\_COUNT + 1}$

Note that PWM\_THRES should be less than the PWM\_COUNT. If this condition is not satisfied, the output pulse of the PWM will always be in High state.

#### 4.1.2 Register Definitions

##### PWM+0000h PWM1 Control register

##### PWM1\_CON

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|--------|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | CLKSEL | CLK [1:0] |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W    | R/W       |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0      | 0         |

**CLK** Select PWM1 clock prescaler scale

- 00** CLK Hz
- 01** CLK/2 Hz
- 10** CLK/4 Hz
- 11** CLK/8 Hz

Note: When PWM1 module is disabled, its output should be kept in LOW state.

**CLKSEL** Select PWM1 clock

- 0** CLK=13M Hz
- 1** CLK=32K Hz

#### PWM+0004h PWM1 max counter value register

#### PWM1\_COUNT

| Bit   | 15                | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | PWM1_COUNT [12:0] |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 1FFFh             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**PWM1\_COUNT** PWM1 max counter value. It will be the initial value for the internal counter. If PWM1\_COUNT is written when the internal counter is counting backwards, no matter which mode it is, there is no effect until the internal counter counts down to zero, i.e. a complete period.

#### PWM+0008h PWM1 Threshold Value register

#### PWM1\_THRES

| Bit   | 15                | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | PWM1_THRES [12:0] |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0                 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**PWM1\_THRES** Threshold value. When the internal counter value is greater than or equals to PWM1\_THRES, the PWM1 output signal will be “0”; when the internal counter is less than PWM1\_THRES, the PWM1 output signal will be “1”.

#### PWM+000Ch PWM2 Control register

#### PWM2\_CON

| Bit   | 15                 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|--------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  |                    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | CLKSEL_L CLK [1:0] |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | R/W R/W 0 0        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**CLK** Select PWM2 clock prescaler scale

- 00** CLK Hz
- 02** CLK/2 Hz
- 10** CLK/4 Hz
- 11** CLK/8 Hz

Note: When PWM2 module is disabled, its output should be keep in LOW state.

**CLKSEL** Select PWM2 clock

- 0** CLK=13M Hz
- 1** CLK=32K Hz

#### PWM+0010h PWM2 max counter value register

#### PWM2\_COUNT

| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|

|       |  |  |  |                   |
|-------|--|--|--|-------------------|
| Name  |  |  |  | PWM2_COUNT [12:0] |
| Type  |  |  |  | R/W               |
| Reset |  |  |  | 1FFFh             |

**PWM2\_COUNT** PWM2 max counter value. It will be the initial value for the internal counter. If PWM2\_COUNT is written when the internal counter is counting backwards, no matter which mode it is, there is no effect until the internal counter counts down to zero, i.e. a complete period.

### PWM+0014h PWM2 Threshold Value register

### PWM2\_THRES

|                          |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     |
|--------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|
| Bit                      | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
| <b>PWM2_THRES [12:0]</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     |
| Name                     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |     |
| Type                     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W |
| Reset                    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0   |

**PWM2\_THRES** Threshold value. When the internal counter value is greater than or equals to PWM2\_THRES, the PWM1 output signal will be “0”; when the internal counter is less than PWM2\_THRES, the PWM2 output signal will be “1”.

Figure 19 shows the PWM waveform with register value present.



Figure 19 PWM waveform with register value present

## 4.2 Alerter

### 4.2.1 General Description

The output of the Alerter has two sources: one is the enhanced pwm output signal, which is implemented inside the Alerter module; the other is the PDM signal that comes from the DSP domain directly. The output source can be selected via the register ALERT\_CON.

The enhanced pwm has three operation modes and is implemented to generate a signal with programmable frequency and tone volume. The frequency and volume are determined by four registers: ALERTER\_CNT1, ALERTER\_THRES, ALERTER\_CNT2 and ALERTER\_CON. ALERTER\_CNT1 and ALERTER\_CNT2 are the initial counting values of internal counter1 and internal counter2, respectively. POWERDOWN signal is applied to power-down the Alerter module. When Alerter is deactivated (POWERDOWN=1), the output will be in low state. The waveform of the alerter from enhanced pwm source in different modes can be shown in Figure 20. In mode 1, the polarity of alerter output signal according to the relationship between internal counter1 and the programmed threshold will be inverted each time internal counter2 reaches zero. In mode2, each time the internal counter2 count backwards to zero the alerter output signal toggles between the normal pwm signal (i.e. signal is low as long as the internal counter1 value is greater than or equals to ALERTER\_THRES, and it is high when the internal counter1 is less than ALERTER\_THRES) and low state. In mode3, the value of internal counter2 has no effect on output signal. That is, the alerter output signal is low as long as the internal counter1 value is above the programmed threshold, and is high when the internal counter1 is less than ALERTER\_THRES, regardless of internal counter2's value.



**Figure 20** Alerter waveform

The output signal frequency is determined by:

$$\left\{ \begin{array}{l} \frac{13000000}{2 \times (\text{ALERTER\_CON}[1:0]+1) \times (\text{ALERTER\_CNT1}+1) \times (\text{ALERTER\_CNT2}+1)} \quad \text{for mode 1 and mode 2} \\ \frac{13000000}{(\text{ALERTER\_CNT1}+1) \times (\text{ALERTER\_CON}[1:0])} \quad \text{for mode 3} \end{array} \right.$$

The volume of the output signal is determined by:  $\frac{\text{ALERTER\_THRES}}{\text{ALERTER\_CNT1}+1}$

#### 4.2.2 Register Definitions

##### ALTER+0000h Alerter counter1 value register

**ALERTER\_CNT  
1**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                          |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>ALERTER_CNT1 [15:0]</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W                        |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | FFFFh                      |

**ALERTER\_CNT1** Alerter max counter's value. ALERTER\_CNT1 is the initial value of internal counter1. If ALERTER\_CNT1 is written when the internal counter1 is counting backwards, no matter which mode it is, there is no effect until the internal counter1 counts down to zero, i.e. a complete period.

##### ALTER+0004h Alerter threshold value register

**ALERTER\_THR  
ES**

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                           |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------------------------|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>ALERTER_THRES [15:0]</b> |

|       |     |
|-------|-----|
| Type  | R/W |
| Reset | 0   |

**ALERTER\_THRES** Threshold value. When the internal counter1 value is greater than or equals to ALERTER\_THRES, the Alerter output signal will be low state; when the counter1 is less than ALERTER\_THRES, the Alerter output signal will be high state.

### ALTER+0008h Alerter counter2 value register

**ALERTER\_CNT  
2**

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                           |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------------------------|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                         |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>ALERTER_CNT2 [5:0]</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W                       |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 111111b                   |

**AIERTER\_CNT2** ALERTER\_CNT2 is the initial value for internal counter2. The internal counter2 decreases by one everytime the internal counter1 count down to zero. The polarity of alerter output signal which depends on the relationship between the internal counter1 and ALERTER\_THRES will be inverted every time when the internal counter2 counts down to zero. E.g. in the beginning, the output signal is low when the internal counter1 is not less than ALERTER\_THRES and is high when the internal counter1 is less than ALERTER\_THRES. But after the internal counter2 counts down to zero, the output signal will be high when the internal counter1 is not less than ALERTER\_THRES and will be low when the internal counter1 is less than ALERTER\_THRES.

### ALTER+000Ch Alerter control register

**ALERTER\_CON**

|       |    |    |    |    |    |    |   |   |             |   |   |   |             |   |   |                  |
|-------|----|----|----|----|----|----|---|---|-------------|---|---|---|-------------|---|---|------------------|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7           | 6 | 5 | 4 | 3           | 2 | 1 | 0                |
| Name  |    |    |    |    |    |    |   |   | <b>TYPE</b> |   |   |   | <b>MODE</b> |   |   | <b>CLK [1:0]</b> |
| Type  |    |    |    |    |    |    |   |   | R/W         |   |   |   | R/W         |   |   | R/W              |
| Reset |    |    |    |    |    |    |   |   | 0           |   |   |   | 0           |   |   | 0                |

**CLK** Select PWM Waveform clock

- 00** 13M Hz
- 01** 13/2M Hz
- 10** 13/4M Hz
- 11** 13/8M Hz

**MODE** Select Alerter mode

- 00** Mode 1 selected
- 01** Mode 2 selected
- 10** Mode 3 selected

**TYPE** Select the ALERTER output source from PWM or PDM

- 0** Output generated from PWM path
- 1** Output generated from PDM path

Note: When alerter module is power down, its output should be kept in low state.

Figure 21 shows the Alerter waveform with register value present.



**Figure 21** Alerter output signal from enhanced pwm with register value present

### 4.3 SIM Interface

The MT6219 contains a dedicated smart card interface to allow the MCU access to the SIM card. It can operate via 5 terminals, using SIMVCC, SIMSEL, SIMRST, SIMCLK and SIMDATA.



**Figure 22** SIM Interface Block Diagram

The SIMVCC is used to control the external voltage supply to the SIM card and SIMSEL determines the regulated smart card supply voltage. SIMRST is used as the SIM card reset signal. SIMDATA and SIMCLK are used for data exchange purpose.

The SIM interface acts as a half duplex asynchronous communication port and its data format is composed of ten consecutive bits: a start bit in state Low, eight information bits, and a tenth bit used for parity checking. The data format can be divided into two modes as follows:

Direct Mode (ODD=SDIR=SINV=0)

**SB D0 D1 D2 D3 D4 D5 D6 D7 PB**

**SB:** Start Bit (in state Low)

**Dx:** Data Byte (LSB is first and logic level ONE is High)

**PB:** Even Parity Check Bit

Indirect Mode (ODD=SDIR=SINV=1)
**SB N7 N6 N5 N4 N3 N2 N1 N0 PB**
**SB:** Start Bit (in state Low)

**Nx:** Data Byte (MSB is first and logic level ONE is Low)

**PB:** Odd Parity Check Bit

If the receiver gets a wrong parity bit, it will respond by pulling the SIMDATA Low to inform the transmitter and the transmitter will retransmit the character.

When the receiver is a SIM Card, the error response starts 0.5 bits after the PB and it may last for 1~2 bit periods.

When the receiver is the SIM interface, the error response starts 0.5 bits after the PB and lasts for 1.5 bit period.

When the SIM interface is the transmitter, it will take a total of 14 bits guard period for the error response to appear. If the receiver shows the error response, the SIM interface will retransmit the previous character again, otherwise it will transmit the next character.



Figure 23 SIM Interface Timing Diagram

#### 4.3.1 Register Definitions

**SIM+0000h      SIM module control register**
**SIM\_CON**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2    | 1         | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|------|-----------|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | WRST | CSTO<br>P | SIMO<br>N |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | W    | R/W       | R/W       |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0    | 0         | 0         |

**SIMON** SIM card power-up/power-down control

- 0** Initiate the card deactivation sequence
- 1** Initiate the card activation sequence

**CSTOP** Enable clock stop mode. Together with CPOL in SIM\_CNF register, it determines the polarity of the SIMCLK in this mode.

- 0** Enable the SIMCLK output.
- 1** Disable the SIMCLK output

**WRST** SIM card warm reset control

### **SIM+0004h      SIM module configuration register**

**SIM\_CNF**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10          | 9           | 8           | 7           | 6             | 5          | 4           | 3           | 2           | 1            | 0            |
|-------|----|----|----|----|----|-------------|-------------|-------------|-------------|---------------|------------|-------------|-------------|-------------|--------------|--------------|
| Name  |    |    |    |    |    | <b>HFEN</b> | <b>T0EN</b> | <b>T1EN</b> | <b>TOUT</b> | <b>SIMSEL</b> | <b>ODD</b> | <b>SDIR</b> | <b>SINV</b> | <b>CPOL</b> | <b>TXACK</b> | <b>RXACK</b> |
| Type  |    |    |    |    |    | R/W         | R/W         | R/W         | R/W         | R/W           | R/W        | R/W         | R/W         | R/W         | R/W          | R/W          |
| Reset |    |    |    |    |    | 0           | 0           | 0           | 0           | 0             | 0          | 0           | 0           | 0           | 0            | 0            |

**RXACK** SIM card reception error handshake control

- 0** Disable character receipt handshaking
- 1** Enable character receipt handshaking

**TXACK** SIM card transmission error handshake control

- 0** Disable character transmission handshaking
- 1** Enable character transmission handshaking

**CPOL** SIMCLK polarity control in clock stop mode

- 0** Make SIMCLK stop in LOW level
- 1** Make SIMCLK stop in HIGH level

**SINV** Data Inverter.

- 0** Not invert the transmitted and received data
- 1** Invert the transmitted and received data

**SDIR** Data Transfer Direction

- 0** LSB is transmitted and received first
- 1** MSB is transmitted and received first

**ODD** Select odd or even parity

- 0** Even parity
- 1** Odd parity

**SIMSEL** SIM card supply voltage select

- 0** SIMSEL pin is set to LOW level
- 1** SIMSEL pin is set to HIGH level

**TOUT** SIM work waiting time counter control

- 0** Disable Time-Out counter
- 1** Enable Time-Out counter

**T1EN** T=1 protocol controller control

- 0** Disable T=1 protocol controller
- 1** Enable T=1 protocol controller

**T0EN** T=0 protocol controller control

- 0** Disable T=0 protocol controller
- 1** Enable T=0 protocol controller

**HFEN** Hardware flow control

- 0** Disable hardware flow control
- 1** Enable hardware flow control

**SIM +0008h SIM Baud Rate Register**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | BAUD[4:0] |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W       |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 22d       |

**SIM\_BRR****SIMCLK** Set SIMCLK frequency

- 00** 13/2 MHz
- 01** 13/4 MHz
- 10** 13/8 MHz
- 11** 13/12 MHz

**BAUD** Determines the 16\*baud rate as a division of SIMCLK (SIMCLK/BAUD[3:0])**SIM +0010h SIM interrupt enable register****SIM\_IRQEN**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | EDCE<br>RR |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | T1EN<br>D  |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W        |

RXER TOEN SIMO ATRER TXER TOU OVRU RXTID TXTID

TOEN SIMO ATRER TXER TOU OVRU RXTID TXTID

EDCE T1EN RXER TOEN SIMO ATRER TXER TOU OVRU RXTID TXTID

For all these bits

- 0** Interrupt is disabled
- 1** Interrupt is enabled

**SIM +0014h SIM module status register****SIM\_STA**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | EDCE<br>RR |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RC         |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | —          |

RXER TOEN SIMO ATRER TXER TOU OVRU RXTID TXTID

TOEN SIMO ATRER TXER TOU OVRU RXTID TXTID

EDCE T1EN RXER TOEN SIMO ATRER TXER TOU OVRU RXTID TXTID

**TXTIDE** Transmit FIFO tide mark reached interrupt occurred**RXTIDE** Receive FIFO tide mark reached interrupt occurred**OVRUN** Transmit/Receive FIFO overrun interrupt occurred**TOUT** Between character time-out interrupt occurred**TXERR** Character transmission error interrupt occurred**ATRERR** ATR start time-out interrupt occurred**SIMOFF** Card deactivation complete interrupt occurred**TOEND** Data Transfer handled by T=0 Controller completed interrupt occurred**RXERR** Character reception error interrupt occurred**T1END** Data Transfer handled by T=1 Controller completed interrupt occurred**EDCERR** T=1 Controller CRC error occurred**SIM +0020h SIM retry limit register****SIM\_RETRY**

| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|

|       |  |  |  |  |                |     |  |  |  |  |  |  |  |                |  |
|-------|--|--|--|--|----------------|-----|--|--|--|--|--|--|--|----------------|--|
| Name  |  |  |  |  | <b>TXRETRY</b> |     |  |  |  |  |  |  |  | <b>RXRETRY</b> |  |
| Type  |  |  |  |  |                | R/W |  |  |  |  |  |  |  | R/W            |  |
| Reset |  |  |  |  |                | 3h  |  |  |  |  |  |  |  | 3h             |  |

**RXRETRY** Specify the max. numbers of receive retries that are allowed when parity error has occurred.

**TXRETRY** Specify the max. numbers of transmit retries that are allowed when parity error has occurred.

### SIM +0024h SIM FIFO tide mark register

**SIM\_TIDE**

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                    |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|--------------------|---|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                  | 0 |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | <b>RXTIDE[3:0]</b> |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W                |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0h                 |   |

**RXTIDE** Trigger point for RXTIDE interrupt

**TXTIDE** Trigger point for TXTIDE interrupt

### SIM +0030h Data register used as Tx/Rx Data Register

**SIM\_DATA**

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                  |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|------------------|---|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                | 0 |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | <b>DATA[7:0]</b> |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W              |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | —                |   |

**DATA** Eight data digits. These correspond to the character being read or written

### SIM +0034h SIM FIFO count register

**SIM\_COUNT**

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                   |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-------------------|---|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                 | 0 |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | <b>COUNT[4:0]</b> |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W               |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0h                |   |

**COUNT** The number of characters in the SIM FIFO when read, and flushes when written.

### SIM +0040h SIM activation time register

**SIM\_ATIME**

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                    |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|--------------------|---|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                  | 0 |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | <b>ATIME[15:0]</b> |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W                |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | AFC7h              |   |

**ATIME** The register defines the duration, in SIM clock cycles, of the time taken for each of the three stages of the card activation process

### SIM +0044h SIM deactivation time register

**SIM\_DTIME**

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                    |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|--------------------|---|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                  | 0 |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | <b>DTIME[11:0]</b> |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W                |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 3E7h               |   |

**DTIME** The register defines the duration, in 13MHz clock cycles, of the time taken for each of the three stages of the card deactivation sequence

### SIM +0048h Character to character waiting time register

**SIM\_WTIME**

|     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|

|       |             |
|-------|-------------|
| Name  | WTIME[15:0] |
| Type  | R/W         |
| Reset | 983h        |

**WTIME** Maximum interval between the leading edge of two consecutive characters in 4 ETU unit

### SIM +004Ch Block to block guard time register

**SIM\_GTIME**

|       |              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|--------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit   | 15           | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | <b>GTIME</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 10d          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**GTIME** Minimum interval between the leading edge of two consecutive characters sent in opposite directions in ETU unit

### SIM +0060h SIM command header register: INS

**SIM\_INS**

|       |             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|-------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit   | 15          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | <b>INSD</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0h          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**SIMINS** This field should be identical to the INS instruction code. When writing to this register, the T=0 controller will be activated and data transfer will be initiated.

**INSD** [Description for this register field]

- 0 T=0 controller receives data from the SIM card
- 1 T=0 controller sends data to the SIM card

### SIM +0064h SIM command header register: P3

**SIM\_P3(ICC\_EN)**

|       |                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|-------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit   | 15                | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | <b>SIMP3[8:0]</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0h                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**SIMP3** This field should be identical to the P3 instruction code. It should be written prior to the SIM\_INS register. While the data transfer is going on, this field shows the no. of the remaining data to be sent or to be received

### SIM +0068h SIM procedure byte register: SW1

**SIM\_SW1(ICC\_EN)**

|       |                    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|--------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit   | 15                 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | <b>SIMSW1[7:0]</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RO                 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0h                 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**SIMSW1** This field holds the last received procedure byte for debug purpose. When the T0END interrupt occurred, it keeps the SW1 procedure byte.

### SIM +006Ch SIM procedure byte register: SW2

**SIM\_SW2(ICC\_DC)**

|      |                    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|--------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit  | 15                 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name | <b>SIMSW2[7:0]</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | RO                 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**Reset** **0h**

**SIMSW2** This field holds the SW2 procedure byte

#### **4.3.2 SIM Card Insertion and Removal**

The detection of physical connection to the SIM card and card removal is done by the external interrupt controller or by GPIO.

#### 4.3.3 Card Activation and Deactivation

The card activation and deactivation sequence are both controlled by hardware. The MCU initiates the activation sequence by writing a “1” to bit 0 of the SIM\_CON register, and then the interface performs the following activation sequence:

- Assert SIMRST LOW
  - Set SIMVCC at HIGH level and SIMDATA in reception mode
  - Enable SIMCLK clock
  - De-assert SIMRST HIGH (required if it belongs to active low reset SIM card)

The final step in a typical card session is contact deactivation in order to prevent the card from being electrically damaged. The deactivation sequence is initiated by writing a “0” to bit 0 of the SIM\_CON register, and then the interface performs the following deactivation sequence:

- Assert SIMRST LOW
  - Set SCIMCLK at LOW level
  - Set SIMDATA at LOW level
  - Set SIMVCC at LOW level

#### 4.3.4 Answer to Reset Sequence

After card activation, a reset operation results in an answer from the card consisting of the initial character TS, followed by at most 32 characters. The initial character TS provides a bit synchronization sequence and defines the conventions to interpret data bytes in all subsequent characters.

On reception of the first character, TS, MCU should read this character, establish the respective required convention and reprogram the related registers. These processes should be completed prior to the completion of reception of the next character. And then, the remainder of the ATR sequence is received, read via the SIM\_DATA in the selected convention and interpreted by the software.

The timing requirement and procedures for ATR sequence are handled by hardware and shall meet the requirement of ISO 7816-3 as shown in **Figure 24**.



**Figure 24** Answer to Reset Sequence

| Time | Value          | Comment                                   |
|------|----------------|-------------------------------------------|
| T1   | > 400 SIMCLK   | SIMCLK start to ATR appear                |
| T2   | < 200 SIMCLK   | SIMCLK start to SIMDATA in reception mode |
| T3   | > 40000 SIMCLK | SIMCLK start to SIMRST High               |
| T4   | —              | SIMVCC High to SIMCLK start               |
| T5   | —              | SIMRST Low to SIMCLK stop                 |
| T6   | —              | SIMCLK stop to SIMDATA Low                |
| T7   | —              | SIMDATA Low to SIMVCC Low                 |

**Table 18** Answer to Reset Sequence Time-Out Condition

### 4.3.5 SIM Data Transfer

Two transfer modes are provided, either in software controlled byte-by-byte fashion or in a block fashion using T=0 controller and DMA controller. In both modes, the time-out counter can be enabled to monitor the elapsed time between two consecutive bytes.

#### 4.3.5.1 Byte Transfer Mode

This mode is used during ATR and PPS procedure. In this mode, the SIM interface only ensures error free character transmission and reception.

##### Receiving Character

Upon detection of the start-bit sent by SIM card, the interface transforms into reception mode and the following bits are shifted into an internal register. If no parity error is detected or character-receive handshaking is disabled, the received-character is written into the SIM FIFO and the SIM\_CNT register is increased by one. Otherwise, the SIMDATA line is held low for 0.5 ETU after detecting the parity error for 1.5 ETU, and the character is re-received. If a character fails to be received correctly for the RXRETRY times, the receive-handshaking is aborted and the last-received character is written into the SIM FIFO, the SIM\_CNT is increased by one and the RXERR interrupt is generated.

When the number of characters held in the receive FIFO exceeds the level defined in the SIM\_TIDE register, a RXTIDE interrupt is generated. The number of characters held in the SIM FIFO can be determined by reading the SIM\_CNT register and writing to this register will flush the SIM FIFO.

## Sending Character

Characters that are to be sent to the card are first written into the SIM FIFO and then automatically transmitted to the card at timed intervals. If character-transmit handshaking is enabled, the SIMDATA line is sampled at 1 ETU after the parity bit. If the card indicates that it did not receive the character correctly, the character is retransmitted a maximum of TXRETRY times before a TXERR interrupt is generated and the transmission is aborted. Otherwise, the succeeding byte in the SIM FIFO is transmitted.

If a character fails to be transmitted and a TXERR interrupt is generated, the interface needs to be reset by flushing the SIM FIFO before any subsequent transmit or receive operation.

When the number of characters held in the SIM FIFO falls below the level defined in the SIM\_TIDE register, a TXTIDE interrupt is generated. The number of characters held in the SIM FIFO can be determined by reading the SIM\_CNT register and writing to this register will flush the SIM FIFO.

### 4.3.5.2 Block Transfer Mode

Basically, the SIM interface is designed to work in conjunction with the T=0 protocol controller and the DMA controller during non-ATR and non-PPS phase; although it is still possible for software to service the data transfer manually as in byte transfer mode if necessary, and thus the T=0 protocol should be controlled by software.

The T=0 controller is accessed via four registers representing the instruction header bytes INS and P3, and the procedure bytes SW1 and SW2. These registers are:

SIM\_INS, SIM\_P3

SIM\_SW1, SIM\_SW2

During characters transfer, SIM\_P3 holds the number of characters to be sent or to be received and SIM\_SW1 holds the last received procedure byte including NULL, ACK, NACK and SW1 for debug purpose.

### Data Receive Instruction

Data Receive Instructions receive data from the SIM card. It is instantiated as the following procedure.

1. Enable the T=0 protocol controller by setting the T0EN bit to 1 in SIM\_CNF register
2. Program the SIM\_TIDE register to 0x0000 (TXTIDE = 0, RXTIDE = 0)
3. Program the SIM IRQEN to 0x019C (Enable RXERR, TXERR, T0END, TOUT and OVRUN interrupts)
4. Write CLA, INS, P1, P2 and P3 into SIM FIFO
5. Program the DMA controller :  
DMA<sub>n</sub>\_MSBSRC and DMA<sub>n</sub>\_LSBSRC : address of SIM\_DATA register  
DMA<sub>n</sub>\_MSBDST and DMA<sub>n</sub>\_LSBDST : memory address reserved to store the received characters  
DMA<sub>n</sub>\_COUNT : identical to P3 or 256 (if P3 == 0)  
DMA<sub>n</sub>\_CON : 0x0078
6. Write P3 into SIM\_P3 register and then INS into SIM\_INS register (Data Transfer is initiated now)
7. Enable the Time-out counter by setting the TOUT bit to 1 in SIM\_CNF register
8. Start the DMA controller by writing 0x8000 into the DMA<sub>n</sub>\_START register to

Upon completion of the Data Receive Instruction, T0END interrupt will be generated and then the Time-out counter should be disabled by setting the TOUT bit back to 0 in SIM\_CNF register.

If error occurs during data transfer (RXERR, TXERR, OVRUN or TOUT interrupt is generated), the SIM card should be deactivated first and then activated prior subsequent operations.

## Data Send Instruction

Data Send Instructions send data to the SIM card. It is instantiated as the following procedure.

1. Enable the T=0 protocol controller by setting the TOEN bit to 1 in SIM\_CNF register
2. Program the SIM\_TIDE register to 0x0100 (TXTIDE = 1, RXTIDE = 0)
3. Program the SIM\_IRQEN to 0x019C (Enable RXERR, TXERR, TOEND, TOUT and OVRUN interrupts)
4. Write CLA, INS, P1, P2 and P3 into SIM FIFO
5. Program the DMA controller :  
DMA $n$ \_MSBSRC and DMA $n$ \_LSBSRC : memory address reserved to store the transmitted characters  
DMA $n$ \_MSBDST and DMA $n$ \_LSBDST : address of SIM\_DATA register  
DMA $n$ \_COUNT : identical to P3  
DMA $n$ \_CON : 0x0074
6. Write P3 into SIM\_P3 register and then (0x0100 | INS) into SIM\_INS register (Data Transfer is initiated now)
7. Enable the Time-out counter by setting the TOUT bit to 1 in SIM\_CNF register
8. Start the DMA controller by writing 0x8000 into the DMA $n$ \_START register

Upon completion of the Data Send Instruction, TOEND interrupt will be generated and then the Time-out counter should be disabled by setting the TOUT bit back to 0 in SIM\_CNF register.

If error occurs during data transfer (RXERR, TXERR, OVRUN or TOUT interrupt is generated), the SIM card should be deactivated first and then activated prior to subsequent operations.

## 4.4 Keypad Scanner

### 4.4.1 General Description

The keypad can be divided into two parts: one is the keypad interface including 7 columns and 6 rows; the other is the key detection block which provides key pressed, key released and de-bounce mechanism. Each time the key is pressed or released, i.e. something different in the 7 x 6 matrix, the key detection block will sense it, and it will start to recognize if it is a key pressed or key released event. Whenever the key status changes and is stable, a KEYPAD IRQ will be issued. The MCU can then read the key(s) pressed directly in KP\_HI\_KEY, KP\_MID\_KEY and KP\_LOW\_KEY registers. To ensure that the key pressed information will not be missed, the status register in keypad will not be read clear by APB bus read command. The status register can only be changed by the key-pressed detection FSM. This keypad can detect one or two key-pressed simultaneously with any combination. **Figure 25** shows one key pressed condition. **Figure 26(a)** and **Figure 26(b)** indicate two keys pressed cases. Since the key press detection depends on the high or low level of the external keypad interface, if keys are pressed at the same time and there exists a key that is on the same column and the same row with the other keys, it will not be able to decode the correct key pressed. For example, if there are three key presses: key1 = (x1, y1), key2 = (x2, y2), and key3 = (x1, y2), then both key3 and key4 = (x2, y1) will be detected, and therefore it will not possible to distinguish correctly. Hence, the keypad can detect only one or two keys pressed simultaneously at any combination. Due to the keypad interface, more than two keys pressed simultaneously with some specific pattern will get the wrong information. If these specific patterns are excluded, the keypad-scanning block can detect 11 keys at the same time and it's shown as **Figure 27**.



Figure 25 One key pressed with de-bounce mechanism denoted



Figure 26 (a) Two keys pressed, case 1 (b) Two keys pressed, case 2



Figure 27 11 keys are detected at the same time

#### 4.4.2 Register Definitions

##### KP +0000h Keypad status KP\_STA

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | STA |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RO  |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0   |   |

**STA** This register indicates the keypad status, and it will not be cleared by read.

**0** No key pressed

1 Key pressed

**KP +0004h Keypad scanning output, the lower 16 keys KP\_LOW\_KEY**

| Bit   | 15                 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|--------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | <b>KEYS [15:0]</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RO                 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | FFFFh              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**KP +0008h Keypad scanning output, the medium 16 keys KP\_MID\_KEY**

| Bit   | 15                  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|---------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | <b>KEYS [31:16]</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RO                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | FFFFh               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**KP+000Ch Keypad scanning output, the higher 4 keys KP\_HIGH\_KEY**

| Bit   | 15                  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|---------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | <b>KEYS [41:32]</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RO                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 3FFh                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

These two registers list the status of 42 keys on the keypad. When the MCU receives the KEYPAD IRQ, both two registers must be read. If any key is pressed, the relative bit will be set to 0.

**KEYS** Status list of the 42 keys.

**KP +00010h De-bounce period setting KP\_DEBOUNCE**

| Bit   | 15                     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | <b>DEBOUNCE [13:0]</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W                    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 400h                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

This register defines the waiting period before key press or release events are considered stale.

**DEBOUNCE** De-bounce time = KP\_DEBOUNCE/32 ms.

## 4.5 General Purpose Inputs/Outputs

MT-6219 offers 55 general-purpose I/O pins and 5 general-purpose output pins. By setting the control registers, MCU software can control the direction, the output value, and read the input values on these pins. These GPIOs and GPOs are multiplexed with other functionalities to reduce the pin count.



**Figure 28** GPIO Block Diagram

#### GPIOs at RESET

Upon hardware reset (SYSRST#), GPIOs are all configured as inputs and the following alternative usages of GPIO pins are enabled:

These GPIOs are used to latch the inputs upon reset to memorize the desired configuration to make sure that the system restarts or boots in the right mode.

#### Multiplexing of Signals on GPIO

The GPIO pins can be multiplexed with other signals.

- DAICLK, DAIPCMIN, DAIPCMOUT, DAIRST: digital audio interface for FTA
- BPI\_BUS6, BPI\_BUS7, BPI\_BUS8, BPI\_BUS9: radio hard-wire control
- BSI\_CS1: additional chip select signal for radio 3-wire interface
- LSCK, LSA0, LSDA, LSCE0#, LSCE1#: serial display interface
- LPCE1#: parallel display interface chip select signal
- NRB, NCLE, NALE, NWEB, NREB, NCEB: nand-flash control signals
- PWM1, PWM2: pulse width modulation signal
- ALERTER: pulse width modulation signal for buzzer
- IRDA\_RXD, IRDA\_TXD, IRDA\_PDN: IrDA control signals
- URXD2, UTXD2, UCTS2, URTS2: data and flow control signals for UART2
- URXD3, UTXD3, UCTS3, URTS3: data and flow control signals for UART3
- CMRST, CMPDN, CMDAT1, CMDAT0: cmos sensor interface
- SRCLKENAI: external power on signal of the external VCXO LDO

#### Multiplexed of Signals on GPO

- SRCLKENA, SRCLKENAN: power on signal of the external VCXO LDO

## 4.5.1 Register Definitions

**GPIO+0000h GPIO direction control register 1**

| Bit   | 15         | 14         | 13         | 12         | 11         | 10         | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|------------|------------|------------|------------|------------|------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name  | GPIO1<br>5 | GPIO1<br>4 | GPIO1<br>3 | GPIO1<br>2 | GPIO1<br>1 | GPIO1<br>0 | GPIO9 | GPIO8 | GPIO7 | GPIO6 | GPIO5 | GPIO4 | GPIO3 | GPIO2 | GPIO1 | GPIO0 |
| Type  | R/W        | R/W        | R/W        | R/W        | R/W        | R/W        | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset | 0          | 0          | 0          | 0          | 0          | 0          | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

**GPIO +0010h GPIO direction control register 2**

| Bit   | 15         | 14         | 13         | 12         | 11         | 10         | 9          | 8          | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0      |
|-------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|--------|
| Name  | GPIO3<br>1 | GPIO3<br>0 | GPIO2<br>9 | GPIO2<br>8 | GPIO2<br>7 | GPIO2<br>6 | GPIO2<br>5 | GPIO2<br>4 | GPIO2<br>3 | GPIO2<br>2 | GPIO2<br>1 | PGIO2<br>0 | GPIO1<br>9 | GPIO1<br>8 | GPIO1<br>7 | GPIO16 |
| Type  | R/W        | R/W    |
| Reset | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0      |

**GPIO+0020h GPIO direction control register 3**

| Bit   | 15         | 14         | 13         | 12         | 11         | 10         | 9          | 8          | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0      |
|-------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|--------|
| Name  | GPIO4<br>7 | GPIO4<br>6 | GPIO4<br>5 | GPIO4<br>4 | GPIO4<br>3 | GPIO4<br>2 | GPIO4<br>1 | GPIO4<br>0 | GPIO3<br>9 | GPIO3<br>8 | GPIO3<br>7 | GPIO3<br>6 | GPIO3<br>5 | GPIO3<br>4 | GPIO3<br>3 | GPIO32 |
| Type  | R/W        | R/W    |
| Reset | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0      |

**GPIO+0030h GPIO direction control register 4**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4          | 3          | 2          | 1          | 0      |
|-------|----|----|----|----|----|----|---|---|---|---|---|------------|------------|------------|------------|--------|
| Name  |    |    |    |    |    |    |   |   |   |   |   | GPIO5<br>4 | GPIO5<br>3 | GPIO5<br>2 | GPIO5<br>1 | GPIO49 |
| Type  |    |    |    |    |    |    |   |   |   |   |   | R/W        | R/W        | R/W        | R/W        | R/W    |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 0          | 0          | 0          | 0          | 0      |

**GPIO<sub>n</sub>** GPIO direction control

- 0    GPIOs are configured as input
- 1    GPIOs are configured as output

**GPIO +0040h GPIO pull-up/pull-down enable register 1**

| Bit   | 15         | 14         | 13         | 12         | 11         | 10         | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|------------|------------|------------|------------|------------|------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name  | GPIO1<br>5 | GPIO1<br>4 | GPIO1<br>3 | GPIO1<br>2 | GPIO1<br>1 | GPIO1<br>0 | GPIO9 | GPIO8 | GPIO7 | GPIO6 | GPIO5 | GPIO4 | GPIO3 | GPIO2 | GPIO1 | GPIO0 |
| Type  | R/W        | R/W        | R/W        | R/W        | R/W        | R/W        | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset | 1          | 1          | 1          | 1          | 1          | 1          | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |

**GPIO +0050h GPIO pull-up/pull-down enable register 2**

| Bit   | 15         | 14         | 13         | 12         | 11         | 10         | 9          | 8          | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0      |
|-------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|--------|
| Name  | GPIO3<br>1 | GPIO3<br>0 | GPIO2<br>9 | GPIO2<br>8 | GPIO2<br>7 | GPIO2<br>6 | GPIO2<br>5 | GPIO2<br>4 | GPIO2<br>3 | GPIO2<br>2 | GPIO2<br>1 | PGIO2<br>0 | GPIO1<br>9 | GPIO1<br>8 | GPIO1<br>7 | GPIO16 |
| Type  | R/W        | R/W    |
| Reset | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1      |

**GPIO+0060h GPIO pull-up/pull-down enable register 3**
**GPIO\_PULLEN3**

| Bit   | 15         | 14         | 13         | 12         | 11         | 10         | 9          | 8          | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0          |
|-------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|
| Name  | GPIO4<br>7 | GPIO4<br>6 | GPIO4<br>5 | GPIO4<br>4 | GPIO4<br>3 | GPIO4<br>2 | GPIO4<br>1 | GPIO4<br>0 | GPIO3<br>9 | GPIO3<br>8 | GPIO3<br>7 | GPIO3<br>6 | GPIO3<br>5 | GPIO3<br>4 | GPIO3<br>3 | GPIO<br>32 |
| Type  | R/W        |
| Reset | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          |

**GPIO+0070h GPIO pull-up/pull-down enable register 4**
**GPIO\_PULLEN4**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0   |
|-------|----|----|----|----|----|----|---|---|------------|------------|------------|------------|------------|------------|------------|-----|
| Name  |    |    |    |    |    |    |   |   | GPIO5<br>4 | GPIO5<br>3 | GPIO5<br>2 | GPIO5<br>1 | GPIO5<br>0 | GPIO4<br>9 | GPIO<br>48 |     |
| Type  |    |    |    |    |    |    |   |   | R/W        | R/W |
| Reset |    |    |    |    |    |    |   |   | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0   |

**GPIO<sub>n</sub>** GPIO direction control

- 0**    GPIOs are configured as input
- 1**    GPIOs are configured as output

**GPIO +0080h GPIO data inversion control register 1**
**GPIO\_DINV1**

| Bit   | 15    | 14    | 13    | 12    | 11    | 10    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-------|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|------|------|------|
| Name  | INV15 | INV14 | INV13 | INV12 | INV11 | INV10 | INV9 | INV8 | INV7 | INV6 | INV5 | INV4 | INV3 | INV2 | INV1 | INV0 |
| Type  | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

**GPIO +0090h GPIO data inversion control register 2**
**GPIO\_DINV2**

| Bit   | 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name  | INV31 | INV30 | INV29 | INV28 | INV27 | INV26 | INV25 | INV24 | INV23 | INV22 | INV21 | INV20 | INV19 | INV18 | INV17 | INV16 |
| Type  | R/W   |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

**GPIO +00A0h GPIO data inversion control register 3**
**GPIO\_DINV3**

| Bit   | 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name  | INV47 | INV46 | INV45 | INV44 | INV43 | INV42 | INV41 | INV40 | INV39 | INV38 | INV37 | INV36 | INV35 | INV34 | INV33 | INV32 |
| Type  | R/W   |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

**GPIO+00B0h GPIO data inversion control register 4**
**GPIO\_DINV4**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0   |
|-------|----|----|----|----|----|----|---|---|-------|-------|-------|-------|-------|-------|-------|-----|
| Name  |    |    |    |    |    |    |   |   | INV54 | INV53 | INV52 | INV51 | INV50 | INV49 | INV48 |     |
| Type  |    |    |    |    |    |    |   |   | R/W   | R/W |
| Reset |    |    |    |    |    |    |   |   | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0   |

**INVn** GPIO inversion control

- 0**    GPIOs data inversion disable
- 1**    GPIOs data inversion enable

**GPIO +00C0h GPIO data output register 1**
**GPIO\_DOUT1**

| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

|       |            |            |            |            |            |            |       |       |       |       |       |       |       |       |       |           |
|-------|------------|------------|------------|------------|------------|------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-----------|
| Name  | GPIO1<br>5 | GPIO1<br>4 | GPIO1<br>3 | GPIO1<br>2 | GPIO1<br>1 | GPIO1<br>0 | GPIO9 | GPIO8 | GPIO7 | GPIO6 | GPIO5 | GPIO4 | GPIO3 | GPIO2 | GPIO1 | GPIO<br>0 |
| Type  | R/W        | R/W        | R/W        | R/W        | R/W        | R/W        | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W       |
| Reset | 0          | 0          | 0          | 0          | 0          | 0          | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0         |

**GPIO +00D0h GPIO data output register 2**
**GPIO\_DOUT2**

|       |            |            |            |            |            |            |            |            |            |            |            |            |            |            |            |             |
|-------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|-------------|
| Bit   | 15         | 14         | 13         | 12         | 11         | 10         | 9          | 8          | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0           |
| Name  | GPIO3<br>1 | GPIO3<br>0 | GPIO2<br>9 | GPIO2<br>8 | GPIO2<br>7 | GPIO2<br>6 | GPIO2<br>5 | GPIO2<br>4 | GPIO2<br>3 | GPIO2<br>2 | GPIO2<br>1 | PGIO2<br>0 | GPIO1<br>9 | GPIO1<br>8 | GPIO1<br>7 | GPIO1<br>16 |
| Type  | R/W         |
| Reset | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0           |

**GPIO +00E0h GPIO data output register 3**
**GPIO\_DOUT3**

|       |            |            |            |            |            |            |            |            |            |            |            |            |            |            |            |        |
|-------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|--------|
| Bit   | 15         | 14         | 13         | 12         | 11         | 10         | 9          | 8          | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0      |
| Name  | GPIO4<br>7 | GPIO4<br>6 | GPIO4<br>5 | GPIO4<br>4 | GPIO4<br>3 | GPIO4<br>2 | GPIO4<br>1 | GPIO4<br>0 | GPIO3<br>9 | GPIO3<br>8 | GPIO3<br>7 | GPIO3<br>6 | GPIO3<br>5 | GPIO3<br>4 | GPIO3<br>3 | GPIO32 |
| Type  | R/W        | R/W    |
| Reset | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0      |

**GPIO+00F0h GPIO data output register 4**
**GPIO\_DOUT4**

|       |    |    |    |    |    |    |   |   |   |            |            |            |            |            |            |        |
|-------|----|----|----|----|----|----|---|---|---|------------|------------|------------|------------|------------|------------|--------|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6          | 5          | 4          | 3          | 2          | 1          | 0      |
| Name  |    |    |    |    |    |    |   |   |   | GPIO5<br>4 | GPIO5<br>3 | GPIO5<br>2 | GPIO5<br>1 | GPIO5<br>0 | GPIO9<br>9 | GPIO48 |
| Type  |    |    |    |    |    |    |   |   |   | R/W        | R/W        | R/W        | R/W        | R/W        | R/W        | R/W    |
| Reset |    |    |    |    |    |    |   |   |   | 0          | 0          | 0          | 0          | 0          | 0          | 0      |

**GPIOOn** GPIO data output control

0    GPIOs data output 1

1    GPIOs data output 0

**GPIO +0100h GPIO data Input register 1**
**GPIO\_DIN1**

|       |            |            |            |            |            |            |       |       |       |       |       |       |       |       |       |       |
|-------|------------|------------|------------|------------|------------|------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| Bit   | 15         | 14         | 13         | 12         | 11         | 10         | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| Name  | GPIO1<br>5 | GPIO1<br>4 | GPIO1<br>3 | GPIO1<br>2 | GPIO1<br>1 | GPIO1<br>0 | GPIO9 | GPIO8 | GPIO7 | GPIO6 | GPIO5 | GPIO4 | GPIO3 | GPIO2 | GPIO1 | GPIO0 |
| Type  | RO         | RO         | RO         | RO         | RO         | RO         | RO    | RO    | RO    | RO    | RO    | RO    | RO    | RO    | RO    | RO    |
| Reset | X          | X          | X          | X          | X          | X          | X     | X     | X     | X     | X     | X     | X     | X     | X     | X     |

**GPIO +0110h GPIO data Input register 2**
**GPIO\_DIN2**

|       |            |            |            |            |            |            |            |            |            |            |            |            |            |            |            |             |
|-------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|-------------|
| Bit   | 15         | 14         | 13         | 12         | 11         | 10         | 9          | 8          | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0           |
| Name  | GPIO3<br>1 | GPIO3<br>0 | GPIO2<br>9 | GPIO2<br>8 | GPIO2<br>7 | GPIO2<br>6 | GPIO2<br>5 | GPIO2<br>4 | GPIO2<br>3 | GPIO2<br>2 | GPIO2<br>1 | PGIO2<br>0 | GPIO1<br>9 | GPIO1<br>8 | GPIO1<br>7 | GPIO1<br>16 |
| Type  | RO          |
| Reset | X          | X          | X          | X          | X          | X          | X          | X          | X          | X          | X          | X          | X          | X          | X          | X           |

**GPIO +0120h GPIO data Input register 3**
**GPIO\_DIN3**

|       |            |            |            |            |            |            |            |            |            |            |            |            |            |            |            |        |
|-------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|--------|
| Bit   | 15         | 14         | 13         | 12         | 11         | 10         | 9          | 8          | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0      |
| Name  | GPIO4<br>7 | GPIO4<br>6 | GPIO4<br>5 | GPIO4<br>4 | GPIO4<br>3 | GPIO4<br>2 | GPIO4<br>1 | GPIO4<br>0 | GPIO3<br>9 | GPIO3<br>8 | GPIO3<br>7 | GPIO3<br>6 | GPIO3<br>5 | GPIO3<br>4 | GPIO3<br>3 | GPIO32 |
| Type  | RO         | RO     |
| Reset | X          | X          | X          | X          | X          | X          | X          | X          | X          | X          | X          | X          | X          | X          | X          | X      |

**GPIO+0130h GPIO data input register 4**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6          | 5          | 4          | 3          | 2          | 1          | 0      | GPIO_DIN4 |
|-------|----|----|----|----|----|----|---|---|---|------------|------------|------------|------------|------------|------------|--------|-----------|
| Name  |    |    |    |    |    |    |   |   |   | GPIO5<br>4 | GPIO5<br>3 | GPIO5<br>2 | GPIO5<br>1 | GPIO5<br>0 | GPIO4<br>9 | GPIO48 |           |
| Type  |    |    |    |    |    |    |   |   |   | RO         | RO         | RO         | RO         | RO         | RO         | RO     |           |
| Reset |    |    |    |    |    |    |   |   |   | X          | X          | X          | X          | X          | X          | X      |           |

**GPIOOn** GPIOs data input

**GPIO +0140h GPO data output register**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4     | 3     | 2     | 1     | 0     | GPO_DOUT |
|-------|----|----|----|----|----|----|---|---|---|---|---|-------|-------|-------|-------|-------|----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   | GPIO4 | GPIO3 | GPIO2 | GPIO1 | GPIO0 |          |
| Type  |    |    |    |    |    |    |   |   |   |   |   | R/W   | R/W   | R/W   | R/W   | R/W   |          |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 0     | 0     | 0     | 0     | 0     |          |

**GPIO +0150h GPIO mode control register 1**

| Bit   | 15      | 14      | 13      | 12      | 11      | 10      | 9       | 8       | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | GPIO_MODE1 |
|-------|---------|---------|---------|---------|---------|---------|---------|---------|---|---|---|---|---|---|---|---|------------|
| Name  | GPIO7_M | GPIO6_M | GPIO5_M | GPIO4_M | GPIO3_M | GPIO2_M | GPIO1_M | GPIO0_M |   |   |   |   |   |   |   |   |            |
| Type  | R/W     |   |   |   |   |   |   |   |   |            |
| Reset | 00      | 00      | 00      | 00      | 00      | 00      | 00      | 00      |   |   |   |   |   |   |   |   |            |

**GPIO0\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** Reserved
- 10** DSP General Purpose Output 3
- 11** Reserved

**GPIO1\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** DICK
- 10** Reserved
- 11** Reserved

**GPIO2\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** DID
- 10** Reserved
- 11** Reserved

**GPIO3\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** DIMS
- 10** Reserved
- 11** Reserved

**GPIO4\_M** GPO mode selection

- 00** Configured as GPIO function
- 01** DSP Clock
- 10** DSP LPT Clock
- 11** MCU Tracer Data 4

**GPIO5\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** AHB Clock
- 10** DSP LPT Data 3
- 11** MCU Tracer Data 3

**GPIO6\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** MCU Clock
- 10** DSP LPT Data 2
- 11** MCU Tracer Data 2

**GPIO7\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** Slow Clock
- 10** DSP LPT Data 1
- 11** MCU Tracer Data 1

### GPIO +0160h GPIO mode control register 2

### GPIO\_MODE2

| Bit   | 15              | 14              | 13              | 12              | 11              | 10              | 9              | 8              | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----------------|----------------|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  | <b>GPIO15_M</b> | <b>GPIO14_M</b> | <b>GPIO13_M</b> | <b>GPIO12_M</b> | <b>GPIO11_M</b> | <b>GPIO10_M</b> | <b>GPIO9_M</b> | <b>GPIO8_M</b> |     |     |     |     |     |     |     |     |
| Type  | R/W             | R/W             | R/W             | R/W             | R/W             | R/W             | R/W            | R/W            | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset | 00              | 00              | 00              | 00              | 00              | 00              | 00             | 00             | 00  | 00  | 00  | 00  | 00  | 00  | 00  | 00  |

**GPIO8\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** SCCB Clock
- 10** DSP LPT Data 0
- 11** MCU Tracer Data 0

**GPIO9\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** SCCB Data
- 10** DSP LPT Synchronization Signal
- 11** MCU Tracer Re-Synchronization Signal

**GPIO10\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** BPI\_BUS6
- 10** Reserved
- 11** Reserved

**GPIO11\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** BPI\_BUS7
- 10** Reserved
- 11** Reserved

**GPIO12\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** BPI\_BUSS8

10 13MHz Clock

11 32KHz Clock

**GPIO13\_M** GPIO mode selection

00 Configured as GPIO function

01 BPI\_BUS9

10 BSI\_CS1

11 Reserved

**GPIO14\_M** GPIO mode selection

00 Configured as GPIO function

01 MS/SD/MMC Card Insertion Signal

10 Reserved

11 Reserved

**GPIO15\_M** GPIO mode selection

00 Configured as GPIO function

01 MS/SD/MMC/MS PO Write Protection Signal

10 Reserved

11 Reserved

**GPIO +0170h GPIO mode control register 3**

**GPIO\_MODE3**

| Bit   | 15              | 14              | 13              | 12              | 11              | 10              | 9               | 8               | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  | <b>GPIO23_M</b> | <b>GPIO22_M</b> | <b>GPIO21_M</b> | <b>GPIO20_M</b> | <b>GPIO19_M</b> | <b>GPIO18_M</b> | <b>GPIO17_M</b> | <b>GPIO16_M</b> |     |     |     |     |     |     |     |     |
| Type  | R/W             | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset | 00              | 00              | 00              | 00              | 00              | 00              | 00              | 00              | 00  | 00  | 00  | 00  | 00  | 00  | 00  | 00  |

**GPIO16\_M** GPIO mode selection

00 Configured as GPIO function

01 Serial LCD Interface/PM IC Interface Clock Signal

10 TDMA Timer Debug Port Clock Output

11 TDMA Timer Uplink Frame Enable Signal

**GPIO17\_M** GPIO mode selection

00 Configured as GPIO function

01 Serial LCD Interface Address/Data Signal

10 TDMA Timer Debug Port Data Output 1

11 TDMA Timer DIRQ Signal

**GPIO18\_M** GPIO mode selection

00 Configured as GPIO function

01 Serial LCD Interface Data/PM IC Interface Data Signal

10 TDMA Timer Debug Port Data Output 0

11 TDMA Timer CTIRQ2 Signal

**GPIO19\_M** GPIO mode selection

00 Configured as GPIO function

01 Serial LCD Interface/PM IC Interface Chip Select Signal 0

10 TDMA Timer Debug Port Frame Sync Signal

11 TDMA Timer CTIRQ1 Signal

**GPIO20\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** Serial LCD Interface Chip Select Signal 1
- 10** Parallel LCD Interface Chip Select Signal 2
- 11** TDMA Timer Event Validate Signal

**GPIO21\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** PWM1
- 10** DSP General Purpose Output 0
- 11** TDMA Timer Uplink Frame Sync Signal

**GPIO22\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** PWM2
- 10** DSP General Purpose Output 1
- 11** TDMA Timer Downlink Frame Enable Signal

**GPIO23\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** Alerter
- 10** DSP General Purpose Output 2
- 11** TDMA Timer Downlink Frame Sync Signal

**GPIO +0180h    GPIO mode control register 4****GPIO\_MODE4**

| Bit   | 15              | 14              | 13              | 12              | 11              | 10              | 9               | 8               | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|---|---|---|---|---|---|---|---|
| Name  | <b>GPIO31_M</b> | <b>GPIO30_M</b> | <b>GPIO29_M</b> | <b>GPIO28_M</b> | <b>GPIO27_M</b> | <b>GPIO26_M</b> | <b>GPIO25_M</b> | <b>GPIO24_M</b> |   |   |   |   |   |   |   |   |
| Type  | R/W             |   |   |   |   |   |   |   |   |
| Reset | 00              | 00              | 00              | 00              | 00              | 00              | 00              | 00              |   |   |   |   |   |   |   |   |

**GPIO24\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** Parallel LCD Interface Chip Select Signal 1
- 10** DSP Task ID 0
- 11** MCU Bus Master ID 0

**GPIO25\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** Nandflash Interface Ready/Busy Signal
- 10** DSP Task ID 1
- 11** MCU Bus Master ID 1

**GPIO26\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** Nandflash Interface Command Latch Signal
- 10** DSP Task ID 2
- 11** MCU Bus Master ID 2

**GPIO27\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** Nandflash Interface Address Latch Signal
- 10** DSP Task ID 3

11 MCU Bus Master ID 3

**GPIO28\_M** GPIO mode selection

00 Configured as GPIO function

01 Nandflash Interface Write Strobe Signal

10 DSP Task ID 4

11 MCU Task ID Serial Data Output

**GPIO29\_M** GPIO mode selection

00 Configured as GPIO function

01 Nandflash Interface Read Strobe Signal

10 DSP Task ID 5

11 MCU Task ID Frame Sync Signal

**GPIO30\_M** GPIO mode selection

00 Configured as GPIO function

01 Nandflash Interface Chip Select Signal

10 DSP Task ID 6

11 MCU Task ID Clock Signal

**GPIO31\_M** GPIO mode selection

00 Configured as GPIO function

01 VCXO Enable Signal Input

10 Reserved

11 Reserved

**GPIO +0190h GPIO mode control register 5**

**GPIO\_MODE5**

| Bit   | 15              | 14              | 13              | 12              | 11              | 10              | 9               | 8               | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  | <b>GPIO39_M</b> | <b>GPIO38_M</b> | <b>GPIO37_M</b> | <b>GPIO36_M</b> | <b>GPIO35_M</b> | <b>GPIO34_M</b> | <b>GPIO33_M</b> | <b>GPIO32_M</b> |     |     |     |     |     |     |     |     |
| Type  | R/W             | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset | 00              | 00              | 00              | 00              | 00              | 00              | 00              | 00              |     |     |     |     |     |     |     |     |

**GPIO32\_M** GPIO mode selection

00 Configured as GPIO function

01 SIM Interface Voltage Select Signal

10 Reserved

11 Reserved

**GPIO33\_M** GPIO mode selection

00 Configured as GPIO function

01 UART3 RXD Signal

10 Reserved

11 Wave Table Interface Data 3

**GPIO34\_M** GPIO mode selection

00 Configured as GPIO function

01 UART3 TXD Signal

10 Reserved

11 Wave Table Interface Data 2

**GPIO35\_M** GPIO mode selection

00 Configured as GPIO function

- 01** UART2 RXD Signal
- 10** UART3 CTS Signal
- 11** Wave Table Interface Clock Output

**GPIO36\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** UART2 TXD Signal
- 10** UART3 RTS Signal
- 11** Wave Table Interface Synchronization Signal

**GPIO37\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** IrDA RXD Signal
- 10** UART2 CTS Signal
- 11** Wave Table Interface Data 1

**GPIO38\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** IrDA TXD Signal
- 10** UART2 RTS Signal
- 11** Wave Table Interface Data 0

**GPIO39\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** IrDA Power Down Control Signal
- 10** Reserved
- 11** Reserved

**GPIO +01A0h GPIO mode control register 6****GPIO\_MODE6**

| Bit   | 15              | 14              | 13              | 12              | 11              | 10              | 9               | 8               | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0 |
|-------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----|-----|-----|-----|-----|-----|-----|---|
| Name  | <b>GPIO47_M</b> | <b>GPIO46_M</b> | <b>GPIO45_M</b> | <b>GPIO44_M</b> | <b>GPIO43_M</b> | <b>GPIO42_M</b> | <b>GPIO41_M</b> | <b>GPIO40_M</b> |     |     |     |     |     |     |     |   |
| Type  | R/W             | R/W | R/W | R/W | R/W | R/W | R/W | R/W |   |
| Reset | 00              | 00              | 00              | 00              | 00              | 00              | 00              | 00              | 00  | 00  | 00  | 00  | 00  | 00  | 00  |   |

**GPIO40\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** External Memory Interface Chip Select Signal 7
- 10** Reserved
- 11** Reserved

**GPIO41\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** nIRQ Signal
- 10** 13 MHz Clock Signal
- 11** 32 KHz Clock Signal

**GPIO42\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** nFIQ signal
- 10** Reserved
- 11** Reserved

**GPIO43\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** Digital Audio Interface Clock Output
- 10** DSP LPT Data 7
- 11** MCU Tracer Interface Clock Signal Output

**GPIO44\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** Digital Audio Interface PCM Data Output
- 10** DSP LPT Data 6
- 11** MCU Tracer Interface Synchronization Signal Output

**GPIO45\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** Digital Audio Interface PCM Data Input
- 10** DSP LPT Data 5
- 11** MCU Tracer Interface Data Output 7

**GPIO46\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** Digital Audio Interface Synchronization Signal Output
- 10** BFE Debug Signal Output
- 11** MCU Tracer Interface Data Output 5

**GPIO47\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** Digital Audio Interface Reset Signal Input
- 10** TDMA Timer Debug Interface Frame Sync Signal
- 11** MCU Tracer Interface Data Output 6

**GPIO +01B0h GPIO mode control register 7****GPIO\_MODE7**

| Bit   | 15 | 14 | 13            | 12            | 11  | 10            | 9   | 8             | 7   | 6             | 5   | 4             | 3   | 2             | 1   | 0 |
|-------|----|----|---------------|---------------|-----|---------------|-----|---------------|-----|---------------|-----|---------------|-----|---------------|-----|---|
| Name  |    |    | <b>GPIO54</b> | <b>GPIO53</b> |     | <b>GPIO52</b> |     | <b>GPIO51</b> |     | <b>GPIO50</b> |     | <b>GPIO49</b> |     | <b>GPIO48</b> |     |   |
| Type  |    |    | R/W           |               | R/W |               | R/W |               | R/W |               | R/W |               | R/W |               | R/W |   |
| Reset |    |    | 0             |               | 0   |               | 0   |               | 0   |               | 0   |               | 0   |               | 0   |   |

**GPIO48\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** CMOS Sensor Reset Signal Output
- 10** Reserved
- 11** Reserved

**GPIO49\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** CMOS Sensor Power Down Signal Output
- 10** Reserved
- 11** Reserved

**GPIO50\_M** GPIO mode selection

- 00** Configured as GPIO function
- 01** CMOS Sensor Data Input 1

10 Reserved

11 Reserved

**GPIO51\_M** GPIO mode selection

00 Configured as GPIO function

01 CMOS Sensor Data Input 0

10 Reserved

11 Reserved

**GPIO52\_M** GPIO mode selection

00 Configured as GPIO function

01 External Memory Interface Chip Select 6

10 Reserved

11 Reserved

**GPIO53\_M** GPIO mode selection

00 Configured as GPIO function

01 External Memory Interface Chip Select 5

10 Reserved

11 Reserved

**GPIO54\_M** GPIO mode selection

00 Configured as GPIO function

01 External Memory Interface Chip Select 4

10 Reserved

11 Reserved

**GPIO +01C0h GPO mode control register 1****GPO\_MODE1**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8             | 7             | 6             | 5             | 4             | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---------------|---------------|---------------|---------------|---------------|---|---|---|---|
| Name  |    |    |    |    |    |    |   | <b>GPO4_M</b> | <b>GPO3_M</b> | <b>GPO2_M</b> | <b>GPO1_M</b> | <b>GPO0_M</b> |   |   |   |   |
| Type  |    |    |    |    |    |    |   | R/W           | R/W           | R/W           | R/W           | R/W           |   |   |   |   |
| Reset |    |    |    |    |    |    |   | 01            | 01            | 01            | 01            | 01            |   |   |   |   |

**GPO0\_M** GPO mode selection

00 Configured as GPO function

01 VCXO Enable Signal Output Active High

10 Reserved

11 Reserved

**GPO1\_M** GPO mode selection

00 Configured as GPO function

01 VCXO Enable Signal Output Active Low

10 Reserved

11 Reserved

**GPO2\_M** GPO mode selection

00 Configured as GPO function

01 External Memory Interface Power Down Control for Pseudo SRAM

10 Reserved

11 Reserved

**GPO3\_M** GPO mode selection

- 00** Configured as GPO function
- 01** External Memory Interface Address 24
- 10** Reserved
- 11** Reserved

#### GPO4\_M GPO mode selection

- 00** Configured as GPO function
- 01** External Memory Interface Address 25
- 10** Reserved
- 11** Reserved

## 4.6 General Purpose Timer

### 4.6.1 General Description

Three general-purpose timers, that are 16 bit long and runs independently with the same clock source are provided. Two timers can operate in two modes: one-shot mode and auto-repeat mode; the other is a free running timer. In one-shot mode, when the timer counts down and reaches zero, it is halted. In auto-repeat mode, as the timer reaches zero, it will simply reset and continue counting backward until the disable signal is set to be one. If the initial counting value (i.e.

GPTIMER1\_DAT for GPT1 or GPTIMER\_DAT2 for GPT2) is written when the timer is running, no matter which mode it is in, there is no effect until the next time the timer is restarted. Hence, be sure to set the desired values for GPTIMER\_DAT and the GPTIMER\_PRESCALER registers before enabling the gptimer.

### 4.6.2 Register Definitions

#### GPT +0000h GPT1 Control register

| Bit   | 15        | 14          | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----------|-------------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | <b>EN</b> | <b>MODE</b> |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W       | R/W         |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0         | 0           |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**MODE** This register controls GPT1 to count repeatedly or just one-shot

- 0** One-shot mode is selected
- 1** Auto-repeat mode is selected

**EN** This register controls GPT1 to start to count or to disables it

- 0** GPT1 is disabled
- 1** GPT1 is enabled

#### GPT +0004h GPT1 Time-Out Interval register

| Bit   | 15                | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | <b>CNT [15:0]</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | FFFFh             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**CNT [15:0]** Initial counting value. GPT1 will count down from GPTIMER1\_DAT. When GPT1 counts down to zero, interrupt of GPT1 will be generated.

**GPT +0008h GPT2 Control register**
**GPTIMER2\_CON**

| Bit   | 15  | 14   | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----|------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | EN  | MODE |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W | R/W  |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0   | 0    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**MODE** This register controls GPT2 to count repeatedly or just one-shot

- 0 One-shot mode is selected
- 1 Auto-repeat mode is selected

**EN** This register controls GPT2 starts to count or disables it

- 0 GPT2 is disabled
- 1 GPT2 is enabled

**GPT +000Ch GPT2 Time-Out Interval register**
**GPTIMER2\_DAT**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | CNT [15:0] |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W        |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | FFFFh      |

**CNT [15:0]** Initial counting value. GPT2 will count down from GPTIMER2\_DAT. When GPT2 counts down to zero, interrupt of GPT2 will be generated.

**GPT +0010h GPT Status register**
**GPTIMER\_STA**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | GPT2 GPT1 |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RC RC     |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0 0       |

This register is for illustrating the gptimer time out status. Each flag is set when the corresponding counter countdown finishes, and can be cleared when the CPU reads the status register.

**GPT +0014h GPT1 Prescaler register**
**GPTIMER1\_PRE SCALER**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0               |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | PRESCALER [2:0] |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W             |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 100b            |

**PRESCALER** This register controls the gptimer1 counting clock

- 000 16K Hz
- 001 8K Hz
- 010 4K Hz
- 011 2K Hz
- 100 1K Hz
- 101 500Hz
- 110 250Hz
- 111 125Hz

**GPT +0018h GPT2 Prescaler register**
**GPTIMER2\_PRE SCALER**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0               |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | PRESCALER [2:0] |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W             |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 100b            |

**PRESCALER** This register controls the gptimer2 counting clock

- 000 16K Hz
- 001 8K Hz
- 010 4K Hz
- 011 2K Hz
- 100 1K Hz
- 101 500Hz
- 110 250Hz
- 111 125Hz

**GPT+001Ch GPT3 Control register**
**GPTIMER3\_CON**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | EN  |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0   |

**EN** This register controls GPT3 starts to count or disables it

- 0 GPT3 is disabled
- 1 GPT3 is enabled

**GPT+0020h GPT3Time-Out Interval register**
**GPTIMER\_DAT3**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | CNT[15:0] |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO        |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0         |

**CNT [15:0]** GPT3 is a free run timer if EN = 1. Software will read this register to count the time interval needed.

**GPT+0024h GPT3 Prescaler register**
**GPTIMER3\_PRE SCALER**

| Bit   | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Type  | R/W |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

**PRESCALER** This register controls the gptimer3 counting clock

- 000 16K Hz
- 001 8K Hz
- 010 4K Hz
- 011 2K Hz
- 100 1K Hz

**101** 500Hz  
**110** 250Hz  
**112** 125Hz

## 4.7 UART

### 4.7.1 General Description

The MT6219 houses three UARTs. The UARTs provide full duplex serial communication channels between the MT6219 and external devices.

The UART has M16C450 and M16550A modes of operation, which are compatible with a range of standard software drivers. The extensions have been designed to be broadly software compatible with 16550A variants, but there are some areas where there are no consensus.

In common with the M16550A, the UART supports word lengths from five to eight bits, an optional parity bit and one or two stop bits, and is fully programmable by an 8-bit CPU interface. A 16-bit programmable baud rate generator and an 8-bit scratch register are included, together with separate transmit and receive FIFOs. Eight modem control lines and a diagnostic loop-back mode are provided. The UART also includes two DMA handshake lines, which are used to indicate when the FIFOs are ready to transfer data to the CPU. Interrupts can be generated from any of the 10 sources.

**Note:** The UART has been designed so that all internal operations are synchronized by the CLK signal. This results in minor timing differences between the UART and the industry standard 16550A device, which mean that the core is not clock for clock identical to the original device.

After a hardware reset, the UART is in M16C450 mode. It can then have its FIFOs enabled and enter M16550A mode. The UART adds further functionality beyond M16550A mode. Each of the extended functions can be selected individually under software control.

The UART provides more powerful enhancements than the industry-standard 16550:

- Hardware flow control. This is a very useful feature when the ISR latency is hard to predict and control in the embedded applications. It relieves the MCU from having to fetch the received data within a fixed amount of time.
- Output of an IR-compatible electrical pulse with a width 3/16 of that of a regular bit period.

**Note:** In order to enable any of the enhancements, the Enhanced Mode bit, EFR[4], has to be set. If EFR[4] is not set, it is not possible to write to IER[7:5], FCR[5:4], ISR[5:4] and MCR[7:6]. This is to ensure that the UART is backward compatible to software that has been written for 16C450 and 16550A devices.

**Figure 29** shows the block diagram of the 6219 UART device.



Figure 29 Block Diagram of UART

#### 4.7.2 Register Definitions

n = 1, 2, 3; for uart1, uart2 and uart3 respectively.

##### UARTn+0000h RX Buffer Register

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0               |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------------|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>RBR[7:0]</b> |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO              |

**RBR** RX Buffer Register. This is a read-only register. The received data can be read by accessing this register.

Modified when LCR[7] = 0.

##### UARTn+0000h TX Holding Register

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0               |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------------|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>THR[7:0]</b> |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | WO              |

**THR** TX Holding Register. This is a write-only register. The data to be transmitted is written to this register, and then sent to PC via serial communication.

Modified when LCR[7] = 0.

##### UARTn+0004h Interrupt Enable Register

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7           | 6           | 5            | 4        | 3            | 2           | 1            | 0            |
|-------|----|----|----|----|----|----|---|---|-------------|-------------|--------------|----------|--------------|-------------|--------------|--------------|
| Name  |    |    |    |    |    |    |   |   | <b>CTSI</b> | <b>RTSI</b> | <b>XOFFI</b> | <b>X</b> | <b>EDSSI</b> | <b>ELSI</b> | <b>ETBEI</b> | <b>ERBFI</b> |
| Type  |    |    |    |    |    |    |   |   |             |             |              |          |              |             |              | R/W          |
| Reset |    |    |    |    |    |    |   |   |             |             |              |          |              |             |              | 0            |

**IER** By storing a ‘1’ to a specific bit position, the interrupt associated with that bit is enabled. Otherwise, the interrupt is disabled.

IER[3:0] are modified when LCR[7] = 0.

IER[7:4] are modified when LCR[7] = 0 & EFR[4] = 1.

**CTSI** Masks an interrupt that is generated when a rising edge is detected on the CTS modem control line.

**Note:** This interrupt is only enabled when hardware flow control is enabled

- 0** Un-mask an interrupt that is generated when a rising edge is detected on the CTS modem control line.
- 1** Mask an interrupt that is generated when a rising edge is detected on the CTS modem control line.

**RTSI** Masks an interrupt that is generated when a rising edge is detected on the RTS modem control line.

**Note:** This interrupt is only enabled when hardware flow control is enabled

- 0** Un-mask an interrupt that is generated when a rising edge is detected on the RTS modem control line
- 1** Mask an interrupt that is generated when a rising edge is detected on the RTS modem control line.

**XOFFI** Masks an interrupt that is generated when an XOFF character is received.

**Note:** This interrupt is only enabled when software flow control is enabled

- 0** Un-mask an interrupt that is generated when an XOFF character is received.
- 1** Mask an interrupt that is generated when an XOFF character is received.

**EDSSI** When set ("1"), an interrupt is generated if DDCD, TERI, DDSR or DCTS (MSR[4:1]) becomes set.

- 0** No interrupt is generated if DDCD, TERI, DDSR or DCTS (MSR[4:1]) becomes set.
- 1** An interrupt is generated if DDCD, TERI, DDSR or DCTS (MSR[4:1]) becomes set.

**ELSI** When set ("1"), an interrupt is generated if BI, FE, PE or OE (LSR[4:1]) becomes set.

- 0** No interrupt is generated if BI, FE, PE or OE (LSR[4:1]) becomes set.
- 1** An interrupt is generated if BI, FE, PE or OE (LSR[4:1]) becomes set.

**ETBEI** When set ("1"), an interrupt is generated if the TX Holding Register is empty or the contents of the TX FIFO have been reduced to its Trigger Level.

- 0** No interrupt is generated if the TX Holding Register is empty or the contents of the TX FIFO have been reduced to its Trigger Level
- 1** An interrupt is generated if the TX Holding Register is empty or the contents of the TX FIFO have been reduced to its Trigger Level

**ERBFI** When set ("1"), an interrupt is generated if the RX Buffer contains data.

- 0** No interrupt is generated if the RX Buffer contains data.
- 1** An interrupt is generated if the RX Buffer contains data.

### UARTn+0008h Interrupt Identification Register

### UARTn\_IIR

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7     | 6   | 5   | 4   | 3   | 2   | 1    | 0 |
|-------|----|----|----|----|----|----|---|---|-------|-----|-----|-----|-----|-----|------|---|
| Name  |    |    |    |    |    |    |   |   | FIFOE | ID4 | ID3 | ID2 | ID1 | ID0 | NINT |   |
| Type  |    |    |    |    |    |    |   |   |       |     |     |     |     |     | RO   |   |
| Reset |    |    |    |    |    |    |   |   | 0     | 0   | 0   | 0   | 0   | 0   | 0    | 1 |

**IIR** Identify if there are pending interrupts; ID4 and ID3 will present only when EFR[4] = 1.

The following table gives the IIR[5:0] codes associated with the possible interrupts:

| IIR[5:0] | Priority Level | Interrupt                 | Source                                                      |
|----------|----------------|---------------------------|-------------------------------------------------------------|
| 000001   | -              | No interrupt pending      |                                                             |
| 000110   | 1              | Line Status Interrupt     | BI, FE, PE or OE set in LSR                                 |
| 000100   | 2              | RX Data Received          | RX Data received or RX Trigger Level reached.               |
| 001100   | 2              | RX Data Timeout           | Timeout on character in RX FIFO.                            |
| 000010   | 3              | TX Holding Register Empty | TX Holding Register empty or TX FIFO Trigger Level reached. |
| 000000   | 4              | Modem Status change       | DDCD, TERI, DDSR or DCTS set in MSR                         |
| 010000   | 5              | Software Flow Control     | XOFF Character received                                     |
| 100000   | 6              | Hardware Flow Control     | CTS or RTS Rising Edge                                      |

**Table 19** The IIR[5:0] codes associated with the possible interrupts

**Line Status Interrupt:** A RX Line Status Interrupt (IIR[5:0] == 000110b) is generated if ELSI (IER[2]) is set and any of BI, FE, PE or OE (LSR[4:1]) becomes set. It's cleared by reading the Line Status Register.

**RX Data Received Interrupt:** A RX Received interrupt (IER[5:0] == 000100b) is generated if EFRBI (IER[0]) is set and either RX Data is placed in the RX Buffer Register or the RX Trigger Level is reached. It's cleared by reading the RX Buffer Register or the RX FIFO (if enabled).

**RX Data Timeout Interrupt:**

When virtual FIFO mode is disabled, RX Data Timeout Interrupt is generated if all of the following apply:

1. There is at least one character in the FIFO
2. The most recent character was received longer than four character periods ago. (inclusive of all start, parity and stop bits)
3. The most recent CPU read of the FIFO was longer than four character periods ago.

The timeout timer is restarted on receipt of a new byte from the RX Shift Register, or on a CPU read from the RX FIFO.

The RX Data Timeout Interrupt is enabled by setting EFRBI (IER[0]) to "1", and it is cleared by reading RX FIFO.

When virtual FIFO mode is enabled, RX Data Timeout Interrupt is generated if all of the following apply:

1. There is no character in the FIFO
2. The most recent character was received longer than four character periods ago. (inclusive of all start, parity and stop bits)
3. The most recent CPU read of the FIFO was longer than four character periods ago.

The timeout timer is restarted on receipt of a new byte from the RX Shift Register.

**RX Holding Register Empty Interrupt:** A TX Holding Register Empty Interrupt (IIR[5:0] = 000010b) is generated if ETRBI (IER[1]) is set and either the TX Holding Register or, if FIFOs are enabled, the TX FIFO becomes empty. It's cleared by writing to the TX Holding Register or TX FIFO if FIFO enabled.

**Modem Status Change Interrupt:** A Modem Status Change Interrupt (IIR[5:0] = 000000b) is generated if EDSSI (IER[3]) is set and either DDCD, TERI, DDSR or DCTS (MSR[3:0]) becomes set. It's cleared by reading the Modem Status Register.

**Software Flow Control Interrupt:** A Software Flow Control Interrupt (IIR[5:0] = 010000b) is generated if Software Flow Control is enabled and XOFFI (IER[5]) becomes set, indicating that an XOFF character has been received. It's cleared by reading the Interrupt Identification Register.

**Hardware Flow Control Interrupt:** A Hardware Flow Control Interrupt (IER[5:0] = 100000b) is generated if Hardware Flow Control is enabled and either RTSI (IER[6]) or CTSI (IER[7]) becomes set indicating that a rising edge has been detected on either the RTS/CTS Modem Control line. It's cleared by reading the Interrupt Identification Register.

### UARTn+0008h FIFO Control Register

### UARTn\_FCR

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7            | 6            | 5            | 4            | 3           | 2           | 1           | 0            |
|------|----|----|----|----|----|----|---|---|--------------|--------------|--------------|--------------|-------------|-------------|-------------|--------------|
| Name |    |    |    |    |    |    |   |   | <b>RFTL1</b> | <b>RFTL0</b> | <b>TFTL1</b> | <b>TFTL0</b> | <b>DMA1</b> | <b>CLRT</b> | <b>CLRR</b> | <b>FIFOE</b> |
| Type |    |    |    |    |    |    |   |   |              |              |              |              |             |             | WO          |              |

**FCR** FCR is used to control the trigger levels of the FIFOs, or flush the FIFOs.

FCR[7:6] is modified when LCR != BFh

FCR[5:4] is modified when LCR != BFh & EFR[4] = 1

FCR[4:0] is modified when LCR != BFh

**FCR[7:6]** RX FIFO trigger threshold

**0** 1

**0** 6

**1** 12

**2** 22

**FCR[5:4]** TX FIFO trigger threshold

**0** 1

**1** 4

**2** 8

**3** 14

**DMA1** This bit determines the DMA mode, which the TXRDY and RXRDY pins support. TXRDY and RXRDY act to support single-byte transfers between the UART and memory (DMA mode 0) or multiple byte transfers (DMA mode1). Note that this bit has no effect unless the FIFOE bit is set as well

**0** The device operates in DMA Mode 0.

**1** The device operates in DMA Mode 1.

TXRDY – mode0: Goes active (low) when the TX FIFO or the TX Holding Register is empty. Becomes inactive when a byte is written to the Transmit channel.

TXRDY – mode1: Goes active (low) when there are no characters in the TX FIFO. Becomes inactive when the TX FIFO is full.

RXRDY – mode0: Becomes active (low) when there is at least one character in the RX FIFO or the RX Buffer Register is full. It becomes inactive when there are no more characters in the RX FIFO or RX Buffer register.

RXRDY – mode1: Becomes active (low) when the RX FIFO Trigger Level reached or an RX FIFO Character Timeout occurs. It goes inactive when the RX FIFO is empty.

**CLRT** Clear Transmit FIFO. This bit is self-clearing.

**0** Leave TX FIFO intact.

**1** Clear all the bytes in the TX FIFO.

**CLRR** Clear Receive FIFO. This bit is self-clearing.

**0** Leave RX FIFO intact.

**1** Clear all the bytes in the RX FIFO.

**FIFOE** FIFO Enabled. This bit must be a 1 for any of the other bits in the registers to have any effect.

**0** Disable both the RX and TX FIFOs.

**1** Enable both the RX and TX FIFOs.

### UARTn+000Ch Line Control Register

### UARTn\_LCR

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6  | 5  | 4   | 3   | 2   | 1    | 0    |
|-------|----|----|----|----|----|----|---|---|------|----|----|-----|-----|-----|------|------|
| Name  |    |    |    |    |    |    |   |   | DLAB | SB | SP | EPS | PEN | STB | WLS1 | WLS0 |
| Type  |    |    |    |    |    |    |   |   |      |    |    |     |     |     |      | R/W  |
| Reset |    |    |    |    |    |    |   |   | 0    | 0  | 0  | 0   | 0   | 0   | 0    | 0    |

**LCR** Line Control Register. Determine characteristics of serial communication signals

Modified when LCR[7] = 0.

**DLAB** Divisor Latch Access Bit.

- 0** The RX and TX Registers are read/written at Address 0 and the IER register is read/written at Address 4.
- 1** The Divisor Latch LS is read/written at Address 0 and the Divisor Latch MS is read/written at Address 4.

**SB** Set Break

- 0** No effect
- 1** SOUT signal is forced into the "0" state.

**SP** Stick Parity

- 0** No effect.
- 1** The Parity bit is forced into a defined state, dependent upon state of EPS and PEN:  
If EPS = "1" & PEN = "1", the Parity bit is set and checked = "0".  
If EPS = "0" & PEN = "1", the Parity bit is set and checked = "1".

**EPS** Even Parity Select

- 0** When EPS="0", an odd number of ones is sent and checked.
- 1** When EPS="1", an even number of ones is sent and checked.

**PEN** Parity Enable

- 0** The Parity is neither transmitted nor checked
- 1** The Parity is transmitted and checked.

**STB** Number of Stop Bits

- 0** One STOP bit is always added.
- 1** Two STOP bits are added after each character is sent; unless the character length is 5 when 1 STOP bit is added.

**WLS1, 0** Word Length Select.

- 0** 5 bits.
- 1** 6 bits
- 2** 7 bits
- 3** 8 bits

### UARTn+0010h Modem Control Register

UARTn\_MCR

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                  | 6                | 5 | 4    | 3    | 2    | 1   | 0   |
|-------|----|----|----|----|----|----|---|---|--------------------|------------------|---|------|------|------|-----|-----|
| Name  |    |    |    |    |    |    |   |   | XOFF<br>STAT<br>US | IR<br>ENAB<br>LE | X | LOOP | OUT2 | OUT1 | RTS | DTR |
| Type  |    |    |    |    |    |    |   |   |                    |                  |   |      |      |      |     | R/W |
| Reset |    |    |    |    |    |    |   |   | 0                  | 0                | 0 | 0    | 0    | 0    | 0   | 0   |

**MCR** Modem Control Register. Control interface signals of the UART.

MCR[4:0] are modified when LCR[7] = 0,

MCR[7:6] are modified when LCR[7] = 0 & EFR[4] = 1.

**XOFF Status** This is a read-only bit.

- 0** When an XON character is received.
- 1** When an XOFF character is received.

**IR Enable** Enable IrDA modulation/demodulation.

- 0** Disable IrDA modulation/demodulation.
- 1** Enable IrDA modulation/demodulation.

**LOOP** Loop-back control bit

- 0** No loop-back is enabled

|             |                                                           |
|-------------|-----------------------------------------------------------|
| <b>1</b>    | Loop-back mode is enabled                                 |
| <b>OUT2</b> | Control the state of the output NOUT2, even in loop mode. |
| <b>0</b>    | NOUT2="1".                                                |
| <b>1</b>    | NOUT2="0".                                                |
| <b>OUT1</b> | Control the state of the output NOUT1, even in loop mode. |
| <b>0</b>    | NOUT1="1".                                                |
| <b>1</b>    | NOUT1="0".                                                |
| <b>RTS</b>  | Control the state of the output NRTS, even in loop mode.  |
| <b>0</b>    | NRTS="1".                                                 |
| <b>1</b>    | NRTS="0".                                                 |
| <b>DTR</b>  | Control the state of the output NDTR, even in loop mode.  |
| <b>0</b>    | NDTR="1".                                                 |
| <b>1</b>    | NDTR="0".                                                 |

### UARTn+0014h Line Status Register

### UARTn\_LSR

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7           | 6                | 5    | 4   | 3  | 2  | 1  | 0  |
|-------|----|----|----|----|----|----|---|---|-------------|------------------|------|-----|----|----|----|----|
| Name  |    |    |    |    |    |    |   |   | FIFOE<br>RR | TEM <sup>T</sup> | THRE | BI  | FE | PE | OE | DR |
| Type  |    |    |    |    |    |    |   |   |             |                  |      | R/W |    |    |    |    |
| Reset |    |    |    |    |    |    |   |   | 0           | 1                | 1    | 0   | 0  | 0  | 0  | 0  |

**LSR** Line Status Register.

Modified when LCR[7] = 0.

**FIFOERR** RX FIFO Error Indicator.

- 0** No PE, FE, BI set in the RX FIFO.
- 1** Set to 1 when there is at least one PE, FE or BI in the RX FIFO.

**TEM<sup>T</sup>** TX Holding Register (or TX FIFO) and the TX Shift Register are empty.

- 0** Empty conditions below are not met.
- 1** If FIFOs are enabled, the bit is set whenever the TX FIFO and the TX Shift Register are empty. If FIFOs are disabled, the bit is set whenever TX Holding Register and TX Shift Register are empty.

**THRE** Indicate if there is room for TX Holding Register or TX FIFO is reduced to its Trigger Level.

- 0** When at least one byte is written to the TX FIFO or the TX Shift Register.
- 1** Set whenever the contents of the TX FIFO are reduced to its Trigger Level (FIFOs are enabled), or whenever TX Holding Register is empty and ready to accept new data (FIFOs are disabled.).

**BI** Break Interrupt.

- 0** Reset by the CPU reading this register
- 1** If the FIFOs are disabled, this bit is set whenever the SIN is held in the 0 state for more than one transmission time (START bit + DATA bits + PARITY + STOP bits).

If the FIFOs are enabled, this error is associated with a corresponding character in the FIFO and is flagged when this byte is at the top of the FIFO. When a break occurs, only one zero character is loaded into the FIFO: the next character transfer is enabled when SIN goes into the marking state and receives the next valid start bit.

**FE** Framing Error.

- 0** Reset by the CPU reading this register
- 1** If the FIFOs are disabled, this bit is set if the received data did not have a valid STOP bit. If the FIFOs are enabled, the state of this bit is revealed when the byte it refers to is the next to be read.

**PE** Parity Error

- 0** Reset by the CPU reading this register  
**1** If the FIFOs are disabled, this bit is set if the received data did not have a valid parity bit. If the FIFOs are enabled, the state of this bit is revealed when the byte it refers to is the next to be read.

#### OE Overrun Error

- 0** Reset by the CPU reading this register  
**1** If the FIFOs are disabled, this bit is set if the RX Buffer was not read by the CPU before new data from the RX Shift Register overwrote the previous contents.

If the FIFOs are enabled, an overrun error occurs when the RX FIFO is full and the RX Shift Register becomes full. OE is set as soon as this happens. The character in the Shift Register is then overwritten, but it is not transferred to the FIFO.

#### DR Data Ready.

- 0** Cleared by the CPU reading the RX Buffer or by reading all the FIFO bytes.  
**1** Set by the RX Buffer becoming full or by a byte being transferred into the FIFO.

### UARTn+0018h Modem Status Register

### UARTn\_MSR

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7     | 6     | 5     | 4     | 3    | 2    | 1    | 0    |
|-------|----|----|----|----|----|----|---|---|-------|-------|-------|-------|------|------|------|------|
| Name  |    |    |    |    |    |    |   |   | DCD   | RI    | DSR   | CTS   | DDCD | TERI | DDSR | DCTS |
| Type  |    |    |    |    |    |    |   |   | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  | R/W  | R/W  |
| Reset |    |    |    |    |    |    |   |   | Input | Input | Input | Input | 0    | 0    | 0    | 0    |

Note: After reset, D4-D7 are inputs. A modem status interrupt can be cleared by writing '0' or set by writing '1' to this register. D0-D3 can be written to.

Modified when LCR[7] = 0.

**MSR** Modem Status Register

**DCD** Data Carry Detect.

When Loop = "0", this is the complement of the NDCD input signal.

When Loop = "1", this is equal to the OUT2 bit in the Modem Control Register.

**RI** Ring Indicator.

When Loop = "0", this is the complement of the NRI input signal.

When Loop = "1", this is equal to the OUT1 bit in the Modem Control Register.

**DSR** Data Set Ready

When Loop = "0", this is the complement of the NDSR input signal.

When Loop = "1", this is equal to the DTR bit in the Modem Control Register.

**CTS** Clear To Send.

When Loop = "0", this is the complement of the NCCTS input signal.

When Loop = "1", this is equal to the RTS bit in the Modem Control Register.

**DDCD** Delta Data Carry Detect.

**0** The state of DCD has not changed since the Modem Status Register was last read

**1** Set if the state of DCD has changed since the Modem Status Register was last read.

**TERI** Trailing Edge Ring Indicator

**0** The NRI input does not change since this register was last read.

**1** Set if the NRI input changes from "0" to "1" since this register was last read.

**DDSR** Delta Data Set Ready

- 0** Cleared if the state of DSR has not changed since this register was last read.
- 1** Set if the state of DSR has changed since this register was last read.

**DCTS** Delta Clear To Send

- 0** Cleared if the state of CTS has not changed since this register was last read.
- 1** Set if the state of CTS has changed since this register was last read.

**UARTn+001Ch Scratch Register**
**UARTn\_SCR**

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4               | 3 | 2 | 1 | 0 |
|------|----|----|----|----|----|----|---|---|---|---|---|-----------------|---|---|---|---|
| Name |    |    |    |    |    |    |   |   |   |   |   | <b>SCR[7:0]</b> |   |   |   |   |
| Type |    |    |    |    |    |    |   |   |   |   |   | R/W             |   |   |   |   |

A general purpose read/write register. After reset, its value is un-defined.

Modified when LCR[7] = 0.

**UARTn+0000h Divisor Latch (LS)**
**UARTn\_DLL**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4               | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|-----------------|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   | <b>DLL[7:0]</b> |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | R/W             |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 1               |   |   |   |   |

**UARTn+0004h Divisor Latch (MS)**
**UARTn\_DLM**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4               | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|-----------------|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   | <b>DLL[7:0]</b> |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | R/W             |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 0               |   |   |   |   |

Note: DLL & DLM can only be updated if DLAB is set ("1"). Note too that division by 1 generates a BAUD signal that is constantly high.

Modified when LCR[7] = 1.

The table below shows the divisor needed to generate a given baud rate from CLK inputs of 13, 26MHz and 52MHz. The effective clock enable generated is 16 x the required baud rate.

| BAUD   | 13MHz | 26MHz | 52MHz |
|--------|-------|-------|-------|
| 110    | 7386  | 14773 | 29545 |
| 300    | 2708  | 5417  | 10833 |
| 1200   | 677   | 1354  | 2708  |
| 2400   | 338   | 677   | 1354  |
| 4800   | 169   | 339   | 677   |
| 9600   | 85    | 169   | 339   |
| 19200  | 42    | 85    | 169   |
| 38400  | 21    | 42    | 85    |
| 57600  | 14    | 28    | 56    |
| 115200 | 6     | 14    | 28    |

**Table 2** Divisor needed to generate a given baud rate

**UARTn+0008h Enhanced Feature Register**
**UARTn\_EFR**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7           | 6           | 5   | 4             | 3                 | 2   | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|-------------|-------------|-----|---------------|-------------------|-----|---|---|
| Name  |    |    |    |    |    |    |   |   | AUTO<br>CTS | AUTO<br>RTS | D5  | ENAB<br>LE -E | SW FLOW CONT[3:0] |     |   |   |
| Type  |    |    |    |    |    |    |   |   | R/W         | R/W         | R/W | R/W           | R/W               | R/W |   |   |
| Reset |    |    |    |    |    |    |   |   | 0           | 0           | 0   | 0             | 0                 | 0   |   |   |

\*NOTE: Only when LCR=BF'h

**Auto CTS** Enables hardware transmission flow control

- 0 Disabled.
- 1 Enabled.

**Auto RTS** Enables hardware reception flow control

- 0 Disabled.
- 1 Enabled.

**Enable-E** Enable enhancement features.

- 0 Disabled.
- 1 Enabled.

**CONT[3:0]** Software flow control bits.

- 00xx** No TX Flow Control
- 10xx** Transmit XON1/XOFF1 as flow control bytes
- 01xx** Transmit XON2/XOFF2 as flow control bytes
- 11xx** Transmit XON1 & XON2 and XOFF1 & XOFF2 as flow control words
- xx00** No RX Flow Control
- xx10** Receive XON1/XOFF1 as flow control bytes
- xx01** Receive XON2/XOFF2 as flow control bytes
- xx11** Receive XON1 & XON2 and XOFF1 & XOFF2 as flow control words

**UARTn+0010h XON1**
**UARTn\_XON1**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3         | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-----------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | XON1[7:0] |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | R/W       |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0         |   |   |   |

**UARTn+0014h XON2**
**UARTn\_XON2**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3         | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-----------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | XON2[7:0] |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | R/W       |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0         |   |   |   |

**UARTn+0018h XOFF1**
**UARTn\_XOFF1**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3          | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|------------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | XOFF1[7:0] |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | R/W        |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0          |   |   |   |

**UARTn+001Ch XOFF2**
**UARTn\_XOFF2**

| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | XOFF2[7:0] |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

\*Note: XON1, XON2, XOFF1, XOFF2 are valid only when LCR=BFh.

**UARTn+0020h AUTOBAUD\_EN**
**UARTn\_AUTOBAUD\_EN**

| Bit   | 15     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | AUTOEN |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**AUTOBAUD\_EN** Auto-baud enable signal

- 0** Auto-baud function disable
- 1** Auto-baud function enable

**UARTn+0024h HIGH SPEED UART**
**UARTn\_HIGHSPEED**

| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | SPEED[1:0] |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**SPEED** UART sample counter base

- 0** based on 16\*baud\_pulse, baud\_rate = system clock frequency/16/{DLH, DLL}
- 1** based on 8\*baud\_pulse, baud\_rate = system clock frequency/8/{DLH, DLL}
- 2** based on 4\*baud\_pulse, baud\_rate = system clock frequency/4/{DLH, DLL}
- 3** based on sampe\_count \* baud\_pulse, baud\_rate = system clock frequency / sampe\_count

The table below shows the divisor needed to generate a given baud rate from CLK inputs of 13MHz based on different HIGHSPEED value.

| BAUD  | HIGHSPEED = 0 | HIGHSPEED = 1 | HIGHSPEED = 2 |
|-------|---------------|---------------|---------------|
| 110   | 7386          | 14773         | 29545         |
| 300   | 2708          | 7386          | 14773         |
| 1200  | 677           | 2708          | 7386          |
| 2400  | 338           | 677           | 2708          |
| 4800  | 169           | 338           | 677           |
| 9600  | 85            | 169           | 338           |
| 19200 | 42            | 85            | 169           |
| 38400 | 21            | 42            | 85            |
| 57600 | 14            | 21            | 42            |

|        |   |    |    |
|--------|---|----|----|
| 115200 | 7 | 14 | 21 |
| 230400 | * | 7  | 14 |
| 460800 | * | *  | 7  |
| 921600 | * | *  | *  |

**Table 20** Divisor needed to generate a given baud rate from 13MHz based on different HIGHSPEED value

The table below shows the divisor needed to generate a given baud rate from CLK inputs of 26MHz based on different HIGHSPEED value.

| BAUD   | HIGHSPEED = 0 | HIGHSPEED = 1 | HIGHSPEED = 2 |
|--------|---------------|---------------|---------------|
| 110    | 14773         | 29545         | 59091         |
| 300    | 5417          | 14773         | 29545         |
| 1200   | 1354          | 5417          | 14773         |
| 2400   | 677           | 1354          | 5417          |
| 4800   | 339           | 677           | 1354          |
| 9600   | 169           | 339           | 667           |
| 19200  | 85            | 169           | 339           |
| 38400  | 42            | 85            | 169           |
| 57600  | 28            | 42            | 85            |
| 115200 | 14            | 28            | 42            |
| 230400 | 7             | 14            | 28            |
| 460800 | *             | 7             | 14            |
| 921600 | *             | *             | 7             |

**Table 21** Divisor needed to generate a given baud rate from 26MHz based on different HIGHSPEED value

The table below shows the divisor needed to generate a given baud rate from CLK inputs of 52MHz based on different HIGHSPEED value.

| BAUD   | HIGHSPEED = 0 | HIGHSPEED = 1 | HIGHSPEED = 2 |
|--------|---------------|---------------|---------------|
| 110    | 29545         | 59091         | 118182        |
| 300    | 10833         | 29545         | 59091         |
| 1200   | 2708          | 10833         | 29545         |
| 2400   | 1354          | 2708          | 10833         |
| 4800   | 677           | 1354          | 2708          |
| 9600   | 339           | 677           | 1354          |
| 19200  | 169           | 339           | 677           |
| 38400  | 85            | 169           | 339           |
| 57600  | 56            | 85            | 169           |
| 115200 | 28            | 56            | 85            |

|        |    |    |    |
|--------|----|----|----|
| 230400 | 14 | 28 | 56 |
| 460800 | 7  | 14 | 28 |
| 921600 | *  | 7  | 14 |

Table 4 Divisor needed to generate a given baud rate from 52MHz based on different HIGHSPEED value

#### UARTn+0028h SAMPLE\_COUNT

#### UARTn\_SAMPLE\_COUN T

| Bit   | 15                | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | SAMPLECOUNT [7:0] |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0                 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

When HIGHSPEED=3, the sample\_count is the threshold value for UART sample counter (sample\_num).

#### UARTn+002Ch SAMPLE\_POINT

#### UARTn\_SAMPLE\_POINT

| Bit   | 15                | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | SAMPLEPOINT [7:0] |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | ffh               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

When HIGHSPEED=3, UART gets the input data when sample\_count=sample\_num.

e.g. system clock = 13MHz, 921600 = 13000000 / 14

sample\_count = 14 and sample point = 7 (sample the central point to decrease the inaccuracy)

#### UARTn+0030h AUTOBAUD\_REG

#### UARTn\_AUTOBAUD\_REG

| Bit   | 15             | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | BAUD_STAT[3:0] |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RO             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**BAUD\_RATE** Autobaud baud rate

- 0 115200
- 1 57600
- 2 38400
- 3 19200
- 4 9600
- 5 4800
- 6 2400
- 7 1200
- 8 300
- 9 110

**BAUDSTAT** Autobaud format

- 0 Autobaud is detecting
- 1 AT\_7N1
- 2 AT\_7O1
- 3 AT\_7E1

- 4** AT\_8N1
- 5** AT\_8O1
- 6** AT\_8E1
- 7** at\_7N1
- 8** at\_7E1
- 9** at\_7O1
- 10** at\_8N1
- 11** at\_8E1
- 12** at\_8O1
- 13** Autobaud detection fails

#### UARTn+0038h AUTOBAUDSAMPLE

#### UARTn\_AUTOBAUDSAM PLE

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|---|---|---|-----|-----|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    |   |   |   |     |     |     |     |     |     |     |
| Type  |    |    |    |    |    |    |   |   |   | R/W |
| Reset |    |    |    |    |    |    |   |   |   |     |     |     |     |     |     | dh  |

Since the system clock may change, autobaud sample duration should change as system clock changes. When system clock = 13MHz, autobaudsample = 6; when system clock = 26MHz, autobaudsample = 13.

#### UARTn+003Ch Guard time added register

#### UARTn\_GUARD

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6   | 5   | 4        | 3   | 2              | 1   | 0 |
|-------|----|----|----|----|----|----|---|---|---|-----|-----|----------|-----|----------------|-----|---|
| Name  |    |    |    |    |    |    |   |   |   |     |     | GUARD_EN |     | GUARD_CNT[3:0] |     |   |
| Type  |    |    |    |    |    |    |   |   |   | R/W | R/W | R/W      | R/W | R/W            | R/W |   |
| Reset |    |    |    |    |    |    |   |   |   |     |     | 0        | 0   | 0              | 0   | 0 |

**GUARD\_CNT** Guard interval count value. Guard interval = (1/(system clock / 16 / div )) \* GUARD\_CNT.

**GUARD\_EN** Guard interval add enable signal

- 0** No guard interval added
- 1** Add guard interval after stop bit

#### UARTn+0040h Escape character register

#### UARTn\_ESCAPE\_DAT

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6   | 5 | 4 | 3               | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|-----|---|---|-----------------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |     |   |   | ESCAPE_DAT[7:0] |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   | R/W |   |   |                 |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |     |   |   | FFh             |   |   |   |

**ESCAPE\_DAT** Escape character added before software flow control data and escape character, i.e. if tx data is xon (31h), with esc\_en =1, uart will transmit data as esc + CEh (~xon).

#### UARTn+0044h Escape enable register

#### UARTn\_ESCAPE\_EN

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | ESC_EN |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W    |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0      |

**ESC\_EN** Add escape character in transmitter and remove escape character in receiver by UART.

- 0** Do not deal with the escape character
- 1** Add escape character in transmitter and remove escape character in receiver

### UARTn+0048h Sleep enable register

### UARTn\_SLEEP\_EN

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | SELL_P_EN |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W       |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0         |

**SLEEP\_EN** For sleep mode issue

- 0** Do not deal with sleep mode indicate signal
- 1** To activate hardware flow control or software control according to software initial setting when chip enters sleep mode. Releasing hardware flow when chip wakes up; but for software control, uart will send xon when awaken and when FIFO does not reach threshold level.

### UARTn+004Ch Virtual FIFO enable register

### UARTn\_VFIFO\_EN

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0        |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | VFIFO_EN |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W      |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0        |

**VFIFO\_EN** Virtual FIFO mechanism enable signal

- 0** Disable VFIFO mode
- 1** Enable VFIFO mode. When virtual mode is enabled, the flow control will base on DMA threshold, and will generate timeout interrupt for DMA.

## 4.8 IrDA Framer

### 4.8.1 General Description

IrDA framer, which is depicted in **Figure 30**, is implemented to reduce the CPU loading for IrDA transmission. IrDA framer functional block can be divided into two parts: the transmitting part and the receiving part. In the transmitter, it will perform BOFs addition, byte stuffing, the addition of 16-bits FCS, and EOF appendence. In the receiving part, it will execute BOFs removal, ESC character removal, CRC checking, and EOF detection. In addition, the framer will perform 3/16 modulation and demodulation to connect to the IR transceiver. The transmitter and receiver all need DMA channel.



Figure 30 IrDA framer functional block

#### 4.8.2 Register Definitions

##### IRDA+0000h TX BUF and RX BUF

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0               |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>BUF[7:0]</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W             |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0               |

**BUF** IrDA Framer transmit or receive data

##### IRDA+0004h TX BUF and RX BUF clear signal

##### BUF\_CLEAR

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0            |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>CLEAR</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W          |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0            |

**CLEAR** When CLEAR=1, the FIFO will be cleared

##### IRDA+0008h Maximum Turn Around Time

##### MAX\_T

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                  |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>MAX_T[13:0]</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W                |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 3E80h              |

**MAX\_T** Maximum turn around time is the maximum time that a station can hold the P/F bit. This parameter along with the baud rate parameter dictates the maximum number of bytes that a station can transmit before giving the line to another station by transmitting a frame with the P/F bit. This parameter is used by one station to indicate the maximum time the other station can send before it must turn the link around. 500ms is the only valid value when the baud rate is less than 115200kbps. The default value is 500ms.

##### IRDA+000Ch Minimum Turn Around Time

##### MIN\_T

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                  |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>MIN_T[15:0]</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W                |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | FDE8h              |

**MIN\_T** Minimum turn around time, the default value is 10ms. The minimum turn around time parameter deals with the time needed for a receiver to recover following saturation by transmission from the same device. This parameter corresponds to the required time delay between the last byte of the last frame sent by a station and the point at which it is ready to receive the first byte of a frame from another station, i.e. it is the latency for transmit to complete and be ready for receive.

### IRDA+0010h      Number of additional BOFs prefixed to the beginning of a frame      BOFS

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6   | 5 | 4 | 3 | 2 | 1 | 0          |
|-------|----|----|----|----|----|----|---|---|------|-----|---|---|---|---|---|------------|
| Name  |    |    |    |    |    |    |   |   | TYPE |     |   |   |   |   |   | BOFS [6:0] |
| Type  |    |    |    |    |    |    |   |   |      | R/W |   |   |   |   |   | R/W        |
| Reset |    |    |    |    |    |    |   |   |      | 0   |   |   |   |   |   | 1011b      |

**BOFs** Additional BOFs number; the additional BOFs parameter indicates the number of additional flags needed at the beginning of every frame. The main purpose of the addition of additional BOFs is to provide a delay at the beginning of each frame for device with long interrupt latency.

**TYPE** Additional BOFs type

- 1 BOF = C0h
- 0 BOF = FFh

### IRDA+0014h      Baud rate divisor      DIV

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6         | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|-----------|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   | DIV[15:0] |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   | R/W       |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   | 55h       |   |   |   |   |   |   |

**DIV** Transmit or receive rate divider. Rate = System clock frequency / DIV/ 16; the default value = 'h55 when in contention mode.

### IRDA+0018h      Transmit frame size      TX\_FRAME\_SIZE

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6                   | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---------------------|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   | TX_FRAME_SIZE[11:0] |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   | R/W                 |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   | 40h                 |   |   |   |   |   |   |

**TX\_FRAME\_SIZE** Transmit frame size; the default value = 64 when in contention mode.

### IRDA+001Ch      Receiving frame1 size      RX\_FRAME1\_SIZE

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6                    | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|----------------------|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   | RX_FRAME1_SIZE[11:0] |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   | RO                   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   | 0                    |   |   |   |   |   |   |

**RX\_FRAME1\_SIZE** The actual number of receiving frame1 size.

### IRDA+0020h      Transmit abort indication      ABORT

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

|       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |
|-------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--------------|
| Name  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>ABORT</b> |
| Type  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | R/W          |
| Reset |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0            |

**ABORT** When set 1, the framer will transmit abort sequence and closes the frame without an FCS field or an ending flag.

### IRDA+0024h IrDA framer transmit enable signal

**TX\_EN**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2            | 1             | 0           |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|--------------|---------------|-------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>TX_ON</b> | <b>TXINVE</b> |             |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>E</b>     | <b>RT</b>     | <b>MODE</b> |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0            | 0             | 0           |

**TX\_EN** Transmit enable

**MODE** Modulation type selection

**0** 3/16 modulation

**1** 1.61us

**TXINVERT** Invert transmit signal

**0** transmit signal is not inverted

**1** inverts transmit signal

**TX\_ONE:** Control the transmit enable signal is one hot or not

**0** tx\_en will not be de-asserted until software programs

**1** tx\_en will be de-asserted (i.e. transmit disabled) automatically after one frame has been sent

### IRDA+0028h IrDA framer receive enable signal

**RX\_EN**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2            | 1             | 0           |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|--------------|---------------|-------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>RX_ON</b> | <b>RXINVE</b> | <b>RX_E</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | R/W          | R/W           | R/W         |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0            | 0             | 0           |

**RX\_EN** Receive enable

**RXINVERT** Invert receive signal

**0** receive signal is not inverted

**1** inverts receive signal

**RX\_ONE** Disable receive when get one frame

**0** rx\_en will not be de-asserted until software programs

**1** rx\_en will be de-asserted (i.e. transmit disabled) automatically after one frame has been sent

### IRDA+002Ch FIFO trigger level indication

**TRIGGER**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2               | 1              | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|-----------------|----------------|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>RX_TRIG[</b> | <b>TX_TRIG</b> |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | R/W             | R/W            |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0               | 0              |   |

**TX\_TRIG** The tx FIFO interrupt trigger threshold

**00** 0 byte

**01** 1 byte

**02** 2 byte

**RX\_TRIG** The rx FIFO interrupt trigger threshold

**00** 1 byte

**01** 2 byte

**02** 3 byte

### IRDA+0030h IRQ enable signal

| Bit   | 15 | 14 | 13 | 12                 | 11            | 10                    | 9                   | 8           | 7           | 6                  | 5                  | 4                  | 3                  | 2           | 1           | 0            | IRQ_ENABLE |
|-------|----|----|----|--------------------|---------------|-----------------------|---------------------|-------------|-------------|--------------------|--------------------|--------------------|--------------------|-------------|-------------|--------------|------------|
| Name  |    |    |    | 2NDR<br>X_CO<br>MP | RXRES<br>TART | THRES<br>HTIME<br>OUT | FIFOTI<br>MEOU<br>T | TXABO<br>RT | RXABO<br>RT | MAXTI<br>MEOU<br>T | MINTI<br>MEOU<br>T | RXCO<br>MPLET<br>E | TXCO<br>MPLET<br>E | STATUS<br>S | RXTRIG<br>G | TXTTRIG<br>G |            |
| Type  |    |    |    |                    | R/W           | R/W                   | R/W                 | R/W         | R/W         | R/W                | R/W                | R/W                | R/W                | R/W         | R/W         | R/W          |            |
| Reset |    |    |    |                    | 0             | 0                     | 0                   | 0           | 0           | 0                  | 0                  | 0                  | 0                  | 0           | 0           | 0            |            |

**IRQ\_ENABLE** Interrupt enable signal

**0** disable

**1** enable

**TXTRIG** Transmit data reaches the threshold level

**0** No interrupt is generated

**1** Interrupt is generated when transmit FIFO size reaches threshold

**RXTRIG** Receive data reaches the threshold level

**0** No interrupt is generated

**1** Interrupt is generated when receive FIFO size reaches threshold

**STATUS** Any status lists as following has happened

(overrun, size\_error)

**0** No interrupt is generated

**1** Interrupt is generated when one of the statuses occurred

**TXCOMPLETE** Transmit one frame completely

**0** No interrupt is generated

**1** Interrupt is generated when transmitting one frame completely

**RXCOMPLETE** Receive one frame completely

**0** No interrupt is generated

**1** Interrupt is generated when receiving one frame completely

**MINTIMEOUT** Minimum time timeout

**0** No interrupt is generated

**1** Interrupt is generated when minimum timer is timed out

**MAXTIMEOUT** Maximum time timeout

**0** No interrupt is generated

**1** Interrupt is generated when maximum timer is timed out

**RXABORT** Receiving aborting frame

**0** No interrupt is generated

**1** Interrupt is generated when receiving aborting frame

**TXABORT** Transmitting aborting frame

**0** No interrupt is generated

**1** Interrupt is generated when transmitting aborting frame

**FIFOTIMEOUT** FIFO timeout

**0** No interrupt is generated

**1** Interrupt is generated when FIFO timeout

**THRESHTIMEOUT** Threshold time timeout

**0** No interrupt is generated

**1** Interrupt is generated when threshold timer is timed out

**RXRESTART** Receiving a new frame before one frame is received completely

**0** No interrupt is generated

**1** Interrupt is generated when receiving a new frame before one frame is received completely

**2NDRX\_COMP** Receiving second frame and get P/F bit

**0** No interrupt is generated

**1** Interrupt is generated when receiving second frame and get P/F bit completely

### IRDA+0034h Interrupt Status

**IRQ\_STA**

| Bit   | 15 | 14 | 13 | 12              | 11                | 10                   | 9                  | 8              | 7              | 6                 | 5                 | 4              | 3              | 2               | 1               | 0               |
|-------|----|----|----|-----------------|-------------------|----------------------|--------------------|----------------|----------------|-------------------|-------------------|----------------|----------------|-----------------|-----------------|-----------------|
| Name  |    |    |    | <b>2NDRX_CO</b> | <b>RXRES_TART</b> | <b>THRESHTIMEOUT</b> | <b>FIFOTIMEOUT</b> | <b>TXABORT</b> | <b>RXABORT</b> | <b>MAXTIMEOUT</b> | <b>MINTIMEOUT</b> | <b>RXCOPLE</b> | <b>TXCOPLE</b> | <b>STATUSES</b> | <b>RXFIFO_O</b> | <b>TXFIFO_O</b> |
| Type  |    |    |    | RC              | RC                | RC                   | RC                 | RC             | RC             | RC                | RC                | RC             | RC             | RC              | RC              | RC              |
| Reset |    |    |    | 0               | 0                 | 0                    | 0                  | 0              | 0              | 0                 | 0                 | 0              | 0              | 0               | 0               | 0               |

**TXFIFO** Transmit FIFO reaches threshold

**RXFIFO** Receive FIFO reaches threshold

**ERROR** generated when one of the statuses occurred

(data\_error, PF\_detect, fifo\_hold1, fifo\_empty, crc\_fail, frame\_error, overrun, size\_error)

**TXCOMPLETE** Transmitting one frame completely

**RXCOMPLETE** Receiving one frame completely

**MINTIMEOUT** Minimum turn around time timeout

**MAXTIMEOUT** Maximum turn around time timeout

**RXABORT** Receiving aborting frame

**TXABORT** Transmitting aborting frame

**FIFOTIMEOUT** FIFO is timeout

**THRESHTIMEOUT** Threshold time timeout

**RXRESTART** Receiving a new frame before one frame is received completely

**2NDRX\_COMP** Receiving second frame and get P/F bit completely

### IRDA+0038h STATUS register

**STATUS**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3                | 2                | 1              | 0               |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|------------------|------------------|----------------|-----------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | <b>FIFOHOLD1</b> | <b>FIFOEMPTY</b> | <b>OVERRUN</b> | <b>RXSIZENE</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | R/W              | R/W              | R/W            | R/W             |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0                | 0                | 0              | 0               |

**RXSIZE** Receive frame size error

**OVERRUN** Frame over run

**FIFOEMPTY** FIFO empty

**FIFOHOLD1** FIFO holds one

**IRDA+003Ch Transceiver power on/off control**
**TRANSCEIVER\_PDN**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | TRANS_PDN |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W       |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 1         |

**Transceiver\_PDN** Power on/off control for external IrDA transceiver

**IRDA+0040h Maximum number of receiving frame size**
**RX\_FRAME\_MAX**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | MAX_RX_FRAME_SIZE |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W               |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0                 |

**RX\_FRAME\_MAX** Receive frame max size, when actual receiving frame size is larger than rx\_frame\_max, RXSIZE is asserted.

**IRDA+0044h Threshold Time**
**THRESH\_T**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                     |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | DISCONNECT_TIME[15:0] |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W                   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | bb8h                  |

**THRESHOLD TIME** Threshold time; it's used to control the time a station will wait without receiving valid frame before it disconnects the link. Associated with this is the time a station will wait without receiving valid frames before it will send a status indication to the service user layer.

**IRDA+0048h Counter enable signal**
**COUNT\_ENABLE**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | THRESH_EN |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W       |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0         |
|       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | MIN_EN    |
|       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | MAX_EN    |

**COUNT\_ENABLE** Counter enable signals

**IRDA+004Ch Indication of system clock rate**
**CLOCK\_RATE**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | CLOCK_RATE |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W        |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0          |

**CLOCK\_RATE** Indication of the system clock rate

- 0 26MHz
- 1 52MHz
- 2 13MHz

**IRDA+0050h System Clock Rate Fix**
**RATE\_FIX**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1               | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----------------|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | <b>RATE_FIX</b> |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W             |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0               |   |

**RATE\_FIX** Fix irda framer sample base clock rate as 13MHz

- 0 clock rate base on clock\_rate selection
- 1 13MHz

**IRDA+0054h RX Frame1 Status**
**FRAME1\_STAT US**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2             | 1                | 0               |                    |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---------------|------------------|-----------------|--------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>UNKNOW</b> | <b>PF_DETECT</b> | <b>CRC_FAIL</b> | <b>FRAME_ERROR</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | CT            | L                | ERROR           |                    |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0             | 0                | 0               |                    |

**FRAME\_ERROR** Framing error, i.e. stop bit = 0

- 0 No framing error
- 1 Framing error occurred

**CRC\_FAIL** CRC check fail

- 0 CRC check successfully
- 1 CRC check fail

**PF\_DETECT** P/F bit detect

- 0 No a P/F bit frame
- 1 Detect P/F bit in this frame

**UNKNOWN\_ERROR** Receiving error data i.e. escape character is followed by a character that is not an esc, bof, or eof character.

- 0 Data received correctly
- 1 Unknown error occurred

**IRDA+0058h RX Frame2 Status**
**FRAME2\_STAT US**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2             | 1                | 0               |                    |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---------------|------------------|-----------------|--------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>UNKNOW</b> | <b>PF_DETECT</b> | <b>CRC_FAIL</b> | <b>FRAME_ERROR</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | CT            | L                | ERROR           |                    |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0             | 0                | 0               |                    |

**FRAME\_ERROR** Framing error, i.e. stop bit = 0

- 0 No framing error
- 1 Framing error occurred

**CRC\_FAIL** CRC check fail

- 0 CRC check successfully
- 1 CRC check fail

**PF\_DETECT** P/F bit detect

**0** No a P/F bit frame

**1** Detect P/F bit in this frame

**UNKNOWN\_ERROR** Receiving error data i.e. escape character is followed by a character that is not an esc, bof, or eof character.

**0** Data receiving correctly

**1** Unknown error occurred

### IRDA+005Ch Receiving frame2 size

**RX\_FRAME2\_SIZE**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                           |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>RX_FRAME2_SIZE[11:0]</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO                          |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0                           |

**RX\_FRAME2\_SIZE** The actual number of receiving frame2 size.

## 4.9 Real Time Clock

### 4.9.1 General Description

The Real Time Clock (RTC) module provides time and date information. It works on the 32.768KHz oscillator with independent power supply. When the MS is powered off, a dedicated regulator is used to supply the RTC block. If the main battery is not present, the backup supply such as a small mercury cell battery or a large capacitor is used. In addition to provide timing data, alarm interrupt is generated and it can be used to power up the base-band core through the BBWAKEUP pin. Also, regulator interrupts corresponding to the seconds; minutes, hours and days can be generated whenever the time counter value reaches a maximum. The year span is supported up to 2127. The maximum day of month values are stored in the RTC block, which depend on the leap year condition.

### 4.9.2 Register Definitions

#### RTC+0000h Baseband power up

**RTC\_BBPU**

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                | 0               |              |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|------------------|-----------------|--------------|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   | <b>AUTO_BBPU</b> | <b>WRITE_EN</b> | <b>PWREN</b> |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W              | R/W             | R/W          |

**KEY\_BBPU** Bus write acceptable only when KEY\_BBPU = 0x43

**AUTO** Controls if BBWAKEUP will automatically be in low state when SYSRST# goes from high to low

**0** BBWAKEUP will not automatically be in low state when SYSRST# goes from high to low

**1** BBWAKEUP will automatically be in low state when SYSRST# goes from high to low

**BBPU** Controls the power of PMIC, when powerkey1=A357h & powerkey2=67D2h it will be the value programmed by software or it will be low if above situation is not true.

**0** Power down

**1** Power on

**WRITE\_EN** When WRITE\_EN is written as 0 by software program, the rtc write interface will be disabled until another system power on.

**PWREN**

- 0** RTC alarm has no action on power switch
- 1** When RTC alarm occurs, BBPU will be assigned as 1, then system will power on by rtc alarm wakeup.

**RTC+0004h    RTC IRQ status**
**RTC\_IRQ\_STA**

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2           | 1           | 0   |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|-------------|-------------|-----|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>TCST</b> | <b>ALST</b> |     |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   | R/C         | A           | R/C |

**ALSTA** This register indicates the IRQ status of whether or not the alarm condition has been met

- 0** No IRQ occurred; alarm condition has not been met
- 1** IRQ occurred; alarm condition has been met

**TCSTA** This register indicates the IRQ status of whether or not the tick condition has been met

- 0** No IRQ occurred; tick condition has not been met
- 1** IRQ occurred; tick condition has been met

**RTC+0008h    RTC IRQ enable**
**RTC\_IRQ\_EN**

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2            | 1           | 0           |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|--------------|-------------|-------------|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>ONESH</b> | <b>TC_E</b> | <b>AL_E</b> |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   | R/W          | R/W         | R/W         |

**ONESHOT** Controls automatic reset of AL\_EN & TC\_EN

**AL\_EN** This register enables the control bit for IRQ generation if the alarm condition has been met

- 0** Disable IRQ generation
- 1** Enable the alarm time match interrupt. Clear it when ONESHOT is high upon generation of the corresponding IRQ

**TC\_EN** This register enables the control bit for IRQ generation if the tick condition has been met

- 0** Disable IRQ generation
- 1** Enable the tick time match interrupt. Clear it when ONESHOT is high upon generation of the corresponding IRQ

**RTC+000Ch    Counter increment IRQ enable**
**RTC\_CII\_EN**

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9             | 8             | 7             | 6            | 5           | 4          | 3           | 2            | 1             | 0           |
|------|----|----|----|----|----|----|---------------|---------------|---------------|--------------|-------------|------------|-------------|--------------|---------------|-------------|
| Name |    |    |    |    |    |    | <b>1/8SEC</b> | <b>1/4SEC</b> | <b>1/2SEC</b> | <b>YEACI</b> | <b>MTHC</b> | <b>DOW</b> | <b>DOMC</b> | <b>HOU</b> C | <b>MINCII</b> | <b>SECC</b> |
| Type |    |    |    |    |    |    | R/W           | R/W           | R/W           | R/W          | R/W         | R/W        | R/W         | R/W          | R/W           | R/W         |

This register activates or de-activates the IRQ generation when the TC counter reaches its maximum value.

**SECCII** Set this bit to 1 to activate the IRQ at each second update

**MINCII** Set the bit to 1 to activate the IRQ at each minute update

**HOUCCI** Set the bit to 1 to activate the IRQ at each hour update

**DOMCII** Set the bit to 1 to activate the IRQ at each day of month update

**DOWCII** Set the bit to 1 to activate the IRQ at each day of week update

**MTHCII** Set the bit to 1 to activate the IRQ at each month update

**YEACII** Set the bit to 1 to activate the IRQ at each year update

**1/2SECCII** Set the bit to 1 to activate the IRQ at each one-half update

**1/4SECCII** Set the bit to 1 to activate the IRQ at each one-fourth update

**1/8SECCII** Set the bit to 1 to activate the IRQ at each one-eighth update

### RTC+0010h RTC alarm mask

### RTC\_AL\_MASK

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6           | 5           | 4           | 3           | 2           | 1            | 0           |
|------|----|----|----|----|----|----|---|---|---|-------------|-------------|-------------|-------------|-------------|--------------|-------------|
| Name |    |    |    |    |    |    |   |   |   | YEA_M<br>SK | MTH_M<br>SK | DOW_M<br>SK | DOM_M<br>SK | HOU_M<br>SK | MIN_MS<br>SK | SEC_M<br>SK |
| Type |    |    |    |    |    |    |   |   |   | R/W         | R/W         | R/W         | R/W         | R/W         | R/W          | R/W         |

The alarm condition for alarm IRQ generation is according to each bit in this register is masked or not.

#### SEC\_MSK

- 0** Condition (RTC\_TC\_SEC = RTC\_AL\_SEC) is checked to generate the alarm signal
- 1** Condition (RTC\_TC\_SEC = RTC\_AL\_SEC) is masked, i.e. the value of RTC\_TC\_SEC will not affect the alarm IRQ generation

#### MIN\_MSK

- 0** Condition (RTC\_TC\_MIN = RTC\_AL\_MIN) is checked to generate the alarm signal
- 1** Condition (RTC\_TC\_MIN = RTC\_AL\_MIN) is masked, i.e. the value of RTC\_TC\_MIN will not affect the alarm IRQ generation

#### HOU\_MSK

- 0** Condition (RTC\_TC\_HOU = RTC\_AL\_HOU) is checked to generate the alarm signal
- 1** Condition (RTC\_TC\_HOU = RTC\_AL\_HOU) is masked, i.e. the value of RTC\_TC\_HOU will not affect the alarm IRQ generation

#### DOM\_MSK

- 0** Condition (RTC\_TC\_DOM = RTC\_AL\_DOM) is checked to generate the alarm signal
- 1** Condition (RTC\_TC\_DOM = RTC\_AL\_DOM) is masked, i.e. the value of RTC\_TC\_DOM will not affect the alarm IRQ generation

#### DOW\_MSK

- 0** Condition (RTC\_TC\_DOW = RTC\_AL\_DOW) is checked to generate the alarm signal
- 1** Condition (RTC\_TC\_DOW = RTC\_AL\_DOW) is masked, i.e. the value of RTC\_TC\_DOW will not affect the alarm IRQ generation

#### MTH\_MSK

- 0** Condition (RTC\_TC\_MTH = RTC\_AL\_MTH) is checked to generate the alarm signal
- 1** Condition (RTC\_TC\_MTH = RTC\_AL\_MTH) is masked, i.e. the value of RTC\_TC\_MTH will not affect the alarm IRQ generation

#### YEA\_MSK

- 0** Condition (RTC\_TC\_YEA = RTC\_AL\_YEA) is checked to generate the alarm signal
- 1** Condition (RTC\_TC\_YEA = RTC\_AL\_YEA) is masked, i.e. the value of RTC\_TC\_YEA will not affect the alarm IRQ generation

### RTC+0014h RTC seconds time counter register

### RTC\_TC\_SEC

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1         | 0   |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----------|-----|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   | TC_SECOND |     |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |   |           | R/W |

**TC\_SECOND** The time counter second initial value. The range of its value is: 0-59.

**RTC+0018h RTC minutes time counter register**
**RTC\_TC\_MIN**

| Bit  | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | TC_MINUTE |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**TC\_MINUTE** The time counter minute initial value. The range of its value is: 0-59.

**RTC+001Ch RTC hours time counter register**
**RTC\_TC\_HOU**

| Bit  | 15      | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|---------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | TC_HOUR |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**TC\_HOUR** The time counter hour initial value. The range of its value is: 0-23.

**RTC+0x0020 RTC day of month time counter register**
**RTC\_TC\_DOM**

| Bit  | 15     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | TC_DOM |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**TC\_DOM** The time counter day of month initial value. The day of month maximum value depends on the leap year condition, i.e. 2 LSB of year time counter are zeros.

**RTC+0x0024 RTC day of week time counter register**
**RTC\_TC\_DOW**

| Bit  | 15     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | TC_DOW |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**TC\_DOW** The time counter day of week initial value. The range of its value is: 1-7.

**RTC+0x0028 RTC month time counter register**
**RTC\_TC\_MTH**

| Bit  | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | TC_MONTH |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**TC\_MONTH** The time counter month initial value. The range of its value is: 1-12.

**RTC+0x002C RTC year time counter register**
**RTC\_TC\_YEA**

| Bit  | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | AL_SECOND |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**TC\_YEAR** The time counter year initial value. The range of its value is: 0-127. (2000-2127)

**RTC+0x0030 RTC second alarm setting register**
**RTC\_AL\_SEC**

| Bit  | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | AL_SECOND |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**AL\_SECOND** The second value of the alarm counter setting. The range of its value is: 0-59.

**RTC+0x0034 RTC minute alarm setting register**
**RTC\_AL\_MIN**

| Bit  | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | AL_MINUTE |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**AL\_MINUTE** The minute value of the alarm counter setting. The range of its value is: 0-59.

**RTC+0x0038 RTC hour alarm setting register**
**RTC\_AL\_HOU**

| Bit  | 15      | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|---------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | AL_HOUR |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**AL\_HOUR** The hour value of the alarm counter setting. The range of its value is: 0-23.

**RTC+0x003C RTC day of month alarm setting register**
**RTC\_AL\_DOM**

| Bit  | 15     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | AL_DOM |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**AL\_DOM** The day of month value of the alarm counter setting. The day of month maximum value depends on the leap year condition, i.e. 2 LSB of year time counter are zeros.

**RTC+0x0040 RTC day of week alarm setting register**
**RTC\_AL\_DOW**

| Bit  | 15     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | AL_DOW |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**AL\_DOW** The day of week value of the alarm counter setting. The range of its value is: 1-7.

**RTC+0x0044 RTC month alarm setting register**
**RTC\_AL\_MTH**

| Bit  | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | AL_MONTH |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**AL\_MONTH** The month value of the alarm counter setting. The range of its value is: 1-12.

**RTC+0x0048 RTC year alarm setting register**
**RTC\_AL\_YEA**

| Bit  | 15      | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|---------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | AL_YEAR |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**AL\_YEAR** The year value of the alarm counter setting. The range of its value is: 0-127. (2000-2127)

**RTC+0x004C XOSC bias current control register**
**RTC\_XOSCCALI**

| Bit  | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | XOSCCALI |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | WO       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**XOSCCALI** This register controls the XOSC32 bias current. Before the first program by software, the XOSCCALI value is 11111b.

**RTC+0050h    RTC\_POWERKEY1 register**
**RTC\_POWERKE  
Y1**

| Bit  | 15                   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | <b>RTC_POWERKEY1</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**RTC+0054h    RTC\_POWERKEY2 register**
**RTC\_POWERKE  
Y2**

| Bit  | 15                   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | <b>RTC_POWERKEY2</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

These register sets are used to determine if the real time clock has been programmed by software; i.e. the time value in real time clock is correct. When the real time clock first power on, the register contents are all undefined, therefore the time values shown are incorrect. Software needs to know if the real time clock has been programmed. Hence, these two registers are defined to solve this power-on issue. After software programs the correct value, these two register sets do not need to be updated. In addition to programming the correct time value, when contents of these register sets are wrong, the interrupt will not be generated; therefore, the real time clock will not generate the interrupts before the software programs it. Unwanted interrupt due to wrong time value will not occur. The correct values of these two register sets are:

**RTC\_POWERKEY1** A357h

**RTC\_POWERKEY2** 67D2h

**RTC+0058h    PDN1**
**RTC\_PDN1**

| Bit  | 15                   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | <b>RTC_PDN1[7:0]</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**RTC\_PDN1[3:1]** is for reset de-bounce mechanism.

- 0** 2ms
- 1** 8ms
- 2** 32ms
- 3** 128ms
- 4** 256ms
- 5** 512ms
- 6** 1024ms
- 7** 2048ms

**RTC\_PDN1[7:4] & RTC\_PDN1[0]** is the spare register for software to keep some power on and power off state information.

**RTC+005Ch    PDN2**
**RTC\_PDN2**

| Bit  | 15                   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | <b>RTC_PDN2[7:0]</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**RTC\_PDN2** The spare register for software to keep some power on and power off state information.

## 4.10 Auxiliary ADC Unit

The auxiliary ADC unit is used to monitor the status of battery and charger, identify the plugged peripheral, and perform temperature measurement. There are 7 input channels for diversified application in this unit.

There are 2 modes of operation: immediate mode and timer-triggered mode. The mode of each channel can be individually selected through register **AUXADC\_CON0**. For example, if the flag **SYN0** in the register **AUXADC\_CON0** is set, the channel 0 will be set in timer-triggered mode. Otherwise, it is in immediate mode.

In immediate mode, the A/D converter will sample the value once only when the flag in the register **AUXADC\_CON1** has been set. For example, if the flag **IMM0** in the register **AUXADC\_CON1** is set, the A/D converter will sample the data for channel 0. The **IMM** flags should be cleared and set again to initialize another sampling.

The value sampled for channel 0 will be stored in register **AUXADC\_DAT0**, the value for channel 1 will be stored in register **AUXADC\_DAT1**, and vice versa.

If the **AUTOSET** flag in the register **AUXADC\_CON3** is set, the auto-sample function is enabled. The A/D converter will sample the data for the channel in which the corresponding data register has been read. For example, in the case where the **SYN1** flag is not set, the **AUTOSET** flag is set, when the data register **AUXADC\_DAT0** has been read, the A/D converter will sample the next value for channel 1 immediately.

If multiple channels are selected at the same time, the task will be performed sequentially on every selected channel. For example, if we set **AUXADC\_CON1** to be 0x7f, that is, all 7 channels are selected, the state machine in the unit will start sampling from channel 6 to channel 0, and save the values of each input channel in the respective registers. The same process also applies in the timer-triggered mode.

In timer-triggered mode, the A/D converter will sample the value for the channels in which the corresponding **SYN** flags are set when the TDMA timer counts to the value specified in the register **TDMA\_AUXEV1**, which is placed in the TDMA timer. For example, if we set **AUXADC\_CON0** to be 0x7f, all 7 channels are selected to be in timer-triggered mode. The state machine will sample all 7 channels sequentially and save the values in registers from **AUXADC\_DAT0** to **AUXADC\_DAT6**, as it does in immediate mode.

There is a dedicated timer-triggered scheme for channel 0. This scheme is enabled by setting the **SYN7** flag in the register **AUXADC\_CON2**. The timing offset for this event is stored in the register **TDMA\_AUXEV0** in the TDMA timer. The sampled data triggered by this specific event is stored in the register **AUXADC\_DAT7**. It is used to separate the results of two individual software routines that perform actions on the auxiliary ADC unit.

The **AUTOCLRn** in the register **AUXADC\_CON3** is set when it is intended to sample only once after setting timer-triggered mode. If **AUTOCLR1** flag has been set, after the data for the channels in timer-triggered mode has been stored, the **SYNn** flags in the register **AUXADC\_CON0** will be cleared. If **AUTOCLR0** flag has been set, after the data for the channel 0 has been stored in the register **AUXADC\_DAT7**, the **SYN7** flag in the register **AUXADC\_CON2** will be cleared.

The usage of the immediate mode and timer-triggered mode are mutually exclusive in terms of individual channel.

The **PUWAIT\_EN** bit in the registers **AUXADC\_CON3** is used to power up the analog port in advance. This ensures that the power has ramped up to the stable state before A/D converter starts the conversion. The analog part will be automatically powered down after the conversion is completed.

## 4.10.1 Register Definitions

**AUXADC+0000h Auxiliary ADC control register 0 AUXADC\_CON0**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6           | 5           | 4           | 3           | 2           | 1           | 0           |
|-------|----|----|----|----|----|----|---|---|---|-------------|-------------|-------------|-------------|-------------|-------------|-------------|
| Name  |    |    |    |    |    |    |   |   |   | <b>SYN6</b> | <b>SYN5</b> | <b>SYN4</b> | <b>SYN3</b> | <b>SYN2</b> | <b>SYN1</b> | <b>SYN0</b> |
| Type  |    |    |    |    |    |    |   |   |   | R/W         |
| Reset |    |    |    |    |    |    |   |   |   | 0           | 0           | 0           | 0           | 0           | 0           | 0           |

**SYNn** These 7 bits define whether the corresponding channel is to be sampled or not in timer-triggered mode. It is associated with timing offset register **TDMA\_AUXEV1**. It supports multiple flags. The flags can be automatically cleared after those channel have been sampled if **AUTOCLR1** in the register **AUXADC\_CON3** is set.

- 0** The channel is not selected.
- 1** The channel is selected.

**AUXADC+0004h Auxiliary ADC control register 1 AUXADC\_CON1**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6           | 5           | 4           | 3           | 2           | 1           | 0           |
|-------|----|----|----|----|----|----|---|---|---|-------------|-------------|-------------|-------------|-------------|-------------|-------------|
| Name  |    |    |    |    |    |    |   |   |   | <b>IMM6</b> | <b>IMM5</b> | <b>IMM4</b> | <b>IMM3</b> | <b>IMM2</b> | <b>IMM1</b> | <b>IMM0</b> |
| Type  |    |    |    |    |    |    |   |   |   | R/W         |
| Reset |    |    |    |    |    |    |   |   |   | 0           | 0           | 0           | 0           | 0           | 0           | 0           |

**IMMn** These 7 bits are set individually to sample the data for the corresponding channel. It supports multiple flags.

- 0** The channel is not selected.
- 1** The channel is selected.

**AUXADC+0008h Auxiliary ADC control register 2 AUXADC\_CON2**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1           | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-------------|-----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | <b>SYN7</b> |     |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |             | R/W |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |             | 0   |

**SYN7** This bit is used only for channel 0 and is to be associated with timing offset register **TDMA\_AUXEV0** in the TDMA timer in timer-triggered mode. The flag can be automatically cleared after channel 0 has been sampled if **AUTOCLR0** in the register **AUXADC\_CON3** is set.

- 0** The channel is not selected.
- 1** The channel is selected.

**AUXADC+000Ch Auxiliary ADC control register 3 AUXADC\_CON3**

| Bit   | 15              | 14 | 13 | 12 | 11                | 10 | 9                | 8                | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
|-------|-----------------|----|----|----|-------------------|----|------------------|------------------|---|---|---|---|---|---|---|------------|
| Name  | <b>AUTO_SET</b> |    |    |    | <b>PUWA_IT_EN</b> |    | <b>AUTO_CLR1</b> | <b>AUTO_CLR0</b> |   |   |   |   |   |   |   | <b>STA</b> |
| Type  | R/W             |    |    |    | R/W               |    | R/W              | R/W              |   |   |   |   |   |   |   | RO         |
| Reset | 0               |    |    |    | 0                 |    | 0                | 0                |   |   |   |   |   |   |   | 0          |

**AUTOSET** This field defines the auto-sample mode of the module. In auto-sample mode, each channel with its sample register being read can start sampling immediately without configuring the control register **AUXADC\_CON1** again.

**PWUWAIT\_EN** Thus field enables the power warm-up period to ensure power stability before the SAR process takes place. It is recommended to activate this field.

- 0** The mode is not enabled.
- 1** The mode is enabled.

**AUTOCLR1** The field defines the auto-clear mode of the module for event 1. In auto-clear mode, each timer-triggered channel gets the samples of the specified channels once the **SYN<sub>n</sub>** bit in the register **AUXADC\_CON0** has been set. The **SYN<sub>n</sub>** bits will be automatically cleared and the channel will not be enabled again by the timer event except when the **SYN<sub>n</sub>** flags are set again.

- 0** The automatic clear mode is not enabled.
- 1** The automatic clear mode is enabled.

**AUTOCLR0** The field defines the auto-clear mode of the module for event 0. In auto-clear mode, the timer-triggered channel 0 gets the sample once the **SYN7** bit in the register **AUXADC\_CON2** has been set. The **SYN7** bit will be automatically cleared and the channel will not be enabled again by the timer event 0 except when the **SYN7** flag is set again.

- 0** The automatic clear mode is not enabled.
- 1** The automatic clear mode is enabled.

**STA** The field defines the state of the module.

- 0** This module is idle.
- 1** This module is busy.

## AUXADC+0010h Auxiliary ADC channel 0 register AUXADC\_DAT0

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | DAT |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO  |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0   |

The register stores the sampled data for the channel 0. There are 8 registers of the same type for the corresponding channel. The overall register definition is listed in **Table 22**.

| Register Address | Register Function                                      | Acronym     |
|------------------|--------------------------------------------------------|-------------|
| AUXADC+0010h     | Auxiliary ADC channel 0 data register                  | AUXADC_DAT0 |
| AUXADC+0014h     | Auxiliary ADC channel 1 data register                  | AUXADC_DAT1 |
| AUXADC+0018h     | Auxiliary ADC channel 2 data register                  | AUXADC_DAT2 |
| AUXADC+001Ch     | Auxiliary ADC channel 3 data register                  | AUXADC_DAT3 |
| AUXADC+0020h     | Auxiliary ADC channel 4 data register                  | AUXADC_DAT4 |
| AUXADC+0024h     | Auxiliary ADC channel 5 data register                  | AUXADC_DAT5 |
| AUXADC+0028h     | Auxiliary ADC channel 6 data register                  | AUXADC_DAT6 |
| AUXADC+002Ch     | Auxiliary ADC channel 0 data register for TDMA event 0 | AUXADC_DAT7 |

**Table 22** Auxiliary ADC data register list

## 4.11 SCCB

### 4.11.1 General Description

SCCB (Serial Camera Control Bus) is a two-wire serial interface for camera control usage. The two signals are SIO\_CK and SIO\_DAT. SIO\_CK is a single-direction, active-high clock signal that must be driven by the master. SIO\_DAT is a bi-directional data signal that can be driven by either the master or the slave. Within the transmission, two situations are defined as the START and STOP conditions. A high to low transition on the SIO\_DAT line while SIO\_CK is high indicates START condition. A low to high transition on the SIO\_DAT line while SIO\_CK is high indicates STOP condition. The master generates START and STOP conditions when it initiates or terminates a transmission. For SCCB, there are 3 kinds of transmissions: 3-phase write transmission, 2-phase write transmission and 2-phase read transmission cycle. There are 9 bits during a phase: 8-bit sequential data transmission followed by a 9<sup>th</sup> bit. The 9<sup>th</sup> bit is a Do not-Care bit or an NA bit, depending on whether the transmission is a write or read phase. The 3-phase write transmission cycle is a full write cycle and the master can write one byte of data to a specific slave. The content of 3-phase write transmission cycle is displayed in **Figure 31**. The ID address indicates the specific slave that the master wants to access. The sub address is the location of the destination register. The purpose of 2-phase write transmission cycle is to identify the sub-address of the specific slave the master intends to access, and it is always followed by a 2-phase read transmission cycle, which has no ability to identify the sub-address. The structure of 2-phase write transmission cycle and 2-phase read transmission cycle are depicted in **Figure 32** and **Figure 33**, respectively.



Figure 31 SCCB 3-phase write transmission cycle



Figure 32 SCCB 2-phase write transmission cycle



Figure 33 SCCB 2-phase read transmission cycle

### 4.11.2 Register Definitions

#### SCCB+0000h SCCB Control Register

CTRL

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |  |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------|--|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | SCCB<br>EN |  |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W        |  |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0          |  |

**SCCB\_EN** This bit is used to enable SCCB, it needs to be accessed when SCCB wants to communicate with slave, i.e. generates write or read transmission cycles.

### SCCB+0008h SCCB Data Length Register

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | DAT_LEN |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | DAT_LEN |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | R/W     |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 0       |

**DAT\_LEN** This field indicates the transmission length minus 1, i.e. to set DAT\_LEN = 1 for 2-phase transmission and to sets DAT\_LEN = 2 for 3-phase transmission.

### SCCB+000Ch SCCB Buffer Time Register

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | TBUF |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | TBUF |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | R/W  |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 3Eh  |

**TBUF** For SCCB, master initiates transmission with START condition, and it ends the transmission by sending STOP condition. TBUF indicates the bus free time between a STOP and START condition, i.e. the interval of STOP and START condition. Base on 13MHz clock frequency, the SCCB buffer time = (TBUF / 13000000), and the default setting is about 4.7us.

### SCCB+0010h SCCB Start Hold Time

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | THDSTA |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | THDSTA |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | R/W    |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 34h    |

**THDSTA** START condition occurs when there is a high to low transition on the SIO\_DAT line while SIO\_CK is high. START hold time indicates that SIO\_CK should be high at least THDSTA after SIO\_DAT becomes low. Base on 13MHZ frequency, the SCCB start hold time = (THDSTA / 13000000), and the default setting is about 4us.

### SCCB+0014h SCCB Data Hold Time

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | THDDAT |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | THDDAT |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | R/W    |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 27h    |

**THDDAT** Since SCCB data can be changed only when SIO\_CK is low, there defines data hold time to indicate the time interval that data cannot be changed after SIO\_CK becomes low. Base on 13MHz frequency, SCCB data hold time = (THDDAT / 13000000), and the default setting is about 3us.

### SCCB+0018h SCCB TLOW

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | TLOW |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | TLOW |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | R/W  |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 46h  |

**TLOW** This field indicates the low period of serial clock. Combines with THIGH, the SIO\_CK duty is adjustable. Bases on 13MHz frequency, the SIO\_CK low period = (TLOW / 13000000), and the default setting is about 5.3us.

### SCCB+001Ch SCCB THIGH

**THIGH**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0            |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>THIGH</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W          |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 3Ch          |

**THIGH** This field indicates the high period of serial clock. Combines with TLOW, the SIO\_CK duty is adjustable. Bases on 13MHz frequency, the SIO\_CK high period = (THIGH / 13000000), and the default setting is about 4.6us.

### SCCB+0020h SCCB Data Register

**DATA**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0           |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>DATA</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W         |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0           |

**DATA** SCCB write data. DATA[8] indicates if the following 8bits is a ID address or not. If it is a ID address, the write or read information is hidden in DATA[0].

- DATA[8]** **0** The following 8-bits is sub address or pure data  
**1** The following 8-bits is ID address field

#### DATA[0]

- 0** When DATA [8] = 1, it means that it's an ID address.  
 DATA [0] = 0, a write cycle  
 DATA [0] = 1, a read cycle
- 1** When DATA [8] = 0, it means that it's not an ID address. It may be a sub address or pure data.

### SCCB+0028h SCCB STOP Setup Time

**TSUSTO**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0             |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>TSUSTO</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W           |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 34h           |

**TSUSTO** A low to high transition on the SIO\_DAT line while SIO\_CK is high indicates STOP condition. For STOP condition, the low to high transition on the SIO\_DAT can be generated after SCCB STOP setup time while SIO\_CK must be high. Bases on 13MHz frequency, SCCB STOP setup time = (TSUSTOP / 13000000), and the default setting is about 4us.

### SCCB+0038h SCCB MODE

**MODE**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0           |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>MODE</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W         |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0           |

**MODE** This bit indicates the SCCB operating mode

- 0** To operate as Slave
- 1** To operate as Master

**SCCB+003Ch SCCB Buf Clear**
**BUF\_CLEAR**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | BUF_CLEAR |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W       |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0         |

**BUF\_CLEAR** Buffer clear bit. Set this bit to clear the SCCB FIFO.

0 Buffer isn't cleared.

1 Clear buffer.

**SCCB+0040h SCCB Status Register**
**STA**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | WRIT E |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W    |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0      |

**READ** Indicate that read complete.

0 Read command does not finish.

1 Read command finishes.

**WRITE** Indicates the write complete.

0 Write command does not finish.

1 Write command finishes.

## 5 Microcontroller Coprocessors

Microcontroller Coprocessors are designed to run computing-intensive processes in place of the Microcontroller (MCU). These coprocessors intend to offer a solution specially targeted for timing critical GSM/GPRS Modem processes that require fast response and large data movement. Controls to the coprocessors are all through memory access via the APB Bus.

### 5.1 Divider

To ease the processing load of MCU, a divider is employed here. The divider can operate signed and unsigned 32bit/32bit division, as well as modulus. The processing time of the divider is from 1 clock cycle to 33 clock cycles, which depends upon the magnitude of the value of the dividend. The detailed processing time is listed below in **Table 6**. From the table we can see that there are two kind of processing time (except for when the dividend is zero) in an item. Which kind depends on whether there is the need for restoration at the last step of the division operation.

After the divider is started by setting START to “1” in Divider Control Register, DIV\_RDY will go low, and it will be asserted after the division process is finished. MCU could detect this status bit by polling it to know the correct access timing. In order to simplify polling, only the value of register DIV\_RDY will appear while Divider Control Register is read. Hence, MCU does not need to mask other bits to extract the value of DIV\_RDY.

In GSM/GPRS system, many divisions are executed with some constant divisors. Therefore, some often-used constants are stored in the divider to speed up the process. By controlling control bits IS\_CNST and CNST\_IDX in Divider Control register, one can start a division without giving a divisor. This could save the time for writing divisor in and the instruction fetch time, and thus make the process more efficient.

| Signed Division                                      |              | Unsigned Division       |              |
|------------------------------------------------------|--------------|-------------------------|--------------|
| Dividend                                             | Clock Cycles | Dividend                | Clock Cycles |
| 0000_0000h                                           | 1            | 0000_0000h              | 1            |
| 0000_00ffh - (-0000_0100h),<br>excluding 0x0000_0000 | 8 or 9       | 0000_0001h - 0000_00ffh | 8 or 9       |
| 0000_ffffh - (-0001_0000h)                           | 16 or 17     | 0000_0100h - 0000_ffffh | 16 or 17     |
| 00ff_ffffh - (-0100_0000h)                           | 24 or 25     | 0001_0000h - 00ff_ffffh | 24 or 25     |
| 7fff_ffffh - (-8000_0000h)                           | 32 or 33     | 0100_0000h - ffff_ffffh | 32 or 33     |

Table 23 Processing time in different value of dividend.

#### 5.1.1 Register Definitions

**DIVIDER+0000h** Divider Control Register **DIV\_CON**

| Bit         | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23              | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------------|-----|-----|-----|-----|-----|-----|-----|-----|-----------------|----|----|----|----|----|----|----|
| <b>Name</b> |     |     |     |     |     |     |     |     |                 |    |    |    |    |    |    |    |
| Type        | R/W | <b>CNST_IDX</b> |    |    |    |    |    |    |    |
| Reset       | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | R/W             |    |    |    |    |    |    |    |
| Bit         | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7               | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

| Name  |     |     |     |     |     |     |     |     |     |    |    | <b>IN_CNST</b> | <b>SIGN</b> |    |    | <b>DIV_RDY</b> | <b>START</b> |
|-------|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|----------------|-------------|----|----|----------------|--------------|
| Type  | R/W | WO | WO | R/W            | R/W         | RO | WO |                |              |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0  | 1  | 0              | 0           | 1  | 0  |                |              |

**START** To start division. It will return to 0 after division has started.

**DIV\_RDY** Current status of divider. Note that when DIV\_CTRL register is read, only the value of DIV\_RDY will appear. That means program does not need to mask other part of the register to extract the information of DIV\_RDY.

0 division is in progress.

1 division is finished.

**SIGN** To indicate signed or unsigned division.

0 Unsigned division.

1 Signed division.

**IS\_CNST** To indicate if internal constant value should be used as a divisor. If IS\_CNST is enabled, User does not need to write the value of the divisor, and divider will automatically use the internal constant value instead. What value divider will use depends on the value of CNST\_IDX.

0 Normal division. Divisor is written in via APB

1 Using internal constant divisor instead.

**CNST\_IDX** Index of constant divisor.

0 divisor = 13

1 divisor = 26

2 divisor = 51

3 divisor = 52

4 divisor = 102

5 divisor = 104

## DIVIDER +0004h

### Divider Dividend register

### DIV\_DIVIDEND

|       |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31                     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>DIVIDEND[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>DIVIDEND[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Dividend.

## DIVIDER +0008h

### Divider Divisor register

### DIV\_DIVISOR

|       |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31                    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>DIVISOR[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                    | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>DIVISOR[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Divisor.

**DIVIDER**  
+000Ch

**Divider Quotient register**

**DIV\_QUOTIENT**

|       |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31                     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>QUOTIENT[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>QUOTIENT[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Quotient.

**DIVIDER**  
+0010h

**Divider Remainder register**

**DIV\_REMAINDE R**

|       |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>REMAINDER[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>REMAINDER[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Remainder.

## 5.2 CSD Accelerator

### 5.2.1 General Description

This unit performs the data format conversion of RA0, RA1, and FAX in CSD service. CSD service consists of two major functions: data flow throttling and data format conversion. The data format conversion is a bit-wise operation and takes a number of instructions to complete a conversion. Therefore, it is not efficient to do by MCU itself. A coprocessor, CSD accelerator, is designed here to reduce the computing power needed to perform this function.

CSD accelerator only helps in converting data format; the data flow throttling function is still implemented by the MCU. CSD accelerator performs three types of data format conversion, RA0, RA1, and FAX.

For RA0 conversion, only uplink RA0 data format conversion is provided here. This is because there are too many judgments on the downlink path conversion, which will greatly increase area cost. Uplink RA0 conversion is to insert one start bit and one stop bit before and after a byte, respectively, during 16 bytes. **Figure 34** illustrates the detailed conversion table.

RA0 converter can only process RA0 data state by state. Before filling in new data, software must make sure the converted data of certain state is withdrawn, or the converted data will be replaced by the new data. For example, if 32-bit data is written, and the state pointer goes from state 0 to state 1, and word ready of state 0 is asserted; then, before writing the next 32-bit data, the word of state 0 should be withdrawn first, or the data will be lost.

RA0 records the number of written bytes, state pointer, and ready state word. The information can help software to perform flow control. See Register Definition for more detail.



**Figure 34** data format conversion of RA0

For RA1 conversion, both directions, downlink and uplink, are supported. The data formats vary in different data rate. The detailed conversion table is shown in **Figure 35** and **Figure 36**. The yellow part is the payload data, and the blue part is the status bit.

| Bit 0 → Bit 6 |     |     |     |     |     |     |
|---------------|-----|-----|-----|-----|-----|-----|
| D1            | D2  | D3  | D4  | D5  | D6  | S1  |
| D7            | D8  | D9  | D10 | D11 | D12 | X   |
| D13           | D14 | D15 | D16 | D17 | D18 | S3  |
| D19           | D20 | D21 | D22 | D23 | D24 | S4  |
| E4            | E5  | E6  | E7  | D25 | D26 | D27 |
| D28           | D29 | D30 | S6  | D31 | D32 | D33 |
| D34           | D35 | D36 | X   | D37 | D38 | D39 |
| D40           | D41 | D42 | S8  | D43 | D44 | D45 |
| D46           | D47 | D48 | S9  |     |     |     |

**Figure 35** data format conversion for 6k/12k RA1

| Bit 0 → Bit 7 |     |     |    |     |     |     |    |  |
|---------------|-----|-----|----|-----|-----|-----|----|--|
| D1            | D2  | D3  | S1 | D4  | D5  | D6  | X  |  |
| D7            | D8  | D9  | S3 | D10 | D11 | D12 | S4 |  |
| E4            | E5  | E6  | E7 | D13 | D14 | D15 | S6 |  |
| D16           | D17 | D18 | X  | D19 | D20 | D21 | S8 |  |
| D22           | D23 | D24 | S9 |     |     |     |    |  |

**Figure 36** data format conversion for 3.6k RA1

For FAX, two types of bit-reversal functions are provided. One is bit-wise reversal, and the other is byte-wise reversal, which are illustrated in **Figure 37** and **Figure 38**, respectively.



**Figure 37** Type 1 bit reverse



**Figure 38** Type 2 bit reverse

| Register Address | Register Function                              | Acronym              |
|------------------|------------------------------------------------|----------------------|
| CSD + 0000h      | CSD RA0 Control Register                       | CSD_RA0_CON          |
| CSD + 0004h      | CSD RA0 Status Register                        | CSD_RA0_STA          |
| CSD + 0008h      | CSD RA0 Input Data Register                    | CSD_RA0_DI           |
| CSD + 000Ch      | CSD RA0 Output Data Register                   | CSD_RA0_DO           |
| CSD + 0100h      | CSD RA1 6K/12K Uplink Input Data Register 0    | CSD_RA1_6_12K_ULDI0  |
| CSD + 0104h      | CSD RA1 6K/12K Uplink Input Data Register 1    | CSD_RA1_6_12K_ULDI1  |
| CSD + 0108h      | CSD RA1 6K/12K Uplink Status Data Register     | CSD_RA1_6_12K_ULSTUS |
| CSD + 010Ch      | CSD RA1 6K/12K Uplink Output Data Register 0   | CSD_RA1_6_12K_ULDO0  |
| CSD + 0110h      | CSD RA1 6K/12K Uplink Output Data Register 1   | CSD_RA1_6_12K_ULDO1  |
| CSD + 0200h      | CSD RA1 6K/12K Downlink Input Data Register 0  | CSD_RA1_6_12K_DLDI0  |
| CSD + 0204h      | CSD RA1 6K/12K Downlink Input Data Register 1  | CSD_RA1_6_12K_DLDI1  |
| CSD + 0208h      | CSD RA1 6K/12K Downlink Output Data Register 0 | CSD_RA1_6_12K_DLDO0  |
| CSD + 020Ch      | CSD RA1 6K/12K Downlink Output Data Register 1 | CSD_RA1_6_12K_DLDO1  |
| CSD + 0210h      | CSD RA1 6K/12K Downlink Status Data Register   | CSD_RA1_6_12K_DLSTUS |
| CSD + 0300h      | CSD RA13.6K Uplink Input Data Register 0       | CSD_RA1_3P6K_ULDI0   |
| CSD + 0304h      | CSD RA13.6K Uplink Status Data Register        | CSD_RA1_3P6K_ULSTUS  |
| CSD + 0308h      | CSD RA13.6K Uplink Output Data Register 0      | CSD_RA1_3P6K_ULDO0   |
| CSD + 030Ch      | CSD RA13.6K Uplink Output Data Register 1      | CSD_RA1_3P6K_ULDO1   |
| CSD + 0400h      | CSD RA1 3.6K Downlink Input Data Register 0    | CSD_RA1_3P6K_DLDI0   |
| CSD + 0404h      | CSD RA1 3.6K Downlink Input Data Register 1    | CSD_RA1_3P6K_DLDI1   |

|             |                                                 |                     |
|-------------|-------------------------------------------------|---------------------|
| CSD + 0408h | CSD RA1 3.6K Downlink Output Data Register 0    | CSD_RA1_3P6K_DLDO0  |
| CSD + 040Ch | CSD RA1 3.6K Downlink Status Data Register      | CSD_RA1_3P6K_DLSTUS |
| CSD + 0500h | CSD FAX Bit Reverse Type 1 Input Data Register  | CSD_FAX_BR1_DI      |
| CSD + 0504h | CSD FAX Bit Reverse Type 1 Output Data Register | CSD_FAX_BR1_DO      |
| CSD + 0510h | CSD FAX Bit Reverse Type 2 Input Data Register  | CSD_FAX_BR2_DI      |
| CSD + 0514h | CSD FAX Bit Reverse Type 2 Output Data Register | CSD_FAX_BR2_DO      |
|             |                                                 |                     |

Table 24 CSD Accelerator Registers

### 5.2.2 Register Definitions

#### CSD+0000h CSD RA0 Control Register

#### CSD\_RA0\_CON

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21  | 20   | 19 | 18       | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|-----|------|----|----------|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |     |      |    |          |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |     |      |    |          |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |     |      |    |          |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5   | 4    | 3  | 2        | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    | RST | BTS0 |    | VLD_BYTE |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    | WO  | WO   |    | R/W      |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    | 0   | 0    |    | 100      |    |    |

**VLD\_BYTE** Specify how many valid bytes in the current input data. It must be specified before filling data in.

**BTS0** Back to state 0. Force RA0 converter go back to state 0. Incomplete word will be padded by STOP bit. For instance, back-to-state0 command is issued after 8 byte data are filled in. Then these bit after the 8<sup>th</sup> byte will be padded with stop bits, and RDYWD2 is asserted. After removing state word 2, the state pointer goes back to state 0. Note that new data filling should take place after removing state word 2, or the state pointer may be out of order.



Figure 39 Example of Back to state 0

**RST** Reset RA0 converter. In case, erroneously operation makes data disordered. This bit can restore all state to original state.

## CSD+0004h CSD RA0 Status Register

CSD RA0 STA

|       |    |    |    |    |    |    |    |         |    |        |    |    |    |       |    |    |
|-------|----|----|----|----|----|----|----|---------|----|--------|----|----|----|-------|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24      | 23 | 22     | 21 | 20 | 19 | 18    | 17 | 16 |
| Name  |    |    |    |    |    |    |    |         |    |        |    |    |    |       |    |    |
| Type  |    |    |    |    |    |    |    |         |    |        |    |    |    |       |    |    |
| Reset |    |    |    |    |    |    |    |         |    |        |    |    |    |       |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7  | 6      | 5  | 4  | 3  | 2     | 1  | 0  |
| Name  |    |    |    |    |    |    |    | BYTECNT |    | CRTSTA |    |    |    | RDYWD |    |    |
| Type  |    |    |    |    |    |    |    | R/W     |    | R/W    |    |    |    | RC    |    |    |
| Reset |    |    |    |    |    |    |    | 0       |    | 0      |    |    |    | 0     |    |    |

**RDYWDO~4** Ready word. To indicate which state word is ready for withdrawal. Data should be withdrawn before next data fills into CSD\_RA0\_DI, if there are any bits asserted.

- 0 Not ready
  - 1 Ready

**CRTSTA** current state. State0 ~ state4. To indicate which state word software is filling in.

**BYTECNT** The total number of bytes software is filling in.

## CSD+0008h CSD RA0 Input Data Register

CSD RA0 PI

**DIN** The RA0 convert input data. Ready word indicator shall be check before filling in data. If any words are ready, withdraw them first; otherwise the ready data in RA0 converter will be replaced.

CSD+000Ch CSD RA0 Output Data Register

CSD RA0 DO

**DOUT** RA0 converted data. The return data corresponds to the ready word indicator defined in CSD\_RA0\_STA register. The five bit of RDYWD map to state0 ~ state 4 accordingly. When CSD\_RA0\_DO is read, the asserted state word will be returned. If there are two state words asserted at the same time, the lower one will be returned.

CSD+0100h CSD RA1 6K/12K Uplink Input Data Register 0

CSD\_RA1\_6\_12  
K ULDI0

|       |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    | DIN |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    | R/W |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    | 0   |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

|       |     |
|-------|-----|
| Name  | DIN |
| Type  | R/W |
| Reset | 0   |

**DIN** The D1 to D32 of RA1 uplink data.

**CSD+0104h CSD RA1 6K/12K Uplink Input Data Register 1**

**CSD\_RA1\_6\_12  
K\_ULDI1**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**DIN** The D33 to D48 of RA1 uplink data.

**CSD+0108h CSD RA1 6K/12K Uplink Status Data Register**

**CSD\_RA1\_6\_12  
K\_ULSTUS**

|       |    |    |    |    |    |    |    |    |    |           |           |           |           |          |           |           |
|-------|----|----|----|----|----|----|----|----|----|-----------|-----------|-----------|-----------|----------|-----------|-----------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22        | 21        | 20        | 19        | 18       | 17        | 16        |
| Name  |    |    |    |    |    |    |    |    |    |           |           |           |           |          |           |           |
| Type  |    |    |    |    |    |    |    |    |    |           |           |           |           |          |           |           |
| Reset |    |    |    |    |    |    |    |    |    |           |           |           |           |          |           |           |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6         | 5         | 4         | 3         | 2        | 1         | 0         |
| Name  |    |    |    |    |    |    |    |    |    | <b>E7</b> | <b>E6</b> | <b>E5</b> | <b>E4</b> | <b>X</b> | <b>SB</b> | <b>SA</b> |
| Type  |    |    |    |    |    |    |    |    |    | R/W       | R/W       | R/W       | R/W       | R/W      | R/W       | R/W       |
| Reset |    |    |    |    |    |    |    |    |    | 0         | 0         | 0         | 0         | 0        | 0         | 0         |

**SA** Represents S1, S3, S6, and S8 of status bits.

**SB** Represents S4 and S9 of status bits.

**X** Represents X of status bits.

**E4** Represents E4 of status bits.

**E5** Represents E5 of status bits.

**E6** Represents E6 of status bits.

**E7** Represents E7 of status bits.

**CSD+010Ch CSD RA1 6K/12K Uplink Output Data Register 0**

**CSD\_RA1\_6\_12  
K\_ULDO0**

|       |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22         | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6          | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    | <b>DOU</b> |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    | R/W        |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    | 0          |    |    |    |    |    |    |

**DOU** The bit 0 to bit 31 of RA1 6K/12K uplink frame.

**CSD+0110h CSD RA1 6K/12K Uplink Output Data Register 1**
**CSD\_RA1\_6\_12  
K\_ULDO1**

|       |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>DOUT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>DOUT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**DOUT** The bit32 to bit 59 of RA1 6K/12K uplink frame.

**CSD+0200h CSD RA1 6K/12K Downlink Input Data Register 0**
**CSD\_RA1\_6\_12  
K\_DLDO0**

|       |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>DIN</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>DIN</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**DIN** The bit 0 to bit 31 of RA1 6K/12K downlink frame.

**CSD+0204h CSD RA1 6K/12K Downlink Input Data Register 1**
**CSD\_RA1\_6\_12  
K\_DLDO1**

|       |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>DIN</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>DIN</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**DIN** The bit32 to bit 59 of RA1 6K/12K downlink frame.

**CSD+0208h CSD RA1 6K/12K Downlink Output Data Register 0**
**CSD\_RA1\_6\_12  
K\_DLDO0**

|       |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>DOUT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>DOUT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**DOUT** The D1 to D32 of RA1 downlink data.

**CSD+020Ch CSD RA1 6K/12K Downlink Output Data Register 1**
**CSD\_RA1\_6\_12  
K\_DLDO1**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| DOUT  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**DOUT** The D33 to D48 of RA1 downlink data.

**CSD+0210h CSD RA1 6K/12K Downlink Status Data Register**
**CSD\_RA1\_6\_12  
K\_DLSTUS**

|       |    |    |    |    |    |    |    |    |    |     |     |     |     |     |     |     |
|-------|----|----|----|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
| Name  |    |    |    |    |    |    |    |    |    |     |     |     |     |     |     |     |
| Type  |    |    |    |    |    |    |    |    |    |     |     |     |     |     |     |     |
| Reset |    |    |    |    |    |    |    |    |    |     |     |     |     |     |     |     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name  |    |    |    |    |    |    |    |    |    | E7  | E6  | E5  | E4  | X   | SB  | SA  |
| Type  |    |    |    |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

**SA** The result of majority votes of S1, S3, S6 and S8. SA is “0” if equal vote.

**SB** The result of majority votes of S4 and S9. SB is “0” if equal vote.

**X** The result of majority votes of two X bits in downlink frame. X is “0” if equal vote.

**E4** Represents E4 of status bits.

**E5** Represents E5 of status bits.

**E6** Represents E6 of status bits.

**E7** Represents E7 of status bits.

**CSD+0300h CSD RA1 3.6K Uplink Input Data Register 0**
**CSD\_RA1\_3P6K  
\_ULDI0**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| DIN   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**DIN** The D1 to D24 of RA1 3.6K uplink data.

**CSD+0304h CSD RA1 3.6K Uplink Status Data Register**
**CSD\_RA1\_3P6K  
\_ULSTUS**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**SA** Represents S1, S3, S6, and S8 of status bits.

**SB** Represents S4 and S9 of status bits.

**X** Represents X of status bits.

**E4** Represents E4 of status bits.

**E5** Represents E5 of status bits.

**E6** Represents E6 of status bits.

**E7** Represents E7 of status bits.

CSD+0308h CSD RA1 3.6K Uplink Output Data Register 0

CSD\_RA1\_3P6K  
ULDO0

**DOUT** The bit 0 to bit 31 of RA1 3.6K uplink frame

CSD+030Ch CSD RA1 3.6K Uplink Output Data Register 1

CSD\_RA1\_3P6K  
ULDO1

**DOUT** The bit 32 to bit 35 of RA1 3.6K uplink frame

CSD+0400h CSD RA1 3.6K Downlink Input Data Register 0

CSD\_RA1\_3P6K  
DLDO

|       |    |    |    |    |    |    |    |    |     |     |    |    |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    | DIN |     |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |     | R/W |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |     | 0   |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    | DIN |     |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |     | R/W |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |     | 0   |    |    |    |    |    |    |

**DIN** The bit 0 to bit 31 of RA1 3.6K downlink frame

**CSD+0404h CSD RA1 3.6K Downlink Input Data Register 1**
**CSD\_RA1\_3P6K  
\_DLDI1**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2   | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    | DIN |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    | 0   |    |    |

**DIN** The bit 32 to bit 35 of RA1 3.6K downlink frame

**CSD+0408h CSD RA1 3.6K Downlink Output Data Register 0**
**CSD\_RA1\_3P6K  
\_DLDO0**

|       |    |    |    |    |    |    |    |      |    |    |    |    |    |      |    |    |
|-------|----|----|----|----|----|----|----|------|----|----|----|----|----|------|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23 | 22 | 21 | 20 | 19 | 18   | 17 | 16 |
| Name  |    |    |    |    |    |    |    |      |    |    |    |    |    | DOUT |    |    |
| Type  |    |    |    |    |    |    |    |      |    |    |    |    |    | R/W  |    |    |
| Reset |    |    |    |    |    |    |    |      |    |    |    |    |    | 0    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7  | 6  | 5  | 4  | 3  | 2    | 1  | 0  |
| Name  |    |    |    |    |    |    |    | DOUT |    |    |    |    |    |      |    |    |
| Type  |    |    |    |    |    |    |    | R/W  |    |    |    |    |    |      |    |    |
| Reset |    |    |    |    |    |    |    | 0    |    |    |    |    |    |      |    |    |

**DIN** The D1 to D24 of RA1 3.6K downlink data.

**CSD+040Ch CSD RA1 3.6K Downlink Status Data Register**
**CSD\_RA1\_3P6K  
\_DLSTUS**

|       |    |    |    |    |    |    |    |    |     |     |     |     |     |     |     |    |
|-------|----|----|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16 |
| Name  |    |    |    |    |    |    |    |    |     |     |     |     |     |     |     |    |
| Type  |    |    |    |    |    |    |    |    |     |     |     |     |     |     |     |    |
| Reset |    |    |    |    |    |    |    |    |     |     |     |     |     |     |     |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0  |
| Name  |    |    |    |    |    |    |    |    | E7  | E6  | E5  | E4  | X   | SB  | SA  |    |
| Type  |    |    |    |    |    |    |    |    | R/W |    |
| Reset |    |    |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   |    |

**SA** The result of majority votes of S1, S3, S6 and S8. SA is “0” if equal vote.

**SB** The result of majority votes of S4 and S9. SB is “0” if equal vote.

**X** The result of majority votes of two X bits in downlink frame. X is “0” if equal vote.

**E4** Represents E4 of status bits.

**E5** Represents E5 of status bits.

**E6** Represents E6 of status bits.

**E7** Represents E7 of status bits.

**CSD+0500h CSD FAX Bit Reverse Type 1 Input Data Register**
**CSD\_FAX\_BR1\_  
DI**

|      |    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    | DIN |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    | R/W |    |    |    |    |    |    |    |

|       |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Reset | 0          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | <b>DIN</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**DIN** 32-bit input data for type 1 bit reverse of FAX data. The action of Type 1 bit reverse is to reverse this word by word.

#### CSD+0504h CSD FAX Bit Reverse Type 1 Output Data Register

**CSD\_FAX\_BR1\_DO**

|       |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>DOUT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>DOUT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**DOUT** 32-bit result data for type 1 bit reverse of FAX data.

#### CSD+0510h CSD FAX Bit Reverse Type 2 Input Data Register

**CSD\_FAX\_BR2\_DI**

|       |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>DIN</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>DIN</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**DIN** 32-bit input data for type 2 bit reverse of FAX data. The action of Type 1 bit reverse is to reverse this word by byte.

#### CSD+0514h CSD FAX Bit Reverse Type 2 Output Data Register

**CSD\_FAX\_BR2\_DO**

|       |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>DOUT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>DOUT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**DOUT** 32-bit result data for type 2 bit reverse of FAX data.

## 5.3 FCS Codec

### 5.3.1 General Description

FCS (Frame Check Sequence) is used to detect errors in the following information bits:

- RLP-frame of CSD services in GSM. The frame length is fixed as 240 or 576 bits including the 24-bit FCS field.
- LLC-frame of GPRS service. The frame length is determined by the information field, and length of the FCS field is 24-bit.

Generation of the frame check sequence is very similar to the CRC coding in baseband signal processing. ETSI GSM specifications 04.22 and 04.64 both define the coding rule. The coding rules are:

1. The CRC shall be ones complement of the modulo-2 sum of:

- the remainder of  $x^k \cdot (x^{23} + x^{22} + x^{21} + \dots + x^2 + x + 1)$  modulo-2 divided by the generator polynomial, where k is the number of bits of the dividend. (i.e. fill the shift registers with all ones initially before feeding data)
- the remainder of the modulo-2 division by the generator polynomial of the product of  $x^{24}$  by the dividend, which are the information bits.

2. The CRC-24 generator polynomial is:

$$G(x) = x^{24} + x^{23} + x^{21} + x^{20} + x^{19} + x^{17} + x^{16} + x^{15} + x^{13} + x^8 + x^7 + x^5 + x^4 + x^2 + 1$$

3. The 24-bit CRC are appended to the data bits in the MSB-first manner.

4. Decoding is identical to encoding except that data fed into the syndrome circuit is 24-bit longer than the information bits at encoding. The dividend is also multiplied by  $x^{24}$ . If no error occurs, the remainder should satisfy

$$R(x) = x^{22} + x^{21} + x^{19} + x^{18} + x^{16} + x^{15} + x^{11} + x^8 + x^5 + x^4 \quad (\text{0x6d8930})$$

And the parity output word will be 0x9276cf.

In contrast to conventional CRC, this special coding scheme makes the encoder fully identical to the decoder and simplifies the hardware design.

### 5.3.2 Register Definitions

#### FCS+0000h FCS input data register

#### FCS\_DATA

| Bit  | 15  | 14  | 13  | 12  | 11  | 10  | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|------|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| Name | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| Type | WO  | WO  | WO  | WO  | WO  | WO  | WO | WO | WO | WO | WO | WO | WO | WO | WO | WO |

**THE** data bits input. First write of this register is the starting point of the encode or decode process.

**DX** X=0...15. The input format is D15·x<sup>n</sup> + D14·x<sup>n-1</sup> + D13·x<sup>n-2</sup> + ... + D<sub>k</sub>·x<sup>k</sup> + ..., thus D15 is the first bit being pushed into the shift register. If the last data word is less than 16 bits, the rest bits are neglected.

#### FCS+0004h Input data length indication register

#### FCS\_DLEN

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----|----|----|----|----|----|---|-----|---|---|---|---|---|---|---|---|
| Name |    |    |    |    |    |    |   | LEN |   |   |   |   |   |   |   |   |
| Type |    |    |    |    |    |    |   | WO  |   |   |   |   |   |   |   |   |

**THE** MCU specifies the total data length in bits to be encoded or decoded.

**LEN** The data length. A number of multiple-of-8 is required (Number\_of\_Bytes x 8)

### FCS+0x0008h FCS parity output register 1, MSB part

FCS\_PAR1

| Bit   | 15  | 14  | 13  | 12  | 11  | 10  | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-------|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| Name  | P15 | P14 | P13 | P12 | P11 | P10 | P9 | P8 | P7 | P6 | P5 | P4 | P3 | P2 | P1 | P0 |
| Type  | RC  | RC  | RC  | RC  | RC  | RC  | RC | RC | RC | RC | RC | RC | RC | RC | RC | RC |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

### FCS+000Ch FCS parity output register 2, LSB part

FCS\_PAR2

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|---|---|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    |   |   | P23 | P22 | P21 | P20 | P19 | P18 | P17 | P16 |
| Type  |    |    |    |    |    |    |   |   | RC  |
| Reset |    |    |    |    |    |    |   |   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

**PARITY** bits output. For FCS\_PAR2, bit 8 to bit15 will be filled by zeros when reading.

**PX** X=0...23. The output format is  $P23 \cdot D^{23} + P22 \cdot D^{22} + P21 \cdot D^{21} + \dots + P_k \cdot D^k + \dots + P1 \cdot D^1 + P0$ , thus P23 is the earliest bit being popped out from the shift register and first appended to the information bits. In other words, {FCS\_PAR2[7:0], FCS\_PAR1[15:8], FCS\_PAR1[7:0]} is the order of appending parity to data.

### FCS+0010h FCS codec status register

FCS\_STAT

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2    | 1   | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|------|-----|-----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | BUSY | FER | RDY |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | RC   | RC  | RC  |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0    | 0   | 0   |

**BUSY** Since the codec works in serial manner and the data word is input in parallel manner, BUSY = 1 indicates that current data word is being processed and write to FCS\_DATA is invalid. BUSY = 0 allows write of FCS\_DATA during encode or decode process.

**FER** Frame error indication, only for decode mode. FER = 0 means no error occurs and FER = 1 means the parity check has failed. Write of FCS\_RST.RST or first write of FCS\_DATA will reset this bit to 0.

**RDY** When RDY = 1, the encode or decode process has been finished. For encode, the parity data in FCS\_PAR1 and FCS\_PAR2 are correctly available. For decode, FCS\_STAT.FER indication is valid. Write of FCS\_RST.RST or first write of FCS\_DATA will reset this bit to 0.

### FCS+0014h FCS codec reset register

FCS\_RST

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2     | 1   | 0   |     |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|-------|-----|-----|-----|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   | EN_DE | PAR | BIT | RST |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   | WO    | WO  | WO  | WO  |

**RST** RST = 0 resets the CRC coprocessor. Before setup of FCS codec, the MCU needs to set RST = 0 to flush the shift register content before encode or decode.

**BIT** BIT = 0 means not to invert the bit order in a byte of data words when the codec is running. BIT = 1 means the bit order in a byte written in FCS\_DATA should be reversed.

**PAR** PAR = 0 means not to invert the bit order in a byte of parity words when the codec is running, include reading of FCS\_PAR1 and FCS\_PAR2. PAR = 1 means bit order of parity words should be reversed, in decoding or encoding.

**EN\_DE** EN\_DE = 0 means encode; EN\_DE = 1 means decode

## 6 Multi-Media Subsystem

MT6219 is specially designed to support multi-media terminals. It integrates several hardware based accelerators such as advanced LCD display controller, hardware JPEG encoder/decoder, hardware Image Resizer, and MPEG4 video CODEC. In addition, MT6219 also incorporates NAND Flash, USB 1.1 Device and SD/MMC/MS/MS Pro Controllers for mass data transfers and storages. This chapter describes those functional blocks in more details.

### 6.1 LCD Interface

MT6219 contains a versatile LCD controller that is optimized for multimedia applications. This controller supports many types of LCD modules and contains a rich set of features to enhance the functionalities. These features are:

- Up to 320 x 240 resolution
- Supports 8-bpp (RGB332), 12-bpp (RGB444), 16-bpp (RGB565), 18-bit (RGB666) and 24-bit (RGB888) color depths
- 4 Layers Overlay with individual vertical and horizontal size, vertical and horizontal offset, source key, opacity and display rotation control (90°, 180°, 270°, mirror and mirror then 90°, 180° and 270°)
- 2 Color Look-Up Tables

For parallel LCD modules, this special LCD controller can reuse external memory interface or use dedicated 8-bit parallel interface to access them and 8080 type interface is supported. It can transfer the display data from the internal SRAM or external SRAM/Flash Memory to the off-chip LCD modules.

For serial LCD modules, this interface performs parallel to serial conversion and both 8- and 9- bit serial interface is supported. The 8-bit serial interface uses four pins – LSCE#, LSDA, LSCK and LSA0 – to enter commands and data. Whereas, the 9-bit serial interface uses three pins – LSCE#, LSDA and LSCK – for the same purpose. Data read is not available with the serial interface and data entered must be 8 bits.



Figure 40 LCD Interface Block Diagram

Figure 41 shows the timing diagram of this serial interface. When the block is idle, LSCK is forced LOW and LSCE# is forced HIGH. Once the data register contains data and the interface is enabled, LSCE# is pulled LOW and remains LOW for the duration of the transmission.



Figure 41 LCD Interface Transfer Timing Diagram

### 6.1.1 Register Definitions

#### LCD +0000h LCD Interface Status Register

#### LCD\_STA

| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|

|       |  |  |  |  |  |  |  |  |  |  |  |  |                 |                  |            |
|-------|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|------------------|------------|
| Name  |  |  |  |  |  |  |  |  |  |  |  |  | <b>CMD_PEND</b> | <b>DATA_PEND</b> | <b>RUN</b> |
| Type  |  |  |  |  |  |  |  |  |  |  |  |  | RO              | RO               | RO         |
| Reset |  |  |  |  |  |  |  |  |  |  |  |  | 0               | 0                | 0          |

**RUN** LCD Interface Running Status

**DATA\_PEND** Data Pending Indicator in Hardware Trigger Mode

**CMD\_PEND** Command Pending Indicator in Hardware Triggered Refresh Mode

### LCD +0004h LCD Interface Interrupt Enable Register

### LCD\_INTEN

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |                |                 |            |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|----------------|-----------------|------------|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2              | 1               | 0          |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>CMD_CPL</b> | <b>DATA_CPL</b> | <b>CPL</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | R/W            | R/W             | R/W        |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0              | 0               | 0          |

**CPL** LCD Frame Transfer Complete Interrupt Control

**DATA\_CPL** Data Transfer Complete in Hardware Triggered Refresh Mode Interrupt Control

**CMD\_CPL** Command Transfer Complete in Hardware Trigger Refresh Mode Interrupt Control

### LCD +0008h LCD Interface Interrupt Status Register

### LCD\_INTSTA

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |                |                 |            |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|----------------|-----------------|------------|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2              | 1               | 0          |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>CMD_CPL</b> | <b>DATA_CPL</b> | <b>CPL</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | RO             | RO              | RO         |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0              | 0               | 0          |

**CPL** LCD Frame Transfer Complete Interrupt

**DATA\_CPL** Data Transfer Complete in Hardware Triggered Refresh Mode Interrupt

**CMD\_CPL** Command Transfer Complete in Hardware Triggered Refresh Mode Interrupt

### LCD +000Ch LCD Interface Frame Transfer Register

### LCD\_START

|       |               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|---------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit   | 15            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | <b>STAR_T</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**START** Start Control of LCD Frame Transfer

### LCD +0010h LCD Parallel/Serial Interface Reset Register

### LCD\_RSTB

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |             |   |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|-------------|---|---|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2           | 1 | 0 |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>RSTB</b> |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | R/W         |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |             | 1 |   |

**RSTB** Parallel/Serial LCD Module Reset Control

### LCD +0014h LCD Serial Interface Configuration Register

### LCD\_SCNF

|      |    |    |    |    |    |    |             |             |   |   |   |   |            |            |            |            |
|------|----|----|----|----|----|----|-------------|-------------|---|---|---|---|------------|------------|------------|------------|
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9           | 8           | 7 | 6 | 5 | 4 | 3          | 2          | 1          | 0          |
| Name |    |    |    |    |    |    | <b>CSP1</b> | <b>CSP0</b> |   |   |   |   | <b>8/9</b> | <b>DIV</b> | <b>SPH</b> | <b>SPO</b> |
| Type |    |    |    |    |    |    | R/W         | R/W         |   |   |   |   | R/W        | R/W        | R/W        | R/W        |

|       |  |  |  |  |   |   |  |  |  |   |   |   |   |   |
|-------|--|--|--|--|---|---|--|--|--|---|---|---|---|---|
| Reset |  |  |  |  | 0 | 0 |  |  |  | 0 | 0 | 0 | 0 | 0 |
|-------|--|--|--|--|---|---|--|--|--|---|---|---|---|---|

**SPO** Clock Polarity Control

**SPH** Clock Phase Control

**DIV** Serial Clock Divide Select Bits

**8/9** 8-bit or 9-bit Interface Selection

**CSP0** Serial Interface Chip Select 0 Polarity Control

**CSP1** Serial Interface Chip Select 1 Polarity Control

### LCD +0018h LCD Parallel Interface Configuration Register

**LCD\_PCNF**

|      |             |    |             |    |             |    |    |    |    |    |    |    |    |            |    |             |
|------|-------------|----|-------------|----|-------------|----|----|----|----|----|----|----|----|------------|----|-------------|
| Bit  | 31          | 30 | 29          | 28 | 27          | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18         | 17 | 16          |
| Name | <b>C2WS</b> |    | <b>C2WH</b> |    | <b>C2RS</b> |    |    |    |    |    |    |    |    |            |    | <b>SYNC</b> |
| Type | R/W         |    | R/W         |    | R/W         |    |    |    |    |    |    |    |    |            |    | R/W         |
| Bit  | 15          | 14 | 13          | 12 | 11          | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2          | 1  | 0           |
| Name |             |    |             |    | <b>WST</b>  |    |    |    |    |    |    |    |    | <b>RLT</b> |    |             |
| Type |             |    |             |    | R/W         |    |    |    |    |    |    |    |    | R/W        |    |             |

**RLT** Read Latency Time

**WST** Write Wait State Time

**SYNC** Synchronous Read Mode Control

**C2RS** Chip Select (LPCE#) to Read Strobe (LRD#) Setup Time

**C2WH** Chip Select (LPCE#) to Write Strobe (LWR#) Hold Time

**C2WS** Chip Select (LPCE#) to Write Strobe (LWR#) Setup Time

### LCD +0800h LCD Parallel Interface Data Register 0 (with LPA0 Low) **LCD\_PDAT0L**

|      |    |    |    |    |    |    |   |   |   |   |   |   |             |   |   |   |
|------|----|----|----|----|----|----|---|---|---|---|---|---|-------------|---|---|---|
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3           | 2 | 1 | 0 |
| Name |    |    |    |    |    |    |   |   |   |   |   |   | <b>DATA</b> |   |   |   |
| Type |    |    |    |    |    |    |   |   |   |   |   |   | R/W         |   |   |   |

**DATA** Writing to LCD+0800 will drive LPA0 low while sending this data out in parallel BANK0

### LCD +0804h LCD Parallel Interface Data Register 0 (with LPA0 High) **LCD\_PDAT0H**

|      |    |    |    |    |    |    |   |   |   |   |   |   |             |   |   |   |
|------|----|----|----|----|----|----|---|---|---|---|---|---|-------------|---|---|---|
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3           | 2 | 1 | 0 |
| Name |    |    |    |    |    |    |   |   |   |   |   |   | <b>DATA</b> |   |   |   |
| Type |    |    |    |    |    |    |   |   |   |   |   |   | R/W         |   |   |   |

**DATA** Writing to LCD+0804 will drive LPA0 high while sending this data out in parallel BANK0.

### LCD +0808h LCD Parallel Interface Data Register 1 (with LPA0 Low) **LCD\_PDAT1L**

|      |    |    |    |    |    |    |   |   |   |   |   |   |             |   |   |   |
|------|----|----|----|----|----|----|---|---|---|---|---|---|-------------|---|---|---|
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3           | 2 | 1 | 0 |
| Name |    |    |    |    |    |    |   |   |   |   |   |   | <b>DATA</b> |   |   |   |
| Type |    |    |    |    |    |    |   |   |   |   |   |   | R/W         |   |   |   |

**DATA** Writing to LCD+0808 will drive LPA0 low while sending this data out in parallel BANK1

### LCD +080Ch LCD Parallel Interface Data Register 1 (with LPA0 High) **LCD\_PDAT1H**

|      |    |    |    |    |    |    |   |   |   |   |   |   |             |   |   |   |
|------|----|----|----|----|----|----|---|---|---|---|---|---|-------------|---|---|---|
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3           | 2 | 1 | 0 |
| Name |    |    |    |    |    |    |   |   |   |   |   |   | <b>DATA</b> |   |   |   |
| Type |    |    |    |    |    |    |   |   |   |   |   |   | R/W         |   |   |   |

**DATA** Writing to LCD+080C will drive LPA0 high while sending this data out in parallel BANK1.

**LCD +0810h LCD Parallel Interface Data Register 2 (with LPA0 Low) LCD\_PDAT2L**

| Bit  | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | DATA |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**DATA** Writing to LCD+0810 will drive LPA0 low while sending this data out in parallel BANK2.

**LCD +0814h LCD Parallel Interface Data Register 2 (with LPA0 High) LCD\_PDAT2H**

| Bit  | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | DATA |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**DATA** Writing to LCD+0814 will drive LPA0 high while sending this data out in parallel BANK2.

**LCD +0A00h LCD Serial Interface Data Register 0 (with LSA0 Low) LCD\_SDAT0L**

| Bit  | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | DATA |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | W    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**DATA** Writing to LCD+0A00 will drive LSA0 low while sending this data out in serial BANK0.

**LCD +0A04h LCD Serial Interface Data Register 0 (with LSA0 High) LCD\_SDAT0H**

| Bit  | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | DATA |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | W    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**DATA** Writing to LCD+0A04 will drive LSA0 high while sending this data out in serial BANK0.

**LCD +0A08h LCD Serial Interface Data Register 1 (with LSA0 Low) LCD\_SDAT1L**

| Bit  | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | DATA |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | W    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**DATA** Writing to LCD+0A08 will drive LSA0 low while sending this data out in serial BANK1.

**LCD +0A0Ch LCD Serial Interface Data Register 1 (with LSA0 High) LCD\_SDAT1H**

| Bit  | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name | DATA |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | W    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**DATA** Writing to LCD+0A0C will drive LSA0 high while sending this data out in serial BANK1.

**LCD +0040h Main Window Size Register LCD\_MWINSIZE**

| Bit  | 31     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name | ROW    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | COLUMN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**COLUMN** Virtual Image Window Column Size

**ROW** Virtual Image Window Row Size

**LCD +0050h Region of Interest Window Control Register**
**LCD\_WROICON**

| Bit  | 31  | 30  | 29  | 28      | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16     |
|------|-----|-----|-----|---------|----|----|----|----|----|----|----|----|----|----|----|--------|
| Name | EN0 | EN1 | EN2 | EN3     |    |    |    |    |    |    |    |    |    |    |    | PERIOD |
| Type | R/W | R/W | R/W | R/W     |    |    |    |    |    |    |    |    |    |    |    | R/W    |
| Bit  | 15  | 14  | 13  | 12      | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0      |
| Name |     | ENC | W2M | DISC ON |    |    |    |    |    |    |    |    |    |    |    | FORMAT |
| Type |     | R/W | R/W | R/W     |    |    |    |    |    |    |    |    |    |    |    | R/W    |

**FORMAT** LCD Module Data Format

|         |       |               |          |                                                        |
|---------|-------|---------------|----------|--------------------------------------------------------|
| 0000000 | 8bit  | 1cycle/1pixel | RGB3.3.2 | RRRGGBB                                                |
| 0000001 |       | 1cycle/1pixel | RGB3.3.2 | BGGGRRR                                                |
| 0001000 |       | 3cycle/2pixel | RGB4.4.4 | RRRRGGGG<br>BBBBRRRR<br>GGGGBBBB                       |
| 0001011 |       | 3cycle/2pixel | RGB4.4.4 | GGGRRRRR<br>RRRRBBBB<br>BBBBGGGG                       |
| 0010000 |       | 2cycle/1pixel | RGB5.6.5 | RRRRRGGG<br>GGGBBBBB                                   |
| 0010011 |       | 2cycle/1pixel | RGB5.6.5 | GGGRRRRR<br>BBBBBGGG                                   |
| 0011000 |       | 3cycle/1pixel | RGB6.6.6 | RRRRRXXX<br>GGGGGGXX<br>BBBBBBXX                       |
| 0011100 |       | 3cycle/1pixel | RGB6.6.6 | XXRRRRRR<br>XXGGGGGG<br>XXBBBBBB                       |
| 0100000 |       | 3cycle/1pixel | RGB8.8.8 | RRRRRRRR<br>GGGGGGGG<br>BBBBBBBB                       |
| 1000000 | 16bit | 1cycle/2pixel | RGB3.3.2 | RRRGGBBRRRGGBB                                         |
| 1000010 |       | 1cycle/2pixel | RGB3.3.2 | RRRGGBBRRRGGBB                                         |
| 1000001 |       | 1cycle/2pixel | RGB3.3.2 | BGGGRRRBBGGGRRR                                        |
| 1000011 |       | 1cycle/2pixel | RGB3.3.2 | BGGGRRRBBGGGRRR                                        |
| 1001100 |       | 1cycle/1pixel | RGB4.4.4 | XXXRRRRGGGGBBBB                                        |
| 1001101 |       | 1cycle/1pixel | RGB4.4.4 | XXXBBBBGGGGRRRR                                        |
| 1001000 |       | 1cycle/1pixel | RGB4.4.4 | RRRRGGGGBBBBXXXX                                       |
| 1001001 |       | 1cycle/1pixel | RGB4.4.4 | BBBBGGGGRRRRXXXX                                       |
| 1010000 |       | 1cycle/1pixel | RGB5.6.5 | RRRRRGGGGGGBBBB                                        |
| 1010001 |       | 1cycle/1pixel | RGB5.6.5 | BBBBBGGGGGGRRRRR                                       |
| 1011100 |       | 3cycle/2pixel | RGB6.6.6 | XXXRRRRRRGGGGGG<br>XXXBBBBBBRRRRRR<br>XXXGGGGGGBBBBBBB |

|         |  |               |          |                                                         |
|---------|--|---------------|----------|---------------------------------------------------------|
| 1011111 |  | 3cycle/2pixel | RGB6.6.6 | XXXXGGGGGRRRRRR<br>XXXRRRRRRBBBBBB<br>XXXBBBBBBGGGGGG   |
| 1011000 |  | 3cycle/2pixel | RGB6.6.6 | RRRRRRGGGGGXXXX<br>BBBBBBRRRRRXXXX<br>GGGGGGGBBBBBBXXXX |
| 1011011 |  | 3cycle/2pixel | RGB6.6.6 | GGGGGGRRRRRXXXX<br>RRRRRRBBBBBXXXX<br>BBBBBBGGGGGGXXXX  |
| 1100000 |  | 3cycle/2pixel | RGB8.8.8 | RRRRRRRGGGGGGGG<br>BBBBBBBRRRRRRRR<br>GGGGGGGGGBBBBBBBB |
| 1100011 |  | 3cycle/2pixel | RGB8.8.8 | GGGGGGGGRRRRRRR<br>RRRRRRRRBBBBBBB<br>BBBBBBBRRRRRRRR   |
|         |  |               |          |                                                         |

**COMMAND** Number of Commands to be sent to LCD module

**DISCON** Block Write Enable Control. By setting both DISCON and W2M to 1, this LCD accelerator will update the ROI window within the MAIN Window

**W2M** Enable Data Address Increasing After Each Data Transfer

**ENC** Command Transfer Enable Control

**PERIOD** Waiting Period Between Two Consecutive Data Transfers

**ENn** Layer Window Enable Control

### LCD +0054h Region of Interest Window Offset Register LCD\_WROIOFS

|      |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | Y-OFFSET |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | X-OFFSET |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**X-OFFSET** ROI Window Column Offset

**Y-OFFSET** ROI Window Row Offset

### LCD +0058h Region of Interest Window Command Start Address Register LCD\_WROICAD D

|      |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**ADDR** ROI Window Command Address

**LCD +005Ch Region of Interest Window Data Start Address Register LCD\_WROIDAD D**

|      |    |    |    |    |    |    |    |      |      |     |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|------|------|-----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23   | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |      | ADDR |     |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |      |      | R/W |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7    | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    | ADDR |      |     |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |      | R/W  |     |    |    |    |    |    |    |

**ADDR** ROI Window Data Address

**LCD +0060h Region of Interest Window Size Register LCD\_WROISIZE**

|      |    |    |    |    |    |    |    |    |    |        |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22     | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    | ROW    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    | R/W    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6      | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    | COLUMN |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    | R/W    |    |    |    |    |    |    |

**COLUMN** ROI Window Column Size

**ROW** ROI Window Row Size

**LCD +0064h Region of Interest Window Hardware Refresh Register LCD\_WROICFG**

|       |     |     |     |     |    |    |    |    |             |             |             |             |    |    |           |    |
|-------|-----|-----|-----|-----|----|----|----|----|-------------|-------------|-------------|-------------|----|----|-----------|----|
| Bit   | 31  | 30  | 29  | 28  | 27 | 26 | 25 | 24 | 23          | 22          | 21          | 20          | 19 | 18 | 17        | 16 |
| Name  | EN0 | EN1 | EN2 | EN3 |    |    |    |    | IMGD<br>MA0 | IMGD<br>MA1 | IMGD<br>MA2 | IMGD<br>MA3 |    |    |           |    |
| Type  | R/W | R/W | R/W | R/W |    |    |    |    | R/W         | R/W         | R/W         | R/W         |    |    |           |    |
| Reset | 0   | 0   | 0   | 0   |    |    |    |    | 0           | 0           | 0           | 0           |    |    |           |    |
| Bit   | 15  | 14  | 13  | 12  | 11 | 10 | 9  | 8  | 7           | 6           | 5           | 4           | 3  | 2  | 1         | 0  |
| Name  |     |     |     |     |    |    |    |    | HWEN        |             |             |             |    |    | HWR<br>EF |    |
| Type  |     |     |     |     |    |    |    |    | R/W         |             |             |             |    |    | R/W       |    |
| Reset |     |     |     |     |    |    |    |    | 0           |             |             |             |    |    | 0         |    |

**ENn** Enable Layer “n” Source Address Latch from Image DMA

**IMGDMAn** Enable Layer “n” Source Data Latch from Image DMA

**HWEN** Enable Hardware Triggered LCD Refresh

**HWREF** Start Control of Hardware Triggered LCD Frame Transfer

**LCD +0070h Layer 0 Window Control Register LCD\_L0WINCO N**

|      |     |           |    |        |    |           |            |           |        |     |    |    |    |    |    |    |
|------|-----|-----------|----|--------|----|-----------|------------|-----------|--------|-----|----|----|----|----|----|----|
| Bit  | 31  | 30        | 29 | 28     | 27 | 26        | 25         | 24        | 23     | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |     |           |    |        |    |           |            |           | SRCKEY |     |    |    |    |    |    |    |
| Type |     |           |    |        |    |           |            |           | R/W    |     |    |    |    |    |    |    |
| Bit  | 15  | 14        | 13 | 12     | 11 | 10        | 9          | 8         | 7      | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |     | KEYE<br>N |    | ROTATE |    | PLAE<br>N | PLAO/<br>1 | OPAE<br>N |        | OPA |    |    |    |    |    |    |
| Type | R/W |           |    | R/W    |    | R/W       | R/W        | R/W       |        | R/W |    |    |    |    |    |    |

**OPA** Opacity Value Setting

**OPAEN** Opacity Enable Control

**PLAO/1** Color Palette Selection

**PLAEN** Color Palette Enable Control

**ROTATE** Rotation Configuration

**000** 0 degree rotation

**001** 90 degree rotation anti-clockwise

**010** 180 degree rotation anti-clockwise

**011** 270 degree rotation anti-clockwise

**100** Horizontal flip

**101** Horizontal flip then 90 degree rotation anti-clockwise

**110** Horizontal flip then 180 degree rotation anti-clockwise

**111** Horizontal flip then 270 degree rotation anti-clockwise

**KEYEN** Source Key Enable Control

**SRCKEY** Source Key Value

**LCD +0074h Layer 0 Window Display Offset Register**
**LCD\_L0WINOFS**

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Y-OFFSET</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W             |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>X-OFFSET</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W             |

**Y-OFFSET** Layer 0 Window Row Offset

**X-OFFSET** Layer 0 Window Column Offset

**+0078h Layer 0 Window Display Start Address Register**
**LCD\_L0WINADD**

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16          |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>ADDR</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W         |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0           |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>ADDR</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W         |

**ADDR** Layer 0 Window Data Address

**LCD +007Ch Layer 0 Window Size**
**LCD\_L0WINSIZE**

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>ROW</b>    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W           |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0             |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>COLUMN</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W           |

**ROW** Layer 0 Window Row Size

**COLUMN** Layer 0 Window Column Size

**LCD +0080h Layer 1 Window Control Register**
**LCD\_L1WINCONT**

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SRCKEY</b> |

| Type | R/W       |        |    |    |           |            |           |     |   |   |   |   |   |   |   |   |
|------|-----------|--------|----|----|-----------|------------|-----------|-----|---|---|---|---|---|---|---|---|
| Bit  | 15        | 14     | 13 | 12 | 11        | 10         | 9         | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name | KEYE<br>N | ROTATE |    |    | PLAE<br>N | PLAO/<br>1 | OPAE<br>N | OPA |   |   |   |   |   |   |   |   |
| Type | R/W       | R/W    |    |    | R/W       | R/W        | R/W       | R/W |   |   |   |   |   |   |   |   |

**OPA** Opacity Value Setting

**OPAEN** Enable Opacity Control

**PLAO/1** Color Palette Selection

**PLAEN** Color Palette Enable Control

**ROTATE** Rotation Configuration

000 0 degree rotation

001 90 degree rotation

010 180 degree rotation

011 270 degree rotation

100 Vertical flip

101 Reserved

110 Horizontal flip

111 Reserved

**KEYEN** Source Key Enable Control

**SRCKEY** Source-Key

### LCD +0084h Layer 1 Window Display Offset Register

### LCD\_L1WINOFS

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25       | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----------|----|----|----|----|----|----|----|----|----|
| Name |    |    |    |    |    |    | Y-OFFSET |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    | R/W      |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9        | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    | X-OFFSET |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    | R/W      |    |    |    |    |    |    |    |    |    |

**X-OFFSET** Layer 1 Window Row Offset

**Y-OFFSET** Layer 1 Window Column Offset

### LCD +0088h Layer 1 Window Display Start Address Register

### LCD\_L1WINADD

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25   | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|----|
| Name |    |    |    |    |    |    | ADDR |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    | R/W  |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    | ADDR |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    | R/W  |    |    |    |    |    |    |    |    |    |

**ADDR** Layer 1 Window Data Address

### LCD +008Ch Layer 1 Window Size

### LCD\_L1WINSIZE

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25     | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|--------|----|----|----|----|----|----|----|----|----|
| Name |    |    |    |    |    |    | ROW    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    | R/W    |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9      | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    | COLUMN |    |    |    |    |    |    |    |    |    |

|      |  |  |  |  |  |  |  |  |  |  |  |  |  |     |
|------|--|--|--|--|--|--|--|--|--|--|--|--|--|-----|
| Type |  |  |  |  |  |  |  |  |  |  |  |  |  | R/W |
|------|--|--|--|--|--|--|--|--|--|--|--|--|--|-----|

**COLUMN** Layer 1 Window Column Size

**ROW** Layer 1 Window Row Size

### LCD +0090h Layer 2 Window Control Register

LCD\_L2WINCO  
N

|      |    |    |              |    |    |               |              |                   |    |    |    |    |    |    |    |               |
|------|----|----|--------------|----|----|---------------|--------------|-------------------|----|----|----|----|----|----|----|---------------|
| Bit  | 31 | 30 | 29           | 28 | 27 | 26            | 25           | 24                | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            |
| Name |    |    |              |    |    |               |              |                   |    |    |    |    |    |    |    | <b>SRCKEY</b> |
| Type |    |    |              |    |    |               |              |                   |    |    |    |    |    |    |    | R/W           |
| Bit  | 15 | 14 | 13           | 12 | 11 | 10            | 9            | 8                 | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0             |
| Name |    |    | <b>KEYEN</b> |    |    | <b>ROTATE</b> | <b>PLAEN</b> | <b>PLAO/OPAEN</b> |    |    |    |    |    |    |    | <b>OPA</b>    |
| Type |    |    | R/W          |    |    | R/W           | R/W          | R/W               |    |    |    |    |    |    |    | R/W           |

**OPA** Opacity Value Setting

**OPAEN** Enable Opacity Control

**PLAO/1** Color Palette Selection

**PLAEN** Color Palette Enable Control

**ROTATE** Rotation Configuration

**000** 0 degree rotation

**001** 90 degree rotation

**010** 180 degree rotation

**011** 270 degree rotation

**100** Vertical flip

**101** Reserved

**110** Horizontal flip

**111** Reserved

**KEYEN** Source Key Enable Control

**SRCKEY** Source-Key

### LCD +0094h Layer 2 Window Display Offset Register

LCD\_L2WINOFS

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Y-OFFSET</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W             |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>X-OFFSET</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W             |

**X-OFFSET** Layer 2 Window Column Offset

**Y-OFFSET** Layer 2 Window Row Offset

### LCD +0098h Layer 2 Window Display Start Address Register

LCD\_L2WINADD

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16          |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>ADDR</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W         |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0           |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>ADDR</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W         |

**ADDR** Layer 2 Window Data Address

### LCD +009Ch Layer 2 Window Size

**LCD\_L2WINSIZE**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>ROW</b>    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W           |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0             |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>COLUMN</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W           |

**COLUMN** Layer 2 Window Column Size

**ROW** Layer 2 Window Row Size

### LCD +00A0h Layer 3 Window Control Register

**LCD\_L3WINCONTRO**

|      |              |    |               |    |             |                  |     |    |    |    |    |    |    |    |    |               |
|------|--------------|----|---------------|----|-------------|------------------|-----|----|----|----|----|----|----|----|----|---------------|
| Bit  | 31           | 30 | 29            | 28 | 27          | 26               | 25  | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            |
| Name |              |    |               |    |             |                  |     |    |    |    |    |    |    |    |    | <b>SRCKEY</b> |
| Type |              |    |               |    |             |                  |     |    |    |    |    |    |    |    |    | R/W           |
| Bit  | 15           | 14 | 13            | 12 | 11          | 10               | 9   | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0             |
| Name | <b>KEYEN</b> |    | <b>ROTATE</b> |    | <b>PLAE</b> | <b>PLA0/OPAE</b> |     |    |    |    |    |    |    |    |    | <b>OPA</b>    |
| Type | R/W          |    | R/W           |    | R/W         | R/W              | R/W |    |    |    |    |    |    |    |    | R/W           |

**OPA** Opacity Value Setting

**OPAEN** Enable Opacity Control

**PLA0/1** Color Palette Selection

**PLAEN** Color Palette Enable Control

**ROTATE** Rotation Configuration

000 0 degree rotation

001 90 degree rotation

010 180 degree rotation

011 270 degree rotation

100 Vertical flip

101 Reserved

110 Horizontal flip

111 Reserved

**KEYEN** Source Key Enable Control

**SRCKEY** Source-Key

### LCD +00A4h Layer 3 Window Display Offset Register

**LCD\_L3WINOFS**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Y-OFFSET</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W             |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>X-OFFSET</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W             |

**X-OFFSET** Layer 3 Window Column Offset

**Y-OFFSET** Layer 3 Window Row Offset

**LCD +00A8h Layer 3 Window Display Start Address Register** **LCD\_L3WINADD**

|      |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | <b>ADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>ADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**ADDR** Layer 3 Window Data Address

**LCD +00ACh Layer 3 Window Size** **LCD\_L3WINSIZE**

|      |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31            | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | <b>ROW</b>    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15            | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>COLUMN</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**COLUMN** Layer 3 Window Column Size

**ROW** Layer 3 Window Row Size

**LCD +0200h~03FCh LCD Interface Color Palette LUT 0 Registers** **LCD\_PAL0**

|      |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | <b>LUT0</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>LUT0</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**LUT0** These Bits Set LUT0 Data in RGB565 Format

**LCD +0400h~05FCh LCD Interface Color Palette LUT 1 Registers** **LCD\_PAL1**

|      |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | <b>LUT1</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>LUT1</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**LUT1** These Bits Set LUT1 Data in RGB565 Format

**LCD +0600h~063C LCD Interface Command/Parameter Registers** **LCD\_COMM**

|      |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | <b>C0</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>C0</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**COMM** Command Data and Parameter Data for LCD Module

**C0** Write to ROI Command Address if C0 = 1, otherwise write to ROI Data Address

## 6.2 JPEG Decoder

### 6.2.1 Overview

To boost JPEG image processing performance, a hardware block is preferred to aid software and deal with JPEG file as much as possible. As a result, JPEG Decoder is designed to decode all baseline and progressive JPEG images with all YUV sampling frequencies combinations. To gain the best speed performance, JPEG decoder will handle all portions of JPEG files except the 17-byte SOF marker. The software program only needs to program related control registers based on the SOF marker and wait for an interrupt coming from hardware. Taking into consideration the limited size of memories, hardware also supports multiple runs of JPEG progressive images and breakpoints insertion in huge JPEG files. Multiple runs can greatly reduce memory usage by 1/N where N is the number of runs. Breakpoints insertion allows software to load partial JPEG file from external flash to internal memory if the JPEG file is too large to sit internally at one time.

### 6.2.2 Register Definitions

**JPEG+0000h JPEG Decoder Control Register**

| Bit  | 31                      | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|------|-------------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name | <b>FILE_ADDR[31:16]</b> |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Type | R/W                     | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Bit  | 15                      | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name | <b>FILE_ADDR[15:0]</b>  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Type | R/W                     | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W |

The JPEG file starting address must be a multiple of 4. Not affected by global reset and JPEG decoder abort.

**FILE\_ADDR** Starting physical address of input JPEG file in SRAM

**JPEG+0004h JPEG Decoder Control Register**

**TBLS\_START\_ADD**  
R

| Bit  | 31                       | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|------|--------------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name | <b>START_ADDR[31:16]</b> |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Type | R/W                      | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Bit  | 15                       | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name | <b>START_ADDR[15:11]</b> |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Type | R/W                      | R/W | R/W | R/W | R/W | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   |

The table starting address must be a multiple of 2K. Not affected by global reset and JPEG decoder abort. Need reprogramming for multiple runs of progressive images.

**START\_ADDR** The starting address of the memory space for 4 quantization tables and 8 Huffman tables. The memory space must be 2K Bytes at least.

**JPEG+0008h JPEG Decoder Control Register**

**SAMP\_FACTOR**

| Bit  | 31                                                                                                                            | 30 | 29 | 28 | 27  | 26 | 25  | 24 | 23  | 22 | 21  | 20 | 19  | 18 | 17  | 16 |
|------|-------------------------------------------------------------------------------------------------------------------------------|----|----|----|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----|
| Name |                                                                                                                               |    |    |    |     |    |     |    |     |    |     |    |     |    |     |    |
| Type |                                                                                                                               |    |    |    |     |    |     |    |     |    |     |    |     |    |     |    |
| Bit  | 15                                                                                                                            | 14 | 13 | 12 | 11  | 10 | 9   | 8  | 7   | 6  | 5   | 4  | 3   | 2  | 1   | 0  |
| Name | <b>H_SAMP_0[1:0]</b> <b>V_SAMP_0[1:0]</b> <b>H_SAMP_1[1:0]</b> <b>V_SAMP_1[1:0]</b> <b>H_SAMP_2[1:0]</b> <b>V_SAMP_2[1:0]</b> |    |    |    |     |    |     |    |     |    |     |    |     |    |     |    |
| Type |                                                                                                                               |    |    |    |     |    |     |    |     |    |     |    |     |    |     |    |
|      |                                                                                                                               |    |    |    | R/W |    |

This register contains the sampling factor of YUV components. Not affected by global reset and JPEG decoder abort.

#### **H\_SAMP\_0** Horizontal sampling factor of the 1<sup>st</sup> component, Y.

- 00** SF is 1
- 01** SF is 2
- 10** Invalid
- 11** SF is 4

#### **V\_SAMP\_0** Vertical sampling factor of the 1<sup>st</sup> component, Y.

- 00** SF is 1
- 01** SF is 2
- 10** Invalid
- 11** SF is 4

#### **H\_SAMP\_1** Horizontal sampling factor of the 2<sup>nd</sup> component, U.

- 00** SF is 1
- 01** SF is 2
- 10** Invalid
- 12** SF is 4

#### **V\_SAMP\_1** Vertical sampling factor of the 2<sup>nd</sup> component, U.

- 00** SF is 1
- 01** SF is 2
- 10** Invalid
- 11** SF is 4

#### **H\_SAMP\_2** Horizontal sampling factor of the 3<sup>rd</sup> component, V.

- 00** SF is 1
- 01** SF is 2
- 10** Invalid
- 13** SF is 4

#### **V\_SAMP\_2** Vertical sampling factor of the 3<sup>rd</sup> component, V.

- 00** SF is 1
- 01** SF is 2
- 10** Invalid
- 11** SF is 4

### **JPEG+000Ch JPEG Decoder Control Register**

#### **COMP\_ID**

| Bit  | 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21                   | 20 | 19 | 18 | 17 | 16 |
|------|----------------------|----|----|----|----|----|----|----|----|----|----------------------|----|----|----|----|----|
| Name | <b>COMP0_ID[7:0]</b> |    |    |    |    |    |    |    |    |    | <b>COMP1_ID[7:0]</b> |    |    |    |    |    |
| Type | R/W                  |    |    |    |    |    |    |    |    |    | R/W                  |    |    |    |    |    |
| Bit  | 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5                    | 4  | 3  | 2  | 1  | 0  |
| Name | <b>COMP2_ID[7:0]</b> |    |    |    |    |    |    |    |    |    | R/W                  |    |    |    |    |    |
| Type | R/W                  |    |    |    |    |    |    |    |    |    | R/W                  |    |    |    |    |    |

This register contains the IDs of YUV components. Not affected by global reset and JPEG decoder abort.

**COMP0\_ID** The 1<sup>st</sup> component (Y) ID extracted from SOF marker.

**COMP1\_ID** The 2<sup>nd</sup> component (U) ID extracted from SOF marker.

**COMP2\_ID** The 3<sup>rd</sup> component (V) ID extracted from SOF marker.

**JPEG+0010h JPEG Decoder Control Register**
**TOTAL MCU NUM**

| Bit  | 31                          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|-----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name | <b>TOTAL MCU NUM[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15                          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>TOTAL MCU NUM[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

This register contains the total MCU number in interleaved scan. Note that if the MCU number is N, program (N-1) into this register. Not affected by global reset and JPEG decoder abort.

**JPEG+0014h JPEG Decoder Control Register**
**INTLV MCU NUM PER MCU ROW**

| Bit  | 31                                    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|---------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15                                    | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>INTLV MCU NUM PER MCU ROW[9:0]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

This register contains the MCU number per row in interleaved scan. Not affected by global reset and JPEG decoder abort.

**JPEG+0018h JPEG Decoder Control Register**
**COMP0\_NONINTLV  
DU\_NUM\_PER\_MC  
U\_ROW**

| Bit  | 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>DUMMY DU</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

This register contains the MCU number per row in non-interleaved scan of the 1<sup>st</sup> component (Y). Not affected by global reset and JPEG decoder abort. Note that COMP0\_NONINTLV\_MCU\_NUM\_PER MCU\_ROW includes the number of DUMMY\_DU if any.

**DUMMY DU** Dummy data unit number in non-interleaved scan of the 1<sup>st</sup> component

- 00** no dummy data unit
- 01** one dummy data unit
- 10** two dummy data units
- 11** three dummy data units

**COMP0\_NONINTLV\_MCU\_NUM\_PER MCU\_ROW** The MCU number per row in non-interleaved scan of the 1<sup>st</sup> component (Y).

In progressive image, dummy data unit columns are inevitable if more than 8 redundant pixel columns are transmitted to fill up the last MCU in a MCU row. For example, in 422 format, a MCU is composed of 16 x 16 pixels. If a given image size is 355 x 400, for JPEG encoder to compress, the image will grow to 368 x 400 first such that both width and height are multiples of 16. It can be seen that to be divisible by 16, there are 13 redundant Y-component pixels in the horizontal (width) direction. These 13 Y-component pixels will be compressed by encoders in interleaved scans because a complete MCU will

need 16 x 16 pixels. It is different from non-interleaved scans, because in non-interleaved scans a complete MCU only needs 8 x 8 Y-component pixels. Therefore, among the 13 redundant pixels the first 5 will still be compressed as interleaved scans while the last 8 will be dropped. In this case, software must program the DUMMY\_DU field to 1 so the hardware will know one 8 x 8 data unit should be skipped at the last of a MCU row in non-interleaved scan.

### JPEG+001Ch JPEG Decoder Control Register

**COMP1\_NONINTLV  
\_DU\_NUM\_PER\_MC  
U\_ROW**

| Bit  | 31 | 30 | 29       | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                      |
|------|----|----|----------|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------|
| Name |    |    |          |    |    |    |    |    |    |    |    |    |    |    |    |                                         |
| Type |    |    |          |    |    |    |    |    |    |    |    |    |    |    |    |                                         |
| Bit  | 15 | 14 | 13       | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                       |
| Name |    |    | DUMMY_DU |    |    |    |    |    |    |    |    |    |    |    |    | COMP1_NONINTLV_MCU_NUM_PER_MCU_ROW[9:0] |
| Type |    |    | R/W      |    |    |    |    |    |    |    |    |    |    |    |    | R/W                                     |

This register contains the MCU number per row in non-interleaved scan of the 2<sup>nd</sup> component (Y). Not affected by global reset and JPEG decoder abort. Note that COMP1\_NONINTLV\_MCU\_NUM\_PER\_MCU\_ROW includes the number of DUMMY\_DU if any.

**DUMMY\_DU** Dummy data unit number in non-interleaved scan of the 2<sup>nd</sup> component

- 00** no dummy data unit
- 01** one dummy data unit
- 10** two dummy data units
- 11** three dummy data units

**COMP1\_NONINTLV\_MCU\_NUM\_PER\_MCU\_ROW** The MCU number per row in non-interleaved scan of the 2<sup>nd</sup> component (U).

### JPEG+0020h JPEG Decoder Control Register

**COMP2\_NONINTLV  
\_DU\_NUM\_PER\_MC  
U\_ROW**

| Bit  | 31 | 30 | 29       | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                      |
|------|----|----|----------|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------|
| Name |    |    |          |    |    |    |    |    |    |    |    |    |    |    |    |                                         |
| Type |    |    |          |    |    |    |    |    |    |    |    |    |    |    |    |                                         |
| Bit  | 15 | 14 | 13       | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                       |
| Name |    |    | DUMMY_DU |    |    |    |    |    |    |    |    |    |    |    |    | COMP2_NONINTLV_MCU_NUM_PER_MCU_ROW[9:0] |
| Type |    |    | R/W      |    |    |    |    |    |    |    |    |    |    |    |    | R/W                                     |

This register contains the MCU number per row in non-interleaved scan of the 3<sup>rd</sup> component (V). Not affected by global reset and JPEG decoder abort. Note that COMP2\_NONINTLV\_MCU\_NUM\_PER\_MCU\_ROW includes the number of DUMMY\_DU if any.

**DUMMY\_DU** Dummy data unit number in non-interleaved scan of the 3<sup>rd</sup> component

- 00** no dummy data unit
- 01** one dummy data unit
- 10** two dummy data units
- 11** three dummy data units

**COMP2\_NONINTLV\_MCU\_NUM\_PER\_MCU\_ROW** The MCU number per row in non-interleaved scan of the 3<sup>rd</sup> component (V).

**JPEG+0024h JPEG Decoder Control Register**
**COMP0\_DATA\_UNIT\_NUM**

|      |                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|-----------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31                                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | <b>COMP0_DATA_UNIT_NUM[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15                                | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>COMP0_DATA_UNIT_NUM[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

This register contains the 8x8 data unit number of the 1<sup>st</sup> component in non-interleaved scans. Note that if the data unit number is N, program (N-1) into this register. Not affected by global reset and JPEG decoder abort.

**JPEG+0028h JPEG Decoder Control Register**
**COMP1\_DATA\_UNIT\_NUM**

|      |                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|-----------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31                                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | <b>COMP1_DATA_UNIT_NUM[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15                                | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>COMP1_DATA_UNIT_NUM[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

This register contains the 8x8 data unit number of the 2<sup>nd</sup> component in non-interleaved frame. Note that if the data unit number is N, program (N-1) into this register. Not affected by global reset and JPEG decoder abort.

**JPEG+002Ch JPEG Decoder Control Register**
**COMP2\_DATA\_UNIT\_NUM**

|      |                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|-----------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31                                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | <b>COMP2_DATA_UNIT_NUM[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15                                | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>COMP2_DATA_UNIT_NUM[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

This register contains the 8x8 data unit number of the 3<sup>rd</sup> component in non-interleaved frame. Note that if the data unit number is N, program (N-1) into this register. Not affected by global reset and JPEG decoder abort.

**JPEG+0030h JPEG Decoder Control Register**
**COMP0\_PROGR\_COEFF\_START\_ADDR**  
**R**

|      |                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|--------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31                                         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | <b>COMP0_PROGR_COEFF_START_ADDR[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15                                         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>COMP0_PROGR_COEFF_START_ADDR[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

This register contains the starting address of the memory space storing the intermediate progressive coefficients of the 1<sup>st</sup> component. This value must be a multiple of 4. Not affected by global reset and JPEG decoder abort.

**JPEG+0034h JPEG Decoder Control Register**

**COMP1\_PROGR\_C**  
**OEFF\_START\_ADD**  
**R**

|      |                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|--------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31                                         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | <b>COMP1_PROGR_COEFF_START_ADDR[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15                                         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>COMP1_PROGR_COEFF_START_ADDR[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

This register contains the starting address of the memory space storing the intermediate progressive coefficients of the 2<sup>nd</sup> component. This value must be a multiple of 4. Not affected by global reset and JPEG decoder abort.

**JPEG+0038h JPEG Decoder Control Register**

**COMP2\_PROGR\_C**  
**OEFF\_START\_ADD**  
**R**

|      |                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|--------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31                                         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | <b>COMP2_PROGR_COEFF_START_ADDR[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15                                         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>COMP2_PROGR_COEFF_START_ADDR[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

This register contains the starting address of the memory space storing the intermediate progressive coefficients of the 3<sup>rd</sup> component. This value must be a multiple of 4. Not affected by global reset and JPEG decoder abort.

**JPEG+003Ch JPEG Decoder Control Register**

**JPEG\_CTRL**

|      |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | <b>JPEG_MOD_E</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15                | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>DU4[2:0]</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Name | <b>DU3[2:0]</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Name | <b>DU2[2:0]</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Name | <b>DU1[2:0]</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Name | <b>DU0[2:0]</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

This register contains 2 information: the operating mode of JPEG decoder and the order of 3 components in a MCU.  
Affected by global reset and JPEG decoder abort. Need reprogramming for multiple runs of progressive images.

**JPEG\_MODE** The operating mode of JPEG decoder.

- 0** Baseline mode
- 1** Progressive mode

**DU9** The 10<sup>th</sup> data unit component category in a MCU

- 100** The 10<sup>th</sup> data unit is the 1<sup>st</sup> component (Y)
- 101** The 10<sup>th</sup> data unit is the 2<sup>nd</sup> component (U)
- 110** The 10<sup>th</sup> data unit is the 3<sup>rd</sup> component (V)
- 111** Not used in current frame
- 000-011** Invalid

- DU8** The 9<sup>th</sup> data unit component category in a MCU  
**100** The 9<sup>th</sup> data unit is the 1<sup>st</sup> component (Y)  
**101** The 9<sup>th</sup> data unit is the 2<sup>nd</sup> component (U)  
**110** The 9<sup>th</sup> data unit is the 3<sup>rd</sup> component (V)  
**111** Not used in current frame  
**000-011** Invalid
- DU7** The 8<sup>th</sup> data unit component category in a MCU  
**100** The 8<sup>th</sup> data unit is the 1<sup>st</sup> component (Y)  
**101** The 8<sup>th</sup> data unit is the 2<sup>nd</sup> component (U)  
**110** The 8<sup>th</sup> data unit is the 3<sup>rd</sup> component (V)  
**111** Not used in current frame  
**000-011** Invalid
- DU6** The 7<sup>th</sup> data unit component category in a MCU  
**100** The 7<sup>th</sup> data unit is the 1<sup>st</sup> component (Y)  
**101** The 7<sup>th</sup> data unit is the 2<sup>nd</sup> component (U)  
**110** The 7<sup>th</sup> data unit is the 3<sup>rd</sup> component (V)  
**111** Not used in current frame  
**000-011** Invalid
- DU5** The 6<sup>th</sup> data unit component category in a MCU  
**100** The 6<sup>th</sup> data unit is the 1<sup>st</sup> component (Y)  
**101** The 6<sup>th</sup> data unit is the 2<sup>nd</sup> component (U)  
**110** The 6<sup>th</sup> data unit is the 3<sup>rd</sup> component (V)  
**111** Not used in current frame  
**000-011** Invalid
- DU4** The 5<sup>th</sup> data unit component category in a MCU  
**100** The 5<sup>th</sup> data unit is the 1<sup>st</sup> component (Y)  
**101** The 5<sup>th</sup> data unit is the 2<sup>nd</sup> component (U)  
**110** The 5<sup>th</sup> data unit is the 3<sup>rd</sup> component (V)  
**111** Not used in current frame  
**000-011** Invalid
- DU3** The 4<sup>th</sup> data unit component category in a MCU  
**100** The 4<sup>th</sup> data unit is the 1<sup>st</sup> component (Y)  
**101** The 4<sup>th</sup> data unit is the 2<sup>nd</sup> component (U)  
**110** The 4<sup>th</sup> data unit is the 3<sup>rd</sup> component (V)  
**111** Not used in current frame  
**000-011** Invalid
- DU2** The 3<sup>rd</sup> data unit component category in a MCU  
**100** The 3<sup>rd</sup> data unit is the 1<sup>st</sup> component (Y)  
**101** The 3<sup>rd</sup> data unit is the 2<sup>nd</sup> component (U)  
**110** The 3<sup>rd</sup> data unit is the 3<sup>rd</sup> component (V)  
**111** Not used in current frame  
**000-011** Invalid
- DU1** The 2<sup>nd</sup> data unit component category in a MCU  
**100** The 2<sup>nd</sup> data unit is the 1<sup>st</sup> component (Y)

**101** The 2<sup>nd</sup> data unit is the 2<sup>nd</sup> component (U)

**110** The 2<sup>nd</sup> data unit is the 3<sup>rd</sup> component (V)

**111** Not used in current frame

**000-011** Invalid

**DU0** The 1<sup>st</sup> data unit component category in a MCU

**100** The 1<sup>st</sup> data unit is the 1<sup>st</sup> component (Y)

**101** The 1<sup>st</sup> data unit is the 2<sup>nd</sup> component (U)

**110** The 1<sup>st</sup> data unit is the 3<sup>rd</sup> component (V)

**111** Not used in current frame

**000-011** Invalid

### JPEG+0040h JPEG Decoder Control Register

**JPEG\_DEC\_TRIG**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    | WO |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    | WO |    |    |    |    |    |    |    |

JPEG\_DEC\_TRIG will trigger JPEG decoding operation no matter what value is programmed.

### JPEG+0044h JPEG Decoder Control Register

**JPEG\_DEC\_ABOR**

**T**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    | WO |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    | WO |    |    |    |    |    |    |    |

JPEG\_DEC\_ABORT will abort JPEG decoding operation and reset JPEG decoder hardware no matter what value is programmed.

### JPEG+0048h JPEG Decoder Control Register

**JPEG\_FILE\_BRP**

|      |    |    |    |    |    |    |    |    |                      |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----------------------|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23                   | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    | JPEG_FILE_BRP[31:16] |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    | R/W                  |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                    | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    | JPEG_FILE_BRP[15:0]  |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    | R/W                  |    |    |    |    |    |    |    |

JPEG\_DEC\_BRP stands for a 32-bit byte breakpoint address that hardware will stall once the breakpoint address is encountered. This control register provides a solution for software to swap internal memory content with external memory in case the JPEG source file is too big for internal memory to store at one time. A breakpoint interrupt will fire when hardware DMA address hits the breakpoint address. Note that the breakpoint address must be a multiple of 4. Not affected by global reset and JPEG decoder abort.

**JPEG+004Ch JPEG Decoder Control Register**
**JPEG\_FILE\_TOTAL\_SIZE**

| Bit  | 31                                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name | <b>JPEG_FILE_TOTAL_SIZE[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15                                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>JPEG_FILE_TOTAL_SIZE[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

JPEG\_FILE\_TOTAL\_SIZE represents the JPEG source file size in bytes. Hardware will fire a file overflow interrupt and stall if the DMA address equals to this address. Note that the breakpoint address must be a multiple of 4. If the file size is not divisible by 4, increment the size value until it is. Not affected by global reset and JPEG decoder abort.

**JPEG+0050h JPEG Decoder Control Register**
**INTLV\_FIRST MCU INDEX**

| Bit  | 31                                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15                                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>INTLV_FIRST MCU INDEX[15:0]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

This control register specifies the first MCU index that hardware will process in the interleaved scans of the current image. The JPEG decoder is able to skip certain MCUs by defining the first and last MCU index. Not affected by global reset and JPEG decoder abort.

**JPEG+0054h JPEG Decoder Control Register**
**INTLV\_LAST MCU INDEX**

| Bit  | 31                                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|-----------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15                                | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>INTLV_LAST MCU INDEX[15:0]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

This control register specifies the last MCU index that hardware will process in the interleaved scans of the current image. The JPEG decoder is able to skip certain MCUs by defining the first and last MCU index. Not affected by global reset and JPEG decoder abort.

**JPEG+0058h JPEG Decoder Control Register**
**COMP0\_FIRST MCU INDEX**

| Bit  | 31                                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15                                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>COMP0_FIRST MCU INDEX[15:0]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|      |     |
|------|-----|
| Type | R/W |
|------|-----|

Only effective in progressive images. This control register specifies the first MCU index that hardware will process in the non-interleaved scans containing Y component of the current image. The JPEG decoder is able to skip certain MCUs by defining the first and last MCU index. Not affected by global reset and JPEG decoder abort.

#### JPEG+005Ch JPEG Decoder Control Register

**COMP0\_LAST\_MCU\_INDEX**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>COMP0_LAST_MCU_INDEX[19:16]</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                                |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>COMP0_LAST_MCU_INDEX[15:0]</b>  |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                                |

Only effective in progressive images. This control register specifies the last MCU index that hardware will process in the non-interleaved scans containing Y component of the current image. The JPEG decoder is able to skip certain MCUs by defining the first and last MCU index. Not affected by global reset and JPEG decoder abort.

#### JPEG+0060h JPEG Decoder Control Register

**COMP1\_FIRST\_MCU\_INDEX**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                     |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>COMP1_FIRST_MCU_INDEX[19:16]</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                                 |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                   |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>COMP1_FIRST_MCU_INDEX[15:0]</b>  |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                                 |

Only effective in progressive images. This control register specifies the first MCU index that hardware will process in the non-interleaved scans containing U component of the current image. The JPEG decoder is able to skip certain MCUs by defining the first and last MCU index. Not affected by global reset and JPEG decoder abort.

#### JPEG+0064h JPEG Decoder Control Register

**COMP1\_LAST\_MCU\_INDEX**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>COMP1_LAST_MCU_INDEX[19:16]</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                                |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>COMP1_LAST_MCU_INDEX[15:0]</b>  |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                                |

Only effective in progressive images. This control register specifies the last MCU index that hardware will process in the non-interleaved scans containing U component of the current image. The JPEG decoder is able to skip certain MCUs by defining the first and last MCU index. Not affected by global reset and JPEG decoder abort.

**JPEG+0068h JPEG Decoder Control Register**
**COMP2\_FIRST MCU INDEX**

|      |    |    |    |    |    |    |    |    |    |    |    |    |                                    |    |    |     |
|------|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------|----|----|-----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19                                 | 18 | 17 | 16  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    | <b>COMP2_FIRST MCU_IND</b>         |    |    |     |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |                                    |    |    | R/W |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3                                  | 2  | 1  | 0   |
| Name |    |    |    |    |    |    |    |    |    |    |    |    | <b>COMP2_FIRST MCU_INDEX[15:0]</b> |    |    |     |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |                                    |    |    | R/W |

Only effective in progressive images. This control register specifies the first MCU index that hardware will process in the non-interleaved scans containing V component of the current image. The JPEG decoder is able to skip certain MCUs by defining the first and last MCU index. Not affected by global reset and JPEG decoder abort.

**JPEG+006Ch JPEG Decoder Control Register**
**COMP2\_LAST MCU INDEX**

|      |    |    |    |    |    |    |    |    |    |    |    |    |                                   |    |    |     |
|------|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------|----|----|-----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19                                | 18 | 17 | 16  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    | <b>COMP2_LAST MCU_IND</b>         |    |    |     |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |                                   |    |    | R/W |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3                                 | 2  | 1  | 0   |
| Name |    |    |    |    |    |    |    |    |    |    |    |    | <b>COMP2_LAST MCU_INDEX[15:0]</b> |    |    |     |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |                                   |    |    | R/W |

Only effective in progressive images. This control register specifies the last MCU index that hardware will process in the non-interleaved scans containing V component of the current image. The JPEG decoder is able to skip certain MCUs by defining the first and last MCU index. Not affected by global reset and JPEG decoder abort.

**JPEG+0070h JPEG Decoder Control Register**
**QT\_ID**

|      |    |    |    |    |    |    |    |    |                         |    |                         |    |                         |    |    |    |
|------|----|----|----|----|----|----|----|----|-------------------------|----|-------------------------|----|-------------------------|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23                      | 22 | 21                      | 20 | 19                      | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |                         |    |                         |    |                         |    |    |    |
| Type |    |    |    |    |    |    |    |    |                         |    |                         |    |                         |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                       | 6  | 5                       | 4  | 3                       | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    | <b>COMP0_QT_ID[3:0]</b> |    | <b>COMP1_QT_ID[3:0]</b> |    | <b>COMP2_QT_ID[3:0]</b> |    |    |    |
| Type |    |    |    |    |    |    |    |    | R/W                     |    | R/W                     |    | R/W                     |    |    |    |

This register contains the quantization table IDs for YUV components. Not affected by global reset and JPEG decoder abort.

**COMP0\_QT\_ID** Quantization table ID of Y component directly extracted from SOF marker

**COMP1\_QT\_ID** Quantization table ID of U component directly extracted from SOF marker

**COMP2\_QT\_ID** Quantization table ID of V component directly extracted from SOF marker

**JPEG+0074h JPEG Decoder Control Register**
**JPEG\_DEC\_INTER RUPT\_STATUS**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

| Name |  |  |  |  |  |  |  |  |  |  |  |  | <b>INT2</b> | <b>INT1</b> | <b>INT0</b> |
|------|--|--|--|--|--|--|--|--|--|--|--|--|-------------|-------------|-------------|
| Type |  |  |  |  |  |  |  |  |  |  |  |  | RO          | RO          | RO          |

The register reflects the interrupt status

**INT2** Set to 1 by file overflow interrupt

**INT1** Set to 1 by breakpoint interrupt

**INT0** Set to 1 by end of file interrupt

## JPEG+0078h JPEG Decoder Control Register

**JPEG\_DEC\_STAT**  
US

| Bit  | 31                      | 30         | 29          | 28          | 27                     | 26 | 25                    | 24 | 23                    | 22 | 21 | 20 | 19                        | 18 | 17 | 16 |
|------|-------------------------|------------|-------------|-------------|------------------------|----|-----------------------|----|-----------------------|----|----|----|---------------------------|----|----|----|
| Name |                         | <b>FOS</b> | <b>BRPS</b> | <b>EOFS</b> |                        |    | <b>JPEG_DEC_STATE</b> |    | <b>HUFF_DEC_STATE</b> |    |    |    | <b>MARKER_PARSER_STAT</b> | E  |    |    |
| Type |                         | RO         | RO          | RO          |                        |    | RO                    |    | RO                    |    |    |    | RO                        |    |    |    |
| Bit  | 15                      | 14         | 13          | 12          | 11                     | 10 | 9                     | 8  | 7                     | 6  | 5  | 4  | 3                         | 2  | 1  | 0  |
| Name | <b>SOS_PARSER_STATE</b> |            |             |             | <b>DHT_PARSER_STAT</b> |    |                       |    | <b>DQT_PARSER_STA</b> |    |    |    | <b>DATA_UNIT_STATE</b>    |    |    |    |
| Type | RO                      |            |             |             | RO                     |    |                       |    | RO                    |    |    |    | RO                        |    |    |    |

## 6.3 JPEG Encoder

### 6.3.1 General Descriptions

The hardware JPEG encoder implements the baseline mode of Standard ISO/IEC 10918-1. It supports YUV 422 format for color pictures and grayscale format. For hardware reduction, it uses standard DC and AC Huffman tables for both the luminance and chrominance components. To adjust the picture compression ratio and picture quality, there are 4 levels of quantization that can be programmed. After initialization by software, the hardware JPEG encoder can generate the entire compressed file.

**Figure 1** shows the procedure of the JPEG encoder. The YUV pixel data that came from image DMA are grouped into 8x8 blocks and then down-sampled to YUV 422 format. For grayscale encoding, only Y component will be present. When encoding, the first thing to do is to turn the pixel data into the frequency domain using FDCT. After the quantizer is done, the quantized DCT coefficients are encoded by RLE and VLC.



**Figure 1** The procedure of JPEG encoder

## 6.3.2 Register Definitions

JPEG = 0x8060\_0000

| Register Address | Register Function                      | Acronym            |
|------------------|----------------------------------------|--------------------|
| JPEG + 008Ch     | JPEG encoder reset register            | JPG_ENC_RST        |
| JPEG + 0090h     | JPEG encoder control register          | JPG_ENC_CTL        |
| JPEG + 0094h     | JPEG encoder interrupt status register | JPG_ENC_INTSTS     |
| JPEG + 0098h     | JPEG encoder block count register      | JPG_ENC_BLK_CNT    |
| JPEG + 009Ch     | JPEG encoder quality register          | JPG_ENC_QUALITY    |
| JPEG + 00a0h     | JPEG encoder base address register     | JPG_ENC_DEST_ADDR  |
| JPEG + 00a4h     | JPEG encoder DMA address register      | JPG_ENC_DMA_ADDR   |
| JPEG + 00a8h     | JPEG encoder STALL address register    | JPG_ENC_STALL_ADDR |

Table 25 JPEG encoder Registers

### JPEG+008ch JPEG encoder reset register

JPG\_ENC\_RST

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RST |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     | 0  |

**RST** Reset the JPEG encoder.

### JPEG+0090h JPEG encoder control register

JPG\_ENC\_CTL

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |     |      |     |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|-----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17   | 16  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |     |      |     |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |     |      |     |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |     |      |     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2   | 1    | 0   |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    | IT  | GRAY | EN  |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W | R/W  | R/W |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    | 1   | 0    | 0   |

**EN** Enable the JPEG encoder. This bit will be cleared by hardware after encoding is done.

**GRAY** Do grayscale encode. Please remember that the image DMA should be programmed as grayscale too.

**0** color

**1** grayscale

**IT** Interrupt Enabling

**0** Disable

**1** Enable

**JPEG+0094h JPEG encoder interrupt status register**
**JPG\_ENC\_INTS  
TS**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17    | 16   |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |      |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |      |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |      |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1     | 0    |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | STALL | DONE |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO    | R/W  |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0     | 0    |

**DONE** Indicates that encoding operation is done.

**STALL** The encoded file size exceeds the limit such that the JPEG encoder stalls.

**JPEG+0098h JPEG block count register**
**JPG\_ENC\_BLK\_CNT**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17      | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1       | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | BLK_CNT |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO      |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0       |    |

**BLK\_CNT** Block count has been encoded.

**JPEG+009ch JPEG encoder quality register**
**JPG\_ENC\_QUALITY**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17      | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1       | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | QUALITY |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W     |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 00      |    |

**QUALITY** Encode quality.

**00** Low quality (quality factor =95), 4~6 times compression ratio.

**01** Fair quality (quality factor =90) , 6~10 times compression ratio

**10** Good quality (quality factor =75), 10~15 times compression ratio

**11** High quality (quality factor =50), 15~20 times compression ratio

**JPEG+00a0h JPEG encoder base address register**
**JPG\_ENC\_DEST\_A  
DDR**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17             | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | BS_ADDR[31:16] |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W            |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0              |    |

|       |                      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|----------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit   | 15                   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | <b>BS_ADDR[15:0]</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0                    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**BS\_ADDR** Base address of encoded data.

### JPEG+00a4h JPEG encoder current address register

**JPG\_ENC\_CURR\_A  
DDR**

|       |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31                     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>DMA_ADDR[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>DMA_ADDR[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**CURR\_ADDR** The current DMA address during encoding.

### JPEG+00a8h JPEG encoder STALL address register

**JPG\_ENC\_STALL\_  
ADDR**

|       |                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31                       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>STALL_ADDR[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>STALL_ADDR[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**STALL\_ADDR** This field is the upper bound of JPEG encoder's write-address. Note that the stall address has to be word-aligned. Whenever the stall address is reached, the JPEG encoder will stall and issue an interrupt to software. After that, if the software programs the JPG\_ENC\_STALL\_ADDR to another value, the JPEG encoder will resume the encoding procedure and automatically use the JPG\_ENC\_DEST\_ADDR as the new starting address. It means that before we change the value of JPG\_ENC\_STALL\_ADDR, the JPG\_ENC\_DEST\_ADDR has to be programmed to a corresponding starting address. However, if the software wants to discard the uncompleted file, it can simply reset the JPEG encoder to cancel the encode operation. Also, it is important that **the value of JPG\_ENC\_STALL\_ADDR should be larger than JPG\_ENC\_DEST\_ADDR by at least 604 bytes** to guarantee that the header of the JPEG file can be completely written into memory.

## 6.4 Image Resizer

### 6.4.1 General Description

This block provides image resizing capability. It receives image data from a block-based image source such as JPEG decoder in format of YUV color space, or a pixel-based image source such as camera in format of RGB or YUV, and performs image resizing. The illustrative diagram is shown in **Figure 42**. The resizing capability in the block is divided into two portions, coarse pass and fine pass. The first pass is coarse resizing pass and it can shrink the image by a factor of 1,

1/4, 1/16, or 1/64. The second pass is fine resizing pass and it can shrink and enlarge the image in fractional ratios. As shown in **Figure 42**, fine resizing pass is composed of horizontal and vertical resizing. Through combination of the two passes, an image can scale up or down in any ratio under some constraints. Furthermore, to enhance throughput there are bypass path for horizontal and vertical resizing when no resizing is needed. The constraint for coarse shrinking is that the size of the image after coarse shrinking is limited to a maximum value of 2047x2047. This assumption should be guaranteed by MMI. This also means that maximum allowable size of the source image is 16376x16376. Coarse shrinking is only supported for block-based image source. Therefore, the maximum size of a pixel-based source image is only 2047x2047.



**Figure 42** Overview of Image Resizer

The block diagram for block-based image sources is shown in **Figure 43**. Here the block "CS" stands for block based CS (Coarse Shrinking). Block based CS is dedicated for JPEG decoder and it is an 8x8 block-based process. Other blocks in the diagram are scan-line based process. The major application is CS, then HR and then VR. The possible applications include CS only, and HR+VR only. The red dotted lines in **Figure 43** indicate hardware handshaking between two blocks. For pixel-based image sources, coarse shrinking will be bypassed.

The base address of Image Resizer is 0x8061\_0000.



Figure 43 Block Diagram of Image Resizer for JPEG decoder

## 6.4.2 Requirements

For block-based image sources, two memory blocks are needed in the block. One is line buffer, and the other is working memory. Line buffer is used to store color components from image sources after coarse scaling. Working memory is for fine scaling. However, for pixel-based image sources only working memory is needed.

### 6.4.2.1 Memory Requirements

First, consider block-based image sources. Let us denote sampling factor for Y-component as  $(H_Y, V_Y)$ , U-component as  $(H_U, V_U)$  and V-component as  $(H_V, V_V)$ .  $H_{\max} = \max(H_Y, H_U, H_V)$ ,  $V_{\max} = \max(V_Y, V_U, V_V)$ . Then the memory requirement for line buffer is (the width of source image size after coarse shrinking)\*( $V_Y * 8 + V_U * 8 + V_V * 8$ ) bytes. For the case where image source is JPEG decoder, it is 50KB as  $(H_Y, H_U, H_V) = (1, 1, 1)$ ,  $(V_Y, V_U, V_V) = (4, 4, 2)$  and the width of source image size after coarse shrinking is 2047. If dual line buffer is desired, it becomes 100KB. The memory requirement for working memory is (the width of target image size)\*(line size of working memory)\*3 bytes. **Note that if image is scaled up then line buffer size must be at least  $(8*V_c+1)$ ;  $c=Y/U/V$ . Therefore, one more line is needed.** More memory is allowable.

Next, consider pixel-based image sources. Only working memory is needed. The memory requirement for working memory is (the width of target image size)\*(line size of working memory)\*3. More memory is allowable.

### 6.4.2.2 Image Requirements

First, consider block-based image sources. The image data from image sources are inputted in unit of color component such as Y- or U- or V-components. Every color component is composed of 8x8 pixels with 8-bit color depth per pixel. Therefore the width of an image source must be multiples of 8\*(maximum horizontal sampling factor). Similarly, the height of an image source also must be multiples of 8\*(maximum vertical sampling factor). The maximum size of target image after coarse shrinking is 2047x2047.

Next, consider pixel-based image sources. The width and height of the source image must be less than 2047, and the same applies to the target image.

## 6.4.3 Coarse Shrinking

Coarse resizing can shrink image by a factor of 1, 1/4, 1/16, or 1/64. It is dedicated for JPEG decoder. Therefore, all processes are based on blocks composed of 8x8 pixels. There are flow control between coarse shrinking and JPEG decoder. When line buffer is not enough for coarse shrinking, coarse shrinking will halt image data input from JPEG decoder until line buffer is enough. If an image has sampling factor ( $H_Y=H_U=H_V$ ) ( $V_Y=V_U=V_V$ ) and image size is desired to be scaled down by 1, 4, 16, or 64 and the YUV format is desired, then the line buffer needs to be big enough to fill in the whole image data after coarse shrinking. Coarse shrinking is only for block-based image sources.

## 6.4.4 Fine Resizing

Fine resizing is composed of horizontal resizing and vertical resizing. It has fractional resizing capability. The image input to fine resizing has a maximum size limit of 2047x2047, so does the output of fine resizing. For the sake of cost and speed, the algorithm used in fine resizing is bilinear algorithm. In horizontal resizing, enough working memory for each color component to fill in two scan-lines is needed. Of course, dual buffer or more can be used. There are some differences between working memory requirements for block- and pixel-based image sources. For block-based image sources, working memory in unit of line must be even. However, this requirement is not necessary for pixel-based image sources. See the register description for the register RESZ\_FRCFG for more detail. For pixel-based image, horizontal or vertical resizing can be triggered if necessary or disabled if unnecessary. However, if horizontal/vertical resizing is unnecessary and triggered, then horizontal/vertical resizing must be reset after resizing finishes.

## 6.4.5 Throughput

For block-based image sources, the processing time for one pixel is about 18 cycles. Therefore, if 15 frames per second are desired, and the Image Resizer is running at 52 MHz, then the maximum pixel number per frame is about 190K. Which is approximately 432x432.

For pixel-based image sources, the processing time for one pixel is about 2.25 cycles. Therefore, if 15 frames per second are desired, and the Image Resizer is running at 52 MHz, then the maximum pixel number per frame is about 1.5M. Which is approximately 1241x1241.

Since memory bandwidth requirements are different for scaling up and down, the throughput can be enhanced by adjusting the register setting of RESZ\_CFG.BWA0/BWB0. When scaling up, memory bandwidth requirements for read is higher than memory bandwidth requirements for write. However, when scaling down, memory bandwidth requirements for write is higher than memory bandwidth requirements for read. Therefore, during horizontal scale up, throughput can be enhanced by setting RESZ\_CFG.B0 with higher value than RESZ\_CFG.A0. Conversely, during horizontal scale down, throughput can be enhanced by setting RESZ\_CFG.A0 with higher value than RESZ\_CFG.B0. As for vertical scaling, during vertical scale up, throughput can be enhanced by setting RESZ\_CFG.B1 with higher value than RESZ\_CFG.A1. Conversely, during vertical scale down, throughput can be enhanced by setting RESZ\_CFG.A1 with higher value than RESZ\_CFG.B1.

## 6.4.6 Register Definitions

| REGISTER ADDRESS | REGISTER NAME                                                  | SYNONYM       |
|------------------|----------------------------------------------------------------|---------------|
| RESZ+ 0000h      | Image Resizer Control Register                                 | RESZ_CFG      |
| RESZ + 0004h     | Image Resizer Control Register                                 | RESZ_CON      |
| RESZ + 0008h     | Image Resizer Status Register                                  | RESZ_STA      |
| RESZ + 000Ch     | Image Resizer Interrupt Register                               | RESZ_INT      |
| RESZ + 0010h     | Image Resizer Source Image Size Register 1                     | RESZ_SRCSZ1   |
| RESZ + 0014h     | Image Resizer Target Image Size Register 1                     | RESZ_TARSZ1   |
| RESZ + 0018h     | Image Resizer Horizontal Ratio Register 1                      | RESZ_HRATIO1  |
| RESZ + 001Ch     | Image Resizer Vertical Ratio Register 1                        | RESZ_VRATIO1  |
| RESZ + 0020h     | Image Resizer Horizontal Residual Register 1                   | RESZ_HRES1    |
| RESZ + 0024h     | Image Resizer Vertical Residual Register 1                     | RESZ_VRES1    |
| RESZ + 0030h     | Image Resizer Block Coarse Shrinking Configuration Register    | RESZ_BLKCSCFG |
| RESZ + 0034h     | Image Resizer Y-Component Line Buffer Memory Base Address      | RESZ_YLMBASE  |
| RESZ + 0038h     | Image Resizer U-Component Line Buffer Memory Base Address      | RESZ_ULMBASE  |
| RESZ + 003Ch     | Image Resizer V-Component Line Buffer Memory Base Address      | RESZ_VLMBASE  |
| RESZ + 0040h     | Image Resizer Fine Resizing Configuration Register             | RESZ_FRCFG    |
| RESZ + 0044h     | Image Resizer Y-Component Working Memory Base Address          | RESZ_YWMBASE  |
| RESZ + 0048h     | Image Resizer U-Component Working Memory Base Address          | RESZ_UWMBASE  |
| RESZ + 004Ch     | Image Resizer V-Component Working Memory Base Address          | RESZ_VWMBASE  |
| RESZ + 0050h     | Image Resizer Y Line Buffer Size Register                      | RESZ_YLBSIZE  |
| RESZ + 0054h     | Image Resizer U Line Buffer Size Register                      | RESZ_ULBSIZE  |
| RESZ + 0058h     | Image Resizer V Line Buffer Size Register                      | RESZ_VLBSIZE  |
| RESZ + 005Ch     | Image Resizer Pixel-Based Resizing Working Memory Base Address | RESZ_PRWMBASE |
| RESZ + 0060h     | Image Resizer Source Image Size Register 2                     | RESZ_SRCSZ2   |
| RESZ + 0064h     | Image Resizer Target Image Size Register 2                     | RESZ_TARSZ2   |
| RESZ + 0068h     | Image Resizer Horizontal Ratio Register 2                      | RESZ_HRATIO2  |
| RESZ + 006Ch     | Image Resizer Vertical Ratio Register 2                        | RESZ_VRATIO2  |
| RESZ + 0070h     | Image Resizer Horizontal Residual Register 2                   | RESZ_HRES2    |
| RESZ + 0074h     | Image Resizer Vertical Residual Register 2                     | RESZ_VRES2    |

### 6.4.6.1 Image Resizer Configuration Register

| RESZ+0000h      Image Resizer Configuration Register      RESZ_CFG |             |    |    |    |             |    |    |    |             |      |      |        |             |    |    |    |
|--------------------------------------------------------------------|-------------|----|----|----|-------------|----|----|----|-------------|------|------|--------|-------------|----|----|----|
| Bit                                                                | 31          | 30 | 29 | 28 | 27          | 26 | 25 | 24 | 23          | 22   | 21   | 20     | 19          | 18 | 17 | 16 |
| Name                                                               | <b>BWB1</b> |    |    |    | <b>BWA1</b> |    |    |    | <b>BWB0</b> |      |      |        | <b>BWA0</b> |    |    |    |
| Type                                                               | R/W         |    |    |    | R/W         |    |    |    | R/W         |      |      |        | R/W         |    |    |    |
| Reset                                                              | 0000        |    |    |    | 0000        |    |    |    | 0000        |      |      |        | 0000        |    |    |    |
| Bit                                                                | 15          | 14 | 13 | 12 | 11          | 10 | 9  | 8  | 7           | 6    | 5    | 4      | 3           | 2  | 1  | 0  |
| Name                                                               |             |    |    |    |             |    |    |    | PRUN<br>2   | PSEL | PCON | PELSC1 |             |    |    |    |

|       |  |  |  |      |  |     |     |     |      |
|-------|--|--|--|------|--|-----|-----|-----|------|
| Type  |  |  |  | R/W  |  | R/W | R/W | R/W | R/W  |
| Reset |  |  |  | 0100 |  | 0   | 0   | 0   | 0000 |

The register is for global configuration of Image Resizer.

**PEL SRC1** The register field specifies which pixel-based image source is serviced.

- 0** Camera Interface (YUV444)
- 1** MPEG4 Decoder (YUV444)
- 2** PNG Decoder
- 3** GIF Decoder (RGB565)
- 4** Image Buffer in Memory (RGB565)

**Others** Reserved

**PCON** The register bit specifies if pixel-based resizing continues whenever an image finishes processing. Once continuous run for pixel-based resizing is enabled and pixel-based resizing is running, the only way to stop is to reset Image Resizer. To stop immediately, reset Image Resizer directly. If the last image is desired, set the register bit to '0' first. Then wait till image resizer is not busy again. Finally, reset Image Resizer.

- 0** Single run
- 1** Continuous run

**PSEL** The register field determines whether pixel-based image sources or block-based image sources is serviced. The register bit must be set correctly, or Resizer may not work. For instance, if block-based resizing is desired but the register bit is set to '1', then block-based resizing will not work.

- 0** Block-based image source is serviced.
- 1** Pixel-based image source is serviced.

**PRUN2** The register bit specifies if pixel-based resizing runs twice every trigger. The first run uses the first set of register settings, including source image size, target image size, horizontal and vertical ratio, horizontal and vertical remainder. The second run uses the second set of register settings. **This option is useful when LCD size and the target size of MPEG4 encoder are different. The first run can resize image with VGA size from camera such that the size of target image become QCIF for MPEG4 encoder and at the same time store it into memory. The second run is to read image with QCIF size from memory, and to resize it and finally to display the result on LCD.**

- 0** Normal mode.
- 1** Pixel-based resizing will run twice every trigger.

**PEL SRC2** The register field specifies which pixel-based image source is serviced.

- 0** Camera Interface (YUV444)
- 1** MPEG4 Decoder (YUV444)
- 2** PNG Decoder
- 3** GIF Decoder (RGB565)
- 4** Image Buffer in Memory (RGB565)

**Others** Reserved

**BWA0** Bandwidth selection for port A of memory interface 0. In block-based mode, memory interface 0 is between BLKCS and BLKHR. In pixel-based mode, memory interface 0 is between PELHR and PELVR. Each memory interface has one write port (port A) and one read port (port B). The arbitration between port A and port B of memory interface 0 is based on the setting of the register fields BWA0 and BWB0. The arbitration scheme is fair between port A and port B. However, if the register field BWA0 is set with larger value than the register field BWB0, then port A can get more bandwidth than port B.

- 0 If memory access of port A and port B take place simultaneously, then grant will be given to port B after port A gets grant once.
  - 1 If memory access of port A and port B take place simultaneously, then grant will be given to port B after port A gets grant twice.
  - 2 If memory access of port A and port B take place simultaneously, then grant will be given to port B after port A gets grant three times.
- ...

**BWB0** Bandwidth selection for port b of memory interface 0. In block-based mode, this is memory interface between BLKCS and BLKHR. In pixel-based mode, this is memory interface between PELHR and PELVR. Each memory interface has one write port (port A) and one read port (port B). The arbitration between port A and port B of memory interface 0 is based on the setting of the register fields BWA0 and BWB0. The arbitration scheme is fair between port A and port B. However, if the register field BWB0 is set to a value larger than the register field BWA0 then port B can get more bandwidth than port A.

- 0 If memory access of port A and port B take place simultaneously, then grant will be given to port A after port B gets grant once.
  - 1 If memory access of port A and port B take place simultaneously, then grant will be given to port A after port B gets grant twice.
  - 2 If memory access of port A and port B take place simultaneously, then grant will be given to port A after port B gets grant three times.
- ...

**BWA1** Bandwidth selection for port A of memory interface 1. In block-based mode, this is memory interface between BLKHR and BLKVR. In pixel-based mode, this is memory interface between PELHR and PELVR. Each memory interface has one write port (port A) and one read port (port B). The arbitration between port A and port B of memory interface 1 is based on the setting of the register fields BWA1 and BWB1. The arbitration scheme is fair between port A and port B. However, if the register field BWA1 is set larger value than the register field BWB1 then port A can get more bandwidth than port B.

- 0 If memory access of port A and port B take place simultaneously, then grant will be given to port B after port A gets grant once.
  - 1 If memory access of port A and port B take place simultaneously, then grant will be given to port B after port A gets grant twice.
  - 2 If memory access of port A and port B take place simultaneously, then grant will be given to port B after port A gets grant three times.
- ...

**BWB1** Bandwidth selection for port b of memory interface 1. In block-based mode, this is memory interface between BLKHR and BLKVR. In pixel-based mode, this is memory interface between PELHR and PELVR. Each memory interface has one write port (port A) and one read port (port B). The arbitration between port A and port B of memory interface 1 is based on the setting of the register fields BWA1 and BWB1. The arbitration scheme is fair between port A and port B. However, if the register field BWB1 is set larger value than the register field BWA1 then port B can get more bandwidth than port A.

- 0 If memory access of port A and port B take place simultaneously, then grant will be given to port A after port B gets grant once.
- 1 If memory access of port A and port B take place simultaneously, then grant will be given to port A after port B gets grant twice.

- 2 If memory access of port A and port B take place simultaneously, then grant will be given to port A after port B gets grant three times.
- ...

#### 6.4.6.2 Image Resizer Control Register

**RESZ+0004h      Image Resizer Control Register      RESZ\_CON**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22   | 21   | 20 | 19 | 18   | 17   | 16   |
|-------|----|----|----|----|----|----|----|----|----|------|------|----|----|------|------|------|
| Name  |    |    |    |    |    |    |    |    |    | PELV | PELH |    |    | BLKV | BLKH | BLKC |
| Type  |    |    |    |    |    |    |    |    |    | RRST | RRST |    |    | RRST | RRST | SRST |
| Reset |    |    |    |    |    |    |    |    |    | 0    | 0    |    |    | 0    | 0    | 0    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6    | 5    | 4  | 3  | 2    | 1    | 0    |
| Name  |    |    |    |    |    |    |    |    |    | PELV | PELH |    |    | BLKV | BLKH | BLKC |
| Type  |    |    |    |    |    |    |    |    |    | RENA | RENA |    |    | RENA | RENA | SENA |
| Reset |    |    |    |    |    |    |    |    |    | R/W  | R/W  |    |    | R/W  | R/W  | R/W  |
|       |    |    |    |    |    |    |    |    |    | 0    | 0    |    |    | 0    | 0    | 0    |

The register is for global control of Image Resizer. Note that block-based and pixel-based resizing CANNOT execute in parallel. Furthermore, software reset will NOT reset all register settings. Remember to trigger Image Resizer first before triggering image sources to Image Resizer.

- BLKCESNA** Writing ‘1’ to the register bit will cause Block Coarse Shrinking to proceed. Block Coarse Shrinking is designed to cooperate width JPEG decoder. It works on the fly. But it needs to be restarted every time before operation.
- BLKHRENA** Writing ‘1’ to the register bit will cause block-based fine horizontal resizing to proceed.
- BLKVRENA** Writing ‘1’ to the register bit will cause block-based fine vertical resizing to proceed.
- BLKCSRST** Writing ‘1’ to the register bit will force Block Coarse Shrinking to stop immediately and keep Block Coarse Shrinking in reset state. In order to have Block Coarse Shrinking goto normal state, ‘0’ needs to be written to the register bit.
- BLKHRRST** Writing ‘1’ to the register will force block-based fine horizontal resizing to stop immediately and keep block-based fine horizontal resizing in reset state. In order to have block-based fine horizontal resizing goto normal state, ‘0’ needs to be written to the register bit.
- BLKVRST** Writing ‘1’ to the register will force fine vertical resizing to stop immediately and keep block-based fine vertical resizing keep in reset state. In order to have block-based fine vertical resizing go to normal state, ‘0’ needs to be written to the register bit.
- PELHRENA** Writing ‘1’ to the register bit will cause pixel-based fine horizontal resizing to proceed. However, if horizontal resizing is not necessary, do not write ‘1’ to the register bit.
- PELVRENA** Writing ‘1’ to the register bit will cause pixel-based fine vertical resizing to proceed. However, if vertical resizing is not necessary, do not write ‘1’ to the register bit.
- PELHRRST** Writing ‘1’ to the register will cause pixel-based fine horizontal resizing to stop immediately and keep pixel-based fine horizontal resizing in reset state. In order to have pixel-based fine horizontal resizing goto normal state, ‘0’ needs to be written to the register bit.
- PELVRST** Writing ‘1’ to the register will pixel-based fine vertical resizing to stop immediately and keep pixel-based fine vertical resizing in reset state. In order to have pixel-based fine vertical resizing go to normal state, ‘0’ needs to be written to the register bit.

### 6.4.6.3 Image Resizer Status Register

**RESZ+0008h Image Resizer Status Register**
RESZ\_STA

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23          | 22                | 21                | 20 | 19 | 18                | 17                | 16                |
|-------|----|----|----|----|----|----|----|----|-------------|-------------------|-------------------|----|----|-------------------|-------------------|-------------------|
| Name  |    |    |    |    |    |    |    |    |             |                   |                   |    |    |                   |                   |                   |
| Type  |    |    |    |    |    |    |    |    |             |                   |                   |    |    |                   |                   |                   |
| Reset |    |    |    |    |    |    |    |    |             |                   |                   |    |    |                   |                   |                   |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7           | 6                 | 5                 | 4  | 3  | 2                 | 1                 | 0                 |
| Name  |    |    |    |    |    |    |    |    | P2ND<br>RUN | PELV<br>RBUS<br>Y | PELH<br>RBUS<br>Y |    |    | BLKV<br>RBUS<br>Y | BLKH<br>RBUS<br>Y | BLKC<br>SBUS<br>Y |
| Type  |    |    |    |    |    |    |    |    | RO          | RO                | RO                |    |    | RO                | RO                | RO                |
| Reset |    |    |    |    |    |    |    |    | 0           | 0                 | 0                 |    |    | 0                 | 0                 | 0                 |

The register indicates global status of Image Resizer.

**BLKCSBUSY** Block-based CS (Corase Shrinking) Busy Status

**BLKHRBUSY** Block-based HR (Horizontal Resizing) Busy Status

**BLKVRBUSY** Block-based VR (Vertical Resizing) Busy Status

**PELHRBUSY** Pixel-based HR (Horizontal Resizing) Busy Status

**PELVRBUSY** Pixel-based VR (Vertical Resizing) Busy Status

**P2NDRUN** Pixel-based 2<sup>nd</sup> running. See description for the register bit RESZ\_CFG.PRUN2.

### 6.4.6.4 Image Resizer Interrupt Register

**RESZ+000Ch Image Resizer Interrupt Register**
RESZ\_INT

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23           | 22           | 21 | 20 | 19 | 18           | 17           | 16           |
|-------|----|----|----|----|----|----|----|----|--------------|--------------|----|----|----|--------------|--------------|--------------|
| Name  |    |    |    |    |    |    |    |    |              |              |    |    |    |              |              |              |
| Type  |    |    |    |    |    |    |    |    |              |              |    |    |    |              |              |              |
| Reset |    |    |    |    |    |    |    |    |              |              |    |    |    |              |              |              |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7            | 6            | 5  | 4  | 3  | 2            | 1            | 0            |
| Name  |    |    |    |    |    |    |    |    | PELV<br>RINT | PELH<br>RINT |    |    |    | BLKV<br>RINT | BLKH<br>RINT | BLKC<br>SINT |
| Type  |    |    |    |    |    |    |    |    | RC           | RC           |    |    |    | RC           | RC           | RC           |
| Reset |    |    |    |    |    |    |    |    | 0            | 0            |    |    |    | 0            | 0            | 0            |

The register shows up the interrupt status of resizer.

**BLKCSINT** Interrupt for BLKCS (Block-based Coarse Shrink). No matter if the register bit RESZ\_BLKCSCFG.INTEN is enabled or not, the register bit will be active whenever BLKCS completes. The software polls on this register bit. The bit is cleared by a read to the register.

**BLKHRINT** Interrupt for BLKHR (Block-based Horizontal Resizing). No matter if the register bit RESZ\_FRCFG.HRINTEN is enabled or not, the register bit will be active whenever BLKHR completes. The software polls on this register bit. The bit is cleared by a read to the register.

**BLKVRINT** Interrupt for BLKVR (Block-based Vertical Resizing). No matter if the register bit RESZ\_FRCFG.VRINTEN is enabled or not, the register bit will be active whenever BLKVR completes. The software polls on this register bit. The bit is cleared by a read to the register.

**PELHRINT** Interrupt for PELHR (Pixel-based Horizontal Resizing). No matter if the register bit RESZ\_FRCFG.HRINTEN is enabled or not, the register bit will be active whenever PELHR completes. The software polls on this register bit. The bit is cleared by a read to the register.

**PELVRINT** Interrupt for PELVR (Pixel -based Vertical Resizing). No matter if the register bit RESZ\_FRCFG.VRINTEN is enabled or not, the register bit will be active whenever PELVR completes. The software polls on this register bit. The bit is cleared by a read to the register.

#### 6.4.6.5 Image Resizer Source Image Size Register 1

**RESZ+0010h      Image Resizer Source Image Size Register 1**
**RESZ\_SRCSZ1**

| Bit  | 31        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name | <b>HS</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>WS</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register specifies the size of source image after coarse shrinking process. **The maximum allowable size is 2047x2047.** Note that the width of source image must be multiples of  $8 \times H_{max}$  and the height of source image must be multiples of  $8 \times V_{max}$  when Block Coarse Shrinking is involved. Otherwise, Image Resizer will be disabled.

**WS** The register field specifies the width of source image after coarse shrink process.

- 1 The width of source image after coarse shrink process is 1.
- 2 The width of source image is 2.

...

**HS** The register field specifies the height of source image after coarse shrink process.

- 1 The height of source image after coarse shrink process is 1.
- 2 The height of source image after coarse shrink process is 2.

...

#### 6.4.6.6 Image Resizer Target Image Size Register 1

**RESZ+0014h      Image Resizer Target Image Size Register 1**
**RESZ\_TARSZ1**

| Bit  | 31        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name | <b>HT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>WT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register specifies the size of target image. **The maximum allowable size is 2047x2047.**

**WT** The register field specifies the width of target image.

- 1 The width of target image is 1.
- 2 The width of target image is 2.

...

**HT** The register field specifies the height of target image.

- 1 The height of target image is 1.
- 2 The height of target image is 2.

...

#### 6.4.6.7 Image Resizer Horizontal Ratio Register 1

**RESZ+0018h Image Resizer Horizontal Ratio Register 1** **RESZ\_HRATIO1**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                   |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RATIO [31:16]</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                  |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                    |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RATIO [15:0]</b>  |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                  |

The register specifies horizontal resizing ratio. It is obtained by  $\text{RESZ\_SRCSZ.WS} * 2^{21} / \text{RESZ\_TARSZ.WT}$ . Before resizing in pixel-based mode, it must be set.

#### 6.4.6.8 Image Resizer Vertical Ratio Register 1

**RESZ+001Ch Image Resizer Vertical Ratio Register 1** **RESZ\_VRATIO1**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                   |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RATIO [31:16]</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                  |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                    |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RATIO [15:0]</b>  |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                  |

The register specifies vertical resizing ratio. It is obtained by  $\text{RESZ\_SRCSZ.HS} * 2^{21} / \text{RESZ\_TARSZ.HT}$ . Before resizing in pixel-based mode, it must be set.

#### 6.4.6.9 Image Resizer Horizontal Residual Register 1

**RESZ+0020h Image Resizer Horizontal Residual Register 1** **RESZ\_HRES1**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RESIDUAL</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W             |

The register specifies horizontal residual. It is obtained by  $\text{RESZ\_SRCSZ.WS \% RESZ\_TARSZ.WT}$ . Before resizing in pixel-based mode, it must be set. The allowable maximum value is 2046.

#### 6.4.6.10 Image Resizer Vertical Residual Register 1

**RESZ+0024h Image Resizer Vertical Residual Register 1** **RESZ\_VRES1**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RESIDUAL</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W             |

The register specifies vertical residual. It is obtained by RESZ\_SRCSZ.HS % RESZ\_TARSZ.HT. Before resizing in pixel-based mode, it must be set. The allowable maximum value is 2046.

#### 6.4.6.11 Image Resizer Block Coarse Shrinking Configuration Register

**RESZ+0030h      Image Resizer Block Coarse Shrinking Configuration Register      RESZ\_BLKCSCFG**

| Bit   | 31        | 30 | 29        | 28 | 27        | 26 | 25        | 24 | 23        | 22 | 21        | 20 | 19 | 18 | 17 | 16           |
|-------|-----------|----|-----------|----|-----------|----|-----------|----|-----------|----|-----------|----|----|----|----|--------------|
| Name  |           |    |           |    |           |    |           |    |           |    |           |    |    |    |    | <b>INTEN</b> |
| Type  |           |    |           |    |           |    |           |    |           |    |           |    |    |    |    | R/W          |
| Reset |           |    |           |    |           |    |           |    |           |    |           |    |    |    |    | 0            |
| Bit   | 15        | 14 | 13        | 12 | 11        | 10 | 9         | 8  | 7         | 6  | 5         | 4  | 3  | 2  | 1  | 0            |
| Name  | <b>VV</b> |    | <b>HV</b> |    | <b>VU</b> |    | <b>HU</b> |    | <b>VY</b> |    | <b>HY</b> |    |    |    |    | <b>CSF</b>   |
| Type  | R/W       |    |    |    |    | R/W          |
| Reset | 00        |    | 00        |    | 00        |    | 00        |    | 00        |    | 00        |    |    |    |    | 00           |

The register is for various configuration of Block Coarse Shrinking in Image Resizer. Block Coarse Shrinking is dedicated for JPEG decoder. Therefore all processes are based on blocks composed of 8x8 pixels. **Note that all parameters must be set before writing '1' to the register bit RESZ\_CON.BLKCSENA.**

**CSF** It stands for Coarse Shrink Factor. The value specifies the scale factor in coarse shrink pass.

- 00** Image size does not change after coarse shrink pass.
- 01** Image size becomes 1/4 of original size after coarse shrink pass.
- 10** Image size becomes 1/16 of original size after coarse shrink pass.
- 11** Image size becomes 1/64 of original size after coarse shrink pass.

**HY** Horizontal sampling factor for Y-component

- 00** Horizontal sampling factor for Y-component is 1.
- 01** Horizontal sampling factor for Y-component is 2.
- 10** Horizontal sampling factor for Y-component is 4.
- 11** No Y-component.

**VY** Vertical sampling factor for Y-component

- 00** Vertical sampling factor for Y-component is 1.
- 01** Vertical sampling factor for Y-component is 2.
- 10** Vertical sampling factor for Y-component is 4.
- 11** No Y-component.

**HU** Horizontal sampling factor for U-component

- 00** Horizontal sampling factor for U-component is 1.
- 01** Horizontal sampling factor for U-component is 2.
- 10** Horizontal sampling factor for U-component is 4.
- 11** No U-component.

**VU** Vertical sampling factor for U-component

- 00** Vertical sampling factor for U-component is 1.
- 01** Vertical sampling factor for U-component is 2.
- 10** Vertical sampling factor for U-component is 4.
- 11** No U-component.

**HV** Horizontal sampling factor for V-component

|              |                                                                                                      |
|--------------|------------------------------------------------------------------------------------------------------|
| <b>00</b>    | Horizontal sampling factor for V-component is 1.                                                     |
| <b>01</b>    | Horizontal sampling factor for V-component is 2.                                                     |
| <b>10</b>    | Horizontal sampling factor for V-component is 4.                                                     |
| <b>11</b>    | No V-component.                                                                                      |
| <b>VV</b>    | Vertical sampling factor for V-component                                                             |
| <b>00</b>    | Vertical sampling factor for V-component is 1.                                                       |
| <b>01</b>    | Vertical sampling factor for V-component is 2.                                                       |
| <b>10</b>    | Vertical sampling factor for V-component is 4.                                                       |
| <b>11</b>    | No V-component.                                                                                      |
| <b>INTEN</b> | Interrupt Enable. When interrupt for BLKCS is enabled, interrupt will arise whenever BLKCS finishes. |
| <b>0</b>     | Interrupt for BLKCS is disabled.                                                                     |
| <b>1</b>     | Interrupt for BLKCS is enabled.                                                                      |

#### 6.4.6.12 Image Resizer Y-Component Line Buffer Memory Base Address Register

| Image Resizer Y-Component Line Buffer Memory Base Address Register |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------------------------------------------------------------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                                | 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                                               | YLMBASE [31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                               | R/W             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit                                                                | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name                                                               | YLMBASE [15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                               | R/W             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register specifies the base address of line buffer for Y-component. It could be byte-aligned. It is only useful in block-based mode.

#### 6.4.6.13 Image Resizer U-Component Line Buffer Memory Base Address Register

| Image Resizer U-Component Line Buffer Memory Base Address Register |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------------------------------------------------------------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                                | 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                                               | ULMBASE [31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                               | R/W             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit                                                                | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name                                                               | ULMBASE [15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                               | R/W             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register specifies the base address of line buffer for U-component. It could be byte -aligned. It is only useful in block-based mode.

#### 6.4.6.14 Image Resizer V-Component Line Buffer Memory Base Address Register

| Image Resizer V-Component Line Buffer Memory Base Address Register |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------------------------------------------------------------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                                | 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                                               | VLMBASE [31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                               | R/W             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit                                                                | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name                                                               | VLMBASE [15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                               | R/W             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|      |                       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|-----------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Type | R/W                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit  | 15                    | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name | <b>VLMBASE [15:0]</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | R/W                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

The register specifies the base address of line buffer for V-component. It could be byte -aligned. It is only useful in block-based mode.

#### 6.4.6.15 Image Resizer Fine Resizing Configuration Register

**RESZ+0040h      Image Resizer Fine Resizing Configuration Register    RESZ\_FRCFG**

|       |             |    |    |    |              |              |    |    |    |              |              |    |    |    |    |             |
|-------|-------------|----|----|----|--------------|--------------|----|----|----|--------------|--------------|----|----|----|----|-------------|
| Bit   | 31          | 30 | 29 | 28 | 27           | 26           | 25 | 24 | 23 | 22           | 21           | 20 | 19 | 18 | 17 | 16          |
| Name  | <b>WMSZ</b> |    |    |    |              |              |    |    |    |              |              |    |    |    |    |             |
| Type  | R/W         |    |    |    |              |              |    |    |    |              |              |    |    |    |    |             |
| Bit   | 15          | 14 | 13 | 12 | 11           | 10           | 9  | 8  | 7  | 6            | 5            | 4  | 3  | 2  | 1  | 0           |
| Name  | <b>SEQ</b>  |    |    |    | <b>PCSF2</b> | <b>PCSF1</b> |    |    |    | <b>VRINT</b> | <b>HRINT</b> |    |    |    |    | <b>VRSS</b> |
| Type  | R/W         |    |    |    | R/W          | R/W          |    |    |    | R/W          | R/W          |    |    |    |    | R/W         |
| Reset | 0           |    |    |    | 00           | 00           |    |    |    | 0            | 0            |    |    |    |    | 0           |

The register specifies various setting of control for fine resizing, including horizontal and vertical resizing. **Note that all parameters must be set before horizontal and vertical resizing proceeds.**

**VRSS** The register bit specifies whether sub-sampling for vertical resizing is enabled. For throughput issue, vertical resizing may be simplified by sub-sampling lines vertically. The register bit is only valid in pixel-based mode.

- 0** Sub-sampling for vertical resizing is disabled.
- 1** Sub-sampling for vertical resizing is enabled.

**HRINTEN** HR (Horizontal Resizing) Interrupt Enable. When interrupt for HR is enabled, interrupt will be issued whenever HR finishes.

- 0** Interrupt for HR is disabled.
- 1** Interrupt for HR is enabled.

**VRINTEN** VR (Vertical Resizing) Interrupt Enable. When interrupt for VR is enabled, interrupt will be issued whenever VR finishes.

- 0** Interrupt for VR is disabled.
- 1** Interrupt for VR is enabled.

**PCSF1** Coarse Shrinking Factor 1 for pixel-based resizing. **Only horizontal coarse shrinking is supported for pixel-based resizing.** When the register bit RESZ\_CFG.PRUN2 is set to ‘1’, the register bit is for the first run.

- 00** No coarse shrinking.
- 01** Image width becomes 1/2 of original size after coarse shrink pass.
- 10** Image width becomes 1/4 of original size after coarse shrink pass.
- 11** Image width becomes 1/8 of original size after coarse shrink pass.

**PCSF2** Coarse Shrinking Factor 2 for pixel-based resizing. **Only horizontal coarse shrinking is supported for pixel-based resizing.** When the register bit RESZ\_CFG.PRUN2 is set to ‘1’, the register bit is for the second run.

- 00** No coarse shrinking.
- 01** Image width becomes 1/2 of original size after coarse shrink pass.
- 10** Image width becomes 1/4 of original size after coarse shrink pass.
- 11** Image width becomes 1/8 of original size after coarse shrink pass.

**SEQ** The register bit is used to force block-based horizontal resizing and vertical resizing to execute sequentially. When the bit is set to '1', even though dual buffer for working memory is used, block-based horizontal resizing will not process the next image data until block-based vertical resizing finishes current image data. The register bit is only valid in block-based mode.

**0** block-based horizontal resizing and vertical resizing can execute parallel.

**1** block-based horizontal resizing and vertical resizing will execute sequentially.

**WMSZ** It stands for Working Memory Size. The register field specifies how many lines can be filled into working memory for each color component in block-based mode. In pixel-based mode, the register specifies how many lines can be filled into working memory. If dual working memory is used, horizontal resizing and vertical resizing can execute in parallel if the register bit SEQ is not set in block-based mode. **It must be even in block-based mode.** Its **maximum allowable value is 2046 in block-based mode, and 16 in pixel-based mode.** In pixel-based mode, if the register field is set with a value more than 16, then horizontal resizing will be disabled. **Furthermore, its minimum value is 4.** Note that in block-based mode different color components are placed in different memory spaces. However, in pixel-based mode all image data are placed in one memory space pixel by pixel.

**2** Working memory for each color component in block-based mode is 2.

**4** Working memory for each color component in block-based mode is 4.

**6** Working memory for each color component in block-based mode is 6.

...

#### 6.4.6.16 Image Resizer Y-Component Working Memory Base Address Register

**RESZ+0044h** **Image Resizer Y-Component Working Memory Base Address Register** **RESZ\_YWMBASE**

|                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit             | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit             | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| YWMBASE [31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| R/W             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| YWMBASE [15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| R/W             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register specifies the base address of working memory for Y-component in block-based mode. It is only useful in block-based mode.

#### 6.4.6.17 Image Resizer U-Component Working Memory Base Address Register

**RESZ+0048h** **Image Resizer U-Component Working Memory Base Address Register** **RESZ\_UWMBASE**

|                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit             | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit             | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| UWMBASE [31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| R/W             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| UWMBASE [15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| R/W             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register specifies the base address of working memory for U-component. It could be byte-aligned. It is only useful in block-based mode.

#### 6.4.6.18 Image Resizer V-Component Working Memory Base Address Register

**RESZ+004Ch      Image Resizer V-Component Working Memory  
Base Address Register      RESZ\_VWMBASE**

|      |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31                     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | <b>VWMBASE [31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15                     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>VWMBASE [15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register specifies the base address of working memory for V-component. It could be bye-aligned. It is only useful in block-based mode.

#### 6.4.6.19 Image Resizer Y Line Buffer Size Register

**RESZ+0050h      Image Resizer Y Line Buffer Size Register      RESZ\_YLBSIZE**

|      |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>YLBZE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register specifies line buffer size for image data after coarse shrinking. **Note that if image is scaled up then line buffer size must be at least (8\*Vmax+1). One more line is needed.** It's only useful in block-based mode.

**YLSZ** It stands for Y-component Line Buffer Size. The register field specifies how many lines of Y-component can be filled into line buffer. Line buffer size for U- and V-component can be determined according to the sampling factor. For example, if  $(V_Y, V_U, V_V)=(4,4,2)$  and line buffer size for Y-component is 32 lines, then the line buffer size for U-component is also 32 lines and V-component 16 lines. If line buffer has capacity for whole image after block coarse shrinking, then block coarse shrinking can be used for the application of scaling down by a factor of 2, or 4, or 8. If dual line buffer is used, block coarse shrinking and horizontal resizing can execute in parallel. The maximum allowable value is 2047.

- 1 Line buffer size for Y-component is 1 line.
- 2 Line buffer size for Y-component is 2 lines.
- 3 Line buffer size for Y-component is 3 lines.

...

#### 6.4.6.20 Image Resizer U Line Buffer Size Register

**RESZ+0054h      Image Resizer U Line Buffer Size Register      RESZ\_ULBSIZE**

|      |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>ULBZE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register specifies line buffer size for image data after coarse shrinking. Note that if image is scaled up then line buffer size must be at least  $(8 \times V_{max} + 1)$ . Therefore one more line is needed. It's only useful in block-based mode.

**ULBSZ** It stands for U-component Line Buffer SiZe. See the description of the register RESZ\_YLBSIZE.

#### 6.4.6.21 Image Resizer V Line Buffer Size Register

**RESZ+0058h Image Resizer V Line Buffer Size Register** **RESZ\_VLBSIZE**

| Bit  | 31    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15    | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | VLBZE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register specifies line buffer size for image data after coarse shrinking. Note that if image is scaled up then line buffer size must be at least  $(8 \times V_{max} + 1)$ . Therefore one more line is needed. It's only useful in block-based mode.

**VLBSZ** It stands for V-component Line Buffer SiZe. See the description of the register RESZ\_YLBSIZE.

#### 6.4.6.22 Image Resizer Pixel-Baed Resizing Working Memory Base Address Register

**RESZ+005Ch Image Resizer Pixel-Based Resizing Working Memory Base Address Register** **RESZ\_PRWMBASE**

| Bit  | 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15               | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | PRWMBASE [31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15               | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | PRWMBASE [15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register specifies the base address of working memory in pixel-based resizing mode. It must be byte-aligned.

#### 6.4.6.23 Image Resizer Source Image Size Register 2

**RESZ+0060h Image Resizer Source Image Size Register 2** **RESZ\_SRCSZ2**

| Bit  | 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | HS  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | WS  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register specifies the size of source image after coarse shrink process. The maximum allowable size is 2047x2047.

Note that the width of source image must be multiples of  $8 \times H_{max}$  and the height of source image must be multiples of  $8 \times V_{max}$  when Block Coarse Shrinking is involved. Otherwise, Image Resizer will be disabled.

**WS** The register field specifies the width of source image after coarse shrink process.

- 1 The width of source image after coarse shrink process is 1.
- 2 The width of source image is 2.

...  
**HS** The register field specifies the height of source image after coarse shrink process.

- 1 The height of source image after coarse shrink process is 1.
  - 2 The height of source image after coarse shrink process is 2.
- ...

#### 6.4.6.24 Image Resizer Target Image Size Register 2

**RESZ+0064h Image Resizer Target Image Size Register 2** **RESZ\_TARSZ2**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16        |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>HT</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W       |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0         |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>WT</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W       |

The register specifies the size of target image. **The maximum allowable size is 2047x2047.**

**WT** The register field specifies the width of target image.

- 1 The width of target image is 1.
  - 2 The width of target image is 2.
- ...

**HT** The register field specifies the height of target image.

- 1 The height of target image is 1.
  - 2 The height of target image is 2.
- ...

#### 6.4.6.25 Image Resizer Horizontal Ratio Register 2

**RESZ+0068h Image Resizer Horizontal Ratio Register 2** **RESZ\_HRATIO2**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                   |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RATIO [31:16]</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                  |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                    |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RATIO [15:0]</b>  |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                  |

The register specifies horizontal resizing ratio. It is obtained by RESZ\_SRCSZ.WS \*  $2^{21}$  / RESZ\_TARSZ.WT. Before resizing in pixel-based mode, it must be set.

#### 6.4.6.26 Image Resizer Vertical Ratio Register 2

**RESZ+006Ch Image Resizer Vertical Ratio Register 2** **RESZ\_VRATIO2**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                   |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RATIO [31:16]</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                  |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                    |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RATIO [15:0]</b>  |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                  |

The register specifies vertical resizing ratio. It is obtained by  $\text{RESZ\_SRCSZ.HS} * 2^{21} / \text{RESZ\_TARSZ.HT}$ . Before resizing in pixel-based mode, it must be set.

#### 6.4.6.27 Image Resizer Horizontal Residual Register 2

**RESZ+0070h Image Resizer Horizontal Residual Register 2**
**RESZ\_HRES2**

|      |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | RESIDUAL |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register specifies horizontal residual. It is obtained by  $\text{RESZ\_SRCSZ.WS \% RESZ\_TARSZ.WT}$ . Before resizing in pixel-based mode, it must be set. The allowable maximum value is 2046.

#### 6.4.6.28 Image Resizer Vertical Residual Register 2

**RESZ+0074h Image Resizer Vertical Residual Register 2**
**RESZ\_VRES2**

|      |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | RESIDUAL |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register specifies vertical residual. It is obtained by  $\text{RESZ\_SRCSZ.HS \% RESZ\_TARSZ.HT}$ . Before resizing in pixel-based mode, it must be set. The allowable maximum value is 2046.

#### 6.4.7 Application Notes

- When Coarse Shrinking is started by writing ‘1’ to RESZ\_CSCON.ENA, some settings will be checked before Coarse Shrinking proceeds. If checking fails, Coarse Shrinking will not work. These checking includes:
  - $0 < \text{RESZ\_SRCSZ.WS} \leq 2047$
  - $0 < \text{RESZ\_SRCSZ.HS} \leq 2047$
- Determine line buffer size by taking into consideration of CSF and sampling factor. For example, if CSF=3 and  $(V_y, V_u, V_v)=(4, x, x)$  then minimum line buffer could be 4 instead of 32.
- Note that if image is scaled up, then line buffer size must be at least  $(8 * V_c + 1)$ ;  $c=Y/U/V$ . Therefore one more line is needed.
- For block-based resizing, do not assign more line buffers for one color component than others. For example,  $(V_y, V_u, V_v)=(1, 1, 1)$  and line buffers for  $(y, u, v)=(16, 8, 8)$ . Line buffers for each color component only need 8 lines in this case. However, line buffers for Y-component is 16, which is much more than other color components in this case. Assign line buffer for each color component based on vertical sampling factor. For instance, if  $(V_y, V_u, V_v)=(2, 1, 1)$  then line buffer for Y-component can be  $16n$ , U-component  $8n$ , and V-component  $8n$ . Where  $n=1, 2, 3, \dots$**

- Working memory. For block-based resizing, it must be even. For pixel-based resizing, maximum value is 16 and minimum 4. Furthermore, for block-based resizing, every color component has different memory space. However, for pixel-based resizing there is only one memory space for working memory. Keep in mind that each pixel occupies 3 bytes. Thus, minimum requirement for working memory in pixel-based resizing is (*pixel number in a line*) $\times$ 3 $\times$ 4 bytes.
- Configuration procedure for block-based image sources

```
RESZ_CFG.PSEL=0;  
RESZ_CFG.PELSRC = select source;  
RESZ_SRCSZ = source image size;  
RESZ_TARSZ = target image size;  
RESZ_BLKCSCFG = select CSF,sampling factor, interrupt enable;  
RESZ_YLBBASE = memory base for Y-component;  
RESZ_ULBBASE = memory base for U-component;  
RESZ_VLBBASE = memory base for V-component;  
RESZ_FRCFG = working memory size,interrupt enable;  
RESZ_YWMBASE = working memory base for Y-component;  
RESZ_UWMBASE = working memory base for U-component;  
RESZ_VWMBASE = working memory base for V-component;  
RESZ_YLBSIZE = line buffer size for Y-component;  
RESZ_ULBSIZE = line buffer size for U-component;  
RESZ_VLBSIZE = line buffer size for V-component;  
RESZ_CON = 0x7;  
// Then wait interrupt or polling RESZ_INT.BLKCSINT or RESZ_INT.BLKHRINT or  
// RESZ_INT.BLKVRINT
```

- Configuration procedure for pixel-based image sources

```
RESZ_CFG.PSEL=1;  
RESZ_SRCSZ = source image size;  
RESZ_TARSZ = target image size;  
RESZ_HRATIO = horizontal ratio;  
RESZ_VRATIO = vertical ratio;  
RESZ_HRES = horizontal residual;  
RESZ_VRES = vertical residual;  
RESZ_FRCFG = working memory size,interrupt enable;  
RESZ_PRWMBASE = working memory base;  
RESZ_CON = 6/2; // 6/2=HR+VR/HR  
// Then wait interrupt or polling RESZ_INT.PELHRINT or RESZ_INT.PELVRTINT
```

## 6.5 NAND FLASH interface

### 6.5.1 General description

MT6219 provides 8-bit NAND flash interface.

The NAND flash interface supports the following features:

- ECC (Hamming code) acceleration capable of one-bit error correction and two bits error detection.
- Programmable ECC block size. Support 128, 256, 512, or 1024 bytes ECC block within a page.

- Command compatible with products from different major vendors including AMD, SAMSUNG, and TOSHIBA.
- Device address space ranges up to 4Gbits.
- Only 8 bits bus width is supported.
- Word access through APB bus.
- Both half-size and full-size channel Direct Memory Access support for massive data transfer.
- Latch sensitive interrupt to indicate ready state for read, program, erase operation and error report.
- Programmable wait states, command/address setup and hold time, read enable hold time, and write enable recovery time.
- Programmable page size including 512 bytes and 2048 bytes.

The NFI core can automatically generate ECC parity bits when programming or reading the device. If the user approves the way it stores the parity bits in the spare area for each page, the AUTOECC mode can be used. Otherwise, the user can prepare the data (may contains file system information or ECC parity bits) for the spare area with another arrangement. In the former case, the core can check the parity bits when reading from the device. The ECC module features the hamming code, which is capable of correcting one bit error and detecting two bits error within one ECC block.

The block diagram of NFI is depicted in **Figure 44**.



**Figure 44** NAND flash interface block diagram

### 6.5.2 Register definition

#### NFI+0000h NAND flash access control register NFI\_ACCCON

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 | 7   | 6 | 5   | 4 | 3   | 2 | 1   | 0 |
|------|----|----|----|----|----|----|-----|---|-----|---|-----|---|-----|---|-----|---|
| Name |    |    |    |    |    |    | C2R |   | W2R |   | WH  |   | WST |   | RLT |   |
| Type |    |    |    |    |    |    | R/W |   | R/W |   | R/W |   | R/W |   | R/W |   |

|       |  |  |  |  |   |   |   |   |   |   |   |   |   |
|-------|--|--|--|--|---|---|---|---|---|---|---|---|---|
| Reset |  |  |  |  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|-------|--|--|--|--|---|---|---|---|---|---|---|---|---|

This is the timing access control register for the NAND flash interface. In order to accommodate operations for different system clock frequencies ranging from 13MHz to 52MHz, wait states and setup/hold time margin can be configured in this register.

**C2R** The field represents the minimum required time from NCEB low to NREB low.

**W2R** The field represents the minimum required time from NWEB high to NREB low. It's in unit of 2T. So the actual time ranges from 2T to 8T in step of 2T.

**WH** Write-enable hold-time.

The field specifies the hold time of NALE, NCLE, NCEB signals relative to the rising edge of NWEB. This field is associated with **WST** to expand the write cycle time, and is associated with **RLT** to expand the read cycle time.

**RLT** Read Latency Time

The field specifies how many wait states to be inserted to meet the requirement of the read access time for the device.

**00** No wait state.

**01** 1T wait state.

**10** 2T wait state.

**11** 3T wait state.

**WST** Write Wait State

The field specifies the wait states to be inserted to meet the requirement of the pulse width of the NWEB signal.

**00** No wait state.

**01** 1T wait state.

**10** 2T wait state.

**11** 3T wait state.

### NFI +0004h NFI page format control register

### NFI\_PAGEFMT

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6          | 5 | 4 | 3 | 2       | 1 | 0     |
|-------|----|----|----|----|----|----|---|---|---|------------|---|---|---|---------|---|-------|
| Name  |    |    |    |    |    |    |   |   |   | ECCBLKSIZE |   |   |   | ADRMODE |   | PSIZE |
| Type  |    |    |    |    |    |    |   |   |   | R/W        |   |   |   | R/W     |   | R/W   |
| Reset |    |    |    |    |    |    |   |   |   | 0          |   |   |   | 0       |   | 0     |

This register manages the page format of the device. It includes the page size, the associated address format, and the ECC block size.

**ECCBLKSIZE** ECC block size.

This field represents the size of one ECC block. The hardware-fuelled ECC generation provides 1, 2 or 4 blocks within a single page.

**0** ECC block size: 128 bytes.

**1** ECC block size: 256 bytes.

**2** ECC block size: 512 bytes.

**3** ECC block size: 1048 bytes.

**4~** Reserved.

**ADRMODE** Address mode. This field specifies the input address format.

**0** Normal input address mode, in which the half page identifier is not specified in the address assignment but in the command set. As in **Table 26**, A7 to A0 identifies the byte address within half a page, A12 to A9 specifies

the page address within a block, and other bits specify the block address. The mode is used mostly for the device with 512 bytes page size.

- 1** Large size input address mode, in which all address information is specified in the address assignment rather than in the command set. As in **Table 27**, A11 to A0 identifies the byte address within a page (column address). The mode is used for the device with 2048 bytes page size.

|                     | NLD7 | NLD6 | NLD5 | NLD4 | NLD3 | NLD2 | NLD1 | NLD0 |
|---------------------|------|------|------|------|------|------|------|------|
| <b>First cycle</b>  | A7   | A6   | A5   | A4   | A3   | A2   | A1   | A0   |
| <b>Second cycle</b> | A16  | A15  | A14  | A13  | A12  | A11  | A10  | A9   |

**Table 26** Address assignment of the first type (ADRMODE = 0, cycles after second one are omitted)

|                     | NLD7 | NLD6 | NLD5 | NLD4 | NLD3 | NLD2 | NLD1 | NLD0 |
|---------------------|------|------|------|------|------|------|------|------|
| <b>First cycle</b>  | A7   | A6   | A5   | A4   | A3   | A2   | A1   | A0   |
| <b>Second cycle</b> | 0    | 0    | 0    | 0    | 0    | 0    | A9   | A8   |

**Table 27** Address assignment of the second type (ADRMODE = 1, cycles after second one are omitted)

#### PSIZE Page Size.

The field specifies the size of one page for the device. Two most widely used page sizes are supported.

- 0** The page size is 528 bytes (including 512 bytes data area and 16 bytes spare area).
- 1** The page size is 2112 bytes (including 2048 bytes data area and 64 bytes spare area).
- 2~** Reserved.

#### NFI +0008h Operation control register NFI\_OPCON

| Bit   | 15 | 14 | 13 | 12         | 11         | 10 | 9 | 8          | 7         | 6 | 5          | 4          | 3 | 2 | 1          | 0          |
|-------|----|----|----|------------|------------|----|---|------------|-----------|---|------------|------------|---|---|------------|------------|
| Name  |    |    |    | <b>NOB</b> |            |    |   | <b>SRD</b> |           |   | <b>EWR</b> | <b>ERD</b> |   |   |            |            |
| Type  |    |    |    |            | <b>W/R</b> |    |   |            | <b>WO</b> |   | <b>WO</b>  | <b>WO</b>  |   |   | <b>R/W</b> | <b>R/W</b> |
| Reset |    |    |    |            |            |    |   | 0          |           |   | 0          | 0          |   |   | 0          | 0          |

This register controls the burst mode and the single mode of the data access. In burst mode, the core supposes there are one or more than one page of data to be accessed. On the contrary, in single mode, the core supposes there are only 4 or less than 4 bytes of data to be accessed.

**BRD** *Burst read mode.* Setting this field to be 1 enables the data read operation. The NFI core will issue read cycles to retrieve data from the device. The core read cycle is issued when the data FIFO is not full or the device is not in the busy state. The NFI core supports consecutive page reading. A page address counter is built in. If the reading reaches the end of the page, the device will enter the busy state to prepare data of the next page, and the NFI core will automatically pause reading and remain idle until the device returns to the ready state. The page address counter will restart to count from 0 after the device returns to the ready state and start retrieving data again. This bit can also be used to re-start DMA read transfer. If the multiple page read and DMA pause mechanism is both enabled, the NFI core may stop DMA transfer after one page is retrieved and an ECC error is captured. To re-start DMA handshaking after the ECC interrupt has been served, the user can write this bit again.

**BWR** *Burst write mode.* Setting to be 1 enables the data burst write operation for DMA operation. Actually, the NFI core will issue write cycles once if the data FIFO is not empty even without setting this flag.

**ERD** *ECC read mode.* Setting to be 1 initializes the ECC checking and correcting for the current page. The ECC checking is only valid when a full ECC block has been read.

- EWR** Setting to be 1 initializes the ECC parity generation for the current page. The ECC code generation is only valid when a full ECC block has been programmed.
- SRD** *Single read mode.* Setting to be 1 initializes the one-shot data read operation. It's mainly used for read ID and read status command, which requires no more than 4 read cycles to retrieve data from the device. The flag will be automatically cleared when the operation is completed.
- NOB** The field represents the number of bytes to be retrieved from the device in single mode, and the number of bytes per AHB transaction in both single and burst mode.
- 0** Read 4 bytes from the device.
  - 1** Read 1 byte from the device.
  - 2** Read 2 bytes from the device.
  - 3** Read 3 bytes from the device.

### NFI +000Ch Command register

### NFI\_CMD

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | CMD |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 45  |

This is the command input register. The user should write this register to issue a command. Please refer to device datasheet for the command set. The core can issue some associated commands automatically. Please check out register **NFI\_CON** for those commands.

**CMD** Command word.

### NFI +0010h Address length register

### NFI\_ADDNOB

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0        |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | ADDR_NOB |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W      |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0        |

This register represents the number of bytes corresponding to current command. The valid number of bytes ranges from 1 to 5. The address format depends on what device is to be used and what commands are to be applied. The NFI core is made transparent to these different situations except for when the user has to define the number of bytes.

The user should write the target address to the address register **NFI\_ADDR** before programming this register.

**ADDR\_NOB** Number of bytes for the address

### NFI +0014h Least significant address register

### NFI\_ADDR

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ADDR3 |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W   |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0     |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ADDR1 |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W   |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0     |

This defines the least significant 4 bytes of the address field to be applied to the device. Since the device bus width is 1 byte, the NFI core arranges the order of address data to be least significant byte first. The user should put the first address byte in the field **ADDR0**, the second byte in the field **ADDR1**, and so on.

**ADDR3** The fourth address byte.

**ADDR2** The third address byte.

**ADDR1** The second address byte.

**ADDR0** The first address byte.

### NFI +0018h Most significant address register

### NFI\_ADDRM

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0            |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>ADDR4</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W          |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0            |

This register defines the most significant byte of the address field to be applied to the device. The NFI core supports address size up to 5 bytes. Programming this register implicitly indicates that the number of address field is 5. In this case, the NFI core will automatically set the **ADDR\_NOB** to 5.

**ADDR4** The fifth address byte.

### NFI +001Ch Write data buffer

### NFI\_DATAW

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>DW3</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W        |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0          |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0          |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>DW1</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W        |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0          |

This is the write port of the data FIFO. It supports word access. The least significant byte **DW0** is to be programmed to the device first, then **DW1**, and so on.

If the data to be programmed is not word aligned, byte write access will be needed. Instead, the user should use another register **NFI\_DATAWB** for byte programming. Writing a word to **NFI\_DATAW** is equivalent to writing four bytes **DW0**, **DW1**, **DW2**, **DW3** in order to **NFI\_DATAWB**. Note that the word alignment is from the perspective of the user. The device bus is byte-wide. According to the flash's nature, the page address will wrap around once it reaches the end of the page.

**DW3** Write data byte 3.

**DW2** Write data byte 2.

**DW1** Write data byte 1.

**DW0** Write data byte 0.

### NFI +0020h Write data buffer for byte access

### NFI\_DATAWB

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>DW0</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W        |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0          |

This is the write port for the data FIFO for byte access.

**DW0** Write data byte.

### NFI +0024h Read data buffer

### NFI\_DATAR

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

|       |     |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|-------|-----|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| Name  | DR3 |    |    |    |    |    |   |   | DR2 |   |   |   |   |   |   |   |
| Type  | R/W |    |    |    |    |    |   |   | R/W |   |   |   |   |   |   |   |
| Reset | 0   |    |    |    |    |    |   |   | 0   |   |   |   |   |   |   |   |
| Bit   | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | DR1 |    |    |    |    |    |   |   | DR0 |   |   |   |   |   |   |   |
| Type  | R/W |    |    |    |    |    |   |   | R/W |   |   |   |   |   |   |   |
| Reset | 0   |    |    |    |    |    |   |   | 0   |   |   |   |   |   |   |   |

This is the read port of the data FIFO. It supports word access. The least significant byte **DR0** is the first byte read from the device, then **DR1**, and so on.

**DR3** Read data byte 3.

**DR2** Read data byte 2.

**DR1** Read data byte 1.

**DR0** Read data byte 0.

#### NFI +002Ch NFI status

#### NFI\_PSTA

|       |    |    |    |    |    |    |   |             |   |   |   |   |               |               |             |            |
|-------|----|----|----|----|----|----|---|-------------|---|---|---|---|---------------|---------------|-------------|------------|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8           | 7 | 6 | 5 | 4 | 3             | 2             | 1           | 0          |
| Name  |    |    |    |    |    |    |   | <b>BUSY</b> |   |   |   |   | <b>DATA W</b> | <b>DATA R</b> | <b>ADDR</b> | <b>CMD</b> |
| Type  |    |    |    |    |    |    |   | RO          |   |   |   |   | RO            | RO            | RO          | RO         |
| Reset |    |    |    |    |    |    |   | 0*          |   |   |   |   | 0             | 0             | 0           | 0          |

This register represents the status of NRB signal and the NFI core control status including command mode, address mode, data program and read mode. The user should poll this register for the end of those operations. Those flags are read-only.

\*The value of **BUSY** bit depends on the GPIO configuration. If GPIO is configured for NAND flash application, the reset value should be 0, which represents that NAND flash is in idle status. When the NAND flash is busy, the value will be 1.

**BUSY** Latched NRB signal for the NAND flash.

**DATAW** The NFI core is in data write mode.

**DATAR** The NFI core is in data read mode.

**ADDR** The NFI core is in address mode.

**CMD** The NFI core is in command mode.

#### NFI +0030h FIFO control

#### NFI\_FIFOCON

|       |    |    |    |    |    |    |   |   |   |   |               |               |                 |                  |                 |                  |
|-------|----|----|----|----|----|----|---|---|---|---|---------------|---------------|-----------------|------------------|-----------------|------------------|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5             | 4             | 3               | 2                | 1               | 0                |
| Name  |    |    |    |    |    |    |   |   |   |   | <b>RESE T</b> | <b>FLUS H</b> | <b>WR_F ULL</b> | <b>WR_E MPTY</b> | <b>RD_F ULL</b> | <b>RD_E MPTY</b> |
| Type  |    |    |    |    |    |    |   |   |   |   | WO            | WO            | RO              | RO               | RO              | RO               |
| Reset |    |    |    |    |    |    |   |   |   |   | 0             | 0             | 0               | 1                | 0               | 1                |

The register represents the status of the data FIFO.

**RESET** Reset the stats machine and data FIFO.

**FLUSH** Flush the data FIFO.

**WR\_FULL** Data FIFO full in burst write mode.

**WR\_EMPTY** Data FIFO empty in burst write mode.

**RD\_FULL** Data FIFO full in burst read mode.

**RD\_EMPTY** Data FIFO empty in burst read mode.

**NFI +0034h NFI control**
**NFI\_CON**

| Bit   | 15 | 14 | 13 | 12 | 11                    | 10           | 9                   | 8                 | 7 | 6                   | 5                           | 4                           | 3                         | 2                         | 1                | 0                |
|-------|----|----|----|----|-----------------------|--------------|---------------------|-------------------|---|---------------------|-----------------------------|-----------------------------|---------------------------|---------------------------|------------------|------------------|
| Name  |    |    |    |    | MULTI<br>PAGE<br>_CON | READ<br>_CON | PROG<br>RAM<br>_CON | ERAS<br>E_CO<br>N |   | DMA<br>PAUS<br>E_EN | SW_P<br>ROGS<br>PARE<br>_EN | MULTI<br>PAG<br>E_RD<br>_EN | AUTO<br>ECC<br>ENC<br>_EN | AUTO<br>ECC<br>DEC<br>_EN | DMA<br>WR_E<br>N | DMA<br>RD_E<br>N |
| Type  |    |    |    |    | R/W                   | R/W          | R/W                 | R/W               |   |                     | R/W                         | R/W                         | R/W                       | R/W                       | R/W              | R/W              |
| Reset |    |    |    |    | 0                     | 0            | 0                   | 0                 |   | 0                   | 0                           | 0                           | 0                         | 0                         | 0                | 0                |

The register controls the DMA and ECC functions. For all field, Setting to be 1 represents enabled, while 0 represents disabled.

**MULTIPAGE\_CON** This bit represents that the first-cycle command for read operation (00h) can be automatically performed to read the next page automatically. Automatic ECC decoding flag **AUTOECC\_DEC\_EN** should also be enabled for multiple page access.

**READ\_CON** This bit represents that the second-cycle command for read operation (30h) can be automatically performed. This conforms to the command set for the device with more than 1Gb capacity.

**PROGRAM\_CON** This bit represents that the second-cycle command for page program operation (10h) can be automatically performed after the data for the entire page (including the spare area) has been written. It should be associated with automatic ECC encoding mode enabled.

**ERASE\_CON** The bit represents that the second-cycle command for block erase operation (D0h) can be automatically performed after the block address is latched.

**DMA\_PAUSE\_EN** This bit is represents that the DMA request from NFI core can be paused when an ECC error has been detected.

**SW\_PROGSPARE\_EN** If enabled, the NFI core allows the user to program or read the spare area. Otherwise, the spare area can be programmed or read by the core.

**MULTI\_PAGE\_RD\_EN** Multiple page burst read enable. If enabled, the burst read operation could continue through multiple pages within a block. It's also possible and more efficient to associate with DMA scheme to read a sector of data contained within the same block.

**AUTOECC\_ENC\_EN** Automatic ECC encoding enable. If enabled, the ECC parity is written automatically to the spare area right after the end of the data area. If **SW\_PROGSPARE\_EN** is set, however, this mode cannot be enabled since the core cannot access the spare area.

**AUTOECC\_DEC\_EN** Automatic ECC decoding enabled, the error checking and correcting are performed automatically on the data read from the memory and vice versa. If enabled, when the page address reaches the end of the data read of one page, additional read cycles will be issued to retrieve the ECC parity-check bits from the spare area to perform checking and correcting.

**DMA\_WR\_EN** This field is used to control the activity of DMA write transfer.

**DMA\_RD\_EN** This field is used to control the activity of DMA read transfer.

**NFI +0038h Interrupt status register**
**NFI\_INTR**

| Bit   | 15 | 14 | 13 | 12 | 11                 | 10          | 9           | 8           | 7           | 6           | 5           | 4           | 3           | 2                 | 1                 | 0                   |                        |
|-------|----|----|----|----|--------------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------------|-------------------|---------------------|------------------------|
| Name  |    |    |    |    | BUSY<br>RET<br>URN | ERR<br>COR3 | ERR<br>COR2 | ERR<br>COR1 | ERR<br>COR0 | ERR<br>DET3 | ERR<br>DET2 | ERR<br>DET1 | ERR<br>DET0 | ERAS<br>E_CO<br>N | RESE<br>T_CO<br>N | WR_C<br>OMPL<br>ETE | RD<br>COM<br>PLET<br>E |
| Type  |    |    |    |    | RC                 | RC          | RC          | RC          | RC          | RC          | RC          | RC          | RC          | RC                | RC                | RC                  |                        |
| Reset |    |    |    |    | 0                  | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0                 | 0                 | 0                   |                        |

The register indicates the status of all the interrupt sources. Read this register will clear all interrupts.

|                       |                                                                               |
|-----------------------|-------------------------------------------------------------------------------|
| <b>BUSY_RETURN</b>    | Indicates that the device state returns from busy by inspecting the R/B# pin. |
| <b>ERR_COR3</b>       | Indicates that the single bit error in ECC block 3 needs to be corrected.     |
| <b>ERR_COR2</b>       | Indicates that the single bit error in ECC block 2 needs to be corrected.     |
| <b>ERR_COR1</b>       | Indicates that the single bit error in ECC block 1 needs to be corrected.     |
| <b>ERR_COR0</b>       | Indicates that the single bit error in ECC block 0 needs to be corrected.     |
| <b>ERR_DET3</b>       | Indicates an uncorrectable error in ECC block 3.                              |
| <b>ERR_DET2</b>       | Indicates an uncorrectable error in ECC block 2.                              |
| <b>ERR_DET1</b>       | Indicates an uncorrectable error in ECC block 1.                              |
| <b>ERR_DET0</b>       | Indicates an uncorrectable error in ECC block 0.                              |
| <b>ERASE_COMPLETE</b> | Indicates that the erase operation is completed.                              |
| <b>RESET_COMPLETE</b> | Indicates that the reset operation is completed.                              |
| <b>WR_COMPLETE</b>    | Indicates that the write operation is completed.                              |
| <b>RD_COMPLETE</b>    | Indicates that the single page read operation is completed.                   |

### NFI +003Ch Interrupt enable register

### NFI\_INTR\_EN

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6                  | 5                 | 4                 | 3                  | 2                      | 1                   | 0                     |
|-------|----|----|----|----|----|----|---|---|---|--------------------|-------------------|-------------------|--------------------|------------------------|---------------------|-----------------------|
| Name  |    |    |    |    |    |    |   |   |   | <b>BUSY_RET_EN</b> | <b>ERR_COR_EN</b> | <b>ERR_DET_EN</b> | <b>ERAS_E_CO_N</b> | <b>RESET_CO_MPLE_N</b> | <b>WR_COMPL_E_N</b> | <b>RD_COMPLETE_EN</b> |
| Type  |    |    |    |    |    |    |   |   |   | R/W                | R/W               | R/W               | R/W                | R/W                    | R/W                 | R/W                   |
| Reset |    |    |    |    |    |    |   |   |   | 0                  | 0                 | 0                 | 0                  | 0                      | 0                   | 0                     |

This register controls the activity for the interrupt sources.

|                          |                                                    |
|--------------------------|----------------------------------------------------|
| <b>BUSY_RETURN_EN</b>    | The busy return interrupt enable.                  |
| <b>ERR_COR_EN</b>        | The error correction interrupt enable.             |
| <b>ERR_DET_EN</b>        | The error detection interrupt enable.              |
| <b>ERASE_COMPLETE_EN</b> | The erase completion interrupt enable.             |
| <b>RESET_COMPLETE_EN</b> | The reset completion interrupt enable.             |
| <b>WR_COMPLETE_EN</b>    | The single page write completion interrupt enable. |
| <b>RD_COMPLETE_EN</b>    | The single page read completion interrupt enable.  |

### NFI+0040h Page counter

### NFI\_PAGECNTR

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3           | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-------------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | <b>CNTR</b> |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | RO          |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0           |   |   |   |

This register represents the number of pages which have been retrieved from the NAND flash. The number is cleared when a new command is issued, incremented by 1 when the end of a page is encountered. To facilitate multiple page read with automatic ECC check and DMA enabled, this register is useful to address the error page that ECC check has detected.

**CNTR** The number of pages that have been retrieved. The field is read-only.

**NFI +0050h ECC block 0 parity error detect syndrome address**
**NFI\_SYM0\_ADDR**  
 R

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-----|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | SYM |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | RO  |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0   |   |   |   |

This register identifies the address within ECC block 0 that a single bit error has been detected.

**SYM** The byte address of the error-correctable bit.

**NFI +0054h ECC block 1 parity error detect syndrome address**
**NFI\_SYM1\_ADDR**  
 R

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-----|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | SYM |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | RO  |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0   |   |   |   |

This register identifies the address within ECC block 1 that a single bit error has been detected.

**SYM** The byte address of the error-correctable bit.

**NFI +0058h ECC block 2 parity error detect syndrome address**
**NFI\_SYM2\_ADDR**  
 R

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-----|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | SYM |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | RO  |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0   |   |   |   |

This register identifies the address within ECC block 2 that a single bit error has been detected.

**SYM** The byte address of the error-correctable bit.

**NFI +005Ch ECC block 3 parity error detect syndrome address**
**NFI\_SYM3\_ADDR**  
 R

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-----|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | SYM |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | RO  |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0   |   |   |   |

This register identifies the address within ECC block 3 that a single bit error has been detected.

**SYM** The byte address of the error-correctable bit.

**NFI +0060h ECC block 0 parity error detect syndrome word**
**NFI\_SYM0\_DAT**

| Bit   | 31 | 30 | 29 | 28  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18 | 17 | 16 |
|-------|----|----|----|-----|----|----|----|----|----|----|----|----|-----|----|----|----|
| Name  |    |    |    | ED3 |    |    |    |    |    |    |    |    | ED2 |    |    |    |
| Type  |    |    |    |     |    |    |    |    |    |    |    |    |     | RO |    |    |
| Reset |    |    |    |     |    |    |    |    |    |    |    |    |     | 0  |    |    |
| Bit   | 15 | 14 | 13 | 12  | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3   | 2  | 1  | 0  |
| Name  |    |    |    | ED1 |    |    |    |    |    |    |    |    | ED0 |    |    |    |
| Type  |    |    |    |     |    |    |    |    |    |    |    |    |     | RO |    |    |

|       |   |   |
|-------|---|---|
| Reset | 0 | 0 |
|-------|---|---|

This register represents the syndrome word for the corrected ECC block 0. To correct the error, the user should first read **NFI\_SYMO\_ADDR** for the address of the correctable word, and then read **NFI\_SYMO\_DAT**, directly XOR the syndrome word with the data word to obtain the correct word.

#### **NFI +0064h    ECC block 1 parity error detect syndrome word                  NFI\_SYM1\_DAT**

|       |     |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |
|-------|-----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|
| Bit   | 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | ED3 |    |    |    |    |    |    |    | ED2 |    |    |    |    |    |    |    |
| Type  | RO  |    |    |    |    |    |    |    | RO  |    |    |    |    |    |    |    |
| Reset | 0   |    |    |    |    |    |    |    | 0   |    |    |    |    |    |    |    |
| Bit   | 15  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | ED1 |    |    |    |    |    |    |    | ED0 |    |    |    |    |    |    |    |
| Type  | RO  |    |    |    |    |    |    |    | RO  |    |    |    |    |    |    |    |
| Reset | 0   |    |    |    |    |    |    |    | 0   |    |    |    |    |    |    |    |

This register represents the syndrome word for the corrected ECC block 0. To correct the error, the user should first read **NFI\_SYM1\_ADDR** for the address of the correctable word, and then read **NFI\_SYM1\_DAT**, directly XOR the syndrome word with the data word to obtain the correct word.

#### **NFI +0068h    ECC block 2 parity error detect syndrome word                  NFI\_SYM2\_DAT**

|       |     |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |
|-------|-----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|
| Bit   | 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | ED3 |    |    |    |    |    |    |    | ED2 |    |    |    |    |    |    |    |
| Type  | RO  |    |    |    |    |    |    |    | RO  |    |    |    |    |    |    |    |
| Reset | 0   |    |    |    |    |    |    |    | 0   |    |    |    |    |    |    |    |
| Bit   | 15  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | ED1 |    |    |    |    |    |    |    | ED0 |    |    |    |    |    |    |    |
| Type  | RO  |    |    |    |    |    |    |    | RO  |    |    |    |    |    |    |    |
| Reset | 0   |    |    |    |    |    |    |    | 0   |    |    |    |    |    |    |    |

This register represents the syndrome word for the corrected ECC block 0. To correct the error, the user should first read **NFI\_SYM2\_ADDR** for the address of the correctable word, and then read **NFI\_SYM2\_DAT**, directly XOR the syndrome word with the data word to obtain the correct word.

#### **NFI +006Ch    ECC block 3 parity error detect syndrome word                  NFI\_SYM3\_DAT**

|       |     |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |
|-------|-----|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|
| Bit   | 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | ED3 |    |    |    |    |    |    |    | ED2 |    |    |    |    |    |    |    |
| Type  | RO  |    |    |    |    |    |    |    | RO  |    |    |    |    |    |    |    |
| Reset | 0   |    |    |    |    |    |    |    | 0   |    |    |    |    |    |    |    |
| Bit   | 15  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | ED1 |    |    |    |    |    |    |    | ED0 |    |    |    |    |    |    |    |
| Type  | RO  |    |    |    |    |    |    |    | RO  |    |    |    |    |    |    |    |
| Reset | 0   |    |    |    |    |    |    |    | 0   |    |    |    |    |    |    |    |

This register represents the syndrome word for the corrected ECC block 0. To correct the error, the user should first read **NFI\_SYM3\_ADDR** for the address of the correctable word, and then read **NFI\_SYM3\_DAT**, directly XOR the syndrome word with the data word to obtain the correct word.\

#### **NFI +0070h    NFI ECC error detect indication register                  NFI\_ERRDET**

|     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|

|       |  |  |  |  |  |  |  |  |  |  |             |             |             |             |
|-------|--|--|--|--|--|--|--|--|--|--|-------------|-------------|-------------|-------------|
| Name  |  |  |  |  |  |  |  |  |  |  | <b>Eblk</b> | <b>Eblk</b> | <b>Eblk</b> | <b>Eblk</b> |
| Type  |  |  |  |  |  |  |  |  |  |  | 3           | 2           | 1           | 0           |
| Reset |  |  |  |  |  |  |  |  |  |  | RO          | RO          | RO          | RO          |
|       |  |  |  |  |  |  |  |  |  |  | 0           | 0           | 0           | 0           |

This register identifies the block in which an uncorrectable error has been detected.

### NFI +0080h NFI ECC parity word 0

**NFI\_PAR0**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1          | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|------------|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | <b>PAR</b> |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RO         |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0          |   |

This register represents the ECC parity for the ECC block 0. It's calculated by the NFI core and can be read by the user. It's generated when writing or reading a page.

| Register Address | Register Function     | Acronym  |
|------------------|-----------------------|----------|
| NFI +0080h       | NFI ECC parity word 0 | NFI_PAR0 |
| NFI +0084h       | NFI ECC parity word 1 | NFI_PAR1 |
| NFI +0088h       | NFI ECC parity word 2 | NFI_PAR2 |
| NFI +008Ch       | NFI ECC parity word 3 | NFI_PAR3 |
| NFI +0090h       | NFI ECC parity word 4 | NFI_PAR4 |
| NFI +0094h       | NFI ECC parity word 5 | NFI_PAR5 |
| NFI +0098h       | NFI ECC parity word 6 | NFI_PAR6 |
| NFI +009Ch       | NFI ECC parity word 7 | NFI_PAR7 |

**Table 28** NFI parity bits register table

### 6.5.3 Device programming sequence

This section lists the program sequences for the NAND flash operations.

For block erase

```
*NFI_INTEREN = 0x8;           // enable erase complete interrupt
*NFI_CMD = 0x60;              // erase first cycle command
*NFI_ADDR = address;          // block address
*NFI_ADDRNOB = 0x2;            // number of page address
while(*NFI_PSTA == 0);         // wait for the address to be programmed
*NFI_CMD = 0xD0;              // erase second cycle command
// Then, wait for the erase complete interrupt.
```

For status read

```
*NFI_CMD = 0x70;              // read status command
*NFI_OPCON = 1100h;            // Set single word read for 1 byte
while(*NFI_PSTA == 0);         // wait for the command to be programmed
status = *NFI_DATAR;           // read the single byte of status
```

For page program with automatic ECC generation and programming

```

*NFI_INTEREN = 0x2;           // enable write complete interrupt
*NFI_CON = 0xa;               // enable automatic ECC generation and DMA handshake
*NFI_CMD = 0x80;               // page program first cycle command
*NFI_ADDR = address;          // page address
*NFI_ADDRNOB = 0x3;            // number of page address
*NFI_OPCON = 0x2;              // Set burst write mode
while(*NFI_PSTA == 0);         // wait for the address to be programmed
// After DMA writing a page of bytes,
*NFI_CMD = 0x10;               // page program second cycle command
// Then, wait for the page program complete interrupt.

```

For page read with automatic ECC check and DMA

```

*NFI_INTEREN = 0x31;           // enable read complete, and ECC interrupts.
*NFI_CON = 0x5;                // enable automatic ECC checking and DMA handshake
*NFI_CMD = 0x0;                 // page read command
*NFI_ADDR = address;            // page address
*NFI_ADDRNOB = 0x3;              // number of page address
*NFI_OPCON = 0x2;                // Set burst write mode
// Wait for the page read ready interrupt.
*NFI_OPCON = 0x1;                // set burst read mode
// Then, use DMA to read a page of bytes,
// After address reaches the end of the page, the NFI core will automatically read // spare read for ECC parity and check it.
if(*NFI_INTR & 0x100) {
    err_correctable_address[0] = *NFI_SYM0_ADDR;
    err_correctable_syndrome[0] = *NFI_SYM0_DAT;
if(*NFI_INTR & 0x200) {
    err_correctable_address[1] = *NFI_SYM1_ADDR;
    err_correctable_syndrome[1] = *NFI_SYM1_DAT;
if(*NFI_INTR & 0x400) {
    err_correctable_address[2] = *NFI_SYM2_ADDR;
    err_correctable_syndrome[2] = *NFI_SYM2_DAT;
if(*NFI_INTR & 0x800) {
    err_correctable_address[3] = *NFI_SYM3_ADDR;
    err_correctable_syndrome[3] = *NFI_SYM3_DAT;
if(*NFI_INTR & 0xf0)
    err_detectable = *NFI_ERRDET;

```

## 6.5.4 Device timing control

This section illustrates the timing diagram.

The ideal timing for write access is listed as listed in **Table 29**.

| Parameter | Description | Timing specification | Timing at 13MHz<br>(WST, WH) = (0,0) | Timing at 26MHz<br>(WST, WH) = (0,0) | Timing at 52MHz<br>(WST, WH) = (1,0) |
|-----------|-------------|----------------------|--------------------------------------|--------------------------------------|--------------------------------------|
|-----------|-------------|----------------------|--------------------------------------|--------------------------------------|--------------------------------------|

|           |                                        |                 |             |            |              |
|-----------|----------------------------------------|-----------------|-------------|------------|--------------|
| $T_{WC1}$ | <i>Write cycle time</i>                | $3T + WST + WH$ | 230.8ns     | 105.4ns    | 76.9ns       |
| $T_{WC2}$ | <i>Write cycle time</i>                | $2T + WST + WH$ | 153.9ns     | 76.9ns     | 57.7ns       |
| $T_{DS}$  | <i>Write data setup time</i>           | $1T + WST$      | 76.9ns      | 38.5ns     | 38.5ns       |
| $T_{DH}$  | <i>Write data hold time</i>            | $1T + WH$       | 76.9ns      | 38.5ns     | 19.2ns       |
| $T_{WP}$  | <i>Write enable time</i>               | $1T + WST$      | 76.9ns      | 38.5ns     | 38.5ns       |
| $T_{WH}$  | <i>Write high time</i>                 | $1T + WH$       | 76.9ns      | 38.5ns     | 19.2ns       |
| $T_{CLS}$ | <i>Command latch enable setup time</i> | 1T              | 76.9ns      | 38.5ns     | 19.2ns       |
| $T_{CLH}$ | <i>Command latch enable hold time</i>  | $1T + WH$       | 76.9ns      | 38.5ns     | 19.2ns       |
| $T_{ALS}$ | <i>Address latch enable setup time</i> | 1T              | 76.9ns      | 38.5ns     | 19.2ns       |
| $T_{ALH}$ | <i>Address latch enable hold time</i>  | $1T + WH$       | 76.9ns      | 38.5ns     | 19.23ns      |
| $F_{WC}$  | <i>Write data rate</i>                 | $1 / T_{WC2}$   | 6.5Mbytes/s | 13Mbytes/s | 17.3Mbytes/s |

Table 29 Write access timing



Figure 45 Command input cycle (1 wait state).



Figure 46 Address input cycle (1 wait state)



Figure 47 Consecutive data write cycles (1 wait state, 0 hold time extension)



**Figure 48** Consecutive data write cycles (1 wait state, 1 hold time extension)

The ideal timing for read access is as listed in **Table 30**.

| Parameter | Description                            | Timing specification | Timing at 13MHz (RLT, WH) = (0,0) | Timing at 26MHz (RLT, WH) = (1,0) | Timing at 52MHz (RLT, WH) = (2,0) |
|-----------|----------------------------------------|----------------------|-----------------------------------|-----------------------------------|-----------------------------------|
| $T_{RC1}$ | <i>Read cycle time</i>                 | $3T + RLT + WH$      | 230.8ns                           | 153.8ns                           | 96.2ns                            |
| $T_{RC2}$ | <i>Read cycle time</i>                 | $2T + RLT + WH$      | 153.9ns                           | 115.4ns                           | 76.9ns                            |
| $T_{DS}$  | <i>Read data setup time</i>            | $1T + RLT$           | 76.9ns                            | 76.9ns                            | 57.7ns                            |
| $T_{DH}$  | <i>Read data hold time</i>             | $1T + WH$            | 76.9ns                            | 38.5ns                            | 19.2ns                            |
| $T_{RP}$  | <i>Read enable time</i>                | $1T + RLT$           | 76.9ns                            | 76.9ns                            | 57.7ns                            |
| $T_{RH}$  | <i>Read high time</i>                  | $1T + WH$            | 76.9ns                            | 38.5ns                            | 19.2ns                            |
| $T_{CLS}$ | <i>Command latch enable setup time</i> | $1T$                 | 76.9ns                            | 38.5ns                            | 19.2ns                            |
| $T_{CLH}$ | <i>Command latch enable hold time</i>  | $1T + WH$            | 76.9ns                            | 38.5ns                            | 19.2ns                            |
| $T_{ALS}$ | <i>Address latch enable setup time</i> | $1T$                 | 76.9ns                            | 38.5ns                            | 19.2ns                            |
| $T_{ALH}$ | <i>Address latch enable hold time</i>  | $1T + WH$            | 76.9ns                            | 38.5ns                            | 19.2ns                            |
| $F_{RC}$  | <i>Write data rate</i>                 | $1 / T_{RC2}$        | 6.5Mbytes/s                       | 8.7Mbytes/s                       | 13Mbytes/s                        |

**Table 30** Read access timing



Figure 49 Serial read cycle (1 wait state, 1 hold time extension)



Figure 50 Status read cycle (1 wait state)



Figure 51 ID and manufacturer read (0 wait state)

## 6.6 USB Device Controller

### 6.6.1 General Description

MT6219 provides a USB function interface that is in compliance with Universal Serial Bus Specification Rev 1.1. The USB device controller supports only full-speed (12Mbps) operation. The cellular phone can make use of this widely available USB interfaces to transmit/receive data with USB hosts such as PC or laptop.

The USB device controller provides 5 additional endpoints aside from the mandatory control endpoint, where among them, 3 endpoints are for IN transactions and 2 endpoints are for OUT transactions. Word, half-word, and byte access are allowed for loading and unloading the FIFO. 4 DMA channels are equipped with the controller to accelerate the data transfer. The features of the endpoints are as follows:

1. Endpoint 0: The control endpoint feature 16 bytes FIFO and accommodates maximum packet size of up to 16 bytes. DMA transfer is not supported.
2. IN endpoint 1: It features 64 bytes FIFO and accommodates maximum packet size of up to 64 bytes. DMA transfer is supported.
3. IN endpoint 2: It features 64 bytes FIFO and accommodates maximum packet size of up to 64 bytes. DMA transfer is supported.
4. IN endpoint 3: It features 16-byte FIFO and accommodates maximum packet size of 16 bytes. DMA transfer is not supported.
5. OUT endpoint 1: It features 64 bytes FIFO and accommodates maximum packet size of 64 bytes. DMA transfer is supported.
6. OUT endpoint 2: It features 64 bytes FIFO and accommodates maximum packet size of 64 bytes. DMA transfer is supported.

For each endpoint except the endpoint 0, if the packet size is smaller than half the size of the FIFO, at most 2 packets can be buffered.

This unit is highly software configurable. All endpoints except the control endpoint can be configured to be a bulk, interrupt or isochronous endpoints. Composite device is also supported. The IN endpoint 1 and the OUT endpoint 1 shares the same endpoint number but they can be used separately. The same applies for the IN endpoint 2 and the OUT endpoint 2.

The USB device uses cable-powered feature for the transceiver but only drains little current. An external resistor (nominally 1.5Kohm) is required to be placed across Vbus and D+ signal. Two additional external serial resistors might be needed to be placed on the output of D+ and D- signals to make the output impedance equivalent to 28~44Ohm.

## 6.6.2 Register Definitions

### 70000000h USB function address register

**USB\_FADDR**

| Bit   | 7          | 6 | 5 | 4 | 3            | 2 | 1 | 0 |
|-------|------------|---|---|---|--------------|---|---|---|
| Name  | <b>UPD</b> |   |   |   | <b>FADDR</b> |   |   |   |
| Type  | RO         |   |   |   | R/W          |   |   |   |
| Reset | 0          |   |   |   | 0            |   |   |   |

This is an 8-bit register that should be written with the function's 7-bit address (received through a SET\_ADDRESS description). It is then used for decoding the function address in subsequent token packets.

**UPD** Set when FADDR is written. It's cleared when the new address takes effect (at the end of the current transfer).

**FADDR** The function address of the device.

### 70000001h USB power control register

**USB\_POWER**

| Bit   | 7             | 6 | 5 | 4                | 3            | 2             | 1               | 0               |
|-------|---------------|---|---|------------------|--------------|---------------|-----------------|-----------------|
| Name  | <b>ISO_UP</b> |   |   | <b>SWRSTENAB</b> | <b>RESET</b> | <b>RESUME</b> | <b>SUSPMODE</b> | <b>SUSPENAB</b> |
| Type  | R/W           |   |   | R/W              | RO           | R/W           | RO              | R/W             |
| Reset | 0             |   |   | 0                | 0            | 0             | 0               | 0               |

**ISO\_UP** When set by the MCU, the core will wait for an SOF token from the time INPKTRDY is set before sending the packet.

**SWRSTENAB** Set by the MCU to enable the mode in which the device can only be reset by the software after detecting reset signals on the bus. In case the software is delayed by other high-priority process and cannot make it in time to read the command from the buffer before the hardware resets the device after detecting the reset signal on the bus, the command will be lost. That is why the software-reset mode is effective. When the flag is enabled, the hardware state machine cannot reset by itself, but rather can only be reset by the software. In this sense, the software and the hardware can stay synchronized on detection of the reset signal.

**RESET** The read-only bit is set when **Reset** signaling is present on the bus.

**RESUME** Set by the MCU to generate **Resume** signaling when the function is in suspend mode. The MCU should clear this bit after 10 ms (a maximum of 15 ms) to end Resume signaling.

**SUSPMODE** Set by the USB core when **Suspend** mode is entered. Cleared when the CPU reads the interrupt register, or sets the Resume bit of this register.

**SUSPENAB** Set by the MCU to enable device into **Suspend** mode when Suspend signaling is received on the bus.

### 70000002h USB IN endpoints interrupt register

**USB\_INTRIN**

| Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|---|---|---|---|---|---|---|---|
|     |   |   |   |   |   |   |   |   |

| Name  |  |  |  |  | EP3 | EP2 | EP1 | EP0 |
|-------|--|--|--|--|-----|-----|-----|-----|
| Type  |  |  |  |  | RC  | RC  | RC  | RC  |
| Reset |  |  |  |  | 0   | 0   | 0   | 0   |

This is a read-only register that indicates which of the interrupts for IN endpoints 0 to 3 are currently active. All active interrupts will be cleared when this register is read.

- EP3** IN endpoint #3 interrupt.
- EP2** IN endpoint #2 interrupt.
- EP1** IN endpoint #1 interrupt.
- EP0** IN endpoint #0 interrupt.

#### 70000004h USB OUT endpoints interrupt register USB\_INTROUT

| Bit   | 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0 |
|-------|---|---|---|---|---|-----|-----|---|
| Name  |   |   |   |   |   | EP2 | EP1 |   |
| Type  |   |   |   |   |   | RC  | RC  |   |
| Reset |   |   |   |   |   | 0   | 0   |   |

This is a read-only register that indicates which of the interrupts for OUT endpoints 1 and 2 are currently active. All active interrupts will be cleared when this register is read.

- EP2** OUT endpoint #2 interrupt.
- EP1** OUT endpoint #1 interrupt.

#### 70000006h USB general interrupt register USB\_INTRUSB

| Bit   | 7 | 6 | 5 | 4 | 3   | 2     | 1      | 0    |
|-------|---|---|---|---|-----|-------|--------|------|
| Name  |   |   |   |   | SOF | RESET | RESUME | SUSP |
| Type  |   |   |   |   | RC  | RC    | RC     | RC   |
| Reset |   |   |   |   | 0   | 0     | 0      | 0    |

This is a read-only register that indicates which USB interrupts are currently active. All active interrupts will be cleared when this register is read.

- SOF** Set at the start of each frame.
- RESET** Set when **Reset** signaling is detected on the bus.
- RESUME** Set when Resume signaling is detected on the bus while the USB core is in suspend mode.
- SUSP** Set when Suspend signaling is detected on the bus.

#### 70000007h USB IN endpoints interrupt enable register USB\_INTRINE

| Bit   | 7 | 6 | 5 | 4 | 3   | 2   | 1   | 0   |
|-------|---|---|---|---|-----|-----|-----|-----|
| Name  |   |   |   |   | EP3 | EP2 | EP1 | EP0 |
| Type  |   |   |   |   | R/W | R/W | R/W | R/W |
| Reset |   |   |   |   | 1   | 1   | 1   | 1   |

This register provides interrupt enable bits for the interrupts in USB\_INTRIN. On reset, the bits corresponding to endpoint 0 and all IN endpoints are set to 1.

- EP3** IN endpoint 3 interrupt enable.
- EP2** IN endpoint 2 interrupt enable.
- EP1** IN endpoint 1 interrupt enable.
- EP0** IN endpoint 0 interrupt enable.

**70000009h USB OUT endpoints interrupt enable register** **USB\_INTROUTE**

| Bit   | 7 | 6 | 5 | 4 | 3 | 2          | 1          | 0 |
|-------|---|---|---|---|---|------------|------------|---|
| Name  |   |   |   |   |   | <b>EP2</b> | <b>EP1</b> |   |
| Type  |   |   |   |   |   | R/W        | R/W        |   |
| Reset |   |   |   |   |   | 1          | 1          |   |

This register provides interrupt enable bits for the interrupts in USB\_INTROUT. On reset, the bits corresponding to all OUT endpoints are set to 1.

**EP2** OUT endpoint 2 interrupt enable.

**EP1** OUT endpoint 1 interrupt enable.

**7000000Bh USB general interrupt enable register** **USB\_INTRUSBE**

| Bit   | 7 | 6 | 5 | 4 | 3          | 2            | 1             | 0           |
|-------|---|---|---|---|------------|--------------|---------------|-------------|
| Name  |   |   |   |   | <b>SOF</b> | <b>RESET</b> | <b>RESUME</b> | <b>SUSP</b> |
| Type  |   |   |   |   | R/W        | R/W          | R/W           | R/W         |
| Reset |   |   |   |   | 0          | 1            | 1             | 0           |

This register provides interrupt enable bits for each of the interrupts for USB\_INTRUSBB.

**SOF** SOF interrupt enable

**RESET** Reset interrupt enable

**RESUME** Resume interrupt enable

**SUSP** Suspend interrupt enable

**7000000Ch USB frame count #1 register** **USB\_FRAME1**

| Bit   | 7 | 6 | 5 | 4 | 3           | 2 | 1 | 0 |
|-------|---|---|---|---|-------------|---|---|---|
| Name  |   |   |   |   | <b>NUML</b> |   |   |   |
| Type  |   |   |   |   | RO          |   |   |   |
| Reset |   |   |   |   | 0           |   |   |   |

This register holds the lower 8 bits of the last received frame number.

**NUML** The lower 8 bits of the frame number.

**7000000Dh USB frame count #2 register** **USB\_FRAME2**

| Bit   | 7 | 6 | 5 | 4 | 3 | 2 | 1           | 0 |
|-------|---|---|---|---|---|---|-------------|---|
| Name  |   |   |   |   |   |   | <b>NUMH</b> |   |
| Type  |   |   |   |   |   |   | RO          |   |
| Reset |   |   |   |   |   |   | 0           |   |

This register holds the upper 3 bits of the last received frame number.

**NUMH** The upper 3 bits of the frame number.

**7000000Eh USB endpoint register index** **USB\_INDEX**

| Bit   | 7 | 6 | 5 | 4 | 3 | 2 | 1            | 0 |
|-------|---|---|---|---|---|---|--------------|---|
| Name  |   |   |   |   |   |   | <b>INDEX</b> |   |
| Type  |   |   |   |   |   |   | R/W          |   |
| Reset |   |   |   |   |   |   | 0            |   |

This register determines which endpoint control/status registers are to be accessed at addresses **USB+10h** to **USB+17h**. Each IN endpoint and each OUT endpoint have their own set of control/status registers. Only one set of IN control/status and one set of OUT control/status registers appear in the memory map at any one time. Before accessing an endpoint's control/status registers, the endpoint number should be written to the **USB\_INDEX** register to ensure that the correct control/status registers appear in the memory map.

**INDEX** The index of the endpoint.

### 7000000Fh USB reset control

### USB\_RSTCTRL

| Bit   | 7            | 6 | 5 | 4 | 3 | 2 | 1              | 0 |
|-------|--------------|---|---|---|---|---|----------------|---|
| Name  | <b>SWRST</b> |   |   |   |   |   | <b>RSTCNTR</b> |   |
| Type  | R/W          |   |   |   |   |   | R/W            |   |
| Reset | 0            |   |   |   |   |   | 0              |   |

This register is used to control the reset process when the device detects the reset command issued from the host.

**SWRST** If the flag **SWRSTENAB** in the register **USB\_POWER** is set to be 1, the software enable mode is enabled, and the device can be reset by writing this flag to be 1.

**RSTCNTR** The field signifies the duration for the reset operation to take place after detecting reset signal on the bus. It is only enabled when software reset is not enabled. If the value is equal to zero, the duration is 2.5us. Otherwise, the duration is equal to this value multiplied by 341 and then added by 2.5 in unit of us. The range consequently starts from 2.5us to 5122.5 us.

### 70000011h USB control/status register for endpoint 0

### USB\_EP0\_CSR

| Bit   | 7                | 6                 | 5                | 4               | 3              | 2                | 1               | 0                |
|-------|------------------|-------------------|------------------|-----------------|----------------|------------------|-----------------|------------------|
| Name  | <b>SSETUPEND</b> | <b>SOUTPKTRDY</b> | <b>SENDSTALL</b> | <b>SETUPEND</b> | <b>DATAEND</b> | <b>SENTSTALL</b> | <b>INPKTRDY</b> | <b>OUTPKTRDY</b> |
| Type  | R/WS             | R/WS              | R/WS             | RO              | R/WS           | R/WC             | R/WS            | RO               |
| Reset | 0                | 0                 | 0                | 0               | 0              | 0                | 0               | 0                |

This register is used for all control/status of endpoint 0. This register is active when **USB\_INDEX** register is set to 0.

**SSETUPEND** The MCU writes a 1 to this bit to clear the **SETUPEND** bit. It's cleared automatically. Only active when a transaction has been started.

**SOUTPKTRDY** The MCU writes a 1 to this bit to clear the **OUTPKTRDY** bit. It's cleared automatically. Only active when an OUT transaction has been started.

**SENDSTALL** The MCU writes a 1 to this bit to terminate the current transaction. The STALL handshake will be transmitted and then this bit will be cleared automatically.

**SETUPEND** This bit will be set when a control transaction ends before the **DATAEND** bit has been set. An interrupt will be generated and FIFO flushed at this time. The bit is cleared by the MCU writing a 1 to the **SSETUPEND** bit.

**DATAEND** The MCU sets this bit:

1. When setting **INPKTRDY** for the last data packet.
2. When clearing **OUTPKTRDY** after unloading the last data packet.
3. When setting **INPKTRDY** for a zero length data packet.

It's cleared automatically

**SENTSTALL** This bit is set when a STALL handshake is transmitted. The MCU should clear this bit by writing a 0.

**INPKTRDY**

The MCU sets this bit after loading a data packet into the FIFO. It is cleared automatically when the data packet has been transmitted. An interrupt is generated when this bit is set.

**OUTPKTRDY**

This bit is set when a data packet has been received. An interrupt is generated when this bit is set. The MCU clears this bit by setting the **SOUTPKTRDY** bit.

**70000016h USB byte count register**
**USB\_EP0\_COU  
NT**

| Bit   | 7     | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------|---|---|---|---|---|---|---|
| Name  | COUNT |   |   |   |   |   |   |   |
| Type  | RO    |   |   |   |   |   |   |   |
| Reset | 0     |   |   |   |   |   |   |   |

This register indicates the number of received data bytes in the endpoint 0. The value returned is valid while **OUTPKTRDY** bit of **USB\_EP0\_CSR** register is set. This register is active when **USB\_INDEX** register is set to 0.

**COUNT** The number of received data bytes in the endpoint 0.

**70000010h USB maximum packet size register for IN endpoint 1~3**
**USB\_EP\_INMAX  
P**

| Bit   | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|------|---|---|---|---|---|---|---|
| Name  | MAXP |   |   |   |   |   |   |   |
| Type  | R/W  |   |   |   |   |   |   |   |
| Reset | 0    |   |   |   |   |   |   |   |

This register holds the maximum packet size for transactions through the currently selected IN endpoint – in units of 8 bytes. In setting the value, the programmer should note the constraints placed by the USB Specification on packet size for bulk interrupt, and isochronous transactions in full-speed operations. There is an INMAXP register for each IN endpoint except endpoint 0. The registers are active when **USB\_INDEX** register is set to 1, 2, and 3, respectively.

The value written to this register should match the *wMaxPacketSize* field of the standard endpoint descriptor for the associated endpoint. A mismatch could cause unexpected results. If a value greater than the configured IN FIFO size for the endpoint is written to the register, the value will be automatically changed to the IN FIFO size. If the value written to the register is less than, or equal to, half the IN FIFO size, two IN packets can be buffered. The configured IN FIFO size for the endpoint 1, 2, and 3, are 64 bytes, 64 bytes, and 16 bytes, respectively.

The register is reset to 0. If the register is changed after packets have been sent from the endpoint, the endpoint IN FIFO should be completely flushed after writing the new value to the register.

**MAXP** The maximum packet size in units of 8 bytes.

**70000011h USB control/status register #1 for IN endpoint 1~3**
**USB\_EP\_INCSR  
1**

| Bit   | 7                      | 6 | 5                | 4                | 3                | 2               | 1                        | 0               |
|-------|------------------------|---|------------------|------------------|------------------|-----------------|--------------------------|-----------------|
| Name  | <b>CLRDATATO<br/>G</b> |   | <b>SENTSTALL</b> | <b>SENDSTALL</b> | <b>FLUSHFIFO</b> | <b>UNDERRUN</b> | <b>FIFONOTEM<br/>PTY</b> | <b>INPKTRDY</b> |
| Type  | WO                     |   | R/WC             | R/W              | WO               | R/WC            | RO                       | R/WS            |
| Reset | 0                      |   | 0                | 0                | 0                | 0               | 0                        | 0               |

This register provides control and status bits for IN transactions through the currently selected endpoint. There is an INCSR1 register for each IN endpoint except endpoint 0. The registers are active when **USB\_INDEX** register is set to 1, 2, and 3, respectively.

**CLRDATATOG**

The MCU writes a 1 to this bit to reset the endpoint IN data toggle to 0.

**SENTSTALL**

The bit is set when a STALL handshake is transmitted. The FIFO is flushed and the **INPKTRDY** bit is cleared. The MCU should clear this bit by writing a 0 to this bit.

**SENDSTALL**

The MCU writes a 1 to this bit to issue a STALL handshake to an IN token. The MCU clears this bit to terminate the stall condition.

**FLUSHFIFO**

The MCU writes a 1 to this bit to flush the next packet to be transmitted from the endpoint IN FIFO. The FIFO pointer is reset and the **INPKTRDY** bit is cleared. If the FIFO contains two packets, **FLUSHFIFO** will need to be set twice to completely clear the FIFO.

**UNDERRUN**

In isochronous mode, this bit is set when a zero length data packet is sent after receiving an IN token with the **INPKTRDY** bit not set. In Bulk/Interrupt mode, this bit is set when a NAK is returned in response to an IN token. The MCU should clear this bit by writing a 0 to this bit.

**FIFONOTEMPTY**

This bit is set when there is at least 1 packet in the IN FIFO.

**INPKTRDY**

The MCU sets this bit after loading a data packet into the FIFO. Only active when an IN transaction has been started. It is cleared automatically when a data packet has been transmitted. An interrupt is generated (if enabled) when the bit is cleared.

**70000012h**
**USB control/status register #2 for IN endpoint 1~3**
**USB\_EP\_INCSR**
**2**

| Bit   | 7              | 6          | 5           | 4              | 3                 | 2 | 1 | 0 |
|-------|----------------|------------|-------------|----------------|-------------------|---|---|---|
| Name  | <b>AUTOSET</b> | <b>ISO</b> | <b>MODE</b> | <b>DMAENAB</b> | <b>RFCDATATOG</b> |   |   |   |
| Type  | R/W            | R/W        | R/W         | R/W            | R/W               |   |   |   |
| Reset | 0              | 0          | 0           | 0              | 0                 |   |   |   |

The register provides further control bits for IN transactions through the currently selected endpoint. There is an INCSR2 register for each IN endpoint except endpoint 0. The registers are active when **USB\_INDEX** register is set to 1, 2, and 3, respectively.

**AUTOSET**

If the MCU sets the bit, **INPKTRDY** will be automatically set when data of the maximum packet size (value in INMAXP) is loaded into the IN FIFO. If a packet of less than the maximum packet size is loaded, then **INPKTRDY** will have to be set manually. When 2 packets are in the IN FIFO then **INPKTRDY** will also be automatically set when the first packet has been sent, if the second packet is the maximum packet size.

**ISO**

The MCU sets this bit to enable the IN endpoint for isochronous transfer, and clears it to enable the IN endpoint for bulk/interrupt transfers.

**MODE**

The MCU sets this bit to enable the endpoint direction as IN, and clears it to enable the endpoint direction as OUT. It's valid only where the same endpoint FIFO is used for both IN and OUT transaction.

**DMAENAB**

The MCU sets this bit to enable the DMA request for the IN endpoint.

**RFCDATATOG**

The MCU sets this bit to force the endpoint's IN data toggle to switch after each data packet is sent regardless of whether an ACK was received. This can be used by interrupt IN endpoints which are used to communicate rate feedback for isochronous endpoints.

**70000013h**
**USB maximum packet size register for OUT endpoint 1~2**
**USB\_EP\_OUTM  
AXP**

| Bit  | 7 | 6 | 5 | 4           | 3 | 2 | 1 | 0 |
|------|---|---|---|-------------|---|---|---|---|
| Name |   |   |   | <b>MAXP</b> |   |   |   |   |
| Type |   |   |   | R/W         |   |   |   |   |

Reset

0

This register holds the maximum packet size for transactions through the currently selected OUT endpoint – in units of 8 bytes. In setting this value, the programmer should note the constraints placed by the USB specification on packet sizes for bulk, interrupt, and isochronous transactions in full speed operations. There is an OUTMAXP register for each OUT endpoint except endpoint 0. The registers are active when **USB\_INDEX** register is set to 1 and 2, respectively.

The value written to this register should match the **wMaxPacketSize** field of the standard endpoint descriptor for the associated endpoint. A mismatch could cause unexpected results. The total amount of data represented by the value written to this register must not exceed the FIFO size for the OUT endpoint, and should not exceed half the FIFO size if double buffering is required. If a value greater than the configured OUT FIFO size for the endpoint is written to the register, the value will be automatically changed to the OUT FIFO size. If the value written to the register is less than, or equal to, half the OUT FIFO size, two OUT packets can be buffered. The configured IN FIFO size for the endpoint 1 and 2 are both 64 bytes.

**MAXP** The maximum packet size in units of 8 bytes.

### 70000014h USB control/status register #1 for OUT endpoint 1~2

**USB\_EP\_OUTC  
SR1**

| Bit   | 7                      | 6                | 5                | 4                | 3                     | 2              | 1               | 0                |
|-------|------------------------|------------------|------------------|------------------|-----------------------|----------------|-----------------|------------------|
| Name  | <b>CLRDATATO<br/>G</b> | <b>SENTSTALL</b> | <b>SENDSTALL</b> | <b>FLUSHFIFO</b> | <b>DATAERRO<br/>R</b> | <b>OVERRUN</b> | <b>FIFOFULL</b> | <b>OUTPKTRDY</b> |
| Type  | WO                     | R/WC             | R/W              | WO               | RO                    | R/WC           | RO              | R/WC             |
| Reset | 0                      | 0                | 0                | 0                | 0                     | 0              | 0               | 0                |

The register provides control status bits for OUT transactions through the currently selected endpoint. The registers are active when **USB\_INDEX** register is set to 1 and 2, respectively.

**CLRDATATO** The MCU writes a 1 to this bit to reset the endpoint data toggle to 0.

**SENTSTALL** The bit is set when a STALL handshake is transmitted. The MCU should clear this bit by writing a 0.

**SENDSTALL** The MCU writes a 1 to this bit to issue a STALL handshake. The MCU clears this bit to terminate the stall condition. This bit has no effect if the OUT endpoint is in isochronous mode.

**FLUSHFIFO** The MCU writes a 1 to this bit to flush the next packet to be read from the endpoint OUT FIFO. If the FIFO contains two packets, **FLUSHFIFO** will need to be set twice to completely clear the FIFO.

**DATAERROR** The bit is set when **OUTPKTRDY** is set if the data packet has a CRC or bit-stuff error. It is cleared when **OUTPKTRDY** is cleared. This bit is only valid in isochronous mode.

**OVERRUN** The bit is set if an OUT packet cannot be loaded into the OUT FIFO. The MCU should clear the bit by writing a zero. This bit is only valid in isochronous mode.

**FIFOFULL** This bit is set when no more packets can be loaded into the OUT FIFO.

**OUTPKTRDY** The bit is set when a data packet has been received. The MCU should clear (write a 0 to) the bit when the packet has been unloaded from the OUT FIFO. An interrupt is generated when the bit is set.

### 70000015h USB control/status register #2 for OUT endpoint 1~2

**USB\_EP\_OUTC  
SR2**

| Bit   | 7                | 6          | 5              | 4              | 3 | 2 | 1 | 0 |
|-------|------------------|------------|----------------|----------------|---|---|---|---|
| Name  | <b>AUTOCLEAR</b> | <b>ISO</b> | <b>DMAENAB</b> | <b>DMAMODE</b> |   |   |   |   |
| Type  | R/W              | R/W        | R/W            | R/W            |   |   |   |   |
| Reset | 0                | 0          | 0              | 0              |   |   |   |   |

This register provides further control bits for OUT transactions through the currently selected endpoint. The registers are active when **USB\_INDEX** register is set to 1 and 2, respectively.

**AUTOCLEAR**

If the MCU sets this bit then the OUTPKTRDY bit will be automatically cleared when a packet of OUTMAXP bytes has been unloaded from the OUT FIFO. When packets of less than the maximum packet size are unloaded, OUTPKTRDY will have to be cleared manually.

**ISO**

The MCU sets this bit to enable the OUT endpoint for isochronous transfers, and clears it to enable the OUT endpoint for bulk/interrupt transfers.

**DMAENAB**

The MCU sets this bit to enable the DMA request for the OUT endpoint.

**DMAMODE**

Two modes of DMA operation are supported: DMA mode 0 in which a DMA request is generated for all received packets, together with an interrupt (if enabled); and DMA mode 1 in which a DMA request (but no interrupt) is generated for OUT packets of size OUTMAXP bytes and an interrupt (but no DMA request) is generated for OUT packets of any other size. The MCU sets the bit to select DMA mode 1 and clears this bit to select DMA mode 0.

**70000016h**
**USB OUT endpoint byte counter register LSB part for USB\_EP\_COUN endpoint 1~2 T1**

| Bit   | 7 | 6 | 5 | 4 | 3    | 2 | 1 | 0 |
|-------|---|---|---|---|------|---|---|---|
| Name  |   |   |   |   | NUML |   |   |   |
| Type  |   |   |   |   | RO   |   |   |   |
| Reset |   |   |   |   | 0    |   |   |   |

This register holds the lower 8 bits of the number of received data bytes in the packet in the FIFO associated with the currently selected OUT endpoint. The value returned is valid while OUTPKTRDY in the register **USB\_OUTCSR1** is set. The registers are active when **USB\_INDEX** register is set to 1 and 2, respectively.

**NUML** The lower 8 bits of the number of received data bytes for the OUT endpoint.

**70000017h**
**USB OUT endpoint byte counter register MSB part for USB\_EP\_COUN endpoint 1~2 T2**

| Bit   | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0 |
|-------|---|---|---|---|---|---|------|---|
| Name  |   |   |   |   |   |   | NUMH |   |
| Type  |   |   |   |   |   |   | RO   |   |
| Reset |   |   |   |   |   |   | 0    |   |

This register holds the upper 3 bits of the number of received data bytes in the packet in the FIFO associated with the currently selected OUT endpoint. The value returned is valid while OUTPKTRDY in the register **USB\_EP\_OUTCSR1** is set. The registers are active when **USB\_INDEX** register is set to 1 and 2, respectively.

**NUMH** The upper 8 bits of the number of received data bytes for the OUT endpoint.

**70000020h**
**USB endpoint 0 FIFO access register USB\_EP0\_FIFO**

| Bit  | 31 | 30 | 29 | 28  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20  | 19 | 18 | 17 | 16 |
|------|----|----|----|-----|----|----|----|----|----|----|----|-----|----|----|----|----|
| Name |    |    |    | DB3 |    |    |    |    |    |    |    | DB2 |    |    |    |    |
| Type |    |    |    | R/W |    |    |    |    |    |    |    | R/W |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12  | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4   | 3  | 2  | 1  | 0  |
| Name |    |    |    | DB1 |    |    |    |    |    |    |    | DB0 |    |    |    |    |
| Type |    |    |    | R/W |    |    |    |    |    |    |    | R/W |    |    |    |    |

This register provides MCU access to the FIFO for endpoint 0. Writing to this register loads data into the FIFO for endpoint 0. Reading from this register unloads data from the FIFO for endpoint 0.

The register provides word, half-word, and byte mode access. If word or half-word accesses are performed, the least significant byte is the first byte to load into the IN FIFO or unload from the OUT FIFO.

**DB0** The first byte to be loaded into or unloaded from the FIFO.

**DB1** The second byte to be loaded into or unloaded from the FIFO.

**DB2** The third byte to be loaded into or unloaded from the FIFO.

**DB3** The forth byte to be loaded into or unloaded from the FIFO.

### 70000024h USB endpoint 1 FIFO access register

**USB\_EP1\_FIFO**

| Bit  | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23         | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|------------|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|
| Name | <b>DB3</b> |    |    |    |    |    |    |    | <b>DB2</b> |    |    |    |    |    |    |    |
| Type | R/W        |    |    |    |    |    |    |    | R/W        |    |    |    |    |    |    |    |
| Bit  | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7          | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>DB1</b> |    |    |    |    |    |    |    | <b>DB0</b> |    |    |    |    |    |    |    |
| Type | R/W        |    |    |    |    |    |    |    | R/W        |    |    |    |    |    |    |    |

This register provides MCU access to the IN FIFO and the OUT FIFO for endpoint 1. Writing to the register loads data into the IN FIFO for endpoint 1. Reading from the register unloads data from the OUT FIFO for endpoint 1.

The register provides word, half-word, and byte mode access. If word or half-word accesses are performed, the least significant byte is the first byte to load into the IN FIFO or unload from the OUT FIFO.

**DB0** The first byte to be loaded in the IN FIFO or unloaded from the OUT FIFO.

**DB1** The second byte to be loaded in the IN FIFO or unloaded from the OUT FIFO.

**DB2** The third byte to be loaded in the IN FIFO or unloaded from the OUT FIFO.

**DB3** The forth byte to be loaded in the IN FIFO or unloaded from the OUT FIFO.

### 70000028h USB endpoint 2 FIFO access register

**USB\_EP2\_FIFO**

| Bit  | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23         | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|------------|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|
| Name | <b>DB3</b> |    |    |    |    |    |    |    | <b>DB2</b> |    |    |    |    |    |    |    |
| Type | R/W        |    |    |    |    |    |    |    | R/W        |    |    |    |    |    |    |    |
| Bit  | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7          | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>DB1</b> |    |    |    |    |    |    |    | <b>DB0</b> |    |    |    |    |    |    |    |
| Type | R/W        |    |    |    |    |    |    |    | R/W        |    |    |    |    |    |    |    |

This register provides MCU access to the IN FIFO and the OUT FIFO for endpoint 2. Writing to the register loads data into the IN FIFO for endpoint 2. Reading from the register unloads data from the OUT FIFO for endpoint 2.

The register provides word, half-word, and byte mode access. If word or half-word accesses are performed, the least significant byte is the first byte to load into the IN FIFO or unload from the OUT FIFO.

**DB0** The first byte to be loaded into the IN FIFO or unloaded from the OUT FIFO.

**DB1** The second byte to be loaded into the IN FIFO or unloaded from the OUT FIFO.

**DB2** The third byte to be loaded into the IN FIFO or unloaded from the OUT FIFO.

**DB3** The forth byte to be loaded into the IN FIFO or unloaded from the OUT FIFO.

### 7000002Ch USB endpoint 3 FIFO access register

**USB\_EP3\_FIFO**

| Bit  | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23         | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|------------|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|
| Name | <b>DB3</b> |    |    |    |    |    |    |    | <b>DB2</b> |    |    |    |    |    |    |    |
| Type | R/W        |    |    |    |    |    |    |    | R/W        |    |    |    |    |    |    |    |

| Bit  | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|-----|----|----|----|----|----|---|-----|---|---|---|---|---|---|---|---|
| Name | DB1 |    |    |    |    |    |   | DB0 |   |   |   |   |   |   |   |   |
| Type | R/W |    |    |    |    |    |   | R/W |   |   |   |   |   |   |   |   |

This register provides MCU access to the IN FIFO for endpoint 3. Writing to the register loads data into the IN FIFO for endpoint 3.

The register provides word, half-word, and byte mode access. If word or half-word accesses are performed, the least significant byte is the first byte to load into the IN FIFO or unload from the OUT FIFO.

**DB0** The first byte to be loaded into the IN FIFO.

**DB1** The second byte to be loaded into the IN FIFO.

**DB2** The third byte to be loaded into the IN FIFO.

**DB3** The forth byte to be loaded into the IN FIFO.

## 70000230h USB enable and test mode control

USB\_SIGNALGO  
OD

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|---|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    |   |   |   |   |   | SDI | DPI | DMI | TM  | EN  |
| Type  |    |    |    |    |    |    |   |   |   |   |   | RO  | RO  | RO  | R/W | R/W |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 0   | 0   | 0   | 0   | 0   |

This register controls the input signals and generates output signals in test mode.

**SDI** Monitored value on differential signal driven by the transceiver

**DPI** Monitored value on single-ended signal DP

**DMI** Monitored value on single-ended signal DM

**TM** Test mode enable

**EN** Input signals enable

## 6.7 Memory Stick and SD Memory Card Controller

### 6.7.1 Introduction

The controller fully supports the Memory Stick bus protocol as defined in Format Specification version 2.0 of Memory Stick Standard (Memory Stick PRO) and the SD Memory Card bus protocol as defined in SD Memory Card Specification Part 1 Physical Layer Specification version 1.0 as well as the MultiMediaCard (MMC) bus protocol as defined in MMC system specification version 2.2. Since SD Memory Card bus protocol is backward compatible to MMC bus protocol, the controller is capable of working well as the host on MMC bus under control of proper firmware. However, the controller can only be configured as either the host of Memory Stick or the host of SD/MMC Memory Card at one time. Hereafter, the controller is also abbreviated as MS/SD controller. The following are the main features of the controller.

- Interface with MCU by APB bus
- 16/32-bit access on APB bus
- 16/32-bit access for control registers
- 32-bit access for FIFO
- Shared pins for Memory Stick and SD/MMC Memory Card

- Built-in 32 bytes FIFO buffers for transmit and receive, FIFO is shared for transmit and receive
- Built-in CRC circuit
- CRC generation can be disabled
- DMA supported
- Interrupt capabilities
- Automatic command execution capability when an interrupt from Memory Stick
- Data rate up to 26 Mbps in serial mode, 26x4 Mbps in parallel model, the module is targeted at 26 MHz operating clock
- Serial clock rate on MS/SD/MMC bus is programmable
- Card detection capabilities
- Controllability of power for memory card
- Not support SPI mode for MS/SD/MMC Memory Card
- Not support multiple SD Memory Cards

## 6.7.2 Overview

### 6.7.2.1 Pin Assignment

Since the controller can only be configured as either the host of Memory Stick or the host of SD/MMC Memory Card at one time, pins for Memory Stick and SD/MMC Memory Card are shared in order to save pin counts. The following lists pins required for Memory Stick and SD/MMC Memory Card. **Table 31** shows how they are shared. In **Table 31**, all I/O pads have embedded both pull up and pull down resistor because they are shared by both the Memory Stick and SD/MMC Memory Card. Pins 2,4,5,8 are only useful for SD/MMC Memory Card. Pull down resistor for these pins can be used for power saving. All embedded pull-up and pull-down resistors can be disabled by programming the corresponding control registers if optimal pull-up or pull-down resistors are required on the system board. The pin VDDPD is used for power saving. Power for Memory Stick or SD/MMC Memory Card can be shut down by programming the corresponding control register. The pin WP (Write Protection) is only valid when the controller is configured for SD/MMC Memory Card. It is used to detect the status of Write Protection Switch on SD/MMC Memory Card.

| No. | Name     | Type   | MMC  | SD      | MS   | MSPRO | Description                   |
|-----|----------|--------|------|---------|------|-------|-------------------------------|
| 1   | SD_CLK   | O      | CLK  | CLK     | SCLK | SCLK  | Clock                         |
| 2   | SD_DAT3  | I/O/PP |      | CD/DAT3 |      | DAT3  | Data Line [Bit 3]             |
| 3   | SD_DAT0  | I/O/PP | DAT0 | DAT0    | SDIO | DAT0  | Data Line [Bit 0]             |
| 4   | SD_DAT1  | I/O/PP |      | DAT1    |      | DAT1  | Data Line [Bit 1]             |
| 5   | SD_DAT2  | I/O/PP |      | DAT2    |      | DAT2  | Data Line [Bit 2]             |
| 6   | SD_CMD   | I/O/PP | CMD  | CMD     | BS   | BS    | Command Or Bus State          |
| 7   | SD_PWRON | O      |      |         |      |       | VDD ON/OFF                    |
| 8   | SD_WP    | I      |      |         |      |       | Write Protection Switch in SD |
| 9   | SD_INS   | I      | VSS2 | VSS2    | INS  | INS   | Card Detection                |

**Table 31** Sharing of pins for Memory Stick and SD/MMC Memory Card Controller

### 6.7.2.2 Card Detection

For Memory Stick, the host or connector should provide a pull up resistor on the signal INS. Therefore, the signal INS will be logic high if no Memory Stick is on line. The scenario of card detection for Memory Stick is shown in **Figure 52**. Before Memory Stick is inserted or powered on, on host side SW1 shall be closed and SW2 shall be opened for card detection. It is the default setting when the controller is powered on. Upon insertion of Memory Stick, the signal INS will have a transition from high to low. Hereafter, if Memory Stick is removed then the signal INS will return to logic high. If card insertion is intended to not be supported, SW1 shall be opened and SW2 closed always.

For SD/MMC Memory Card, detection of card insertion/removal by hardware is also supported. Because a pull down resistor with about  $470\text{ K}\Omega$  resistance which is impractical to embed in an I/O pad is needed on the signal CD/DAT3, and it has to be capable of being connected or disconnected dynamically onto the signal CD during initialization period, an additional I/O pad is needed to switch on/off the pull down resistor on the system board. The scenario of card detection for SD/MMC Memory Card is shown in **Figure 53**. Before SD/MMC Memory Card is inserted or powered on, SW1 and SW2 shall be opened for card detection on the host side. Meanwhile, pull down resistor  $R_{CD}$  on system board shall attach onto the signal CD/DAT3 by the output signal RCDEN. In addition, SW3 on the card is default to be closed. Upon insertion of SD/MMC Memory Card, the signal CD/DAT3 will have a transition from low to high. If SD/MMC Memory Card is removed then the signal CD/DAT3 will return to logic low. After the card identification process, pull down resistor  $R_{CD}$  on system board shall disconnect with the signal CD/DAT3 and SW3 on the card shall be opened for normal operation.

Since the scheme above needs a mechanical switch such as a relay on system board, it is not ideal enough. Thus, a dedicated pin “INS” is used to perform card insertion and removal for SD/MMC. The pin “INS” will connect to the pin “VSS2” of a SD/MMC connector. Then the scheme of card detection is the same as that for MS. It is shown in **Figure 52**.



**Figure 52** Card detection for Memory Stick



Figure 53 Card detection for SD/MMC Memory Card

## 6.7.3 Register Definitions

| REGISTER ADDRESS | REGISTER NAME                                       | SYNONYM      |
|------------------|-----------------------------------------------------|--------------|
| MSDC + 0000h     | MS/SD Memory Card Controller Configuration Register | MSDC_CFG     |
| MSDC + 0004h     | MS/SD Memory Card Controller Status Register        | MSDC_STA     |
| MSDC + 0008h     | MS/SD Memory Card Controller Interrupt Register     | MSDC_INT     |
| MSDC + 000Ch     | MS/SD Memory Card Controller Data Register          | MSDC_DAT     |
| MSDC + 00010h    | MS/SD Memory Card Pin Status Register               | MSDC_PS      |
| MSDC + 00014h    | MS/SD Memory Card Controller IO Control Register    | MSDC_IOCON   |
| MSDC + 0020h     | SD Memory Card Controller Configuration Register    | SDC_CFG      |
| MSDC + 0024h     | SD Memory Card Controller Command Register          | SDC_CMD      |
| MSDC + 0028h     | SD Memory Card Controller Argument Register         | SDC_ARG      |
| MSDC + 002Ch     | SD Memory Card Controller Status Register           | SDC_STA      |
| MSDC + 0030h     | SD Memory Card Controller Response Register 0       | SDC_RESP0    |
| MSDC + 0034h     | SD Memory Card Controller Response Register 1       | SDC_RESP1    |
| MSDC + 0038h     | SD Memory Card Controller Response Register 2       | SDC_RESP2    |
| MSDC + 003Ch     | SD Memory Card Controller Response Register 3       | SDC_RESP3    |
| MSDC + 0040h     | SD Memory Card Controller Command Status Register   | SDC_CMDSTA   |
| MSDC + 0044h     | SD Memory Card Controller Data Status Register      | SDC_DATSTA   |
| MSDC + 0048h     | SD Memory Card Status Register                      | SDC_CSTA     |
| MSDC + 004Ch     | SD Memory Card IRQ Mask Register 0                  | SDC_IRQMASK0 |
| MSDC + 0050h     | SD Memory Card IRQ Mask Register 1                  | SDC_IRQMASK1 |
| MSDC + 0060h     | Memory Stick Controller Configuration Register      | MSC_CFG      |
| MSDC + 0064h     | Memory Stick Controller Command Register            | MSC_CMD      |
| MSDC + 0068h     | Memory Stick Controller Auto Command Register       | MSC_ACMD     |
| MSDC + 006Ch     | Memory Stick Controller Status Register             | MSC_STA      |

Table 32 MS/SD Controller Register Map

### 6.7.3.1 Global Register Definitions

#### MSDC+0000h MS/SD Memory Card Controller Configuration Register MSDC\_CFG

|       |                |    |    |    |               |    |               |    |                    |             |                   |                    |                    |                   |                   |              |
|-------|----------------|----|----|----|---------------|----|---------------|----|--------------------|-------------|-------------------|--------------------|--------------------|-------------------|-------------------|--------------|
| Bit   | 31             | 30 | 29 | 28 | 27            | 26 | 25            | 24 | 23                 | 22          | 21                | 20                 | 19                 | 18                | 17                | 16           |
| Name  | <b>FIFOTHD</b> |    |    |    | <b>PRCFG2</b> |    | <b>PRCFG1</b> |    | <b>PRCFG0</b>      |             | <b>VDDP<br/>D</b> | <b>RCDE<br/>N</b>  | <b>DIRQ<br/>EN</b> | <b>PINEN</b>      | <b>DMAE<br/>N</b> | <b>INTEN</b> |
| Type  | R/W            |    |    |    | R/W           |    | R/W           |    | R/W                |             | R/W               | R/W                | R/W                | R/W               | R/W               | R/W          |
| Reset | 0001           |    |    |    | 01            |    | 01            |    | 01                 |             | 0                 | 0                  | 0                  | 0                 | 0                 | 0            |
| Bit   | 15             | 14 | 13 | 12 | 11            | 10 | 9             | 8  | 7                  | 6           | 5                 | 4                  | 3                  | 2                 | 1                 | 0            |
| Name  | <b>SCLKF</b>   |    |    |    |               |    |               |    | <b>SCLK<br/>ON</b> | <b>CRED</b> | <b>STDB<br/>Y</b> | <b>CLKS<br/>RC</b> | <b>RST</b>         | <b>NOCR<br/>C</b> | <b>RED</b>        | <b>MSDC</b>  |
| Type  | R/W            |    |    |    |               |    |               |    | R/W                | R/W         | R/W               | R/W                | W                  | R/W               | R/W               | R/W          |
| Reset | 00000000       |    |    |    |               |    |               |    | 0                  | 0           | 1                 | 0                  | 0                  | 0                 | 0                 | 0            |

The register is for general configuration of the MS/SD controller. Note that MSDC\_CFG[31:16] can be accessed by 16-bit APB bus access.

**MSDC** The register bit is used to configure the controller as the host of Memory Stick or as the host of SD/MMC Memory card. The default value is to configure the controller as the host of Memory Stick.

- 0** Configure the controller as the host of Memory Stick
- 1** Configure the controller as the host of SD/MMC Memory card

**RED** Rise Edge Data. The register bit is used to determine that serial data input is latched at the falling edge or the rising edge of serial clock. The default setting is at the rising edge. If serial data has worse timing, set the register bit to ‘1’. **When memory card has worse timing on return read data, set the register bit to ‘1’.**

- 0** Serial data input is latched at the rising edge of serial clock.
- 1** Serial data input is latched at the falling edge of serial clock.

**NOCRC** CRC Disable. A ‘1’ indicates that data transfer without CRC is desired. For write data block, data will be transmitted without CRC. For read data block, CRC will not be checked. It is for testing purpose.

- 0** Data transfer with CRC is desired.
- 1** Data transfer without CRC is desired.

**RST** Software Reset. Writing a ‘1’ to the register bit will cause internal synchronous reset of MS/SD controller, but does not reset register settings.

- 0** Otherwise
- 1** Reset MS/SD controller

**CLKSRC** The register bit specifies which clock is used as source clock of memory card. If MUC clock is used, the fastest clock rate for memory card is  $52/2=26\text{MHz}$ . If USB clock is used, the fastest clock rate for memory card is  $48/2=24\text{MHz}$ .

- 0** Use MCU clock as source clock of memory card.
- 1** Use USB clock as source clock of memory card.

**STDBY** Standby Mode. If the module is powered down, operating clock to the module will be stopped. At the same time, clock to card detection circuitry will also be stopped. If detection of memory card insertion and removal is desired, write ‘1’ to the register bit. If interrupt for detection of memory card insertion and removal is enabled, interrupt will take place whenever memory is inserted or removed.

- 0** Standby mode is disabled.
- 1** Standby mode is enabled.

**CRED** Card Rise Edge Data. The register bit is used to determine that serial data from memory card is output at the falling edge or the rising edge of serial clock. The default setting is at the falling edge.

- 0** Serial data is output at the falling edge of serial clock.
- 1** Serial data is output at the rising edge of serial clock.

**SCLKON** Serial Clock Always On. It is for debugging purpose.

- 0** Not to have serial clock always on.
- 1** To have serial clock always on.

**SCLKF** The register field controls clock frequency of serial clock on MS/SD bus. Denote clock frequency of MS/SD bus serial clock as  $f_{\text{slave}}$  and clock frequency of the MS/SD controller as  $f_{\text{host}}$  which is 52 or 26 MHz. Then the value of the register field is as follows. **Note that the allowable maximum frequency of  $f_{\text{slave}}$  is 26MHz.**

$$\text{00000000b} \quad f_{\text{slave}} = (1/2) * f_{\text{host}}$$

$$\text{00000001b} \quad f_{\text{slave}} = (1/4) * f_{\text{host}}$$

$$\text{00000010b} \quad f_{\text{slave}} = (1/8) * f_{\text{host}}$$

**00000011b**  $f_{\text{slave}} = (1/12) * f_{\text{host}}$

...

**00010000b**  $f_{\text{slave}} = (1/16 * 4) * f_{\text{host}}$

...

**11111111b**  $f_{\text{slave}} = (1/(255 * 4)) * f_{\text{host}}$

**INTEN** Interrupt Enable. Note that if interrupt capability is disabled then application software must poll the status of the register MSDC\_STA to check for any interrupt request.

- 0** Interrupt induced by various conditions is disabled, no matter the controller is configured as the host of either SD/MMC Memory Card or Memory Stick.
- 1** Interrupt induced by various conditions is enabled, no matter the controller is configured as the host of either SD/MMC Memory Card or Memory Stick.

**DMAEN** DMA Enable. Note that if DMA capability is disabled then application software must poll the status of the register MSDC\_STA for checking any data transfer request. If DMA is desired, the register bit must be set before command register is written.

- 0** DMA request induced by various conditions is disabled, no matter the controller is configured as the host of either SD/MMC Memory Card or Memory Stick.
- 1** DMA request induced by various conditions is enabled, no matter the controller is configured as the host of either SD/MMC Memory Card or Memory Stick.

**PINEN** Pin Interrupt Enable. The register bit is used to control if the pin for card detection is used as an interrupt source.

- 0** The pin for card detection is not used as an interrupt source.
- 1** The pin for card detection is used as an interrupt source.

**DIRQEN** Data Request Interrupt Enable. The register bit is used to control if data request is used as an interrupt source.

- 0** Data request is not used as an interrupt source.
- 1** Data request is used as an interrupt source.

**RCDEN** The register bit controls the output pin RCDEN that is used for card identification process when the controller is for SD/MMC Memory Card. Its output will control the pull down resistor on the system board to connect or disconnect with the signal CD/DAT3.

- 0** The output pin RCDEN will output logic low.
- 1** The output pin RCDEN will output logic high.

**VDDPD** The register bit controls the output pin VDDPD that is used for power saving. The output pin VDDPD will control power for memory card.

- 0** The output pin VDDPD will output logic low. The power for memory card will be turned off.
- 1** The output pin VDDPD will output logic high. The power for memory card will be turned on.

**PRCFG0<sup>1</sup>** Pull Up/Down Register Configuration for the pin INS. The default value is 0b01.

- 00** Pull up resistor and pull down resistor in the I/O pad of the pin INS are all disabled.
- 01** Pull down resistor in the I/O pad of the pin INS is enabled.
- 10** Pull up resistor in the I/O pad of the pin INS is enabled.
- 11** Use keeper of IO pad.

**PRCFG1** Pull Up/Down Register Configuration for the pin CMD/BS. The default value is 0b01.

- 00** Pull up resistor and pull down resistor in the I/O pad of the pin CMD/BS are all disabled.
- 01** Pull down resistor in the I/O pad of the pin CMD/BS is enabled.

<sup>1</sup> Pull up/down resistor for the pin INS is under control of GPIO setting instead of the register in MT6218B.

**10** Pull up resistor in the I/O pad of the pin CMD/BS is enabled.

**11** Use keeper of IO pad.

**PRCFG2** Pull Up/Down Register Configuration for the pins DAT0, DAT1, DAT2, DAT3 and WP<sup>2</sup>. The default value is 0b01.

**00** Pull up resistor and pull down resistor in the I/O pads of the pins DAT0, DAT1, DAT2, DAT3 and WP. are all disabled.

**01** Pull down resistor in the I/O pads of the pins DAT0, DAT1, DAT2, DAT3 and WP. is enabled.

**10** Pull up resistor in the I/O pads of the pins DAT0, DAT1, DAT2, DAT3 and WP. is enabled.

**11** Use keeper of IO pad.

**FIFOTHD** FIFO Threshold. The register field determines when to issue a DMA request. For write transactions, DMA requests will be asserted if the number of free entries in FIFO are larger than or equal to the value in the register field. For read transactions, DMA requests will be asserted if the number of valid entries in FIFO are larger than or equal to the value in the register field. The register field must be set according to the setting of data transfer count in DMA burst mode. If single mode for DMA transfer is used, the register field shall be set to 0b0001.

**0000** Invalid.

**0001** Threshold value is 1.

**0010** Threshold value is 2.

...

**1000** Threshold value is 8.

**others** Invalid

### MSDC+0004h MS/SD Memory Card Controller Status Register

### MSDC\_STA

| Bit   | 15   | 14          | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6       | 5 | 4 | 3   | 2   | 1  | 0  |
|-------|------|-------------|----|----|----|----|---|---|---|---------|---|---|-----|-----|----|----|
| Name  | BUSY | FIFOC<br>LR |    |    |    |    |   |   |   | FIFOCNT |   |   | INT | DRQ | BE | BF |
| Type  | R    | W           |    |    |    |    |   |   |   | RO      |   |   | RO  | RO  | RO | RO |
| Reset | 0    | -           |    |    |    |    |   |   |   | 0000    |   |   | 0   | 0   | 0  | 0  |

The register contains the status of FIFO, interrupts and data requests.

**BF** The register bit indicates if FIFO in MS/SD controller is full.

**0** FIFO in MS/SD controller is not full.

**1** FIFO in MS/SD controller is full.

**BE** The register bit indicates if FIFO in MS/SD controller is empty.

**0** FIFO in MS/SD controller is not empty.

**1** FIFO in MS/SD controller is empty.

**DRQ** The register bit indicates if any data transfer is required. While any data transfer is required, the register bit still will be active even if the register bit DIRQEN in the register MSDC\_CFG is disabled. Data transfer can be achieved by DMA channel alleviating MCU loading, or by polling the register bit to check if any data transfer is requested. While the register bit DIRQEN in the register MSDC\_CFG is disabled, the second method is used.

**0** No DMA request exists.

**1** DMA request exists.

<sup>2</sup> Pull up/down resistor for the pin WP is under control of GPIO setting instead of the register in MT6218B.

**INT** The register bit indicates if any interrupt exists. While any interrupt exists, the register bit still will be active even if the register bit INTEN in the register MSDC\_CFG is disabled. MS/SD controller can interrupt MCU by issuing interrupt request to Interrupt Controller, or software/application polls the register endlessly to check if any interrupt request exists in MS/SD controller. While the register bit INTEN in the register MSDC\_CFG is disabled, the second method is used. For read commands, it is possible that timeout error takes place. Software can read the status register to check if timeout error takes place without OS time tick support or data request is asserted. Note that the register bit will be cleared when reading the register MSDC\_INT.

- 0** No interrupt request exists.
- 1** Interrupt request exists.

**FIFOCNT** FIFO Count. The register field shows how many valid entries are in FIFO.

- 0000** There is 0 valid entry in FIFO.
- 0001** There is 1 valid entry in FIFO.
- 0010** There are 2 valid entries in FIFO.
- ...
- 1000** There are 8 valid entries in FIFO.
- others** Invalid

**FIFOCLR** Clear FIFO. Writing ‘1’ to the register bit will cause the content of FIFO clear and reset the status of FIFO controller.

- 0** No effect on FIFO.
- 1** Clear the content of FIFO clear and reset the status of FIFO controller.

**BUSY** Status of the controller. If the controller is in busy state, the register bit will be ‘1’. Otherwise ‘0’.

- 0** The controller is in busy state.
- 1** The controller is in idle state.

### MSDC+0008h MS/SD Memory Card Controller Interrupt Register

### MSDC\_INT

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7                | 6               | 5               | 4                | 3                | 2              | 1           | 0  |
|-------|----|----|----|----|----|----|---|---|------------------|-----------------|-----------------|------------------|------------------|----------------|-------------|----|
| Name  |    |    |    |    |    |    |   |   | <b>SDR1_BIRQ</b> | <b>MSIFI_RQ</b> | <b>SDMC IRQ</b> | <b>SDDA TIRQ</b> | <b>SDCM DIRQ</b> | <b>PINIR Q</b> | <b>DIRQ</b> |    |
| Type  |    |    |    |    |    |    |   |   | RC               | RC              | RC              | RC               | RC               | RC             | RC          | RC |
| Reset |    |    |    |    |    |    |   |   | 0                | 0               | 0               | 0                | 0                | 0              | 0           | 0  |

The register contains the status of interrupts. Note that the register still show status of interrupt even though interrupt is disabled, that is, the register bit INTEN of the register MSDC\_CFG is set to ‘0’. It implies that software interrupt can be implemented by polling the register bit INT of the register MSDC\_STA and this register. **However, if hardware interrupt is desired, remember to clear the register before setting the register bit INTEN of the register MSDC\_CFG to ‘1’.** Or undesired hardware interrupt arisen from previous interrupt status may take place.

**DIRQ** Data Request Interrupt. The register bit indicates if any interrupt for data request exists. Whenever data request exists and data request as an interrupt source is enabled, i.e., the register bit DIRQEN in the register MSDC\_CFG is set to ‘1’, the register bit will be active. It will be reset when reading it. For software, data requests can be recognized by polling the register bit DRQ or by data request interrupt. Data request interrupts will be generated every FIFOTHD data transfers.

- 0** No Data Request Interrupt.
- 1** Data Request Interrupt occurs.

**PINIRQ** Pin Change Interrupt. The register bit indicates if any interrupt for memory card insertion/removal exists.

Whenever memory card is inserted or removed and card detection interrupt is enabled, i.e., the register bit PINEN in the register MSDC\_CFG is set to '1', the register bit will be set to '1'. It will be reset when the register is read.

**0** Otherwise.

**1** Card is inserted or removed.

**SDCMDIRQ** SD Bus CMD Interrupt. The register bit indicates if any interrupt for SD CMD line exists. Whenever interrupt for SD CMD line exists, i.e., any bit in the register SDC\_CMDSTA is active, the register bit will be set to '1' if interrupt is enabled. It will be reset when the register is read.

**0** No SD CMD line interrupt.

**1** SD CMD line interrupt exists.

**SDDATIRQ** SD Bus DAT Interrupt. The register bit indicates if any interrupt for SD DAT line exists. Whenever interrupt for SD DAT line exists, i.e., any bit in the register SDC\_DATSTA is active, the register bit will be set to '1' if interrupt is enabled. It will be reset when the register is read.

**0** No SD DAT line interrupt.

**1** SD DAT line interrupt exists.

**SDMCIRQ** SD Memory Card Interrupt. The register bit indicates if any interrupt for SD Memory Card exists. Whenever interrupt for SD Memory Card exists, i.e., any bit in the register SDC\_CSTA is active, the register bit will be set to '1' if interrupt is enabled. It will be reset when the register is read.

**0** No SD Memory Card interrupt.

**1** SD Memory Card interrupt exists.

**MSIFIRQ** MS Bus Interface Interrupt. The register bit indicates if any interrupt for MS Bus Interface exists. Whenever interrupt for MS Bus Interface exists, i.e., any bit in the register MSC\_STA is active, the register bit will be set to '1' if interrupt is enabled. It will be reset when the register MSDC\_STA or MSC\_STA is read.

**0** No MS Bus Interface interrupt.

**1** MS Bus Interface interrupt exists.

**SDR1BIRQ** SD/MMC R1b Response Interrupt. The register bit will be active when a SD/MMC command with R1b response finishes and the DAT0 line has transition from busy to idle state.

**0** No interrupt for SD/MMC R1b response.

**1** Interrupt for SD/MMC R1b response exists.

### MSDC+000Ch MS/SD Memory Card Controller Data Register

### MSDC\_DAT

|      |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | DATA[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | DATA[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register is used to read/write data from/to FIFO inside MS/SD controller. Data access is in unit of 32 bits.

### MSDC+0010h MS/SD Memory Card Pin Status Register

### MSDC\_PS

|       |    |    |    |    |    |    |   |   |   |   |   |         |      |        |       |      |
|-------|----|----|----|----|----|----|---|---|---|---|---|---------|------|--------|-------|------|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4       | 3    | 2      | 1     | 0    |
| Name  |    |    |    |    |    |    |   |   |   |   |   | PINC_HG | PINO | POEN_0 | PIENO | CDEN |
| Type  |    |    |    |    |    |    |   |   |   |   |   | RC      | RO   | R/W    | R/W   | R/W  |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 0       | 0    | 0      | 0     | 0    |

The register is used for card detection. When the memory card controller is powered on, and the system is powered on, the power for the memory card is still off unless power has been supplied by the PMIC. Meanwhile, pad for card detection defaults to pull down when the system is powered on. The scheme of card detection for MS is the same as that for SD/MMC.

For detecting card insertion, first pull up INS pin, and then enable card detection and input pin at the same time. After 32 cycles of controller clock, status of pin changes will emerge. For detecting card removal, just keep enabling card detection and input pin.

**CDEN** Card Detection Enable. The register bit is used to enable or disable card detection.

- 0** Card detection is disabled.
- 1** Card detection is enabled.

**PENO** The register bit is used to control input pin for card detection.

- 0** Input pin for card detection is disabled.
- 1** Input pin for card detection is enabled.

**POENO** The register bit is used to control output of input pin for card detection.

- 0** Output of input pin for card detection is disabled.
- 1** Output of input pin for card detection is enabled.

**PINO** The register shows the value of input pin for card detection.

- 0** The value of input pin for card detection is logic low.
- 1** The value of input pin for card detection is logic high.

**PINCHG** Pin Change. The register bit indicates the status of card insertion/removal. If memory card is inserted or removed, the register bit will be set to '1' no matter pin change interrupt is enabled or not. It will be cleared when the register is read.

- 0** Otherwise.
- 1** Card is inserted or removed.

### MSDC+0014h MS/SD Memory Card Controller IO Control Register      MSDC\_IOCON

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7              | 6              | 5 | 4              | 3 | 2              | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|----------------|----------------|---|----------------|---|----------------|---|---|
| Name  |    |    |    |    |    |    |   |   | <b>SRCF G1</b> | <b>SRCF G0</b> |   | <b>ODCCFG1</b> |   | <b>ODCCFG0</b> |   |   |
| Type  |    |    |    |    |    |    |   |   | R/W            | R/W            |   | R/W            |   | R/W            |   |   |
| Reset |    |    |    |    |    |    |   |   | 1              | 1              |   | 000            |   | 011            |   |   |

The register specifies **Output Driving Capability** and **Slew Rate** of IO pads for MSDC. The reset value is suggestion setting. If output driving capability of the pins DAT0, DAT1, DAT2 and DAT3 is too large, it's possible to arise ground bounce and thus result in glitch on SCLK.

**ODCCFG0** Output driving capability the pins CMD/BS and SCLK

- |            |      |
|------------|------|
| <b>000</b> | 2mA  |
| <b>001</b> | 4mA  |
| <b>010</b> | 6mA  |
| <b>011</b> | 8mA  |
| <b>100</b> | 10mA |
| <b>101</b> | 12mA |
| <b>110</b> | 14mA |
| <b>111</b> | 16mA |

**ODCCFG1** Output driving capability the pins DAT0, DAT1, DAT2 and DAT3

- 000** 2mA
- 001** 4mA
- 010** 6mA
- 011** 8mA
- 100** 10mA
- 101** 12mA
- 110** 14mA
- 111** 16mA

**SRCFG0** Output driving capability the pins CMD/BS and SCLK

- 0** Fast Slew Rate
- 1** Slow Slew Rate

**SRCFG1** Output driving capability the pins DAT0, DAT1, DAT2 and DAT3

- 0** Fast Slew Rate
- 1** Slow Slew Rate

### 6.7.3.2 SD Memory Card Controller Register Definitions

#### MSDC+0020h SD Memory Card Controller Configuration Register

SDC\_CFG

| Bit   | 31            | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23            | 22 | 21 | 20 | 19                | 18 | 17          | 16 |
|-------|---------------|----|----|----|----|----|----|----|---------------|----|----|----|-------------------|----|-------------|----|
| Name  | DTOC          |    |    |    |    |    |    |    | WDOD          |    |    |    | <b>MDLE<br/>N</b> |    | <b>SIEN</b> |    |
| Type  | R/W           |    |    |    |    |    |    |    | R/W           |    |    |    | R/W               |    | R/W         |    |
| Reset | 00000000      |    |    |    |    |    |    |    | 0000          |    |    |    | 0                 |    | 0           |    |
| Bit   | 15            | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7             | 6  | 5  | 4  | 3                 | 2  | 1           | 0  |
| Name  | <b>BSYDLY</b> |    |    |    |    |    |    |    | <b>BLKLEN</b> |    |    |    |                   |    |             |    |
| Type  | R/W           |    |    |    |    |    |    |    | R/W           |    |    |    |                   |    |             |    |
| Reset | 1000          |    |    |    |    |    |    |    | 000000000000  |    |    |    |                   |    |             |    |

The register is used for configuring the MS/SD Memory Card Controller when it is configured as the host of SD Memory Card. If the controller is configured as the host of Memory Stick, the contents of the register have no impact on the operation of the controller. Note that SDC\_CFG[31:16] can be accessed by 16-bit APB bus access.

**BLKLEN** It refers to Block Length. The register field is used to define the length of one block in unit of byte in a data transaction. The maximal value of block length is 2048 bytes.

- 000000000000** Reserved.
- 000000000001** Block length is 1 byte.
- 000000000010** Block length is 2 bytes.
- ...
- 011111111111** Block length is 2047 bytes.
- 100000000000** Block length is 2048 bytes.

**BSYDLY** The register field is only valid for the commands with R1b response. If the command has a response of R1b type, MS/SD controller must monitor the data line 0 for card busy status from the bit time that is two serial clock cycles after the command end bit to check if operations in SD/MMC Memory Card have finished. The register field is used to expand the time between the command end bit and end of detection period to detect card busy status. If time is up and there is no card busy status on data line 0, then the controller will abandon the detection.

- 0000** No extend.

**0001** Extend one more serial clock cycle.

**0010** Extend two more serial clock cycles.

...

**1111** Extend fifteen more serial clock cycle.

**SIEN** Serial Interface Enable. It should be enabled as soon as possible before any command.

**0** Serial interface for SD/MMC is disabled.

**1** Serial interface for SD/MMC is enabled.

**MDLEN** Multiple Data Line Enable. The register can be enabled only when SD Memory Card is applied and detected by software application. It is the responsibility of the application to program the bit correctly when an MultiMediaCard is applied. If an MultiMediaCard is applied and 4-bit data line is enabled, then 4 bits will be output every serial clock. Therefore, data integrity will fail.

**0** 4-bit Data line is disabled.

**1** 4-bit Data line is enabled.

**WDOD** Write Data Output Delay. The period from finish of the response for the initial host write command or the last write data block in a multiple block write operation to the start bit of the next write data block requires at least two serial clock cycles. The register field is used to extend the period (Write Data Output Delay) in unit of one serial clock.

**0000** No extend.

**0001** Extend one more serial clock cycle.

**0010** Extend two more serial clock cycles.

...

**1111** Extend fifteen more serial clock cycle.

**DTOC** Data Timeout Counter. The period from finish of the initial host read command or the last read data block in a multiple block read operation to the start bit of the next read data block requires at least two serial clock cycles. The counter is used to extend the period (Read Data Access Time) in unit of 65,536 serial clock. See the register field description of the register bit RDINT for reference.

**00000000** Extend 65,536 more serial clock cycle.

**00000001** Extend 65,536x2 more serial clock cycle.

**00000010** Extend 65,536x3 more serial clock cycle.

...

**11111111** Extend 65,536x 256 more serial clock cycle.

### MSDC+0024h SD Memory Card Controller Command Register

### SDC\_CMD

| Bit   | 15   | 14   | 13  | 12    | 11   | 10     | 9   | 8 | 7     | 6   | 5      | 4 | 3   | 2 | 1   | 0 |
|-------|------|------|-----|-------|------|--------|-----|---|-------|-----|--------|---|-----|---|-----|---|
| Name  | INTC | STOP | RW  | DTYPE | IDRT | RSPTYP |     |   | BREAK | CMD |        |   |     |   |     |   |
| Type  | R/W  | R/W  | R/W | R/W   | R/W  |        | R/W |   | R/W   |     | R/W    |   | R/W |   | R/W |   |
| Reset | 0    | 0    | 0   | 00    | 0    |        | 000 |   | 0     |     | 000000 |   |     |   |     |   |

The register defines a SD Memory Card command and its attribute. Before MS/SD controller issues a transaction onto SD bus, application shall specify other relative setting such as argument for command. After application writes the register, MS/SD controller will issue the corresponding transaction onto SD serial bus. If the command is GO\_IDLE\_STATE, the controller will have serial clock on SD/MMC bus run 128 cycles before issuing the command.

**CMD** SD Memory Card command. It is totally 6 bits.

**BREAK** Abort a pending MMC GO\_IRQ\_MODE command. It is only valid for a pending GO\_IRQ\_MODE command waiting for MMC interrupt response.

- 0** Other fields are valid.
- 1** Break a pending MMC GO\_IRQ\_MODE command in the controller. Other fields are invalid.

**RSPTYP** The register field defines response type for the command. For commands with R1 and R1b response, the register SDC\_CSTA (not SDC\_STA) will update after response token is received. This register SDC\_CSTA contains the status of the SD/MMC and it will be used as response interrupt sources. Note that if CMD7 is used with all 0's RCA then RSPTYP must be "000". And the command "GO\_TO\_IDLE" also have RSPTYP='000'.

**000** There is no response for the command. For instance, broadcast command without response and GO\_INACTIVE\_STATE command.

**001** The command has R1 response. R1 response token is 48-bit.

**010** The command has R2 response. R2 response token is 136-bit.

**011** The command has R3 response. Even though R3 is 48-bit response, but it does not contain CRC checksum.

**100** The command has R4 response. R4 response token is 48-bit. (Only for MMC)

**101** The command has R5 response. R5 response token is 48-bit. (Only for MMC)

**110** The command has R6 response. R6 response token is 48-bit.

**111** The command has R1b response. If the command has a response of R1b type, MS/SD controller must monitor the data line 0 for card busy status from the bit time that is two or four serial clock cycles after the command end bit to check if operations in SD/MMC Memory Card have finished. There are two cases for detection of card busy status. The first case is that the host stops the data transmission during an active write data transfer. The card will assert busy signal after the stop transmission command end bit followed by four serial clock cycles. The second case is that the card is in idle state or under a scenario of receiving a stop transmission command between data blocks when multiple block write command is in progress. The register bit is valid only when the command has a response token.

**IDRT** Identification Response Time. The register bit indicates if the command has a response with  $N_{ID}$  (that is, 5 serial clock cycles as defined in SD Memory Card Specification Part 1 Physical Layer Specification version 1.0) response time. The register bit is valid only when the command has a response token. Thus the register bit must be set to '1' for CMD2 (ALL\_SEND\_CID) and ACMD41 (SD\_APP\_OP\_CMD).

**0** Otherwise.

**1** The command has a response with  $N_{ID}$  response time.

**DTYPE** The register field defines data token type for the command.

**00** No data token for the command

**01** Single block transaction

**10** Multiple block transaction. That is, the command is a multiple block read or write command.

**11** Stream operation. It only shall be used when an MultiMediaCard is applied.

**RW** The register bit defines the command is a read command or write command. The register bit is valid only when the command will cause a transaction with data token.

**0** The command is a read command.

**1** The command is a write command.

**STOP** The register bit indicates if the command is a stop transmission command.

**0** The command is not a stop transmission command.

**1** The command is a stop transmission command.

**INTR** The register bit indicates if the command is GO\_IRQ\_STATE. If the command is GO\_IRQ\_STATE, the period between command token and response token will not be limited.

- 0** The command is not GO\_IRQ\_STATE.
- 1** The command is GO\_IRQ\_STATE.

### MSDC+0028h SD Memory Card Controller Argument Register

**SDC\_ARG**

|      |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | <b>ARG [31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>ARG [15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register contains the argument of the SD/MMC Memory Card command.

### MSDC+002Ch SD Memory Card Controller Status Register

**SDC\_STA**

|       |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit   | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | <b>WP</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | -         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

The register contains various status of MS/SD controller as the controller is configured as the host of SD Memory Card.

**SDCBUSY** The register field indicates if MS/SD controller is busy, that is, any transmission is going on CMD or DAT line on SD bus.

- 0** MS/SD controller is idle.
- 1** MS/SD controller is busy.

**CMDBUSY** The register field indicates if any transmission is going on CMD line on SD bus.

- 0** No transmission is going on CMD line on SD bus.
- 1** There exists transmission going on CMD line on SD bus.

**DATBUSY** The register field indicates if any transmission is going on DAT line on SD bus. **For those commands without data but still involving DAT line, the register bit is useless. For example, if an Erase command is issued, then checking if the register bit is '0' before issuing next command with data would not guarantee that the controller is idle. In this situation, use the register bit SDCBUSY.**

- 0** No transmission is going on DAT line on SD bus.
- 1** There exists transmission going on DAT line on SD bus.

**R1BSY** The register field shows the status of DAT line 0 for commands with R1b response.

- 0** SD/MMC Memory card is not busy.
- 1** SD/MMC Memory card is busy.

**WP** It is used to detect the status of Write Protection Switch on SD Memory Card. The register bit shows the status of Write Protection Switch on SD Memory Card. There is no default reset value. The pin WP (Write Protection) is also only useful while the controller is configured for SD Memory Card.

- 1** Write Protection Switch ON. It means that memory card is desired to be write-protected.
- 0** Write Protection Switch OFF. It means that memory card is writable.

### MSDC+0030h SD Memory Card Controller Response Register 0

**SDC\_RESP0**

|      |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | <b>RESP [31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | RO                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|      |             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|-------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit  | 15          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name | RESP [15:0] |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type | RO          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

The register contains parts of the last SD/MMC Memory Card bus response. See description for the register field SDC\_RESP3.

### MSDC+0034h SD Memory Card Controller Response Register 1

SDC\_RESP1

|      |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | RESP [63:48] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | RO           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | RESP [47:32] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | RO           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register contains parts of the last SD/MMC Memory Card bus response. See description for the register field SDC\_RESP3.

### MSDC+0038h SD Memory Card Controller Response Register 2

SDC\_RESP2

|      |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | RESP [95:80] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | RO           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | RESP [79:64] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | RO           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register contains parts of the last SD/MMC Memory Card bus response. See description for the register field SDC\_RESP3.

### MSDC+003Ch SD Memory Card Controller Response Register 3

SDC\_RESP3

|      |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name | RESP [127:112] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | RO             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | RESP [111:96]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | RO             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register contains parts of the last SD/MMC Memory Card bus response. The register fields SDC\_RESP0, SDC\_RESP1, SDC\_RESP2 and SDC\_RESP3 compose the last SD/MMC Memory card bus response. For response of type R2, that is, response of the command ALL\_SEND\_CID, SEND\_CSD and SEND\_CID, only bit 127 to 0 of response token is stored in the register field SDC\_RESP0, SDC\_RESP1, SDC\_RESP2 and SDC\_RESP3. For response of other types, only bit 39 to 8 of response token is stored in the register field SDC\_RESP0.

### MSDC+0040h SD Memory Card Controller Command Status Register

SDC\_CMDSTA

|       |             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|-------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit   | 15          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | MMCI_RQ     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RSPC_RCER_R |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | RC          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

The register contains the status of MS/SD controller during command execution and that of MS/SD bus protocol after command execution when MS/SD controller is configured as the host of SD/MMC Memory Card. The register will also be used as interrupt sources. The register will be cleared when reading the register. Meanwhile, if interrupt is enabled and thus interrupt caused by the register is generated, reading the register will deassert the interrupt.

**CMDRDY** For command without response, the register bit will be ‘1’ once the command completes on SD/MMC bus. For command with response, the register bit will be ‘1’ whenever the command is issued onto SD/MMC bus and its corresponding response is received **without CRC error**.

- 0** Otherwise.
- 1** Command with/without response finish successfully without CRC error.

**CMDTO** Timeout on CMD detected. A ‘1’ indicates that MS/SD controller detected a timeout condition while waiting for a response on the CMD line.

- 0** Otherwise.
- 1** MS/SD controller detected a timeout condition while waiting for a response on the CMD line.

**RSPCRCERR** CRC error on CMD detected. A ‘1’ indicates that MS/SD controller detected a CRC error **after reading a response from the CMD line**.

- 0** Otherwise.
- 1** MS/SD controller detected a CRC error after reading a response from the CMD line.

**MMCIRQ** MMC requests an interrupt. A ‘1’ indicates that a MMC supporting command class 9 issued an interrupt request.

- 0** Otherwise.
- 1** A ‘1’ indicates that a MMC supporting command class 9 issued an interrupt request.

### MSDC+0044h SD Memory Card Controller Data Status Register SDC\_DATSTA

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2                 | 1         | 0           |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|-------------------|-----------|-------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | DATC<br>RCER<br>R | DATT<br>O | BLKD<br>ONE |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | RC                | RC        | RC          |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0                 | 0         | 0           |

The register contains the status of MS/SD controller during data transfer on DAT line(s) when MS/SD controller is configured as the host of SD/MMC Memory Card. The register also will be used as interrupt sources. The register will be cleared when reading the register. Meanwhile, if interrupt is enabled and thus interrupt caused by the register is generated, reading the register will deassert the interrupt.

**BLKDONE** The register bit indicates the status of data block transfer.

- 0** Otherwise.
- 1** A data block was successfully transferred.

**DATTO** Timeout on DAT detected. A ‘1’ indicates that MS/SD controller detected a timeout condition while waiting for data token on the DAT line.

- 0** Otherwise.
- 1** MS/SD controller detected a timeout condition while waiting for data token on the DAT line.

**DATCRCERR** CRC error on DAT detected. A ‘1’ indicates that MS/SD controller detected a CRC error after reading a block of data from the DAT line or SD/MMC signaled a CRC error after writing a block of data to the DAT line.

- 0** Otherwise.

- 1 MS/SD controller detected a CRC error after reading a block of data from the DAT line or SD/MMC signaled a CRC error after writing a block of data to the DAT line.

### MSDC+0048h SD Memory Card Status Register

**SDC\_CSTA**

| Bit   | 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | <b>CSTA [31:16]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RC                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 00000000000000000000 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>CSTA [15:0]</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RC                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 00000000000000000000 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

After commands with R1 and R1b response this register contains the status of the SD/MMC card and it will be used as response interrupt sources. In all register fields, logic high indicates error and logic low indicates no error. The register will be cleared when reading the register. Meanwhile, if interrupt is enabled and thus interrupt caused by the register is generated, reading the register will deassert the interrupt.

- CSTA31** **OUT\_OF\_RANGE.** The command's argument was out of the allowed range for this card.
- CSTA30** **ADDRESS\_ERROR.** A misaligned address that did not match the block length was used in the command.
- CSTA29** **BLOCK\_LEN\_ERROR.** The transferred block length is not allowed for this card, or the number of transferred bytes does not match the block length.
- CSTA28** **ERASE\_SEQ\_ERROR.** An error in the sequence of erase commands occurred.
- CSTA27** **ERASE\_PARAM.** An invalid selection of write-blocks for erase occurred.
- CSTA26** **WP\_VIOLATION.** Attempt to program a write-protected block.
- CSTA25** Reserved. Return zero.
- CSTA24** **LOCK\_UNLOCK\_FAILED.** Set when a sequence or password error has been detected in lock/unlock card command or if there was an attempt to access a locked card.
- CSTA23** **COM\_CRC\_ERROR.** The CRC check of the previous command failed.
- CSTA22** **ILLEGAL\_COMMAND.** Command not legal for the card state.
- CSTA21** **CARD\_ECC\_FAILED.** Card internal ECC was applied but failed to correct the data.
- CSTA20** **CC\_ERROR.** Internal card controller error.
- CSTA19** **ERROR.** A general or an unknown error occurred during the operation.
- CSTA18** **UNDERRUN.** The card could not sustain data transfer in stream read mode.
- CSTA17** **OVERRUN.** The card could not sustain data programming in stream write mode.
- CSTA16** **CID/CSD\_OVERWRITE.** It can be either one of the following errors: 1. The CID register has been already written and cannot be overwritten 2. The read only section of the CSD does not match the card. 3. An attempt to reverse the copy (set as original) or permanent WP (unprotected) bits was made.
- CSTA[15:4]** Reserved. Return zero.
- CSTA3** **AKE\_SEQ\_ERROR.** Error in the sequence of authentication process
- CSTA[2:0]** Reserved. Return zero.

### MSDC+004Ch SD Memory Card IRQ Mask Register 0

**SDC\_IRQMASK0**

| Bit   | 31                     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | <b>IRQMASK [31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 00000000000000000000   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

|       |                  |
|-------|------------------|
| Name  | IRQMASK [15:0]   |
| Type  | R/W              |
| Reset | 0000000000000000 |

The register contains parts of SD Memory Card Interrupt Mask Register. See the register description of the register SDC\_IRQMASK1 for reference. The register will mask interrupt sources from the register SDC\_CMDSTA and SDC\_DATSTA. IRQMASK[15:0] is for SDC\_CMDSTA and IRQMASK[31:16] for SDC\_DATSTA. A ‘1’ in some bit of the register will mask the corresponding interrupt source with the same bit position. For example, if IRQMASK[0] is ‘1’ then interrupt source from the register field CMDRDY of the register SDC\_CMDSTA will be masked. A ‘0’ in some bit will not cause interrupt mask on the corresponding interrupt source from the register SDC\_CMDSTA and SDC\_DATSTA.

### MSDC+0050h SD Memory Card IRQ Mask Register 1

|       |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | IRQMASK [63:48]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0000000000000000 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15               | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | IRQMASK [47:32]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0000000000000000 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The register contains parts of SD Memory Card Interrupt Mask Register. The registers SDC\_IRQMASK1 and SDC\_IRQMASK0 compose the SD Memory Card Interrupt Mask Register. The register will mask interrupt sources from the register SDC\_CSTA. A ‘1’ in some bit of the register will mask the corresponding interrupt source with the same bit position. For example, if IRQMASK[63] is ‘1’ then interrupt source from the register field OUT\_OF\_RANGE of the register SDC\_CSTA will be masked. A ‘0’ in some bit will not cause interrupt mask on the corresponding interrupt source from the register SDC\_CSTA.

### 6.7.3.3 Memory Stick Controller Register Definitions

#### MSDC+0060h Memory Stick Controller Configuration Register MSC\_CFG

|       |       |      |    |    |    |    |   |   |   |   |   |   |   |   |         |      |
|-------|-------|------|----|----|----|----|---|---|---|---|---|---|---|---|---------|------|
| Bit   | 15    | 14   | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1       | 0    |
| Name  | PMODE | PRED |    |    |    |    |   |   |   |   |   |   |   |   | BUSYCNT | SIEN |
| Type  | R/W   | R/W  |    |    |    |    |   |   |   |   |   |   |   |   | R/W     | R/W  |
| Reset | 0     | 0    |    |    |    |    |   |   |   |   |   |   |   |   | 101     | 0    |

The register is used for Memory Stick Controller Configuration when MS/SD controller is configured as the host of Memory Stick.

**SIEN** Serial Interface Enable. It should be enabled as soon as possible before any command.

**0** Serial interface for Memory Stick is disabled.

**1** Serial interface for Memory Stick is enabled.

**BUSYCNT** RDY timeout setting in unit of serial clock cycle. The register field is set to the maximum BUSY timeout time (set value  $\times 4 + 2$ ) to wait until the RDY signal is output from the card. RDY timeout error detection is not performed when BUSYCNT is set to 0. The initial value is 0x5. That is, BUSY signal exceeding  $5 \times 4 + 2 = 22$  serial clock cycles causes a RDY timeout error.

**000** Not detect RDY timeout

**001** BUSY signal exceeding  $1 \times 4 + 2 = 6$  serial clock cycles causes a RDY timeout error.

**010** BUSY signal exceeding  $2 \times 4 + 2 = 10$  serial clock cycles causes a RDY timeout error.

...

**111** BUSY signal exceeding  $7 \times 4 + 2 = 30$  serial clock cycles causes a RDY timeout error.

**PRED** Parallel Mode Rising Edge Data. The register field is only valid in parallel mode, that is, MSPRO mode. In parallel mode, data must be driven and latched at the falling edge of serial clock on MS bus. In order to mitigate hold time issue, the register can be set to '1' such that write data is driven by MSDC at the rising edge of serial clock on MS bus.

**0** Write data is driven by MSDC at the falling edge of serial clock on MS bus.

**1** Write data is driven by MSDC at the rising edge of serial clock on MS bus.

**PMODE** Memory Stick PRO Mode.

**0** Use Memory Stick serial mode.

**1** Use Memory Stick parallel mode.

### MSDC+0064h Memory Stick Controller Command Register

**MSC\_CMD**

| Bit   | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3               | 2 | 1 | 0 |
|-------|------|----|----|----|----|----|---|---|---|---|---|---|-----------------|---|---|---|
| Name  |      |    |    |    |    |    |   |   |   |   |   |   | <b>DATASIZE</b> |   |   |   |
| Type  |      |    |    |    |    |    |   |   |   |   |   |   | R/W             |   |   |   |
| Reset | 0000 |    |    |    |    |    |   |   |   |   |   |   | 0000000000      |   |   |   |

The register is used for issuing a transaction onto MS bus. Transaction on MS bus is started by writing to the register MSC\_CMD. The direction of data transfer, that is, read or write transaction, is extracted from the register field PID. 16-bit CRC will be transferred for a write transaction even if the register field DATASIZE is programmed as zero under the condition where the register field NOCRC in the register MSDC\_CFG is '0'. If the register field NOCRC in the register MSDC\_CFG is '1' and the register field DATASIZE is programmed as zero, then writing to the register MSC\_CMD will not induce transaction on MS bus. The same applies for when the register field RDY in the register MSC\_STA is '0'.

**DATASIZE** Data size in unit of byte for the current transaction.

**0000000000** Data size is 0 byte.

**0000000001** Data size is one byte.

**0000000010** Data size is two bytes.

...

**0111111111** Data size is 511 bytes.

**1000000000** Data size is 512 bytes.

**PID** Protocol ID. It is used to derive Transfer Protocol Code (TPC). The TPC can be derived by cascading PID and its reverse version. For example, if PID is 0x1, then TPC is 0x1e, that is, 0b0001 cascades 0b1110. In addition, the direction of the bus transaction can be determined from the register bit 15, that is, PID[3].

### MSDC+0068h Memory Stick Controller Auto Command Register

**MSC\_ACMD**

| Bit   | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3                | 2 | 1 | 0 |
|-------|------|----|----|----|----|----|---|---|---|---|---|---|------------------|---|---|---|
| Name  |      |    |    |    |    |    |   |   |   |   |   |   | <b>ADATASIZE</b> |   |   |   |
| Type  |      |    |    |    |    |    |   |   |   |   |   |   | R/W              |   |   |   |
| Reset | 0111 |    |    |    |    |    |   |   |   |   |   |   | 0000000001       |   |   | 0 |

The register is used for issuing a transaction onto MS bus automatically after the MS command defined in MSC\_CMD completed on MS bus. Auto Command is a function used to automatically execute a command like GET\_INT or READ\_REG for checking status after SET\_CMD ends. If auto command is enabled, the command set in the register will be executed once the INT signal on MS bus is detected. After auto command is issued onto MS bus, the register bit ACEN will

become disabled automatically. Note that if auto command is enabled then the register bit RDY in the register MSC\_STA caused by the command defined in MSC\_CMD will be suppressed until auto command completes. Note that the register field ADATASIZE cannot be set to zero, or the result will be unpredictable.

**ACEN** Auto Command Enable.

- 0** Auto Command is disabled.
- 1** Auto Command is enabled.

**ADATASIZE** Data size in unit of byte for Auto Command. Initial value is 0x01.

- 0000000000** Data size is 0 byte.
- 0000000001** Data size is one byte.
- 0000000010** Data size is two bytes.
- ...
- 0111111111** Data size is 511 bytes.
- 1000000000** Data size is 512 bytes.

**APID** Auto Command Protocol ID. It is used to derive Transfer Protocol Code (TPC). Initial value is GSET\_INT(0x7).

**MSDC+006Ch Memory Stick Controller Status Register**

**MSC\_STA**

| Bit   | 15    | 14   | 13  | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3    | 2    | 1   | 0   |
|-------|-------|------|-----|-----|----|----|---|---|---|---|---|------|------|------|-----|-----|
| Name  | CMDNK | BREQ | ERR | CED |    |    |   |   |   |   |   | HSRD | CRCE | TOER | SIF | RDY |
| Type  | R     | R    | R   | R   |    |    |   |   |   |   |   | RO   | RO   | RO   | RO  | RO  |
| Reset | 0     | 0    | 0   | 0   |    |    |   |   |   |   |   | 0    | 0    | 0    | 0   | 1   |

The register contains various status of Memory Stick Controller, that is, MS/SD controller is configured as Memory Stick Controller. These statuses can be used as interrupt sources. Reading the register will NOT clear it. The register will be cleared whenever a new command is written to the register MSC\_CMD.

**RDY** The register bit indicates the status of transaction on MS bus. The register bit will be cleared when writing to the command register MSC\_CMD.

- 0** Otherwise.
- 1** A transaction on MS bus is ended.

**SIF** The register bit indicates the status of serial interface. If an interrupt is active on MS bus, the register bit will be active. Note the difference between the signal RDY and SIF. When parallel mode is enabled, the signal SIF will be active whenever any of the signal CED, ERR, BREQ and CMDNK is active. **In order to separate interrupts caused by the signals RDY and SIF, the register bit SIF will not become active until the register MSDC\_INT is read once. That is, the sequence for detecting the register bit SIF by polling is as follows:**

1. Detect the register bit RDY of the register MSC\_STA
2. Read the register MSDC\_INT
3. Detect the register bit SIF of the register MSC\_STA



**0** Otherwise.

**1** An interrupt is active on MS bus

**TOER** The register bit indicates if a BUSY signal timeout error takes place. When timeout error occurs, the signal BS will become logic low '0'. The register bit will be cleared when writing to the command register MSC\_CMD.

**0** No timeout error.

**1** A BUSY signal timeout error takes place. The register bit RDY will also be active.

**CRCER** The register bit indicates if a CRC error occurs while receiving read data. The register bit will be cleared when writing to the command register MSC\_CMD.

**0** Otherwise.

**1** A CRC error occurs while receiving read data. The register bit RDY will also be active.

**HSRDY** The register bit indicates the status of handshaking on MS bus. The register bit will be cleared when writing to the command register MSC\_CMD.

**0** Otherwise.

**1** A Memory Stick card responds to a TPC by RDY.

**CED** The register bit is only valid when parallel mode is enabled. In fact, it's value is from DAT[0] when serial interface interrupt takes place. See Format Specification version 2.0 of Memory Stick Standard (Memory Stick PRO) for more details.

**0** Command does not terminate.

**1** Command terminates normally or abnormally.

**ERR** The register bit is only valid when parallel mode is enabled. In fact, it's value is from DAT[1] when serial interface interrupt takes place. See Format Specification version 2.0 of Memory Stick Standard (Memory Stick PRO) for more details.

**0** Otherwise.

**1** Indicate memory access error during memory access command.

**BREQ** The register bit is only valid when parallel mode is enabled. In fact, it's value is from DAT[2] when serial interface interrupt takes place. See Format Specification version 2.0 of Memory Stick Standard (Memory Stick PRO) for more details.

**0** Otherwise.

**1** Indicate request for data.

**CMDNK** The register bit is only valid when parallel mode is enabled. In fact, it's value is from DAT[3] when serial interface interrupt takes place. See Format Specification version 2.0 of Memory Stick Standard (Memory Stick PRO) for more details.

**0** Otherwise

**1** Indicate non-recognized command.

## 6.7.4 Application Notes

### 6.7.4.1 Initialization Procedures After Power On

Disable power down control for MSDC module

Remember to power on MSDC module before starting any operation to it.

### 6.7.4.2 Card Detection Procedures

The pseudo code is as follows:

```
MSDC_CFG.PRCFG0 = 2'b10  
MSDC_PS = 2'b11  
MSDC_CFG.VDDPD = 1  
if(MSDC_PS.PINCHG) { // card is inserted  
    . . .  
}
```

The pseudo code segment perform the following tasks:

1. First pull up CD/DAT3 (INS) pin.
2. Enable card detection and input pin at the same time.
3. Turn on power for memory card.
4. Detect insertion of memory card.

### 6.7.4.3 Notes on Commands

For MS, check if MSC\_STA.RDY is ‘1’ before issuing any command.

For SD/MMC, if the command desired to be issued involves data line, for example, commands with data transfer or R1b response, check if SDC\_STA.SDCBUSY is ‘0’ before issuing. If the command desired to be issued does not involve data line, only check if SDC\_STA.CMDBUSY is ‘0’ before issuing.

### 6.7.4.4 Notes on Data Transfer

- For SD/MMC, if multiple-block-write command is issued then only issue STOP\_TRANS command inter-blocks instead of intra-blocks.
- Once SW decides to issue STOP\_TRANS commands, no more data transfer from or to the controller.

### 6.7.4.5 Notes on Frequency Change

Before changing the frequency of serial clock on MS/SD/MMC bus, it is necessary to disable serial interface of the controller. That is, set the register bit SIEN of the register SDC\_CFG to ‘0’ for SD/MMC controller, and set the register bit SIEN of the register MSC\_CFG to ‘0’ for Memory Stick controller. Serial interface of the controller needs to be enabled again before starting any operation to the memory card.

### 6.7.4.6 Notes on Response Timeout

If a read command does not receive response, that is, it terminates with a timeout, then register SDC\_DATSTA needs to be cleared by reading it. The register bit “DATTO” should be active. However, it may take a while before the register bit

becomes active. The alternative is to send the STOP\_TRANS command. However, this method will receive response with illegal-command information. Also, remember to check if the register bit SDC\_STA.CMDBUSY is active before issuing the STOP\_TRANS command. The procedure is as follows:

1. Read command => response time out
2. Issue STOP\_TRANS command => Get Response
3. Read register SDC\_DATSTA to clear it

#### 6.7.4.7 Source or Destination Address is not word-aligned

It is possible that the source address is not word-aligned when data move from memory to MSDC. Similarly, destination address may be not word-aligned when data move from MSDC to memory. This can be solved by setting DMA byte-to-word functionality.

1. DMA<sub>n</sub>.CON.SIZE=0
2. DMA<sub>n</sub>.CON.BTW=1
3. DMA<sub>n</sub>.CON.BURST=2
4. DMA<sub>n</sub>.COUNT=byte number instead of word number

Note n=4 ~ 11

#### 6.7.4.8 Miscellaneous notes

- Siemens MMC card: When a write command is issued and followed by a STOP\_TRANS command, Siemens MMC card will de-assert busy status even though flash programming has not yet finished. Software must use “Get Status” command to make sure that flash programming finishes.

### 6.8 2D acceleration

#### 6.8.1 2D Engine

##### 6.8.1.1 General Description

To enhance MMI display and gaming experiences, a 2D acceleration engine is implemented. It supports 16-bpp RGB565 color mode and 8-bpp index color mode. Main features are listed as follows:

- Rectangle fill
- Bitblt: multi-Bitblt without transform, 7 rotate, mirror (transparent) Bitblt
- Alpha blending
- Line drawing: normal line, dotted line
- Font caching: normal font, italic font

MCU can program 2D engine registers via APB. However, MCU has to make sure that the 2D engine is not BUSY before any write to 2D engine registers occurs. An interrupt scheme is also provided for more flexibility.

A command queue of size 32 by 28 and a command parser are implemented for further offloading of MCU. If command queue is enabled, MCU has to check the command queue free space before writing to the command queue data register. Command queue parser will consume command queue entries upon 2D engine requests. **Figure 54** shows the command queue and 2D engine block diagram. Please refer to graphic command queue functional specification for more details.



Figure 54 The command queue and 2D engine block diagram.

### 6.8.1.2 Register Definitions

Table 33 shows the 2D engine register mapping on APB and through command queue.

| APB Address | CMQ mapped Address | Register Function                      | Acronym    |
|-------------|--------------------|----------------------------------------|------------|
| G2D+0100h   | 100h               | 2D engine fire mode control register   | FMODE_CON  |
|             | 102h               | reserved                               |            |
| G2D+0104h   | 104h               | Engine sub-mode control register       | SMODE_CON  |
|             | 106h               | reserved                               |            |
| G2D+0108h   | 108h               | 2D engine common control register      | COM_CON    |
|             | 10Ah               | reserved                               |            |
| G2D+0110h   |                    | 2D engine status register              | STA        |
|             |                    |                                        |            |
| G2D+0200h   | 200h               | Source base address low word register  | SRC_BASE_L |
|             | 202h               | Source base address high word register | SRC_BASE_H |
| G2D+0204h   | 204h               | Source pitch register                  | SRC_PITCH  |
|             | 206h               | reserved                               |            |

|                       |             |                                             |                              |
|-----------------------|-------------|---------------------------------------------|------------------------------|
| G2D+0208h             | 208h        | Source Y register                           | <b>SRC_Y</b>                 |
|                       | 20Ah        | Source X register                           | <b>SRC_X</b>                 |
| G2D+020Ch             | 20Ch        | Source height register                      | <b>SRC_H</b>                 |
|                       | 20Eh        | Source width register                       | <b>SRC_W</b>                 |
|                       |             |                                             |                              |
| G2D+0210h             | 210h        | Source foreground color                     | <b>SRC_FG_CLR</b>            |
|                       | 212h        | reserved                                    |                              |
| G2D+0214h             | 214h        | Source background color                     | <b>SRC_BG_CLR</b>            |
|                       | 216h        | reserved                                    |                              |
| G2D+0218h             | 218h        | Pattern foreground color                    | <b>PAT_FG_CLR</b>            |
|                       | 21Ah        | reserved                                    |                              |
| G2D+021Ch             | 21Ch        | Pattern background color                    | <b>PAT_BG_CLR</b>            |
|                       | 21Eh        | reserved                                    |                              |
|                       |             |                                             |                              |
| G2D+0300h             | 300h        | Destination base address low word register  | <b>DST_BASE_L</b>            |
|                       | 302h        | Destination base address high word register | <b>DST_BASE_H</b>            |
| G2D+0304h             | 304h        | Destination pitch register                  | <b>DST_PITCH</b>             |
|                       | 306h        | reserved                                    |                              |
| G2D+0308h             | 308h        | Destination Y register                      | <b>DST_Y</b>                 |
|                       | 30Ah        | Destination X register                      | <b>DST_X</b>                 |
| G2D+030Ch             | 30Ch        | Destination height register                 | <b>DST_H</b>                 |
|                       | 30Eh        | Destination width register                  | <b>DST_W</b>                 |
|                       |             |                                             |                              |
| G2D+0500h             | 500h        | Top clip Y                                  | <b>CLP_T</b>                 |
|                       | 502h        | Left clip X                                 | <b>CLP_L</b>                 |
| G2D+0504h             | 504h        | Bottom clip Y                               | <b>CLP_B</b>                 |
|                       | 506h        | Right clip X                                | <b>CLP_R</b>                 |
|                       |             |                                             |                              |
| G2D+0700h ~ G2D+071Fh | 700h ~ 71Fh | Tilt address                                | <b>TILT_0300 ~ TILT_1F1C</b> |
|                       |             |                                             |                              |
| G2D+0800h ~ G2D+0BFFh | 800h ~ BFFh | Palette, 256 entries                        | <b>PAL_00 ~ PAL_FF</b>       |
|                       |             |                                             |                              |

**Table 33** The 2D engine register mapping.

**Table 34** shows the 2D engine shared registers under different engine function modes.

| APB Address | CMQ Address | Rectangle fill | Bitblt          | Alpha blending  | Line Drawing | Font caching    |
|-------------|-------------|----------------|-----------------|-----------------|--------------|-----------------|
| G2D+0200h   | 200h        |                | <b>SRC_BASE</b> | <b>SRC_BASE</b> |              | <b>SRC_BASE</b> |

|                          |                |                   |                            |                            |                   |                                  |
|--------------------------|----------------|-------------------|----------------------------|----------------------------|-------------------|----------------------------------|
| G2D+0204h                | 204h           |                   | <b>SRC_PITCH</b>           | <b>SRC_PITCH</b>           |                   |                                  |
| G2D+0208h                | 208h           |                   | <b>SRC_XY</b>              | <b>SRC_XY</b>              |                   |                                  |
| G2D+020Ch                | 20Ch           |                   | <b>SRC_WH</b>              | <b>SRC_WH</b>              |                   | <b>SRC_WH</b>                    |
|                          |                |                   |                            |                            |                   |                                  |
| G2D+0210h                | 210h           |                   | <b>SRC_KEY</b>             |                            | <b>K1</b>         | <b>SRC_KEY</b>                   |
| G2D+0214h                | 214h           |                   |                            | <b>SRC_ALPHA</b>           | <b>K2</b>         |                                  |
| G2D+0218h                | 218h           | <b>PAT_FG_CLR</b> |                            |                            | <b>PAT_FG_CLR</b> | <b>PAT_FG_CLR</b>                |
| G2D+021Ch                | 21Ch           |                   |                            | <b>DST_ALPHA</b>           | <b>E</b>          | <b>PAT_BG_CLR</b>                |
|                          |                |                   |                            |                            |                   |                                  |
| G2D+0300h                | 300h           | <b>DST_BASE</b>   | <b>DST_BASE</b>            | <b>DST_BASE</b>            | <b>DST_BASE</b>   | <b>DST_BASE</b>                  |
| G2D+0304h                | 304h           | <b>DST_PITCH</b>  | <b>DST_PITCH</b>           | <b>DST_PITCH</b>           | <b>DST_PITCH</b>  | <b>DST_PITCH</b>                 |
| G2D+0308h                | 308h           | <b>DST_XY</b>     | <b>DST_XY</b>              | <b>DST_XY</b>              | <b>XY_START</b>   | <b>DST_XY</b>                    |
| G2D+030Ch                | 30Ch           | <b>DST_WH</b>     | <b>DST_WH</b>              | <b>DST_WH</b>              | <b>XY_END</b>     | <b>DST_WH</b>                    |
|                          |                |                   |                            |                            |                   |                                  |
| G2D+0500h                | 500h           | <b>CLP_LT</b>     | <b>CLP_LT</b>              | <b>CLP_LT</b>              | <b>CLP_LT</b>     | <b>CLP_LT</b>                    |
| G2D+0504h                | 504h           | <b>CLP_RB</b>     | <b>CLP_RB</b>              | <b>CLP_RB</b>              | <b>CLP_RB</b>     | <b>CLP_RB</b>                    |
|                          |                |                   |                            |                            |                   |                                  |
| G2D+0700h ~<br>G2D+071Fh | 700h ~<br>71Fh |                   |                            |                            |                   | <b>TILT_0300 ~<br/>TILT_1F1C</b> |
|                          |                |                   |                            |                            |                   |                                  |
| G2D+0800h ~<br>G2D+0BFFh | 800h ~<br>BFFh |                   | <b>PAL_00 ~<br/>PAL_FF</b> | <b>PAL_00 ~<br/>PAL_FF</b> |                   |                                  |
|                          |                |                   |                            |                            |                   |                                  |

Table 34 2D engine common registers

Below shows common control registers.

### G2D+0100h Graphic 2D Engine Fire Mode Control Register

**G2D\_FMODE\_C  
ON**

| Bit   | 31  | 30  | 29  | 28  | 27  | 26                  | 25  | 24                  | 23  | 22  | 21  | 20                  | 19  | 18  | 17  | 16  |
|-------|-----|-----|-----|-----|-----|---------------------|-----|---------------------|-----|-----|-----|---------------------|-----|-----|-----|-----|
| Name  |     |     |     |     |     |                     |     |                     |     |     |     |                     |     |     |     |     |
| Type  | R/W | R/W | R/W | R/W | R/W | R/W                 | R/W | R/W                 | R/W | R/W | R/W | R/W                 | R/W | R/W | R/W | R/W |
| Reset | 0   | 0   | 0   | 0   | 0   | 0                   | 0   | 0                   | 0   | 0   | 0   | 0                   | 0   | 0   | 0   | 0   |
| Bit   | 15  | 14  | 13  | 12  | 11  | 10                  | 9   | 8                   | 7   | 6   | 5   | 4                   | 3   | 2   | 1   | 0   |
| Name  |     |     |     |     |     | <b>SRC_CLR_MODE</b> |     | <b>DST_CLR_MODE</b> |     |     |     | <b>G2D_ENG_MODE</b> |     |     |     |     |
| Type  |     |     |     |     |     | R/W                 |     | R/W                 |     |     |     | R/W                 |     |     |     |     |
| Reset |     |     |     |     |     | 000                 |     | 000                 |     |     |     | 0000                |     |     |     |     |

Write this register will fire the 2D engine according to the CLR\_MODE and ENG\_MODE field.

**SRC\_CLR\_MODE** source color mode

**000** 16-bpp, LUT disable

**100** 8-bpp, LUT disable

**110** 8-bpp, LUT enable

**others** reserved

**DST\_CLR\_MODE** destination color mode

**000** 16-bpp, LUT disable

**010** 16-bpp, LUT enable

**100** 8-bpp, LUT disable

**others** reserved

**G2D\_ENG\_MODE** 2D engine function mode

**0001** rectangle fill

**0011** 8x8 pattern fill

**0100** Bitblt

**1000** alpha blending

**1010** font caching

**1011** line drawing

**others** not allowed

**G2D+0104h Graphic 2D Engine Sub-mode Control Register**
**G2D\_SMODE\_C  
ON**

| Bit   | 31          | 30         | 29 | 28 | 27          | 26             | 25             | 24             | 23 | 22 | 21 | 20 | 19          | 18 | 17           | 16 |
|-------|-------------|------------|----|----|-------------|----------------|----------------|----------------|----|----|----|----|-------------|----|--------------|----|
| Name  |             |            |    |    |             |                |                |                |    |    |    |    |             |    |              |    |
| Type  |             |            |    |    |             |                |                |                |    |    |    |    |             |    |              |    |
| Reset |             |            |    |    |             |                |                |                |    |    |    |    |             |    |              |    |
| Bit   | 15          | 14         | 13 | 12 | 11          | 10             | 9              | 8              | 7  | 6  | 5  | 4  | 3           | 2  | 1            | 0  |
| Name  | <b>FITA</b> | <b>FBG</b> |    |    | <b>LDOT</b> | <b>LX_M_JR</b> | <b>LX_IN_C</b> | <b>LY_IN_C</b> |    |    |    |    | <b>BTRA</b> |    | <b>BMODE</b> |    |
| Type  | R/W         | R/W        |    |    | R/W         | R/W            | R/W            | R/W            |    |    |    |    | R/W         |    | R/W          |    |
| Reset | 0           | 0          |    |    | 0           | 0              | 0              | 0              |    |    |    |    | 0           |    | 111          |    |

Write this register to set the 2D engine configuration.

**FITA** font italic

**FBG** font background

**LDOT** line dotted

**LX\_MJR**

**0** y major

**1** x major

**LX\_INC**

**0** x decrement

**1** x increment

**LY\_INC**

**0** y decrement

**1** y increment

**BTRA** Bitblt transparent

**BMODE** Bitblt transform mode

**000** mirror then rotate 90

**001** rotate 90

- 010** rotate 270
- 011** mirror then rotate 270
- 100** rotate 180
- 101** mirror
- 110** mirror then rotate 180
- 111** none

### G2D+0108h Graphic 2D Engine Common Control Register G2D\_COM\_CON

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18            | 17            | 16         |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|---------------|------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |               |               |            |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |               |               |            |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |               |               |            |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2             | 1             | 0          |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>CLP_EN</b> | <b>PAL_EN</b> | <b>RST</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W           | R/W           | R/W        |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    | 0             | 0             | 0          |

Write this register to set the 2D engine configuration.

**RST** 2D engine (control only) reset

**PAL\_EN** palette enable. This bit should be set before any write to or read from the palette RAM.

**CLP\_EN** clip enable.

### G2D+010Ch Graphic 2D Engine Interrupt Control Register G2D\_IRQ\_CON

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18        | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2         | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>EN</b> |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W       |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    | 0         |    |    |

Write this register to set the 2D engine IRQ configuration.

**EN** interrupt enable. The interrupt is negative edge sensitive.

### G2D+0110h Graphic 2D Engine Common Status Register G2D\_COM\_STA

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18          | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |             |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |             |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |             |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2           | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>BUSY</b> |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    | RO          |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    | 0           |    |    |

Read this register to get the 2D engine status. 2D engine may function abnormally if any 2D engine register is modified when BUSY.

**BUSY** 2D engine is busy

## 6.8.2 Command Queue

### 6.8.2.1 General Description

To enhance MMI display and gaming experiences, a command queue FIFO of size 32 by 28 and a command parser are implemented for further offloading of MCU. If command queue is enabled, software program has to check the command queue free space before writing to the command queue data register. Command queue parser will consume command queue entries upon 2D engine requests. **Figure 54** shows the command queue and 2D engine block diagram.



**Figure 55** The command queue and 2D engine block diagram.

### 6.8.2.2 Register Definitions

MCU APB bus registers are listed as followings.

#### GCMQ+0000h Graphic Command Queue Control Register      GCMQ\_CON

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17        | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1         | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>EN</b> |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W       |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           | 0  |

**EN** command queue enable

#### GCMQ+0004h Graphic Command Queue Status Register      GCMQ\_STA

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**FREE** number of free command queue entries

GCMQ+0008h Graphic Command Queue Data Register

GCMQ DAT

**ADDR [11:0]** write address for mapped 2D engine registers

**DATA [15:0]** write data for mapped 2D engine registers

## 6.9 GIF Decoder

## **6.9.1 General Description**

GIF Decoder is aimed to decode GIF pictures. This hardware-assisted GIF decoding alleviates the software from computation-intensive jobs, and frees the MCU for other jobs. For a handheld device with multimedia functionality, this kind of hardware acceleration is certainly a plus, especially when MCU is not running at a very high clock rate. **Figure 56** shows the GIF file structure. The GIF decoder is aimed to do header parsing and to perform LZW decompression.



Figure 56 GIF file structure

### 6.9.2 Register Definitions

**GIFDEC+0004 Global Color Table Base Address**

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | GCT_BASE_DR |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |             |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |

**GCT\_BASE\_ADDR** Images in a GIF file can either use the global color table or define a local color table. The global color map is optional but recommended for images where accurate color rendition is desired. Decoding of GIF file requires a memory block to store global color table. The number of color map equals to  $2^{\text{number of global color table}}$ , where each entry consists of three byte values representing the red, green, and blue, respectively. GCT\_BASE\_ADDR defines the starting address of memory block used for keeping global color table content for GIF decoding.

**GIFDEC+0008 Local Color Table Base Address**
**LCT\_BASE\_ADDR**  
**DR**

| Bit   | 31                     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | <b>LCT_BASE[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>LCT_BASE[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**LCT\_BASE\_ADDR** Images in a GIF file can either use the global color table or define a local color table. Decoding of GIF file requires a memory block to store local color table. The number of color map equals to  $2^{\text{number of local color table}}$ , where each entry consists of three byte values representing the red, green, and blue, respectively. LCT\_BASE\_ADDR defines the starting address of memory block used for keeping local color table content for GIF decoding.

**GIFDEC+000C LZW Decode Stack Base Address**
**STACK\_BASE\_ADDR**

| Bit   | 31                     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | <b>STK_BASE[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>STK_BASE[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**STK\_BASELZW** decompression is a tree-based backward searching algorithm. Hence, it needs memory to store the tree searching results. STK\_BASE is the starting address of the memory block that keeps LZW decompression information.

**GIFDEC+0010 Graphical Control Extension**
**GCE\_REG**

| Bit   | 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>TC_INDEX[7:0]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

The graphic control extension affects how the next image is to be drawn. If transparent color flag is set, pixels with color of transparent color index will not be displayed.

**TC\_FLG** Transparent indication flag.

- 0 No transparency in this image
- 1 To perform transparency in this image

**TC\_INDEX** Transparent color index indicates which color needs is transparent.

**GIFDEC+0014 LZW Decompression Tree Base Address**  
**h**
**TREE\_BASE\_A  
DDE**

|       |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | TREE_BASE[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15               | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | TREE_BASE[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**TREE\_BASE\_ADDR** To perform LZW decompression, GIF decoder has to parse the GIF file and construct a directory of LZW codebook. This directory is tree-like. Hence, it needs a memory block to store the LZW codebook. TREE\_BASE is the starting address of the memory block that keeps the dictionary for LZW decompression.

**GIFDEC+0018 Decompression Control Register**  
**h**
**DEC\_CTRL\_AD  
DR**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**RS\_BIT** Restricted size.

- 0 Small size GIF image
- 1 Large size GIF image

**OUTLOC** Output location. GIF decoder will write out decompression data to system memory directly or to resizer according to the value of OUT\_LOC. When the GIF file is a interlace one, the output data should be placed in system memory, and it cannot output to resizer directly.

- 0 Output data to system memory
- 1 Output data to resizer

**GIFDEC+001C GIF Decoder Interrupt Status**  
**h**
**STATUS\_REG**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**STATUS** Indicates interrupt status of GIF decoder

**STATUS[0] GIFT\_TERMINATE**

- 0 GIF does not finish yet

1 GIF decode finish

**STATUS[1]** IMG\_FINISH

0 Image does not finish yet

1 Image decode finish

**STATUS[2]** TEXT extension block

0 No text extension block

1 Text extension block is present

**STATUS[3]** GCE extension block

0 No GCE block

1 GCE block is present

**STATUS[4]** INPUT\_EMPTY

0 Input file is not empty yet

1 Input file is empty

**GIFDEC+0020** **GIF Decoder Start Decode Signal**

**START\_REG**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17            | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1             | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>STAR T</b> |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W           |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               | 0  |

**START** GIF decoder start decode bit. When an image needs to be decompressed, start bit needs to be set as one, and it will be cleared as zero by hardware when decompression finishes.

0 No image decoding event

1 Image decoding starts

**GIFDEC+0030** **Output RGB Base Address**

**ORGB\_BASE\_A  
DDR**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                           |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>ORGB_BASE_ADDR[31:16]</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                          |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                            |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                            |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>ORGB_BASE_ADDR[15:0]</b>  |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                          |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                            |

**ORGB\_BASE\_ADDR** The decompression results of GIF file can output to system memory or resizer. When it is directed to system memory, it requires a memory block. ORGB\_BASE\_ADDR is the starting address of the memory block to output GIF decompression results.

**GIFDEC+0034** **Software Reset Register**

**RESET\_REG**

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

|       |                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
|-------|------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|
| Name  |                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Type  |                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Reset |                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Bit   | 15               | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| Name  | <b>RESET_KEY</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Type  | WO               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |
| Reset | 0                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |

This is a software-reset mechanism to prevent hardware hang.

**RESET\_KEY** reset\_key = 'h12, when write reset\_key as 'h12, the GIF decoder will enter reset state.

## GIFDEC+0054 Logical Screen Description Register One LSD\_REG\_1

|       |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>LSD_WIDTH[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>LSD_HEIGHT[15:0]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**LSD\_WIDTH** Width of logical screen of image

**LSD\_HEIGHT** Height of logical screen of image

## GIFDEC+0058 Logical Screen Description Register Two LSD\_REG\_2

|       |                         |                 |    |    |    |    |    |    |    |                 |    |             |            |    |                           |    |
|-------|-------------------------|-----------------|----|----|----|----|----|----|----|-----------------|----|-------------|------------|----|---------------------------|----|
| Bit   | 31                      | 30              | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22              | 21 | 20          | 19         | 18 | 17                        | 16 |
| Name  | <b>PRATIO</b>           |                 |    |    |    |    |    |    |    |                 |    |             |            |    |                           |    |
| Type  | R/W                     |                 |    |    |    |    |    |    |    |                 |    |             |            |    |                           |    |
| Reset | 0                       |                 |    |    |    |    |    |    |    |                 |    |             |            |    |                           |    |
| Bit   | 15                      | 14              | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6               | 5  | 4           | 3          | 2  | 1                         | 0  |
| Name  | <b>PRAT</b><br><b>O</b> | <b>BG_COLOR</b> |    |    |    |    |    |    |    | <b>GCT_SIZE</b> |    | <b>GCTS</b> | <b>BPP</b> |    | <b>GCTFL</b><br><b>LG</b> |    |
| Type  | R/W                     | R/W             |    |    |    |    |    |    |    | R/W             |    | R/W         | R/W        |    | R/W                       |    |
| Reset | 0                       | 0               |    |    |    |    |    |    |    | 0               |    | 0           | 0          |    | 0                         |    |

**PRATIO** Pixel aspect ratio. If this value is nonzero, the pixel width and the height are not equal. (PRATIO+15)/64 is the pixel width divided by the pixel height

**BG\_COLOR** Index into the global color table for selecting the background color

**GCT\_SIZE**  $2^{(GCT\_SIZE+1)}$  gives the number of entries in the global color table

**GCTS** Indicates if the entries are sorted in order of importance

**0** Not sorted

**1** Sorted

**BPP** Bits per pixel minus 1

**GCTFLG** Set when there is a global color table

## 6.10 Camera Interface



MT6219 incorporates a feature rich image signal processor to connect with a variety of CMOS sensor components. This processor consists of TG and ISP.

This timing generator (TG) cooperates with CMOS master type sensor only. That means sensor should send vertical and horizontal signals to TG. TG offers sensor required data clock and receive sensor Bayer pattern raw data by internal auto synchronization. Received raw data can go through simple process such as color component offset adjustment. The main purpose of TG is to create data clock for CMOS master type sensor and accept vertical/horizontal synchronization signal and sensor data; and then generate grabbed area of raw data to the ISP unit.

ISP accepts Bayer pattern raw data that is generated by TG. The output of ISP is YCbCr 888 data format which can be easily encoded by the compress engine (JPEG encoder and MPEG4 encoder). It can be the basic data domain of other data format translation such as R/G/B domain. The ISP is pipelined, and during processing stages ISP hardware can auto extract meaningful information for further AE/AF/AWB calculation. These information are temporary stored on ISP registers and can be read back by MCU.

### 6.10.1 Register Definitions

**CAM+0000h TG Phase Counter Register**

| Bit   | 31          | 30 | 29           | 28            | 27            | 26 | 25 | 24 | 23            | 22 | 21 | 20 | 19            | 18 | 17 | 16 |
|-------|-------------|----|--------------|---------------|---------------|----|----|----|---------------|----|----|----|---------------|----|----|----|
| Name  | <b>PCEN</b> |    | <b>CLKEN</b> | <b>CLKPOL</b> | <b>CLKCNT</b> |    |    |    | <b>CLKRS</b>  |    |    |    | <b>CLKFL</b>  |    |    |    |
| Type  | R/W         |    | R/W          | R/W           | R/W           |    |    |    | R/W           |    |    |    | R/W           |    |    |    |
| Reset | 0           |    | 0            | 0             | 1             |    |    |    | 0             |    |    |    | 1             |    |    |    |
| Bit   | 15          | 14 | 13           | 12            | 11            | 10 | 9  | 8  | 7             | 6  | 5  | 4  | 3             | 2  | 1  | 0  |
| Name  |             |    |              |               |               |    |    |    | <b>PIXCNT</b> |    |    |    | <b>DLATCH</b> |    |    |    |
| Type  |             |    |              |               |               |    |    |    | R/W           |    |    |    | R/W           |    |    |    |
| Reset |             |    |              |               |               |    |    |    | 1             |    |    |    | 1             |    |    |    |

**PCEN** TG Phase Counter Enable Control

**CLKEN** Enable Clock Output to CMOS sensor

**CLKPOL** CMOS sensor clock polarity control

**PCCNT** TG Phase Counter Frequency Control

**CLKRS** CMOS sensor clock rising edge control

**CLKFL** CMOS sensor clock falling edge control

**DLATCH** Data Latch Position control

**CAM+0004h CMOS Sensor Size Configuration Register**
**CAM\_CAMWIN**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>PIXELS</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W           |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ffffh         |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0             |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>LINES</b>  |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W           |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ffffh         |

**PIXEL** Total input pixel number

**LINE** Total input line number

**CAM+0008h TG Grab Range Start/End Pixel Configuration Register CAM\_GRABCOL**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16           |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>START</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W          |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0            |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0            |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>END</b>   |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W          |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0            |

**START** Grab start pixel number

**END** Grab end pixel number

**CAM+000Ch TG Grab Range Start/End Line Configuration Register**
**CAM\_GRABRO**  
W

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16           |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>START</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W          |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0            |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0            |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>END</b>   |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W          |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0            |

**START** Grab start line number

**END** Grab end line number

**CAM+0010h CMOS Sensor Mode Configuration Register**
**CAM\_CSMODE**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22           | 21           | 20           | 19         | 18          | 17 | 16        |
|-------|----|----|----|----|----|----|----|----|----|--------------|--------------|--------------|------------|-------------|----|-----------|
| Name  |    |    |    |    |    |    |    |    |    |              |              |              |            |             |    |           |
| Type  |    |    |    |    |    |    |    |    |    |              |              |              |            |             |    |           |
| Reset |    |    |    |    |    |    |    |    |    |              |              |              |            |             |    |           |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6            | 5            | 4            | 3          | 2           | 1  | 0         |
| Name  |    |    |    |    |    |    |    |    |    | <b>VSPOL</b> | <b>HSPOL</b> | <b>PWRON</b> | <b>RST</b> | <b>AUTO</b> |    | <b>EN</b> |
| Type  |    |    |    |    |    |    |    |    |    | R/W          | R/W          | R/W          | R/W        | R/W         |    | R/W       |

|       |  |  |  |  |  |  |  |  |   |   |   |   |   |  |  |   |
|-------|--|--|--|--|--|--|--|--|---|---|---|---|---|--|--|---|
| Reset |  |  |  |  |  |  |  |  | 0 | 0 | 0 | 0 | 0 |  |  | 0 |
|-------|--|--|--|--|--|--|--|--|---|---|---|---|---|--|--|---|

**VSPOL** CMOS sensor Vsync input polarity

**HSPOL** CMOS sensor Hsync input polarity

**AUTO** Auto lock sensor input horizontal pixel numbers enable

**EN** CMOS sensor process counter enable

### CAM+0014h Component R,Gr,B,Gb Offset Adjustment Register

### CAM\_RGBOFF

|       |           |    |    |    |          |    |    |    |            |    |    |    |           |    |    |    |
|-------|-----------|----|----|----|----------|----|----|----|------------|----|----|----|-----------|----|----|----|
| Bit   | 31        | 30 | 29 | 28 | 27       | 26 | 25 | 24 | 23         | 22 | 21 | 20 | 19        | 18 | 17 | 16 |
| Name  | <b>RS</b> |    |    |    | <b>R</b> |    |    |    | <b>GRS</b> |    |    |    | <b>GR</b> |    |    |    |
| Type  | R/W       |    |    |    | R/W      |    |    |    | R/W        |    |    |    | R/W       |    |    |    |
| Reset | 0         |    |    |    | 0        |    |    |    | 0          |    |    |    | 0         |    |    |    |
| Bit   | 15        | 14 | 13 | 12 | 11       | 10 | 9  | 8  | 7          | 6  | 5  | 4  | 3         | 2  | 1  | 0  |
| Name  | <b>BS</b> |    |    |    | <b>B</b> |    |    |    | <b>GBS</b> |    |    |    | <b>GB</b> |    |    |    |
| Type  | R/W       |    |    |    | R/W      |    |    |    | R/W        |    |    |    | R/W       |    |    |    |
| Reset | 0         |    |    |    | 0        |    |    |    | 0          |    |    |    | 0         |    |    |    |

**RS** Sign of raw data (0,0) offset adjustment control

**R** Component R offset adjustment

**GRS** Sign of raw data (0,1) offset adjustment control

**GR** Component Gr offset adjustment

**BS** Sign of raw data (1,0) offset adjustment control

**B** Component B offset adjustment

**GBS** Sign of raw data (1,1) offset adjustment control

**GB** Component Gb offset adjustment

### CAM+0018h View Finder Mode Control Register

### CAM\_VFCON

|       |    |    |    |    |    |    |    |    |                |                 |    |    |    |               |    |    |
|-------|----|----|----|----|----|----|----|----|----------------|-----------------|----|----|----|---------------|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23             | 22              | 21 | 20 | 19 | 18            | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |                |                 |    |    |    |               |    |    |
| Type  |    |    |    |    |    |    |    |    |                |                 |    |    |    |               |    |    |
| Reset |    |    |    |    |    |    |    |    |                |                 |    |    |    |               |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7              | 6               | 5  | 4  | 3  | 2             | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    | <b>SP_MODE</b> | <b>TAKE_PIC</b> |    |    |    | <b>FR_CON</b> |    |    |
| Type  |    |    |    |    |    |    |    |    | R/W            | R/W             |    |    |    | R/W           |    |    |
| Reset |    |    |    |    |    |    |    |    | 0              | 0               |    |    |    | 0             |    |    |

**SP\_MODE** Still Picture Mode

**TAKE\_PIC** Take Picture Request

**FR\_CON** Frame Sampling Rate Control

**000** Every frame is sampled

**001** One frame is sampled every 2 frames

**010** One frame is sampled every 3 frames

**011** One frame is sampled every 4 frames

**100** One frame is sampled every 5 frames

**101** One frame is sampled every 6 frames

**110** One frame is sampled every 7 frames

**111** One frame is sampled every 8 frames

**CAM+001Ch Camera Module Interrupt Enable Register**
**CAM\_INTEN**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19   | 18   | 17   | 16   |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3    | 2    | 1    | 0    |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    | IDLE | GMCO | REZO | EXPD |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    | VRUN | VRUN | O    |      |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    | R/W  | R/W  | R/W  | R/W  |
|       |    |    |    |    |    |    |    |    |    |    |    |    | 0    | 0    | 0    | 0    |

**LAST** Returning idle state interrupt enable control

**GMCOVRUN** GMC port over run interrupt enable control

**REZOVRUN** Resizer over run interrupt enable control

**EXPDO** Exposure done interrupt enable control

**CAM+0020h Camera Module Interrupt Status Register**
**CAM\_INTSTA**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19   | 18   | 17   | 16   |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3    | 2    | 1    | 0    |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    | IDLE | GMCO | REZO | EXPD |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    | VRUN | VRUN | O    |      |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    | R/W  | R/W  | R/W  | R/W  |
|       |    |    |    |    |    |    |    |    |    |    |    |    | 0    | 0    | 0    | 0    |

**CAM+0030h Preprocessing Control Register 1**
**CAM\_CTRL1**

| Bit   | 31        | 30 | 29           | 28           | 27 | 26 | 25 | 24 | 23        | 22 | 21 | 20 | 19 | 18         | 17 | 16 |
|-------|-----------|----|--------------|--------------|----|----|----|----|-----------|----|----|----|----|------------|----|----|
| Name  |           |    |              |              |    |    |    |    |           |    |    |    |    |            |    |    |
| Type  |           |    |              |              |    |    |    |    |           |    |    |    |    |            |    |    |
| Reset |           |    |              |              |    |    |    |    |           |    |    |    |    |            |    |    |
| Bit   | 15        | 14 | 13           | 12           | 11 | 10 | 9  | 8  | 7         | 6  | 5  | 4  | 3  | 2          | 1  | 0  |
| Name  | BYPP<br>G |    | GLID_<br>POL | GPID_<br>POL |    |    |    |    | PGAIN_INT |    |    |    |    | PGAIN_FRAC |    |    |
| Type  | R/W       |    | R/W          | R/W          |    |    |    |    | R/W       |    |    |    |    | R/W        |    |    |
| Reset | 0         |    | 0            | 0            |    |    |    |    | 2         |    |    |    |    | 0          |    |    |

**GAIN\_COMP** Gain Compensation Control

**P\_LIMIT** Interpolation Limitation Control

**BYPPG** Bypass pre-gain operating enable

**GLID\_POL** Polarity of the line identifier swapped for digital gain operating

**GPID\_POL** Polarity of the pixel identifier swapped for digital gain operating

**PGAIN\_INT** Pre-gain multiplier integer part

**PGAIN\_FRAC** Pre-gain multiplier fraction part

**CAM+0034h Component R,G,B Gain Control Register 1**
**CAM\_RGBGAIN**
**1**

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18     | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |
|      |    |    |    |    |    |    |    |    |    |    |    |    |    | B_GAIN |    |    |

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |         |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---------|---|
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W     |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 80h     |   |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1       | 0 |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | GR_GAIN |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W     |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 80h     |   |

**B\_GAIN** B Gain

**GR\_GAIN** G Gain

### CAM+0038h Component R,G,B Gain Control Register 2

**CAM\_RGBGAIN**  
2

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17     | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R_GAIN |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 80h    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1      | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |

**R\_GAIN** R Gain

### CAM+003Ch Histogram Boundary Control Register1

**CAM\_HIST1**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |     |   |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|-----|---|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17     | 16  |   |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | H1_BND |     |   |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W    |     |   |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 10h    |     |   |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  |    | 7  | 6  | 5  | 4  | 3  | 2      | 1   | 0 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | H3_BND |     |   |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W    |     |   |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 30h    |     |   |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        | 40H |   |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |     |   |

**H1\_BND** Histogram window 1 boundary value

**H2\_BND** Histogram window 2 boundary value

**H3\_BND** Histogram window 3 boundary value

**H4\_BND** Histogram window 4 boundary value

### CAM+0040h Histogram Boundary Control Register2

**CAM\_HIST2**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |   |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|---|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17     | 16 |   |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | H5_BND |    |   |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W    |    |   |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 80h    |    |   |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  |    | 7  | 6  | 5  | 4  | 3  | 2      | 1  | 0 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |   |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |   |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |   |

**H5\_BND** Histogram window 5 boundary value

### CAM+0044h Preprocessing Control Register 2

**CAM\_CTRL2**

|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

| Name  |                  |                |    |    |                |    |              | <b>AEAL_L</b> | <b>CNTE_N</b> | <b>AEPID_POL</b> | <b>AEGI_D_PO_L</b> | <b>CNTC_LR</b> | <b>AEGMSEL</b> | <b>AESEL</b> |
|-------|------------------|----------------|----|----|----------------|----|--------------|---------------|---------------|------------------|--------------------|----------------|----------------|--------------|
| Type  |                  |                |    |    |                |    |              | R/W           | R/W           | R/W              | R/W                | R/W            | R/W            | R/W          |
| Reset |                  |                |    |    |                |    |              | 0             | 1             | 0                | 0                  | 0              | 0              | 1            |
| Bit   | 15               | 14             | 13 | 12 | 11             | 10 | 9            | 8             | 7             | 6                | 5                  | 4              | 3              | 2            |
| Name  | <b>ATFE_DGEN</b> | <b>ATFA_LL</b> |    |    | <b>AWBA_LL</b> |    | <b>GONLY</b> | <b>RLEN</b>   |               | <b>INTEN</b>     |                    |                |                |              |
| Type  | R/W              | R/W            |    |    | R/W            |    | R/W          | R/W           |               | R/W              |                    |                |                |              |
| Reset | 0                | 0              |    |    | 1              |    | 0            | 0             |               | 0                |                    |                |                |              |

**AEALL** AE full frame single window enable

**CNTEN** AE counter enable

**CNTCLR** AE count clear enable

**AEPID\_POL** Polarity of the pixel identifier swapped for AE operating

**AEGID\_POL** Polarity of the line identifier swapped for AE operating

**AEGMSEL** AE gamma curve selection

**00** use gamma curve 0

**01** use gamma curve 1

**10** use gamma curve 2

**11** use gamma curve 3

**AESEL** AE path select

**ATFEDGEN** ATG Edge Enable Control

**ATFALL** ATF area all control

**AWBALL** AWB full frame single window enable

**GONLY** Use G component only for AE

**RLEN** [Description for this register field]

**INTEN** Interpolation FIFO enable

### CAM+0048h AE Window 1 Register

**CAM\_AEWIN1**

| Bit   | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21            | 20 | 19 | 18 | 17 | 16 |
|-------|-------------|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|
| Name  | <b>LEFT</b> |    |    |    |    |    |    |    |    |    | <b>RIGHT</b>  |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    |    |    | R/W           |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    |    |    | 0             |    |    |    |    |    |
| Bit   | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5             | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>TOP</b>  |    |    |    |    |    |    |    |    |    | <b>BOTTOM</b> |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    |    |    | R/W           |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    |    |    | 0             |    |    |    |    |    |

**LEFT** AE 1<sup>st</sup> window left side

**RIGHT** AE 1<sup>st</sup> window right side

**TOP** AE 1<sup>st</sup> window top side

**BOTTOM** AE 1<sup>st</sup> window bottom side

### CAM+004Ch AE Window 2 Register

**CAM\_AEWIN2**

| Bit   | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21           | 20 | 19 | 18 | 17 | 16 |
|-------|-------------|----|----|----|----|----|----|----|----|----|--------------|----|----|----|----|----|
| Name  | <b>LEFT</b> |    |    |    |    |    |    |    |    |    | <b>RIGHT</b> |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    |    |    | R/W          |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    |    |    | 0            |    |    |    |    |    |
| Bit   | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5            | 4  | 3  | 2  | 1  | 0  |

| Name  | TOP | BOTTOM |
|-------|-----|--------|
| Type  | R/W | R/W    |
| Reset | 0   | 0      |

**LEFT** AE 2<sup>nd</sup> window left side

**RIGHT** AE 2<sup>nd</sup> window right side

**TOP** AE 2<sup>nd</sup> window top side

**BOTTOM** AE 2<sup>nd</sup> window bottom side

#### CAM+0050h AE Window 3 Register

**CAM\_AEWIN3**

| Bit   | 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|----|
| Name  | LEFT |    |    |    |    |    |    |    | RIGHT  |    |    |    |    |    |    |    |
| Type  | R/W  |    |    |    |    |    |    |    | R/W    |    |    |    |    |    |    |    |
| Reset | 0    |    |    |    |    |    |    |    | 0      |    |    |    |    |    |    |    |
| Bit   | 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | TOP  |    |    |    |    |    |    |    | BOTTOM |    |    |    |    |    |    |    |
| Type  | R/W  |    |    |    |    |    |    |    | R/W    |    |    |    |    |    |    |    |
| Reset | 0    |    |    |    |    |    |    |    | 0      |    |    |    |    |    |    |    |

**LEFT** AE 3<sup>rd</sup> window left side

**RIGHT** AE 3<sup>rd</sup> window right side

**TOP** AE 3<sup>rd</sup> window top side

**BOTTOM** AE 3<sup>rd</sup> window bottom side

#### CAM+0054h AE Window 4 Register

**CAM\_AEWIN4**

| Bit   | 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|----|
| Name  | LEFT |    |    |    |    |    |    |    | RIGHT  |    |    |    |    |    |    |    |
| Type  | R/W  |    |    |    |    |    |    |    | R/W    |    |    |    |    |    |    |    |
| Reset | 0    |    |    |    |    |    |    |    | 0      |    |    |    |    |    |    |    |
| Bit   | 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | TOP  |    |    |    |    |    |    |    | BOTTOM |    |    |    |    |    |    |    |
| Type  | R/W  |    |    |    |    |    |    |    | R/W    |    |    |    |    |    |    |    |
| Reset | 0    |    |    |    |    |    |    |    | 0      |    |    |    |    |    |    |    |

**LEFT** AE 4<sup>th</sup> window left side

**RIGHT** AE 4<sup>th</sup> window right side

**TOP** AE 4<sup>th</sup> window top side

**BOTTOM** AE 4<sup>th</sup> window bottom side

#### CAM+0058h AE Window 5 Register

**CAM\_AEWIN5**

| Bit   | 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|----|
| Name  | LEFT |    |    |    |    |    |    |    | RIGHT  |    |    |    |    |    |    |    |
| Type  | R/W  |    |    |    |    |    |    |    | R/W    |    |    |    |    |    |    |    |
| Reset | 0    |    |    |    |    |    |    |    | 0      |    |    |    |    |    |    |    |
| Bit   | 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | TOP  |    |    |    |    |    |    |    | BOTTOM |    |    |    |    |    |    |    |
| Type  | R/W  |    |    |    |    |    |    |    | R/W    |    |    |    |    |    |    |    |
| Reset | 0    |    |    |    |    |    |    |    | 0      |    |    |    |    |    |    |    |

**LEFT** AE 5<sup>th</sup> window left side

**RIGHT** AE 5<sup>th</sup> window right side

**TOP** AE 5<sup>th</sup> window top side

**BOTTOM** AE 5<sup>th</sup> window bottom side

### CAM+005Ch AE Window 6 Register

**CAM\_AEWIN6**

| Bit   | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23            | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-------------|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|----|
| Name  | <b>LEFT</b> |    |    |    |    |    |    |    | <b>RIGHT</b>  |    |    |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    | R/W           |    |    |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    | 0             |    |    |    |    |    |    |    |
| Bit   | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7             | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>TOP</b>  |    |    |    |    |    |    |    | <b>BOTTOM</b> |    |    |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    | R/W           |    |    |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    | 0             |    |    |    |    |    |    |    |

**LEFT** AE 6<sup>th</sup> window left side

**RIGHT** AE 6<sup>th</sup> window right side

**TOP** AE 6<sup>th</sup> window top side

**BOTTOM** AE 6<sup>th</sup> window bottom side

### CAM+0060h AE Window 7 Register

**CAM\_AEWIN7**

| Bit   | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23            | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-------------|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|----|
| Name  | <b>LEFT</b> |    |    |    |    |    |    |    | <b>RIGHT</b>  |    |    |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    | R/W           |    |    |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    | 0             |    |    |    |    |    |    |    |
| Bit   | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7             | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>TOP</b>  |    |    |    |    |    |    |    | <b>BOTTOM</b> |    |    |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    | R/W           |    |    |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    | 0             |    |    |    |    |    |    |    |

**LEFT** AE 7<sup>th</sup> window left side

**RIGHT** AE 7<sup>th</sup> window right side

**TOP** AE 7<sup>th</sup> window top side

**BOTTOM** AE 7<sup>th</sup> window bottom side

### CAM+0064h AE Window 8 Register

**CAM\_AEWIN8**

| Bit   | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23            | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-------------|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|----|
| Name  | <b>LEFT</b> |    |    |    |    |    |    |    | <b>RIGHT</b>  |    |    |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    | R/W           |    |    |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    | 0             |    |    |    |    |    |    |    |
| Bit   | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7             | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>TOP</b>  |    |    |    |    |    |    |    | <b>BOTTOM</b> |    |    |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    | R/W           |    |    |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    | 0             |    |    |    |    |    |    |    |

**LEFT** AE 8<sup>th</sup> window left side

**RIGHT** AE 8<sup>th</sup> window right side

**TOP** AE 8<sup>th</sup> window top side

**BOTTOM** AE 8<sup>th</sup> window bottom side

### CAM+0068h AE Window 9 Register

**CAM\_AEWIN9**

| Bit   | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23           | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-------------|----|----|----|----|----|----|----|--------------|----|----|----|----|----|----|----|
| Name  | <b>LEFT</b> |    |    |    |    |    |    |    | <b>RIGHT</b> |    |    |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    | R/W          |    |    |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    | 0            |    |    |    |    |    |    |    |

|       |            |    |    |    |    |    |   |   |               |   |   |   |   |   |   |   |
|-------|------------|----|----|----|----|----|---|---|---------------|---|---|---|---|---|---|---|
| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | <b>TOP</b> |    |    |    |    |    |   |   | <b>BOTTOM</b> |   |   |   |   |   |   |   |
| Type  | R/W        |    |    |    |    |    |   |   | R/W           |   |   |   |   |   |   |   |
| Reset | 0          |    |    |    |    |    |   |   | 0             |   |   |   |   |   |   |   |

**LEFT** AE 9<sup>th</sup> window left side

**RIGHT** AE 9<sup>th</sup> window right side

**TOP** AE 9<sup>th</sup> window top side

**BOTTOM** AE 9<sup>th</sup> window bottom side

**CAM+006Ch AWB Window Register**
**CAM\_AWBWIN**

|       |             |    |    |    |    |    |    |    |               |    |    |    |    |    |    |    |
|-------|-------------|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|----|
| Bit   | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23            | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>LEFT</b> |    |    |    |    |    |    |    | <b>RIGHT</b>  |    |    |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    | R/W           |    |    |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    | 0             |    |    |    |    |    |    |    |
| Bit   | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7             | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>TOP</b>  |    |    |    |    |    |    |    | <b>BOTTOM</b> |    |    |    |    |    |    |    |
| Type  | R/W         |    |    |    |    |    |    |    | R/W           |    |    |    |    |    |    |    |
| Reset | 0           |    |    |    |    |    |    |    | 0             |    |    |    |    |    |    |    |

**LEFT** AWB window left side

**RIGHT** AWB window right side

**TOP** AWB window top side

**BOTTOM** AWB window bottom side

**CAM+0070h Color Processing Stage Control Register**
**CAM\_CPSCON1**

|       |                |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |    |
|-------|----------------|----|----|----|----|----|----|----|-----------------|----|----|----|----|----|----|----|
| Bit   | 31             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23              | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |                |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |    |
| Type  |                |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |    |
| Reset |                |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |    |
| Bit   | 15             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7               | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>BYPIN T</b> |    |    |    |    |    |    |    | <b>NONLIN N</b> |    |    |    |    |    |    |    |
| Type  | R/W            |    |    |    |    |    |    |    | R/W             |    |    |    |    |    |    |    |
| Reset | 0              |    |    |    |    |    |    |    | 0               |    |    |    |    |    |    |    |

**BYPINT** Interpolation first 4 invalid output pixel used enable

**NONLIN** Nonlinear mode enable in color correction operation

**LEDGEN** Line edge enable

**DISLJ** Disable line judge enable

**CAM+0074h Interpolation Register1**
**CAM\_INTER1**

|       |                 |    |    |    |    |    |    |    |                |    |    |    |    |    |    |    |
|-------|-----------------|----|----|----|----|----|----|----|----------------|----|----|----|----|----|----|----|
| Bit   | 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23             | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>THRE_V</b>   |    |    |    |    |    |    |    | <b>THRE_SM</b> |    |    |    |    |    |    |    |
| Type  | R/W             |    |    |    |    |    |    |    | R/W            |    |    |    |    |    |    |    |
| Reset | 0Ah             |    |    |    |    |    |    |    | 05h            |    |    |    |    |    |    |    |
| Bit   | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7              | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>THRE_DHV</b> |    |    |    |    |    |    |    | <b>THRE_RT</b> |    |    |    |    |    |    |    |
| Type  | R/W             |    |    |    |    |    |    |    | R/W            |    |    |    |    |    |    |    |
| Reset | 19h             |    |    |    |    |    |    |    | 10h            |    |    |    |    |    |    |    |

**THRE\_V** [Description for this register field]

**THRE\_SM** [Description for this register field]

**THRE\_DHV** [Description for this register field]

**THRE\_RT** [Description for this register field]

**CAM+0078h Interpolation Register 2**
**CAM\_INTER2**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**THRE\_LEDGE**

R/W

14h

**THRE\_LEDGE** [Description for this register field]

**CAM+007Ch Edge Core Register**
**CAM\_EDGCOR\_E**

| Bit   | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23               | 22               | 21              | 20 | 19 | 18 | 17 | 16 |
|-------|--------------|----|----|----|----|----|----|----|------------------|------------------|-----------------|----|----|----|----|----|
| Name  | <b>COREH</b> |    |    |    |    |    |    |    | <b>EMBO_SS1</b>  | <b>EMBO_SS2</b>  | <b>COREH2</b>   |    |    |    |    |    |
| Type  | R/W          |    |    |    |    |    |    |    | R/W              | R/W              | R/W             |    |    |    |    |    |
| Reset | 08h          |    |    |    |    |    |    |    | 0                | 0                | 1Fh             |    |    |    |    |    |
| Bit   | 15           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                | 6                | 5               | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>COREV</b> |    |    |    |    |    |    |    | <b>TOP_SLOPE</b> | <b>TOP_SLOPE</b> | <b>CORE_CON</b> |    |    |    |    |    |
| Type  | R/W          |    |    |    |    |    |    |    | R/W              | R/W              | R/W             |    |    |    |    |    |
| Reset | 8h           |    |    |    |    |    |    |    | 0                |                  | 14h             |    |    |    |    |    |

**COREH** [Description for this register field]

**EMBOSS1** Emboss effect mode 1 enable

**EMBOSS2** Emboss effect mode 2 enable

**COREH2** [Description for this register field]

**COREV**[3:2] Negative Slope [1:0] Positive Slope

**TOP\_SLOPE** [Description for this register field]

**CORE\_CON** [Description for this register field]

**CAM+0080h Edge Gain Register 1**
**CAM\_EDGGAIN\_1**

| Bit   | 31               | 30 | 29                | 28 | 27              | 26 | 25 | 24           | 23 | 22             | 21 | 20 | 19                | 18 | 17              | 16 |
|-------|------------------|----|-------------------|----|-----------------|----|----|--------------|----|----------------|----|----|-------------------|----|-----------------|----|
| Name  | <b>SPECIGAIN</b> |    | <b>SPECIPONLY</b> |    | <b>EGAIN_H</b>  |    |    |              |    |                |    |    |                   |    | <b>EGAIN_H2</b> |    |
| Type  | R/W              |    | R/W               |    | R/W             |    |    |              |    |                |    |    |                   |    | R/W             |    |
| Reset | 0                |    | 0                 |    | 1               |    |    |              |    |                |    |    |                   |    | 3               |    |
| Bit   | 15               | 14 | 13                | 12 | 11              | 10 | 9  | 8            | 7  | 6              | 5  | 4  | 3                 | 2  | 1               | 0  |
| Name  |                  |    |                   |    | <b>EGAIN_VB</b> |    |    | <b>OILEN</b> |    | <b>KNEESEL</b> |    |    | <b>EGAINLILNE</b> |    |                 |    |
| Type  |                  |    |                   |    | R/W             |    |    | R/W          |    | R/W            |    |    | R/W               |    |                 |    |
| Reset |                  |    |                   |    | 3               |    |    | 0            |    | 3              |    |    | 2                 |    |                 |    |

**SPECIGAIN** Edge special gain value

**SPECIPONLY** Edge special p only value

**EGAIN\_H** Edge gain H value

**EGAIN\_H2** Edge gain H2 value

**EGAIN\_VB** Edge gain Vb value

**OILEN** Oil effect enable

**KNEESEL** [Description for this register field]

**EGAINLINE** Edge gain line value

**CAM+0084h Edge Gain Register 2**
**CAM\_EDGGAIN  
2**

|       |    |    |    |    |    |    |    |    |          |          |    |    |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|----------|----------|----|----|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23       | 22       | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |          |          |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |          |          |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |          |          |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7        | 6        | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    | SPECIABS | SPECIINV |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    | R/W      | R/W      |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    | 0        | 0        |    |    |    |    |    | Fh |

**SPECIABS** Edge special absolute enable

**SPECIINV** Edge special invert enable

**EGAIN\_HC** Edge gain Hc

**CAM+0088h Edge Threshold Register**
**CAM\_EDGTHRE**

|       |       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
|-------|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|
| Bit   | 31    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  |
| Name  |       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
| Type  |       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
| Reset |       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
| Bit   | 15    | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0   |
| Name  | ONLYC |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
| Type  | R/W   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
| Reset | 0     |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 07h |

**ETH3** Edge threshold value

**ETH\_CON** [Description for this register field]

**ONLYC** Edge enhanced C component only enable

**THRE\_EDGE\_SUP** [Description for this register field]

**THRL\_EDGE\_SUP** [Description for this register field]

**CAM+008Ch Edge Vertical Control Register**
**CAM\_EDGVCO  
N**

|       |      |    |    |    |    |    |    |    |       |       |    |    |    |    |    |     |
|-------|------|----|----|----|----|----|----|----|-------|-------|----|----|----|----|----|-----|
| Bit   | 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22    | 21 | 20 | 19 | 18 | 17 | 16  |
| Name  | HPEN |    |    |    |    |    |    |    |       |       |    |    |    |    |    |     |
| Type  | R/W  |    |    |    |    |    |    |    |       |       |    |    |    |    |    |     |
| Reset | 0    |    |    |    |    |    |    |    |       |       |    |    |    |    |    | 1Fh |
| Bit   | 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7     | 6     | 5  | 4  | 3  | 2  | 1  | 0   |
| Name  |      |    |    |    |    |    |    |    | SUP_V | SDN_V |    |    |    |    |    |     |
| Type  |      |    |    |    |    |    |    |    | R/W   | R/W   |    |    |    |    |    |     |
| Reset |      |    |    |    |    |    |    |    | 0     | 2     |    |    |    |    |    | 32h |

**HPEN** Edge high pass enable

**E\_TH1\_V** [Description for this register field]

**HALF\_V** [Description for this register field]

**SUP\_V** [Description for this register field]

**SDN\_V** [Description for this register field]

**E\_TH3\_V** [Description for this register field]

### CAM+0090h Axis RGB Gain Register

**CAM\_AXGAIN**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>R_GAIN</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W           |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 3Fh           |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0             |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>G_GAIN</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W           |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 3Fh           |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>B_GAIN</b> |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W           |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 3Fh           |

**R\_GAIN** Axis R component gain

**G\_GAIN** Axis G component gain

**B\_GAIN** Axis B component gain

### CAM+0094h OPD Configuration Register

**CAM\_OPDCFG**

| Bit   | 31          | 30          | 29       | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16             |
|-------|-------------|-------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----------------|
| Name  | <b>OPDE</b> | <b>OPDC</b> | <b>N</b> |    |    |    |    |    |    |    |    |    |    |    |    | <b>U_GAIN</b>  |
| Type  | R/W         | R/W         |          |    |    |    |    |    |    |    |    |    |    |    |    | R/W            |
| Reset | 1           | 0           |          |    |    |    |    |    |    |    |    |    |    |    |    | 1Fh            |
| Bit   | 15          | 14          | 13       | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0              |
| Name  |             |             |          |    |    |    |    |    |    |    |    |    |    |    |    | <b>V_GAIN</b>  |
| Type  |             |             |          |    |    |    |    |    |    |    |    |    |    |    |    | R/W            |
| Reset |             |             |          |    |    |    |    |    |    |    |    |    |    |    |    | 1Fh            |
|       |             |             |          |    |    |    |    |    |    |    |    |    |    |    |    | <b>Y_LIMIT</b> |
|       |             |             |          |    |    |    |    |    |    |    |    |    |    |    |    | R/W            |
|       |             |             |          |    |    |    |    |    |    |    |    |    |    |    |    | 3              |

**OPDEN** OPD counter enable

**OPDCLR** OPD counter clear enable

**SUPSEL** Reserved

**U\_GAIN** OPD U gain value

**V\_GAIN** OPD V gain value

**Y\_LIMIT** Reserved

### CAM+0098h OPD Component Parameter Register

**CAM\_OPDPAR**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>S_RB_P</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W           |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 7Fh           |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0             |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>S_RB_N</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W           |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 7Fh           |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>S_MG_P</b> |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W           |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 7Fh           |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>S_MG_N</b> |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W           |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 7Fh           |

**S\_RB\_P** OPD SR Bp value

**S\_RB\_N** OPD SR Bn value

**S\_MG\_P** OPD SMGp value  
**S\_MG\_N** OPD SNGn value

### CAM+009Ch Color Matrix 1 Register

**CAM\_MATRIX1**

|       |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20         | 19 | 18 | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    | <b>M11</b> |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    | R/W        |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    | 20h        |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4          | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    | <b>M12</b> |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    | R/W        |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    | 80h        |    |    |    |    |

**M11** Color matrix 11 value  
**M12** Color matrix 12 value  
**M13** Color matrix 13 value

### CAM+00A0h Color Matrix 2 Register

**CAM\_MATRIX2**

|       |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20         | 19 | 18 | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    | <b>M21</b> |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    | R/W        |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    | 80h        |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4          | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    | <b>M22</b> |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    | R/W        |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    | 20h        |    |    |    |    |

**M21** Color matrix 21 value  
**M22** Color matrix 22 value  
**M23** Color matrix 23 value

### CAM+00A4h Color Matrix 3 Register

**CAM\_MATRIX3**

|       |    |    |    |    |    |    |    |    |    |    |    |            |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20         | 19 | 18 | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    | <b>M31</b> |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    | R/W        |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    | 80h        |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4          | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    | <b>M32</b> |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    | R/W        |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    | 80h        |    |    |    |    |

**M31** Color matrix 31 value  
**M32** Color matrix 32 value  
**M33** Color matrix 33 value

### CAM+00A8h Color Matrix RGB Gain Register

**CAM\_MTXGAIN**

|       |    |    |    |    |    |    |    |    |    |    |    |               |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20            | 19 | 18 | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    | <b>R_GAIN</b> |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    | R/W           |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    | 20h           |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4             | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    | <b>G_GAIN</b> |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    | R/W           |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    | <b>B_GAIN</b> |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |    |    | R/W           |    |    |    |    |

|       |  |     |  |     |  |
|-------|--|-----|--|-----|--|
| Reset |  | 20h |  | 20h |  |
|-------|--|-----|--|-----|--|

**R\_GAIN** Color matrix R component gain value

**G\_GAIN** Color matrix G component gain value

**B\_GAIN** Color matrix B component gain value

### CAM+00ACh Color Process Stage Control Register 2

### CAM\_CPSCON2

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23            | 22               | 21             | 20                | 19 | 18             | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|---------------|------------------|----------------|-------------------|----|----------------|----|----|
| Name  |    |    |    |    |    |    |    |    |               |                  |                |                   |    |                |    |    |
| Type  |    |    |    |    |    |    |    |    |               |                  |                |                   |    |                |    |    |
| Reset |    |    |    |    |    |    |    |    |               |                  |                |                   |    |                |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7             | 6                | 5              | 4                 | 3  | 2              | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    | <b>BYPG M</b> | <b>RGBE DGEN</b> | <b>YEDG EN</b> | <b>OPRG M_IVT</b> |    | <b>Y_EGAIN</b> |    |    |
| Type  |    |    |    |    |    |    |    |    | R/W           | R/W              | R/W            | R/W               |    | R/W            |    |    |
| Reset |    |    |    |    |    |    |    |    | 0             | 0                | 0              | 0                 |    | 0              |    |    |

**BYPGM** Bypass gamma enable

**RGBEDGAINEN** Reserved

**YEDGEN** Y channel edge enable

**OPDGM\_IVT** Gamma output inverse mode enable

**Y\_EGAIN** Y channel edge gain value

### CAM+00B0h AWB RGB Gain Register

### CAM\_AWBGAIN

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23               | 22 | 21               | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|------------------|----|------------------|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |                  |    |                  |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |                  |    |                  |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |                  |    |                  |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                | 6  | 5                | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    | <b>AWB_RGAIN</b> |    | <b>AWB_BGAIN</b> |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    | R/W              |    | R/W              |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    | 80h              |    | 80h              |    |    |    |    |    |

**AWB\_RGAIN** AWB R component gain value

**AWB\_GGAIN** AWB G component gain value

**AWB\_BGAIN** AWB B component gain value

### CAM+00B4h Gamma RGB Flare Register

### CAM\_GAMFLRE

| Bit   | 31            | 30 | 29 | 28 | 27 | 26 | 25 | 24              | 23            | 22  | 21             | 20 | 19 | 18 | 17 | 16 |
|-------|---------------|----|----|----|----|----|----|-----------------|---------------|-----|----------------|----|----|----|----|----|
| Name  |               |    |    |    |    |    |    |                 | <b>SIGN_R</b> |     | <b>FLARE_R</b> |    |    |    |    |    |
| Type  |               |    |    |    |    |    |    |                 | R/W           |     | R/W            |    |    |    |    |    |
| Reset |               |    |    |    |    |    |    |                 | 0             |     | 0              |    |    |    |    |    |
| Bit   | 15            | 14 | 13 | 12 | 11 | 10 | 9  | 8               | 7             | 6   | 5              | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>SIGN_G</b> |    |    |    |    |    |    | <b>FLAIRE_G</b> | <b>SIGN_B</b> |     | <b>FLARE_B</b> |    |    |    |    |    |
| Type  | R/W           |    |    |    |    |    |    | R/W             |               | R/W |                |    |    |    |    |    |
| Reset | 0             |    |    |    |    |    |    | 0               |               | 0   |                |    |    |    |    |    |

**SIGN\_R** Reserved

**FLARE\_R** Reserved

**SIGN\_G** Reserved

**FLARE\_G** Reserved

**SIGN\_B** Reserved

**FLARE\_B** Reserved

**CAM+00B8h Y Channel Configuration Register**
**CAM\_YCHAN**

| Bit   | 31                        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                    |
|-------|---------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|
| Name  |                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>CONTRAST_GAIN</b>  |
| Type  |                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                   |
| Reset |                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 40h                   |
| Bit   | 15                        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                     |
| Name  | <b>SIGN_BRIGHT_OFFSET</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>CSUP_EDGE_GAIN</b> |
| Type  | R/W                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                   |
| Reset | 1                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 10h                   |

**CONTRAST\_GAIN** Y channel contrast gain value

**SIGN\_BRIGHT\_OFFSET** Sign bit of Y channel brightness offset value

**BRIGHT\_OFFSET** Y channel brightness offset value

**CSUP\_EDGE\_GAIN** Chroma suppression edge gain value

**CAM+00BCh UV Channel Configuration Register**
**CAM\_UVCHAN**

| Bit   | 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23                   | 22 | 21 | 20 | 19 | 18 | 17 | 16         |
|-------|----------------------|----|----|----|----|----|----|----|----------------------|----|----|----|----|----|----|------------|
| Name  |                      |    |    |    |    |    |    |    |                      |    |    |    |    |    |    | <b>U11</b> |
| Type  |                      |    |    |    |    |    |    |    |                      |    |    |    |    |    |    | R/W        |
| Reset |                      |    |    |    |    |    |    |    |                      |    |    |    |    |    |    | 20h        |
| Bit   | 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                    | 6  | 5  | 4  | 3  | 2  | 1  | 0          |
| Name  | <b>SIGN_U_OFFSET</b> |    |    |    |    |    |    |    | <b>SIGN_V_OFFSET</b> |    |    |    |    |    |    | <b>V22</b> |
| Type  | R/W                  |    |    |    |    |    |    |    | R/W                  |    |    |    |    |    |    | R/W        |
| Reset | 0                    |    |    |    |    |    |    |    | 0                    |    |    |    |    |    |    | 0          |

**U11** Hue U channel operating value

**V11** Hue V channel operating value

**SIGN\_U\_OFFSET** Sign bit of Hue U channel offset value

**U\_OFFSET** Hue U channel offset value

**SIGN\_V\_OFFSET** Sign bit of Hue V channel offset value

**V\_OFFSET** Hue V channel offset value

**CAM+00C0h Space Convert YUV Register 1**
**CAM\_SCONV1**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Y_GAIN</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W           |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | FFh           |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0             |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>U_GAIN</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W           |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 91h           |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | B8h           |

**Y\_GAIN** Space Convert Y channel gain value

**U\_GAIN** Space Convert U channel gain value

**V\_GAIN** Space Convert V channel gain value

**CAM+00C4h Space Convert YUV Register 2**
**CAM\_SCONV2**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Y_OFFSET</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W             |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 01h             |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>U_OFFSET</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W             |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 80h             |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>V_OFFSET</b> |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W             |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 80h             |

**Y\_OFFSET** Space Convert Y channel offset value

**U\_OFFSET** Space Convert U channel offset value

**V\_OFFSET** Space Convert V channel offset value

**CAM+00C8h Gamma Operation Register 1**
**CAM\_GAMMA1**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GAMMA_B1</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W             |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 32h             |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GAMMA_B2</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W             |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 50h             |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GAMMA_B3</b> |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W             |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 65h             |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GAMMA_B4</b> |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W             |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 76h             |

**GAMMA\_B1** Gamma operating B1 value

**GAMMA\_B2** Gamma operating B2 value

**GAMMA\_B3** Gamma operating B3 value

**GAMMA\_B4** Gamma operating B4 value

**CAM+00CCh Gamma Operation Register 2**
**CAM\_GAMMA2**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GAMMA_B5</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W             |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 94h             |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GAMMA_B6</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W             |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Aeh             |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GAMMA_B7</b> |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W             |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | C5h             |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Dah             |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GAMMA_B8</b> |

**GAMMA\_B5** Gamma operating B5 value

**GAMMA\_B6** Gamma operating B6 value

**GAMMA\_B7** Gamma operating B7 value

**GAMMA\_B8** Gamma operating B8 value

**CAM+00D0h Gamma Operation Register 3**
**CAM\_GAMMA3**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16               |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GAMMA_B9</b>  |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W              |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | E4h              |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GAMMA_B10</b> |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W              |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | EDh              |

|       |                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit   | 15               | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | <b>GAMMA_B11</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | F7h              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**GAMMA\_B9** Gamma operating B9 value

**GAMMA\_B10** Gamma operating B10 value

**GAMMA\_B11** Gamma operating B11 value

#### CAM+00D4h OPD Y Result Register

**CAM\_OPDY**

|       |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>OPD_Y[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>OPD_Y[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**OPD\_Y** OPD Y component accumulation result

#### CAM+00D8h OPD MG Result Register

**CAM\_OPDMG**

|       |                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>OPD_MG[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>OPD_MG[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**OPD\_MG** OPD MG component accumulation result

#### CAM+00DCh OPD RB Result Register

**CAM\_OPDRB**

|       |                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>OPD_RB[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>OPD_RB[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**OPD\_RB** OPD RB component accumulation result

#### CAM+00E0h OPD Pixel Count Register

**CAM\_OPDCNT**

|       |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31            | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>PXLCNT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15            | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>PXLCNT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**PXLCNT** OPD pixel counter accumulation result

**CAM+00E4h AE Window 1 Result Register**

**CAM\_AE1RLT**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                    |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SUM_AE1[28:16]</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R                     |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                     |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SUM_AE1[15:0]</b>  |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                     |

**SUM\_AE1** AE window 1 accumulation result

**CAM+00E8h AE Window 2 Result Register**

**CAM\_AE2RLT**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                    |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SUM_AE2[28:16]</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                     |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SUM_AE2[15:0]</b>  |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                     |

**SUM\_AE2** AE window 2 accumulation result

**CAM+00ECh AE Window 3 Result Register**

**CAM\_AE3RLT**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                    |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SUM_AE3[28:16]</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                     |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SUM_AE3[15:0]</b>  |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                     |

**SUM\_AE3** AE window 3 accumulation result

**CAM+00F0h AE Window 4 Result Register**

**CAM\_AE4RLT**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                    |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SUM_AE4[28:16]</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                     |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SUM_AE4[15:0]</b>  |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                     |

**SUM\_AE4** AE window 4 accumulation result

**CAM+00F4h AE Window 5 Result Register**

**CAM\_AE5RLT**

|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |                       |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-----------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | <b>SUM_AE5[28:16]</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | RO                    |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 0                     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |                       |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | <b>SUM_AE5[15:0]</b>  |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | RO                    |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   | 0                     |

**SUM\_AE5** AE window 5 accumulation result

#### CAM+00F8h AE Window 6 Result Register

**CAM\_AE6RLT**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                       |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SUM_AE6[28:16]</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                       |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SUM_AE6[15:0]</b>  |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                     |

**SUM\_AE6** AE window 6 accumulation result

#### CAM+00FCCh AE Window 7 Result Register

**CAM\_AE7RLT**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                       |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SUM_AE7[28:16]</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                       |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SUM_AE7[15:0]</b>  |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                     |

**SUM\_AE7** AE window 7 accumulation result

#### CAM+0100h AE Window 8 Result Register

**CAM\_AE8RLT**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                       |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SUM_AE8[28:16]</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                       |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SUM_AE8[15:0]</b>  |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                     |

**SUM\_AE8** AE window 8 accumulation result

#### CAM+0104h AE Window 9 Result Register

**CAM\_AE9RLT**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                       |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SUM_AE9[28:16]</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                       |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SUM_AE9[15:0]</b>  |

|       |    |
|-------|----|
| Type  | RO |
| Reset | 0  |

**SUM\_AE9** AE window 9 accumulation result

#### CAM+0108h AE A Number Result Register

**CAM\_AEARLT**

|       |    |    |    |    |    |    |    |    |       |    |    |    |    |       |    |    |
|-------|----|----|----|----|----|----|----|----|-------|----|----|----|----|-------|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19 | 18    | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |       |    |    |    |    | A_RLT |    |    |
| Type  |    |    |    |    |    |    |    |    |       |    |    |    |    | R     |    |    |
| Reset |    |    |    |    |    |    |    |    |       |    |    |    |    | 0     |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7     | 6  | 5  | 4  | 3  | 2     | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    | A_RLT |    |    |    |    |       |    |    |
| Type  |    |    |    |    |    |    |    |    | RO    |    |    |    |    |       |    |    |
| Reset |    |    |    |    |    |    |    |    | 0     |    |    |    |    |       |    |    |

#### CAM+010Ch AE B Number Result Register

**CAM\_AEBRLT**

|       |    |    |    |    |    |    |    |    |       |    |    |    |    |       |    |    |
|-------|----|----|----|----|----|----|----|----|-------|----|----|----|----|-------|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19 | 18    | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |       |    |    |    |    | B_RLT |    |    |
| Type  |    |    |    |    |    |    |    |    |       |    |    |    |    | R     |    |    |
| Reset |    |    |    |    |    |    |    |    |       |    |    |    |    | 0     |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7     | 6  | 5  | 4  | 3  | 2     | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    | B_RLT |    |    |    |    |       |    |    |
| Type  |    |    |    |    |    |    |    |    | RO    |    |    |    |    |       |    |    |
| Reset |    |    |    |    |    |    |    |    | 0     |    |    |    |    |       |    |    |

#### CAM+0110h AE C Number Result Register

**CAM\_AECRLT**

|       |    |    |    |    |    |    |    |    |       |    |    |    |    |       |    |    |
|-------|----|----|----|----|----|----|----|----|-------|----|----|----|----|-------|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19 | 18    | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |       |    |    |    |    | C_RLT |    |    |
| Type  |    |    |    |    |    |    |    |    |       |    |    |    |    | R     |    |    |
| Reset |    |    |    |    |    |    |    |    |       |    |    |    |    | 0     |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7     | 6  | 5  | 4  | 3  | 2     | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    | C_RLT |    |    |    |    |       |    |    |
| Type  |    |    |    |    |    |    |    |    | RO    |    |    |    |    |       |    |    |
| Reset |    |    |    |    |    |    |    |    | 0     |    |    |    |    |       |    |    |

#### CAM+0114h AE D Number Result Register

**CAM\_AEDRLT**

|       |    |    |    |    |    |    |    |    |       |    |    |    |    |       |    |    |
|-------|----|----|----|----|----|----|----|----|-------|----|----|----|----|-------|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19 | 18    | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |       |    |    |    |    | D_RLT |    |    |
| Type  |    |    |    |    |    |    |    |    |       |    |    |    |    | R     |    |    |
| Reset |    |    |    |    |    |    |    |    |       |    |    |    |    | 0     |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7     | 6  | 5  | 4  | 3  | 2     | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    | D_RLT |    |    |    |    |       |    |    |
| Type  |    |    |    |    |    |    |    |    | RO    |    |    |    |    |       |    |    |
| Reset |    |    |    |    |    |    |    |    | 0     |    |    |    |    |       |    |    |

#### CAM+0118h AE E Number Result Register

**CAM\_AEERLT**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18    | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    | E_RLT |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    | R     |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    | 0     |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2     | 1  | 0  |

|       |       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------|-------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Name  | E_RLT |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type  | RO    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset | 0     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**CAM+011Ch Low Pass Filter Control Register**
**CAM\_LPFCON**

| Bit   | 31          | 30        | 29          | 28        | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18         | 17         | 16         |
|-------|-------------|-----------|-------------|-----------|----|----|----|----|----|----|----|----|----|------------|------------|------------|
| Name  |             |           |             |           |    |    |    |    |    |    |    |    |    |            |            |            |
| Type  |             |           |             |           |    |    |    |    |    |    |    |    |    |            |            |            |
| Reset |             |           |             |           |    |    |    |    |    |    |    |    |    |            |            |            |
| Bit   | 15          | 14        | 13          | 12        | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2          | 1          | 0          |
| Name  | Y_LP<br>FEN | Y_LPFTYPE | C_LP<br>FEN | C_LPFTYPE |    |    |    |    |    |    |    |    |    | SUB1/<br>8 | SUB1/<br>4 | SUB1/<br>2 |
| Type  | R/W         | R/W       | R/W         | R/W       |    |    |    |    |    |    |    |    |    | R/W        | R/W        | R/W        |
| Reset | 0           | 2         | 1           | 2         |    |    |    |    |    |    |    |    |    | 0          | 1          | 0          |

**Y\_LPFEN** Enable Luminance channel low pass filter

**Y\_LPFTYPE** Luminance channel filter selection

**C\_LPFEN** Enable Chrominance channel low pass filter

**C\_LPFTYPE** Chrominance channel filter selection

**SUB1/8** Enable 1:8 sub-sampling

**SUB1/4** Enable 1:4 sub-sampling

**SUB1/2** Enable 1:2 sub-sampling

**CAM+0180h Camera Interface Debug Mode Control Register**
**CAM\_DEBUG**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23        | 22          | 21        | 20          | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|-----------|-------------|-----------|-------------|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |           |             |           |             |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |           |             |           |             |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |           |             |           |             |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7         | 6           | 5         | 4           | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    | GMCO<br>N | GMC<br>MODE | CNTO<br>N | CNT<br>MODE |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    | R/W       | R/W         | R/W       | R/W         |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    | 0         | 0           | 0         | 0           |    |    |    |    |

**GMCON** Enable GMC Debug Port

**GCMODEGMC** Debug Mode Select 0:sRGB 1:YCbCr

**CNTON** Enable Debug Mode Data Transfer Counter

**CNTMODE** Data Transfer Count Selection

00 sRGB count

01 YCbCr count

10 GMC port count

11 Resizer port count

**CAM+0184h**
**Camera Module Debug Information Write Out  
Destination Address**
**CAM\_DSTADDR**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23             | 22  | 21    | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----------------|-----|-------|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    | DST_ADD[31:16] |     |       |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |                | R/W |       |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |                |     | 4000h |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7              | 6   | 5     | 4  | 3  | 2  | 1  | 0  |

|       |                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------|----------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Name  | <b>DST_ADD[15:0]</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type  | R/W                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset | 0000h                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**DST\_ADD** Debug Information Write Output Destination Address

**CAM+0188h Camera Module Debug Information Last Transfer Destination Address CAM\_LASTADD R**

|       |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31                     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>LAST_ADD[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>LAST_ADD[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**LAST\_ADD** Debug Information Last Transfer Destination Address

**CAM+018Ch Camera Module Frame Buffer Transfer Out Count Register CAM\_XFERCNT**

|       |                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|---------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31                        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>XFER_COUNT [31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>XFER_COUNT [15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**XFER\_COUNT** Pixel Transfer Count per Frame

**CAM+0190h CMOS Sensor Test Model Configuration Register 1 CAM\_MDLCFG1**

|       |                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|-------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31                                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>VSYNC</b>                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>ON RST STILL PATTERN CLK_DIV</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W R/W R/W R/W R/W                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 0 0 0 0                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**VSYNC** VSYNC high duration in line unit(IDLE\_PIXEL\_PER\_LINE + PIXEL)

**IDLE\_PIXEL\_PER\_LINE** HSYNC low duration in pixel unit

**ON** Enable CMOS Sensor Model

**RST** Reset CMOS Sensor Model

**STILL** Still picture Mode

**PATTERN** CMOS Sensor Model Test Pattern Selection

**CLK\_DIV** Pixel\_Clock/System\_Clock Ratio

**CAM+0194h CMOS Sensor Test Model Configuration Register 2 CAM\_MDLCFG2**

|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |       |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | LINE  |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0     |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | PIXEL |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0     |

**LINE** CMOS Sensor Model Line Number

**PIXEL** CMOS Sensor Model Pixel Number (HSYNC high duration in pixel unit)

## 6.11 Image DMA

### 6.11.1 General Description

Image DMA plays the role of moving image data between different image modules and memory. **Figure 57** illustrates the interconnections around Image DMA. The major functions of Image DMA are list below.

- Data movement
- Color format conversion (RGB565  $\Leftrightarrow$  RGB888, YUV444  $\Leftrightarrow$  YUV420, YUV444  $\Rightarrow$  YUV422)
- Data stream flow control on JPEG Encoder DMA
- Twice resizing for video capture
- Hardware handshaking with LCD DMA, and direct couple interface to LCD DMA
- Image panning
- Supporting BMP image file formats.

Image DMA consists of five DMA engines. They are JPEG Encoder DMA, Video DMA, Image Buffer Write 1 DMA (IBW1 DMA), IBW2 DMA, and Image Buffer Read 1 DMA (IBR1 DMA). Each DMA engine has specific purposes. The details of each DMA engine are described in following sections.



Figure 57 inter-connection around Image DMA

### 6.11.1.1 JPEG Encoder DMA

The main function of JPEG Encoder DMA is to receive YUV 444 data from Image Engine by pixels and transmit YUV 422 data to JPEG Encoder by 8 X 8 blocks.

#### 6.11.1.1.1 Flow Control

To achieve pixel to block conversion, line buffer must be given, and its line count must be multiple of 8. For better performance, it's recommended to have a minimum of 16 lines of buffer. For applications where images are captured from camera, because the data stream from camera can not be stopped, the number of lines must not be less than 16, (24 lines or more is recommended). Otherwise, data may be lost in the interface between camera module and Resizer.

#### 6.11.1.1.2 Padding

For pictures whose frame size are not multiple of 16 X 8 block, JPEG Encoder DMA takes the responsibility to handle the image boundary. In horizontal direction, JPEG Encoder DMA automatically pads the last pixel of every line to the tail of the corresponding line until the number of pixels in the line is multiple of 16. Similarly, JPEG Encoder pads the last line to the tail of the image frame until the line count is multiple of 8 in vertical direction. An example is illustrated in **Figure 58**. In this case, the original frame size is  $(16n + 13) \times (8n + 6)$ , which is not multiple of 16 X 8. Therefore, three additional pixels are padded to the end of each line to make the pixel count multiple of 16. In the vertical direction, two more lines are padded with last line to make line count to multiple of 8.



**Figure 58** Frame Padding

#### 6.11.1.3 Gray Mode

JPEG Encoder DMA also supports Gray Image JPEG Encoding. That is, only Y components are transmitted to JPEG Encoder for Encoding. For memory and bus bandwidth saving, U and V components are truncated before writing into buffer memory. As a result, the memory size in gray mode will be half of what it is in normal mode.

Furthermore, the frame padding is a little different from that in normal mode. JPEG Encode DMA will construct the frame to the multiple of an 8 X 8 block instead of a 16 X 8 block in normal mode.

#### 6.11.1.2 Video DMA

The main function of the Video DMA is to move data from Image Engine to Video Buffer, or from Video Buffer to Resizer. Video Buffer is used to contain YUV420 image data for MPEG4/H.263 codec. It consists of three continuous memory buffers for Y, U, and V component data. Data format in the Image Engine and Resizer is YUV444, and therefore color format conversion is needed during data movement.

For MPEG4/H.263 encoding, Video DMA receives data from Image Engine, and converts it into YUV420 format, and then writes into Y, U, V buffer separately. Software starts MPEG4/H.263 encoder after all of the frame data are ready.

For MPEG4/H.263 decoding, MPEG4/H.263 decoder writes out decoded data to video buffer, and Video DMA is then triggered by software to move data to Resizer.

##### 6.11.1.2.1 Twice Resizing

In most applications, video capture goes along with LCD preview to allow users to see what they have captured immediately. If the frame size of LCD and video frame is the same, it's very easy to accomplish this by enabling Video DMA and IBW2 DMA at the same time to write frame data to Video Buffer and LCD frame buffer simultaneously. However, this does not work if the frame size differs between LCD and video frame.

Twice resizing mode is designed to solve this problem. The data path is illustrated in **Figure 39**. In Pass 1, data from camera module are resized to the size of Video Frame, and then moved to video buffer by Video DMA. When Pass 1 is done, Video DMA will automatically start Pass 2 to read data back from the video buffer, and put them into Resizer to start the second resizing. Second resized data are converted to RGB format by Image Engine, and moved to LCD buffer by IBW2 DMA, and then displayed on LCD.

Note that not only Image DMA needs to be configured to enable this function, but also Resizer and Image Engine need to be configured as well.



**Figure 59** Data path of Twice Resizing

#### 6.11.1.2.2 Auto-Restart

To reduce MCU interrupt frequency, an Auto-Restart mode is designed. Video DMA automatically restarts itself to receive next frame without being re-configured and re-enabled by MCU. This can save a lot of MCU time since the MCU no longer needs to handle Image DMA at each frame boundary, which also makes the data stream smoother. This function shall be used only in video encoding. Turning on the function in video decoding mode will result in data overrun.

Usually, double buffer scheme are employed to smooth video encoding. Therefore, the second base address register is provided in Video DMA to contain the second address. Video DMA automatically switches the base address between the two addresses at every restart.

For the case of single buffer scheme, the two base address registers have to be programmed with the same address.

Video DMA will not stop transfer until it is disabled by MCU.

Note that associated settings must be programmed in Resizer and Image Engine as well.

#### 6.11.1.3 Image Buffer Write 1 DMA

The main function of IBW1 DMA is to move RGB data from Image Engine to memory, and the format of the written data is RGB565. IBW1 plays the role of saving the backup image. Whenever JPEG DMA, Video DMA, or IBW2 DMA is dumping images, IBW1 can be enabled to dump a backup image simultaneously. Even when PAN function is enabled in IBW2 DMA, IBW1 can also be enabled to dump the original image.

### 6.11.1.4 Image Buffer Write 2 DMA

The main function of IBW2 DMA is to move RGB data from Image Engine to memory or LCD DMA, and the format of the written data is RGB565. The basic function of IBW2 DMA is identical to IBW1. However, IBW2 has more additional functions as described in the following subsections.

#### 6.11.1.4.1 Twice Resizing

As mentioned in Video DMA section, Twice Resizing needs IBW2 DMA to write out the second pass data. Once this function is enabled, IBW2 will wait for Pass 2 start signal from Video DMA to start receiving data. Pixel data are ignored before Pass 2 start signal has been received.

#### 6.11.1.4.2 Hardware Handshake with LCD DMA

IBW2 DMA issues interrupt along with the base address of the LCD buffer to LCD DMA at the end of frame transfer. LCD DMA could start moving data into LCD based on the signals.

The advantage of hardware handshaking is to reduce interrupts to MCU. This could make system more efficient.

#### 6.11.1.4.3 Direct Couple to LCD DMA

A more efficient and memory saving way to move frame data to LCD is through Direct Couple Interface. The interface is between IBW2 DMA and LCD DMA, as depicted in **Figure 57**, and consists of request, acknowledge, and 16-bit data bus. In this mode, frame data skips the frame buffer and are written to LCD DMA directly. LCD DMA updates the data on the fly.

However this mode cannot work in camera preview. This is because LCD update could halt for a long time, and therefore the next pixel data from the camera may not be captured in time. Thus, resulting in lost data.

#### 6.11.1.4.4 Auto-Restart

Similar to Video DMA, IBW2 DMA can restart itself to receive next frame, and switch base address at every restart.

#### 6.11.1.4.5 Image Panning

IBW2 DMA can grab a part of the image frame as a new image, as illustrated in **Figure 62**. The advantage is that the system does not need to prepare a large piece of memory to store the entire image frame just to show a small portion of it. This can save memory usage, especially for large images. The detailed usage is shown in the register definition of IMGDMA\_IBW2\_CON.

### 6.11.1.5 Image Buffer Read 1 DMA

The main function of IBR1 DMA is to move RGB data from memory to Resizer. The data format to Resizer is RGB888 and the data formats from memory can be RGB565 (which supports internal editing format), or RGB888 and BGR888 (which support BMP data format). The data placement in memory is illustrated in **Figure 60**.

With IBR1 DMA, RGB image data in memory can be directly used for video encoding, JPEG encoding, and image panning.



Figure 60 RGB data in memory

### 6.11.2 DMA Enabling Sequence

In general, the DMAs at the downstream of the data path must be enabled first. For instance, for Video capturing, the data path is Camera module → Resizer → Image Engine → Video DMA → Video Buffer. Video DMA has to be enabled before Image Processor, Resizer and Camera module.

The second example is video playback. The data path is Video Buffer → Video DMA → Resizer → Image Engine → IBW2 DMA → LCD frame buffer. IBW2 DMA has to be enabled before Resizer and Image Engine and then Video DMA.

### 6.11.3 Register Definitions

| Register Address | Register Function                        | Acronym             |
|------------------|------------------------------------------|---------------------|
| IMGDMA + 0000h   | Image DMA Status Register                | IMGDMA_STA          |
| IMGDMA + 0004h   | Image DMA Interrupt Acknowledge Register | IMGDMA_ACKINT       |
| IMGDMA + 0100h   | JPEG DMA Start Register                  | IMGDMA_JPEG_STR     |
| IMGDMA + 0104h   | JPEG DMA Control Register                | IMGDMA_JPEG_CON     |
| IMGDMA + 0108h   | JPEG DMA Base Address Register           | IMGDMA_JPEG_BSADDR  |
| IMGDMA + 010Ch   | JPEG DMA Horizontal Size Register        | IMGDMA_JPEG_HSIZE   |
| IMGDMA + 0110h   | JPEG DMA Vertical Size Register          | IMGDMA_JPEG_VSIZE   |
| IMGDMA + 0114h   | JPEG DMA FIFO Length Register            | IMGDMA_JPEG_FIFOLEN |
| IMGDMA + 0118h   | JPEG Write Pointer Register              | IMGDMA_JPEG_WRPTR   |
| IMGDMA + 011Ch   | JPEG Write Horizontal Count Register     | IMGDMA_JPEG_WRHCNT  |
| IMGDMA + 0120h   | JPEG Write Vertical Count Register       | IMGDMA_JPEG_WRVCNT  |
| IMGDMA + 0124h   | JPEG Read Pointer Register               | IMGDMA_JPEG_RDPTR   |
| IMGDMA + 0128h   | JPEG Read Horizontal Count Register      | IMGDMA_JPEG_RDHCNT  |
| IMGDMA + 012Ch   | JPEG Read Vertical Count Register        | IMGDMA_JPEG_RDVCNT  |
| IMGDMA + 0130h   | JPEG FIFO Line Count Register            | IMGDMA_JPEG_FFCNT   |

|                |                                                 |                             |
|----------------|-------------------------------------------------|-----------------------------|
| IMGDMA + 0134h | JPEG FIFO Write Line Index Register             | <b>IMGDMA_JPEG_FFWRLIDX</b> |
| IMGDMA + 0138h | JPEG FIFO Read Line Index Register              | <b>IMGDMA_JPEG_FFRDLIDX</b> |
| IMGDMA + 0200h | Video DMA Start Register                        | <b>IMGDMA_VDO_STR</b>       |
| IMGDMA + 0204h | Video DMA Control Register                      | <b>IMGDMA_VDO_CON</b>       |
| IMGDMA + 0208h | Video DMA Base Address 1 Register               | <b>IMGDMA_VDO_BSADDR1</b>   |
| IMGDMA + 020Ch | Video DMA Base Address 2 Register               | <b>IMGDMA_VDO_BSADDR2</b>   |
| IMGDMA + 0210h | Video DMA Horizontal Size Register              | <b>IMGDMA_VDO_HSIZE</b>     |
| IMGDMA + 0214h | Video DMA Vertical Size Register                | <b>IMGDMA_VDO_VSIZE</b>     |
| IMGDMA + 0218h | Video DMA Horizontal Count Register             | <b>IMGDMA_VDO_HCNT</b>      |
| IMGDMA + 021Ch | Video DMA Vertical Count Register               | <b>IMGDMA_VDO_VCNT</b>      |
| IMGDMA + 0300h | Image Buffer Write DMA1 Start Register          | <b>IMGDMA_IBW1_STR</b>      |
| IMGDMA + 0304h | Image Buffer Write DMA1 Control Register        | <b>IMGDMA_IBW1_CON</b>      |
| IMGDMA + 0308h | Image Buffer Write DMA1 Base Address Register   | <b>IMGDMA_IBW1_BSADDR</b>   |
| IMGDMA + 030Ch | Image Buffer Write DMA1 Number of Pixels        | <b>IMGDMA_IBW1_PXLNUM</b>   |
| IMGDMA + 0310h | Image Buffer Write DMA1 Remaining Pixels        | <b>IMGDMA_IBW1_RMGPXL</b>   |
| IMGDMA + 0400h | Image Buffer Write DMA2 Start Register          | <b>IMGDMA_IBW2_STR</b>      |
| IMGDMA + 0404h | Image Buffer Write DMA2 Control Register        | <b>IMGDMA_IBW2_CON</b>      |
| IMGDMA + 0408h | Image Buffer Write DMA2 Base Address 1 Register | <b>IMGDMA_IBW2_BSADDR1</b>  |
| IMGDMA + 040Ch | Image Buffer Write DMA2 Base Address 2 Register | <b>IMGDMA_IBW2_BSADDR2</b>  |
| IMGDMA + 0410h | Image Buffer Write DMA2 Horizontal Size         | <b>IMGDMA_IBW2_HSIZE</b>    |
| IMGDMA + 0414h | Image Buffer Write DMA2 Vertical Size           | <b>IMGDMA_IBW2_VSIZE</b>    |
| IMGDMA + 0418h | Image Buffer Write DMA2 Horizontal Pitch1       | <b>IMGDMA_IBW2_HPITCH1</b>  |
| IMGDMA + 041Ch | Image Buffer Write DMA2 Horizontal Pitch2       | <b>IMGDMA_IBW2_HPITCH2</b>  |
| IMGDMA + 0420h | Image Buffer Write DMA2 Vertical Pitch1         | <b>IMGDMA_IBW2_VPITCH1</b>  |
| IMGDMA + 0424h | Image Buffer Write DMA2 Vertical Pitch2         | <b>IMGDMA_IBW2_VPITCH2</b>  |
| IMGDMA + 0428h | Image Buffer Write DMA2 Horizontal Count        | <b>IMGDMA_IBW2_HCNT</b>     |
| IMGDMA + 042Ch | Image Buffer Write DMA2 Vertical Count          | <b>IMGDMA_IBW2_VCNT</b>     |
| IMGDMA + 0500h | Image Buffer Write DMA1 Start Register          | <b>IMGDMA_IBR1_STR</b>      |
| IMGDMA + 0504h | Image Buffer Write DMA1 Control Register        | <b>IMGDMA_IBR1_CON</b>      |
| IMGDMA + 0508h | Image Buffer Write DMA1 Base Address Register   | <b>IMGDMA_IBR1_BSADDR</b>   |
| IMGDMA + 050Ch | Image Buffer Write DMA1 Number of Pixels        | <b>IMGDMA_IBR1_PXLNUM</b>   |
| IMGDMA + 0510h | Image Buffer Write DMA1 Remaining Pixels        | <b>IMGDMA_IBR1_PXLCNT</b>   |

Table 35 Tracer Registers

**IMGDMA+0000h**
**Image DMA Status Register**
**IMGDMA\_STA**

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Name  |    |    |    |    |    |    |   |                   |   |   |   | <b>IBR1<br/>RUN</b> | <b>IBW2<br/>RUN</b> | <b>IBW1<br/>RUN</b> | <b>VDO<br/>RUN</b> | <b>JPEG<br/>RUN</b> |
|-------|----|----|----|----|----|----|---|-------------------|---|---|---|---------------------|---------------------|---------------------|--------------------|---------------------|
| Type  |    |    |    |    |    |    |   |                   |   |   |   | RO                  | RO                  | RO                  | RO                 | RO                  |
| Reset |    |    |    |    |    |    |   |                   |   |   |   | 0                   | 0                   | 0                   | 0                  | 0                   |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                 | 7 | 6 | 5 | 4                   | 3                   | 2                   | 1                  | 0                   |
| Name  |    |    |    |    |    |    |   | <b>TWC<br/>IT</b> |   |   |   | <b>IBR1<br/>IT</b>  | <b>IBW2<br/>IT</b>  | <b>IBW1<br/>IT</b>  | <b>VDO<br/>IT</b>  | <b>JPEG<br/>IT</b>  |
| Type  |    |    |    |    |    |    |   | RO                |   |   |   | RO                  | RO                  | RO                  | RO                 | RO                  |
| Reset |    |    |    |    |    |    |   | 0                 |   |   |   | 0                   | 0                   | 0                   | 0                  | 0                   |

This register helps software program being well aware of the global status of Image DMA channels.

**JPEG IT**      Interrupt status for JPEG DMA

- 0** No interrupt is generated.
- 1** An interrupt is pending and waiting for service.

**VDO IT**      Interrupt status for Video DMA

- 0** No interrupt is generated.
- 1** An interrupt is pending and waiting for service.

**IBW1 IT**      Interrupt status for Image Buffer Write DMA1

- 0** No interrupt is generated.
- 1** An interrupt is pending and waiting for service.

**IBW2 IT**      Interrupt status for Image Buffer Write DMA2

- 0** No interrupt is generated.
- 1** An interrupt is pending and waiting for service.

**IBR1 IT**      Interrupt status for Image Buffer Read DMA1

- 0** No interrupt is generated.
- 2** An interrupt is pending and waiting for service.

**TWC IT**      Interrupt status for Twice Resizing of Video DMA.

- 0** No interrupt is generated.
- 1** An interrupt is pending and waiting for service.

**JPEG RUN**      JPEG DMA status

- 0** JPEG DMA is stopped or has completed the transfer already.
- 1** JPEG DMA is currently running.

**VDO RUN**      Video DMA status

- 0** Video DMA is stopped or has completed the transfer already.
- 1** Video DMA is currently running.

**IBW1 RUN**      Image Buffer Write DMA1 status

- 0** Image Buffer Write DMA1 is stopped or has completed the transfer already.
- 1** Image Buffer Write DMA1 is currently running.

**IBW2 RUN**      Image Buffer Write DMA2 status

- 0** Image Buffer Write DMA2 is stopped or has completed the transfer already.
- 1** Image Buffer Write DMA2 is currently running.

**IBR1 RUN**      Image Buffer Read DMA1 status

- 0** Image Buffer Read DMA1 is stopped or has completed the transfer already.
- 1** Image Buffer Read DMA1 is currently running.

**IMGDMA+0004** Image DMA Interrupt Acknowledge Register  
**h**
**IMGDMA\_ACKIN**  
**T**

|      |    |    |    |    |    |    |    |                          |    |    |    |                           |                           |                           |                          |                           |
|------|----|----|----|----|----|----|----|--------------------------|----|----|----|---------------------------|---------------------------|---------------------------|--------------------------|---------------------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                       | 23 | 22 | 21 | 20                        | 19                        | 18                        | 17                       | 16                        |
| Name |    |    |    |    |    |    |    |                          |    |    |    |                           |                           |                           |                          |                           |
| Type |    |    |    |    |    |    |    |                          |    |    |    |                           |                           |                           |                          |                           |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                        | 7  | 6  | 5  | 4                         | 3                         | 2                         | 1                        | 0                         |
| Name |    |    |    |    |    |    |    | <b>TWC</b><br><b>ACK</b> |    |    |    | <b>IBR1</b><br><b>ACK</b> | <b>IBW2</b><br><b>ACK</b> | <b>IBW1</b><br><b>ACK</b> | <b>VDO</b><br><b>ACK</b> | <b>JPEG</b><br><b>ACK</b> |
| Type |    |    |    |    |    |    |    | WO                       |    |    |    | WO                        | WO                        | WO                        | WO                       | WO                        |

This register is used to acknowledge the current interrupt request associated with the completion event of a DMA channel by software program. Note that this is a write-only register, and any read to it will return a value of “0”.

**ACK** Interrupt acknowledge for the DMA channel

**0** No effect

**1** Interrupt request is acknowledged and should be relinquished.

**IMGDMA+0100** JPEG DMA Start Register  
**h**
**JPEG\_STR**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17         | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1          | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>STR</b> |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W        |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            | 0  |

This register controls the activity of a DMA channel. Note that before setting STR to “1”, all the configurations shall be done by giving proper values.

**STR** Start control for a DMA channel

**0** stop DMA

**1** activate DMA

**IMGDMA+0104** JPEG DMA Control Register  
**h**
**JPEG\_CON**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |     |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------|-----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17                       | 16  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |     |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |     |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1                        | 0   |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GRAY</b><br><b>IT</b> |     |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                      | R/W |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          | 0   |

**GRAY** Gray mode jpeg encoding. Only Y components are encoded.

**0** color mode.

**1** gray mode

**IT** Interrupt Enabling

**0** Disable

1 Enable

### IMGDMA+0108 JPEG DMA Base Address Register h

| Bit  | 31                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name | <b>ADDR[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>ADR[15:0]</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**ADDR** Base address of the JPEG DMA FIFO.

### IMGDMA+010C JPEG DMA Horizontal Size Register h

| Bit  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>HSIZE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**HSIZE** Horizontal dimension of image. 0 stands for 1 pixels, and n-1 stands for n pixels.

### IMGDMA+0110 JPEG DMA Vertical Size Register h

| Bit  | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>VSIZE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**VSIZE** Vertical dimension of image. 0 stands for 1 pixels, and n-1 stands for n pixels.

### IMGDMA+0114 JPEG DMA FIFO Length Register h

| Bit  | 31             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | <b>FIFOLEN</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | R/W            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

JPEG DMA FIFO Length must be the multiple of 8. The memory needed for a certain FIFO length is

$$\left\lceil \frac{HSIZE}{16} \right\rceil \times 16 \times FIFOLEN \times 2 \text{ bytes for color mode, and } \left\lceil \frac{HSIZE}{8} \right\rceil \times 8 \times FIFOLEN \text{ bytes for gray mode.}$$

**FIFOLEN** JPEG DMA FIFO Length. FIFOLEN must be the multiple of 8.

**IMGDMA+0118 JPEG Write Pointer Register**  
**h**
**JPEG\_WRPTR**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**WRPTR** Write pointer to display current writing address.

**IMGDMA+011C JPEG Write Horizontal Count Register**  
**h**
**JPEG\_WRHCNT**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**WRHCNT** Displays the horizontal pixel count. This is a down-count counter. Hence this register reflects the remaining pixels of a line.

**IMGDMA+0120 JPEG Write Vertical Count Register**  
**h**
**JPEG\_WRVCNT**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**WRVCNT** Displays the vertical pixel count. This is a down-count counter. Hence this register reflects the remaining lines.

**IMGDMA+0124 JPEG Read Pointer Register**  
**h**
**JPEG\_RDPTR**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**RDPTR** Read pointer to display current reading address.

**IMGDMA+0128 JPEG Read Horizontal Count Register**  
**h**
**JPEG\_RDHCNT**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|      |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**RDHCNT** Displays the horizontal pixel count. This is a down-count counter. Hence this register reflects the remaining pixels of a line.

### IMGDMA+012C JPEG Read Vertical Count Register h

JPEG\_RDVCNT

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**RDVCNT** Displays the vertical pixel count. This is a down-count counter. Hence this register reflects the remaining lines.

### IMGDMA+0130 JPEG FIFO Line Count Register h

JPEG\_FFCNT

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**FFCNT** Displays the FIFO Line Count of JPEG FIFO.

### IMGDMA+0134 JPEG Write Line Index Register h

JPEG\_FFWRLID

X

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**YIDX** Displays which FIFO line JPEG DMA is writing, YIDX = 1 ~ FIFOLEN.

### IMGDMA+0138 JPEG Read Line Index Register h

JPEG\_FFRDLID

X

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**YIDX** Displays which FIFO line JPEG DMA is reading, YIDX = 1 ~ FIFOLEN.

**IMGDMA+0200 Video DMA Start Register**  

Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16  
Name \_\_\_\_\_  
Type \_\_\_\_\_  
Reset \_\_\_\_\_  
Bit 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0  
Name \_\_\_\_\_  
Type \_\_\_\_\_  
Reset \_\_\_\_\_

VDO\_STR

|       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| Bit   | 31    | 30    | 29    | 28    | 27    | 26    | 25    | 24    | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
| Name  | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ |
| Type  | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ |
| Reset | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ |
| Bit   | 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| Name  | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | STR   | _____ |
| Type  | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | R/W   | _____ |
| Reset | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | 0     |

This register controls the activity of a DMA channel. Note that before setting STR to “1”, all the configurations should be done by giving proper values.

**STR** Start control for a DMA channel

- 0** stop DMA
- 1** activate DMA

**IMGDMA+0204 Video DMA Control Register**  

Bit 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16  
Name \_\_\_\_\_  
Type \_\_\_\_\_  
Reset \_\_\_\_\_  
Bit 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0  
Name \_\_\_\_\_  
Type \_\_\_\_\_  
Reset \_\_\_\_\_

VDO\_CON

|       |       |       |       |       |       |       |       |       |       |       |       |           |        |       |       |         |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-----------|--------|-------|-------|---------|
| Bit   | 31    | 30    | 29    | 28    | 27    | 26    | 25    | 24    | 23    | 22    | 21    | 20        | 19     | 18    | 17    | 16      |
| Name  | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____     | _____  | _____ | _____ | _____   |
| Type  | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____     | _____  | _____ | _____ | _____   |
| Reset | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____     | _____  | _____ | _____ | _____   |
| Bit   | 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4         | 3      | 2     | 1     | 0       |
| Name  | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | AUTO RSTR | TWC IT | TWC   | DIR   | DONE IT |
| Type  | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | R/W       | R/W    | R/W   | R/W   | R/W     |
| Reset | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | _____ | 0         | 0      | 0     | 0     | 0       |

**DONE IT** DMA Done Interrupt Enabling. Interrupt issues when all of the transfers are done. For the application of twice resizing, interrupt will issue at the end of the second run, as illustrated in **Figure 61**. For auto-restart mode, interrupt issues at every restart.


**Figure 61** Interrupt Timing

**0** Disable

**1** Enable

**DIR** Direction of DMA

**0** Video decoding. Video Buffer to Resizer.

**1** Video encoding. Image Engine to Video Buffer.

**TWC** Twice Resizing. It is used when the frame size of LCD is different from the frame size of MPEG4 encoder. While this function is enabled, Video DMA will write data to video buffer first, and then read back from the same buffer.

These data will pass through resizer again to convert to different frame size. At the end of Video write, a start pulse will issue to the two Image Buffer Write DMAs. If IBW DMAs are also enabled this function, they will wait for this signal to start data movement, otherwise this signal is useless for them.

Once this function is enabled, DIR must be set 1.

- 0** Disable
- 1** Enable

**TWC IT** Twice Resizing Interrupt Enabling. This function only takes effect if Twice Resizing is enabled. Interrupt issues at the end of first run, as illustrated in **Figure 39**.

- 0** Disable
- 1** Enable

**AUTO RSTR** Automatic restart. Video DMA automatically restarts while current frame is finished. Base address will be automatically switched between VDO\_BSADDR1 and VDO\_BSADDR2. For single buffer application, please set VDO\_BSADDR1 and VDO\_BSADDR2 with the same value. This function can be used with twice resizing.

- 0** Disable
- 1** Enable

### IMGDMA+0208 Video Base Address 1 Register

VDO\_BSADDR1

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ADDR |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W  |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0    |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ADDR |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W  |

**ADDR** First base address of video frame buffer.

### IMGDMA+020C Video Base Address 2 Register

VDO\_BSADDR2

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ADDR |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W  |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0    |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ADDR |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W  |

**ADDR** Second base address of video frame buffer.

### IMGDMA+0210 Video Horizontal Size Register

VDO\_HSIZE

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0    |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | SIZE |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W  |

**SIZE** Horizontal dimension of a video frame. 1 stands for 1 pixel, and n stands for n pixels. Note that the horizontal size must be multiple of 16.

**IMGDMA+0214 Video Vertical Size Register**  
**h**
**VDO\_VSIZE**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16          |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0           |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SIZE</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W         |

**SIZE** Vertical dimension of a video frame. 1 stands for 1 pixel, and n stands for n pixels. Note that the vertical size must be multiple of 16.

**IMGDMA+0218 Video Horizontal Count Register**  
**h**
**VDO\_HCNT**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16           |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0            |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>COUNT</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO           |

**COUNT** Horizontal pixel count. 1 stands for 1 pixel, and n stands for n pixels.

**IMGDMA+021C Video Vertical Count Register**  
**h**
**VDO\_VCNT**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16           |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0            |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>COUNT</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO           |

**COUNT** Vertical pixel count. 1 stands for 1 pixel, and n stands for n pixels.

**IMGDMA+0300 Image Buffer Write DMA1 Start Register**  
**h**
**IBW1\_STR**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0          |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>STR</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W        |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0          |

This register controls the activity of a DMA channel. Note that before setting STR to “1”, all the configurations should be done by giving proper values.

**STR** Start control for a DMA channel

- 0** stop DMA
- 1** activate DMA

**IMGDMA+0304** Image Buffer Write DMA1 Control Register **IBW1\_CON**  
**h**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17        | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1         | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>IT</b> |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W       |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           | 0  |

**IT** Interrupt Enabling

**0** Disable

**1** Enable

**IMGDMA+0308** Image Buffer Write DMA1 Base Address Register **IBW1\_BSADDR**  
**h**

|      |    |    |    |    |    |    |    |             |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|-------------|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24          | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    | <b>ADDR</b> |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R/W         |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8           | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    | <b>ADDR</b> |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R/W         |    |    |    |    |    |    |    |    |

**ADDR** Base address of the image buffer.

**IMGDMA+030C** Image Buffer Write DMA1 Number of Pixels Register **IBW1\_PXNUM**  
**h**

|      |    |    |    |    |    |    |    |            |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24         | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    | <b>NUM</b> |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R/W        |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8          | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    | <b>NUM</b> |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R/W        |    |    |    |    |    |    |    |    |

**NUM** Number of pixels of the transferred image. 0 represents 1 pixel, and n-1 represents n pixels.

**IMGDMA+0310** Image Buffer Write DMA1 Remaining Pixels Register **IBW1\_RMGPXL**  
**h**

|      |    |    |    |    |    |    |    |            |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24         | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    | <b>NUM</b> |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | RO         |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8          | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    | <b>NUM</b> |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | RO         |    |    |    |    |    |    |    |    |

**NUM** Remaining pixel count. 0 represents 1 pixel, and n-1 represents n pixels.

**IMGDMA+0400 Image Buffer Write DMA2 Start Register**  
**h**
**IBW2\_STR**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0          |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>STR</b> |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W        |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0          |

This register controls the activity of a DMA channel. Note that before setting STR to “1”, all the configurations should be done by giving proper value

**STR** Start control for a DMA channel

- 0** stop DMA
- 1** activate DMA

**IMGDMA+0404 Image Buffer Write DMA2 Control Register**  
**h**
**IBW2\_CON**

|       |    |    |    |    |    |    |    |    |    |    |            |           |                  |            |            |           |
|-------|----|----|----|----|----|----|----|----|----|----|------------|-----------|------------------|------------|------------|-----------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21         | 20        | 19               | 18         | 17         | 16        |
| Name  |    |    |    |    |    |    |    |    |    |    |            |           |                  |            |            |           |
| Type  |    |    |    |    |    |    |    |    |    |    |            |           |                  |            |            |           |
| Reset |    |    |    |    |    |    |    |    |    |    |            |           |                  |            |            |           |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5          | 4         | 3                | 2          | 1          | 0         |
| Name  |    |    |    |    |    |    |    |    |    |    | <b>PAN</b> | <b>DC</b> | <b>AUTO RSTR</b> | <b>LCD</b> | <b>TWC</b> | <b>IT</b> |
| Type  |    |    |    |    |    |    |    |    |    |    | R/W        | R/W       | R/W              | R/W        | R/W        | R/W       |
| Reset |    |    |    |    |    |    |    |    |    |    | 0          | 0         | 0                | 0          | 0          | 0         |

**IT** Interrupt Enabling

- 0** Disable
- 1** Enable

**TWC** Twice Resizing, which is used when the frame size of LCD is different from the frame size of MPEG4 encoder. Once the function is enabled, IBW2 DMA will wait for start pulse from video DMA to start data transfer.

- 0** Disable
- 1** Enable

**LCD** Signaling LCD DMA. Frame ready signal is issued at the beginning of frames in Direct Couple mode, and is issued at the end of frames in Dual Buffer mode. Note that in the case of automatic restart plus direct couple mode, this function must be enabled to trigger LCD DMA.

- 0** Disable
- 1** Enable

**AUTO RSTR** Automatic restart. IBW2 DMA automatically restarts itself while current frame is finished.

- 0** Disable
- 1** Enable

**DC** Directly coupling to LCD DMA. Once this function is enabled, image data will dump to LCD DMA directly instead of dumping to LCD frame buffer.

- 0** Disable

**1 Enable**

**PAN** Picture panning. Once this function is enabled, only the pixels in the region specified by HPITCH1, HPITCH2, VPITCH1, and VPITCH2 are dumped. The PITCHs are defined as **Figure 62**.



**Figure 62** Picture Panning

- 0** Disable
- 1** Enable

**IMGDMA+0408** **Image Buffer Write DMA2 Base Address 1 Register** **IBW2\_BSADDR1**  
**h**

|             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit         | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**ADDR** First base address of the LCD frame buffer.

**IMGDMA+040C** **Image Buffer Write DMA2 Base Address 2 Register** **IBW2\_BSADDR2**  
**h**

|             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit         | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**ADDR** Second base address of the LCD frame buffer.

**IMGDMA+0410** **Image Buffer Write DMA2 Horizontal Size Register** **IBW2\_HSIZE**  
**h**

|             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit         | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

|      |             |
|------|-------------|
| Name | <b>SIZE</b> |
| Type | R/W         |

**SIZE** Horizontal size of a frame. 0 stands for 1 pixel, and n-1 stands for n pixels.

**IMGDMA+0414** **Image Buffer Write DMA2 Vertical Size Register** **IBW2\_VSIZE**  
**h**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**SIZE** Vertical size of a frame. 0 stands for 1 pixel, and n-1 stands for n pixels.

**IMGDMA+0418** **Image Buffer Write DMA2 Horizontal Pitch1 Register** **IBW2\_HPITCH1**  
**h**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**PITCH** First horizontal pitch of a frame. 0 stands for the first pixel, and n-1 stands for the n<sup>th</sup> pixel.

**IMGDMA+041C** **Image Buffer Write DMA2 Horizontal Pitch2 Register** **IBW2\_HPITCH2**  
**h**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**PITCH** Second horizontal pitch of a frame. 0 stands for the first pixel, and n-1 stands for the n<sup>th</sup> pixel.

**IMGDMA+0420** **Image Buffer Write DMA2 Vertical Pitch1 Register** **IBW2\_VPITCH1**  
**h**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**PITCH** First vertical pitch of a frame. 0 stands for the first pixel, and n-1 stands for the n<sup>th</sup> pixels.

**IMGDMA+0424** **Image Buffer Write DMA2 Vertical Pitch2 Register** **IBW2\_VPITCH2**  
**h**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|      |    |    |    |    |    |    |   |   |   |   |   |   |   |   |       |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-------|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   |       |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |   |       |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1     |
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   | PITCH |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W   |

**PITCH** Second vertical pitch of a frame. 0 stands for the first pixel, and n-1 stands for the n<sup>th</sup> pixels.

### IMGDMA+0428 Image Buffer Write DMA2 Horizontal Count Register IBW2\_HCNT h

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0   |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CNT |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO  |

**CNT** Horizontal pixel count. 0 stands for 1 pixel, and n-1 stands for n pixels.

### IMGDMA+042C Image Buffer Write DMA2 Vertical Count Register IBW2\_VCNT h

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0   |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CNT |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO  |

**CNT** Vertical line count. 0 stands for 1 line, and n-1 stands for n lines.

### IMGDMA+0500 Image Buffer Read DMA1 Start Register IBR1\_STR h

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0   |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | STR |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0   |

This register controls the activity of a DMA channel. Note that before setting STR to “1”, all the configurations should be done by giving proper values.

**STR** Start control for a DMA channel

- 0 stop DMA
- 1 activate DMA

### IMGDMA+0504 Image Buffer Read DMA1 Control Register IBR1\_CON h

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |      |     |     |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|------|-----|-----|
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |      |     |     |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |      |     |     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2    | 1   | 0   |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | ORDE | FMT | IT  |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | R/W  | R/W | R/W |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0    | 0   | 0   |

**IT** Interrupt Enabling

0 Disable

1 Enable

**FMT** Data format

0 RGB565

1 RGB888

**ORDER** Data order

0 BGR888, from MSB to LSB.

1 RGB888, from MSB to LSB.

### IMGDMA+0508

### Image Buffer Read DMA1 Base Address Register

### IBR1\_BSADDR

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |      |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|------|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    | ADDR |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W  |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2    | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    | ADDR |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W  |    |    |

**ADDR** Base address of the image buffer.

### IMGDMA+050C

### Image Buffer Read DMA1 Number of Pixels Register

### IBR1\_PXLNUM

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    | NUM |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2   | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    | NUM |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W |    |    |

**NUM** Number of pixels of the transferred image. 0 represents 1 pixel, and n-1 represents n pixels.

### IMGDMA+0510

### Image Buffer Read DMA1 Remaining Pixels Register

### IBR1\_PXLCNT

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |       |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18    | 17 | 16 |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    | COUNT |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    | RO    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2     | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    | COUNT |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    | RO    |    |    |

**COUNT** Pixel count. 0 represents 1 pixel, and n-1 represents n pixels.

## 6.12 Image Engine

The Image Engine is used to manipulate image adjustments and a variety of filtering effects. It works inside the DMA architecture, which minimizes the intervention of the CPU. The engine can directly access the external and internal memories and provide a large extent of flexibility for system performance consideration.

The function of the engine basically contains two categories: pixel adjustment and filtering effect.

Pixel adjustment includes brightness, contrast, and hue adjustment, color adjustment, and gamma correction. These effects are integrated on both the encoding and decoding path of image and video material. It can provide on-the-fly manipulation on these raw materials. For camera preview and capture, it can perform the effects on the incoming image frame immediately, and output to both frame buffer for display and image buffer for image compression. For video playback, it can perform the effects on the decoded frame immediately and output to the frame buffer for display.

The filtering effect includes linear and non-linear (ranking) effects. The linear filtering provides blur and sharpening effects with programmable mask design. The non-linear filtering provides ranking filter to emulate noise reduction, dilation and erosion effects. We can also implement other artistic effects by performing multi-pass filtering with combination of a variety of effects.

### 6.12.1 Register Definitions

| Register Address | Register Function                    | Acronym           |
|------------------|--------------------------------------|-------------------|
| IMG+0000h        | Image flow control register          | IMGPROC_IMAGE_CON |
| IMG+0004h        | Control register                     | IMGPROC_CON       |
| IMG+0008h        | Interrupt enable register            | IMGPROC_INTREN    |
| IMG+000Ch        | Interrupt status register            | IMGPROC_INTR      |
| IMG+0010h        | Status register                      | IMGPROC_STATUS    |
| IMG+0100h        | Hue adjustment coefficient C11       | IMGPROC_HUE11     |
| IMG+0104h        | Hue adjustment coefficient C12       | IMGPROC_HUE12     |
| IMG+0108h        | Hue adjustment coefficient C21       | IMGPROC_HUE21     |
| IMG+010Ch        | Hue adjustment coefficient C22       | IMGPROC_HUE22     |
| IMG+0110h        | Saturation adjustment coefficient    | IMGPROC_SAT       |
| IMG+0120h        | Brightness adjustment coefficient B1 | IMGPROC_BRIADJ1   |
| IMG+0124h        | Brightness adjustment coefficient B2 | IMGPROC_BRIADJ2   |
| IMG+0128h        | Contrast adjustment coefficient      | IMGPROC_CONADJ    |
| IMG+0130h        | Colorize effect coefficient          | IMGPROC_COLORIZEU |
| IMG+0134h        | Colorize effect coefficient          | IMGPROC_COLORIZEV |
| IMG+0140h        | Mask coefficient C11                 | IMGPROC_MASK11    |
| IMG+0144h        | Mask coefficient C12                 | IMGPROC_MASK12    |
| IMG+0148h        | Mask coefficient C13                 | IMGPROC_MASK13    |
| IMG+014Ch        | Mask coefficient C21                 | IMGPROC_MASK21    |
| IMG+0150h        | Mask coefficient C22                 | IMGPROC_MASK22    |
| IMG+0154h        | Mask coefficient C23                 | IMGPROC_MASK23    |

|           |                                               |                                 |
|-----------|-----------------------------------------------|---------------------------------|
| IMG+0158h | Mask coefficient C31                          | <b>IMGPROC_MASK31</b>           |
| IMG+015Ch | Mask coefficient C32                          | <b>IMGPROC_MASK32</b>           |
| IMG+0160h | Mask coefficient C33                          | <b>IMGPROC_MASK33</b>           |
| IMG+0164h | Mask down-scaling coefficient                 | <b>IMGPROC_SCALE</b>            |
| IMG+0170h | Gamma correction offset for segment 0         | <b>IMGPROC_GAMMA_OFF0</b>       |
| IMG+0174h | Gamma correction offset for segment 1         | <b>IMGPROC_GAMMA_OFF1</b>       |
| IMG+0178h | Gamma correction offset for segment 2         | <b>IMGPROC_GAMMA_OFF2</b>       |
| IMG+017Ch | Gamma correction offset for segment 3         | <b>IMGPROC_GAMMA_OFF3</b>       |
| IMG+0180h | Gamma correction offset for segment 4         | <b>IMGPROC_GAMMA_OFF4</b>       |
| IMG+0184h | Gamma correction offset for segment 5         | <b>IMGPROC_GAMMA_OFF5</b>       |
| IMG+0188h | Gamma correction offset for segment 6         | <b>IMGPROC_GAMMA_OFF6</b>       |
| IMG+018Ch | Gamma correction offset for segment 7         | <b>IMGPROC_GAMMA_OFF7</b>       |
| IMG+0190h | Gamma correction slope for segment 0          | <b>IMGPROC_GAMMA_SLP0</b>       |
| IMG+0194h | Gamma correction slope for segment 1          | <b>IMGPROC_GAMMA_SLP1</b>       |
| IMG+0198h | Gamma correction slope for segment 2          | <b>IMGPROC_GAMMA_SLP2</b>       |
| IMG+019Ch | Gamma correction slope for segment 3          | <b>IMGPROC_GAMMA_SLP3</b>       |
| IMG+01A0h | Gamma correction slope for segment 4          | <b>IMGPROC_GAMMA_SLP4</b>       |
| IMG+01A4h | Gamma correction slope for segment 5          | <b>IMGPROC_GAMMA_SLP5</b>       |
| IMG+01A8h | Gamma correction slope for segment 6          | <b>IMGPROC_GAMMA_SLP6</b>       |
| IMG+01ACh | Gamma correction slope for segment 7          | <b>IMGPROC_GAMMA_SLP7</b>       |
| IMG+01B0h | Gamma correction control register             | <b>IMGPROC_GAMMA_CON</b>        |
| IMG+0200h | Color adjustment offset x for red segment 1   | <b>IMGPROC_COLOR1R_OFFSET_X</b> |
| IMG+0204h | Color adjustment offset x for red segment 2   | <b>IMGPROC_COLOR2R_OFFSET_X</b> |
| IMG+0208h | Color adjustment offset x for green segment 1 | <b>IMGPROC_COLOR1G_OFFSET_X</b> |
| IMG+020Ch | Color adjustment offset x for green segment 2 | <b>IMGPROC_COLOR2G_OFFSET_X</b> |
| IMG+0210h | Color adjustment offset x for blue segment 1  | <b>IMGPROC_COLOR1B_OFFSET_X</b> |
| IMG+0214h | Color adjustment offset x for blue segment 2  | <b>IMGPROC_COLOR2B_OFFSET_X</b> |
| IMG+0220h | Color adjustment offset y for red segment 1   | <b>IMGPROC_COLOR1R_OFFSET_Y</b> |
| IMG+0224h | Color adjustment offset y for red segment 2   | <b>IMGPROC_COLOR2R_OFFSET_Y</b> |
| IMG+0228h | Color adjustment offset y for green segment 1 | <b>IMGPROC_COLOR1G_OFFSET_Y</b> |
| IMG+022Ch | Color adjustment offset y for green segment 2 | <b>IMGPROC_COLOR2G_OFFSET_Y</b> |
| IMG+0230h | Color adjustment offset y for blue segment 1  | <b>IMGPROC_COLOR1B_OFFSET_Y</b> |
| IMG+0234h | Color adjustment offset y for blue segment 2  | <b>IMGPROC_COLOR2B_OFFSET_Y</b> |
| IMG+0240h | Color adjustment slope for red segment 0      | <b>IMGPROC_COLOR1G_SLOPE</b>    |
| IMG+0244h | Color adjustment slope for red segment 1      | <b>IMGPROC_COLOR1G_SLOPE</b>    |
| IMG+0248h | Color adjustment slope for red segment 2      | <b>IMGPROC_COLOR2G_SLOPE</b>    |
| IMG+0250h | Color adjustment slope for red segment 0      | <b>IMGPROC_COLOR1G_SLOPE</b>    |
| IMG+0254h | Color adjustment slope for red segment 1      | <b>IMGPROC_COLOR1G_SLOPE</b>    |
| IMG+0258h | Color adjustment slope for red segment 2      | <b>IMGPROC_COLOR2G_SLOPE</b>    |

|           |                                          |                     |
|-----------|------------------------------------------|---------------------|
| IMG+0260h | Color adjustment slope for red segment 0 | IMGPROC_COLOR1G_SLP |
| IMG+0264h | Color adjustment slope for red segment 1 | IMGPROC_COLOR1G_SLP |
| IMG+0268h | Color adjustment slope for red segment 2 | IMGPROC_COLOR2G_SLP |
| IMG+0304h | Image frame width register               | IMGPROC_IMGWIDTH    |
| IMG+0308h | Image frame height register              | IMGPROC_IMGHEIGHT   |
| IMG+030Ch | Image frame source start address         | IMGPROC_ADDR_SRC    |
| IMG+0310h | Image frame destination start address    | IMGPROC_ADDR_DST    |
| IMG+0314h | Image frame filtering dummy pixel        | IMGPROC_DUMMYPXL    |

**Table 36** Image Engine Registers

### IMG+0000h Image Engine image flow control register

**IMGPROC\_IMA  
GE\_CON**

| Bit   | 15    | 14 | 13 | 12 | 11   | 10 | 9 | 8 | 7 | 6   | 5   | 4   | 3   | 2 | 1   | 0 |
|-------|-------|----|----|----|------|----|---|---|---|-----|-----|-----|-----|---|-----|---|
| Name  | GMODE |    |    |    | MASK |    |   |   |   | GMA | CLR | INV | CBA |   | HSA |   |
| Type  | R/W   |    |    |    | R/W  |    |   |   |   | R/W | R/W | R/W | R/W |   | R/W |   |
| Reset | 0     |    |    |    | 0    |    |   |   |   | 0   | 0   | 0   | 0   |   | 0   |   |

This register is used to define which effects are to be applied on the video stream or on the stand-alone image. The user can simply set this register to 0 if intended to bypass Image Engine.

The MSB 4 bits controls the operating mode and image flow of the engine. They should be set prior to enabling the respective functions; and when all are equal to 0, no operation will take effect.

The MASK field defines which mask filtering effect is to be applied. The effects comprise of linear and non-linear effects. Some linear effects, such as Low-pass, High-pass, un-sharpening effects, should be associated with the mask table, therefore the user should program the mask coefficients. The LP (low-pass) filter provides smoothing effects. Since it is supposed to get un-biased data, the convolution will be normalized to its original intensity. The HP (high-pass) filter, which provides sharpening effects, does not necessarily produce un-biased data. We provide two HP filters, one with scaling factor and the other without. Depending on what mask type is defined, the result may reveal only edge information or may keep the average intensity to achieve the sharpening effects. We recommend using symmetrical form of mask.

In addition to 3x3 masks, 5x5 and 7x7 masks are also provided. But only the blur effects are provided for the later two effects. The user does not have to program the mask coefficients.

The LSB 7 bits controls all the pixel adjustment effect.

For gamma correction and color adjustment, which are to be performed on RGB color space, the Image Engine provides piece-wise linear programming mechanism. The user should know the slope and offset of respective segments.

Color invert effect, performed on YUV or RGB color spaces, provides negative film effects.

Contrast and brightness, hue and saturation effects are to be performed on YUV color space. Although, the user can also do post-processing on the image prepared in RGB form. The Image Engine can convert it into YUV space for those operations.

**GMODE** Graph mode. The field defines the image flow in each case.

- 1000** *Image Encode mode.* (RGB to YUV) In this mode, the Image Engine performs the color space conversion from RGB color space to YUV color space. This mode is mainly used for image encoding, such as JPEG encoding. In this mode, we assume no image effects are to be applied.
- 0100** *Image effect mode.* (RGB to RGB) In this mode, the Image Engine applies image effects on the stand-alone image. The data source and destination is supposed to be in RGB color space. In this mode, the user should program image size and related information on image DMA. The image DMA retrieves image, performs image effects on Image Engine, and then writes to the memory.
- 0011** *MPEG encode mode.* (YUV to YUV, then RGB) In this mode, the image is converted from YUV color space to both YUV and RGB color space with different image dimensions. The pixel in YUV is for encoding, while that in RGB is for displaying. In this mode, we assume no image effects are to be performed in Image Engine. The user can adjust the image quality by programming ISP.
- 0010** *Capture mode.* (YUV to YUV) In this mode, the captured image in YUV color space and is not performed color space conversion. This mode is mainly used for image capture.
- 0001** *Playback mode.* (YUV to RGB) In this mode, the Image Engine performs the color space conversion from YUV color space to RGB color space. This mode is mainly used for preview, image playback, and video playback.

**MASK** Mask filtering effect enabling control.

- 0101** Linear LP (low-pass) filtering effect enable. Mask coefficients required.
- 0110** Linear HP (high-pass) filtering effect enable. Mask coefficients required.
- 0111** Linear HP filtering (with scale down) effect enable. Mask coefficients required.
- 1001** Blur effect enable. (5x5 mask)
- 1010** More blur effect enable. (7x7 mask)
- 1011** Un-sharp mask effect enable. Mask coefficients required.
- 1100** Maximum ranking (dilation) filter effect enable
- 1101** Median ranking filter effect enable
- 1110** Minimum ranking (erosion) filter effect enable

**GMA** Gamma correction enable bit

**CLR** Color adjustment enable bit

**INV** Color invert enable bit

**CBA** Contrast and brightness adjustment enable bit

**HSA** Hue and saturation adjustment enable

- 001** Gray-scale effect enable
- 010** Colorize effect enable
- 101** Hue adjustment enable
- 110** Saturation adjustment enable
- 111** Hue and saturation adjustment enable

### IMG+0004h Mask filtering Control register      IMGPROC\_CON

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4           | 3 | 2 | 1           | 0             |
|-------|----|----|----|----|----|----|---|---|---|---|---|-------------|---|---|-------------|---------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   | <b>INIT</b> |   |   | <b>STOP</b> | <b>STAR T</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   | WO          |   |   | WO          | WO            |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 0           |   |   | 0           | 0             |

This register is used to control the filtering process and coefficients setting.

**INIT** Writing logic-1 resets hue, saturation, brightness, and contrast adjusting coefficients. The flag is write-only.

**STOP** Writing logic-1 stops the image filter processing. The flag is write-only.

**START** Writing logic-1 starts the image filter processing. The flag is write-only.

### IMG+0008h Interrupt enable register

**IMGPROC\_INTR**  
**EN**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>EN</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W       |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0         |

This register is the interrupt enable control register. To enable the interrupt, the flag should be set to be 1.

**EN** Interrupt enable flag.

### IMG +000Ch Interrupt status register

**IMGPROC\_INTR**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0           |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>INTR</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RC          |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0           |

This register is the interrupt status register. The core set the flag to be 1 to represent the interrupt is asserted. Reading this register will clear the interrupt.

**INTR** Interrupt status flag. The flag is read-clear.

### IMG +0010h Status register

**IMGPROC\_STS**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0           |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>BUSY</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO          |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0           |

This register is the status register. The user could poll this register to see if the filtering process is ready or not. The flag is read-only.

**BUSY** Filtering is in process.

### IMG+0100h Hue adjustment coefficient C11

**IMGPROC\_HUE**  
**11**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>C11</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W        |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 40h        |

### IMG+0104h Hue adjustment coefficient C12

**IMGPROC\_HUE**  
**12**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>C12</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W        |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0          |

**IMG+0108h Hue adjustment coefficient C21**
**IMGPROC\_HUE  
21**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | C21 |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0   |

**IMG+010Ch Hue adjustment coefficient C22**
**IMGPROC\_HUE  
22**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | C22 |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 40h |

This register controls the parameter of hue adjustment for the image. The effect is performed on the U and V component of YUV color space. The user should specify the coefficients that form the transformation matrix. The formula is listed as follows:

$$\begin{bmatrix} u_o \\ v_o \end{bmatrix} = \begin{bmatrix} C11 & C12 \\ C21 & C22 \end{bmatrix} \cdot \begin{bmatrix} u_i \\ v_i \end{bmatrix}$$

where  $C11 = 64\cos\theta$ ,  $C12 = 64\sin\theta$ ,  $C21 = -64\sin\theta$ ,  $C22 = 64\cos\theta$

The coefficients are in 2's complement format and range from C0h to 40h (from -64 to 64 in decimal, while 64 is normalized to 1 corresponding to cosine values). Any value beyond this range is invalid.

For example, to rotate the color space counterclockwise by 30 degree, the coefficients should be 37h, 20h, e0h, and 37h.

**C11** The coefficient C11 of the transformation matrix in 2's complement format.

**C12** The coefficient C12 of the transformation matrix in 2's complement format.

**C21** The coefficient C21 of the transformation matrix in 2's complement format.

**C22** The coefficient C22 of the transformation matrix in 2's complement format.

**IMG+0110h Saturation adjustment coefficient**
**IMGPROC\_SAT  
ADJ**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | SAT |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 20h |

This register defines the parameter of saturation adjustment for the image. The basics of saturation tuning is to multiply the U and V component by a scaling factor, which could range from 0 to 255, to degrade or enhance the strength on color components. Setting to 20h represents no scaling.

**SAT** Saturation coefficient.

**IMG+0120h Brightness adjustment coefficient B1**
**IMGPROC\_BRIA  
DJ1**

| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|

|       |  |  |  |  |  |  |  |  |  |  |  |            |  |
|-------|--|--|--|--|--|--|--|--|--|--|--|------------|--|
| Name  |  |  |  |  |  |  |  |  |  |  |  | <b>BRI</b> |  |
| Type  |  |  |  |  |  |  |  |  |  |  |  | R/W        |  |
| Reset |  |  |  |  |  |  |  |  |  |  |  | 0          |  |

This register defines the parameter of brightness adjustment for the image. The parameter is in unsigned format. Setting the value to be greater than 0 adds to the intensity of the image pixel. In terms of transfer curve, it represents the offset in the y-axis. The valid value ranges from 0 to 255.

**BRI** Brightness adjustment coefficient.

#### IMG+0124h Brightness adjustment coefficient B2

**IMGPROC\_BRIA**  
**DJ2**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3          | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|------------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | <b>DRK</b> |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | R/W        |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0          |   |   |   |

This register controls the parameter of brightness adjustment for the image. The parameter is in unsigned format. Setting the value to be greater than 0 degrades the intensity of the image pixel. In terms of transfer curve, it represents the offset in the x-axis. The valid value ranges from 0 to 255.

**DRK** Brightness adjustment coefficient

#### IMG+0128h Contrast adjustment coefficient

**IMGPROC\_CON**  
**ADJ**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3          | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|------------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | <b>CON</b> |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | R/W        |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 20h        |   |   |   |

This register defines the parameter of contrast adjustment for the image pixel. The parameter is in unsigned format with normalization factor 20h. Setting the value to be greater than 20h enhances the contrast for the image; and setting the value to be less than 20h lowers the contrast for the image. The valid value ranges from 0 to 255.

**CON** Contrast adjustment coefficient

#### IMG+0130h Colorize u component coefficient

**IMGPROC\_COL**  
**ORIZEU**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3           | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-------------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | <b>UCOM</b> |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | R/W         |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0           |   |   |   |

#### IMG+0134h Colorize v component coefficient

**IMGPROC\_COL**  
**ORIZEV**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3           | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-------------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | <b>VCOM</b> |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | R/W         |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0           |   |   |   |

These registers controls the parameters of colorize effect for the image. The valid value ranges from -128 to 127 in 2's complement format. If the values of both coefficients are zero, it implies the gray-scale effect.

**UCOM** Colorize effect u component coefficient.

**VCOM** Colorize effect v component coefficient.

### IMG+0140h Mask coefficient C11

IMGPROC\_MAS  
K11

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | C11 |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0   |   |

### IMG+0144h Mask coefficient C12

IMGPROC\_MAS  
K12

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | C12 |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0   |   |

### IMG+0148h Mask coefficient C13

IMGPROC\_MAS  
K13

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | C13 |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0   |   |

### IMG+014Ch Mask coefficient C21

IMGPROC\_MAS  
K21

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | C21 |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0   |   |

### IMG+0150h Mask coefficient C22

IMGPROC\_MAS  
K22

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | C22 |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0   |   |

### IMG+0154h Mask coefficient C23

IMGPROC\_MAS  
K23

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | C23 |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0   |   |

**IMG+0158h Mask coefficient C31**
**IMGPROC\_MAS  
K31**

| Bit   | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | C31 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**IMG+015Ch Mask coefficient C32**
**IMGPROC\_MAS  
K32**

| Bit   | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | C32 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**IMG+0160h Mask coefficient C33**
**IMGPROC\_MAS  
K33**

| Bit   | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | C33 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

These registers define the 9 mask coefficients for linear filtering. The coefficients are in 2's complement format with range from -16 to 15. The index associated with these coefficients represents the row index followed by the column index. The Image Engine performs the same arithmetic convolution on 3 components of the target image.

$$\begin{bmatrix} C11 & C12 & C13 \\ C21 & C22 & C23 \\ C31 & C32 & C33 \end{bmatrix}$$

- C11** Mask coefficient C11.
- C12** Mask coefficient C12.
- C13** Mask coefficient C13.
- C21** Mask coefficient C21.
- C22** Mask coefficient C22.
- C23** Mask coefficient C23.
- C31** Mask coefficient C31.
- C32** Mask coefficient C32.
- C33** Mask coefficient C33

**IMG+0164h Mask data down-scaling coefficient**
**IMGPROC\_SCA  
LE**

| Bit   | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | SCA |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

This register stores the value that could divide the mask data after convolution. It's used for normalization, and only for linear HP mode.

**SCA** The value used to scale down the mask data.

### IMG+0170h Gamma correction offset value for segment 0

IMGPROC\_GAM  
MA\_OFF0

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2    | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|------|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | OFF0 |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | R/W  |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0    |   |   |

This register stores the y-offset value of the segment 0 for gamma correction.

**OFF0** Offset value.

For offset values of other segments, please refer to **Table 37**.

### IMG+0190h Gamma correction slope value for segment 0

IMGPROC\_GAM  
MA\_SLP0

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2    | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|------|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | SLP0 |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | R/W  |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0    |   |   |

This register stores the slope value of the segment 0 for gamma correction.

**SLP0** Slope value.

For slope values of other segments, please refer to **Table 37**.

### IMG+01B0h Gamma correction control register

IMGPROC\_GAM  
MA\_CON

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | GTO |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0   |   |

This register is used to control the gamma correction mode.

**GTO** gamma value greater than one indicator

- 0** Gamma value is not greater than one.
- 1** Gamma value is greater than one.

| Register Address | Register Function                            | Acronym            |
|------------------|----------------------------------------------|--------------------|
| IMG+0170h        | Offset value for the 1 <sup>st</sup> segment | IMGPROC_GAMMA_OFF0 |
| IMG+0174h        | Offset value for the 2 <sup>nd</sup> segment | IMGPROC_GAMMA_OFF1 |
| IMG+0178h        | Offset value for the 3 <sup>rd</sup> segment | IMGPROC_GAMMA_OFF2 |
| IMG+017Ch        | Offset value for the 4 <sup>th</sup> segment | IMGPROC_GAMMA_OFF3 |
| IMG+0180h        | Offset value for the 5 <sup>th</sup> segment | IMGPROC_GAMMA_OFF4 |

|           |                                              |                    |
|-----------|----------------------------------------------|--------------------|
| IMG+0184h | Offset value for the 6 <sup>th</sup> segment | IMGPROC_GAMMA_OFF5 |
| IMG+0188h | Offset value for the 7 <sup>th</sup> segment | IMGPROC_GAMMA_OFF6 |
| IMG+018Ch | Offset value for the 8 <sup>th</sup> segment | IMGPROC_GAMMA_OFF7 |
| IMG+0190h | Slope value for the 1 <sup>st</sup> segment  | IMGPROC_GAMMA_SLP0 |
| IMG+0194h | Slope value for the 2 <sup>nd</sup> segment  | IMGPROC_GAMMA_SLP1 |
| IMG+0198h | Slope value for the 3 <sup>rd</sup> segment  | IMGPROC_GAMMA_SLP2 |
| IMG+019Ch | Slope value for the 4 <sup>th</sup> segment  | IMGPROC_GAMMA_SLP3 |
| IMG+01A0h | Slope value for the 5 <sup>th</sup> segment  | IMGPROC_GAMMA_SLP4 |
| IMG+01A4h | Slope value for the 6 <sup>th</sup> segment  | IMGPROC_GAMMA_SLP5 |
| IMG+01A8h | Slope value for the 7 <sup>th</sup> segment  | IMGPROC_GAMMA_SLP6 |
| IMG+01ACh | Slope value for the 8 <sup>th</sup> segment  | IMGPROC_GAMMA_SLP7 |

**Table 37** Gamma correction offset and slope register list

**IMG+0200h Color adjustment offset x for 2<sup>nd</sup> segment, red**
**IMGPROC\_COL  
OR1R\_OFFSET\_X**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | OFFX |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W  |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0    |

**IMG+0220h Color adjustment offset y for 2<sup>nd</sup> segment, red**
**IMGPROC\_COL  
OR1R\_OFFSET\_Y**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | OFFY |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W  |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0    |

**IMG+0240h Color adjustment slope for 2<sup>nd</sup> segment, red**
**IMGPROC\_COL  
OR1R\_SLOPE**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | SLP |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0   |

The above lists part of the registers that define the color adjustment parameters.

Color adjustment in Image Engine is used to tune the red, green, and blue color dimension individually to exhibit required color tone as a whole. We provide 3-segment piecewise linear transfer curve for the user to be configured.

The x offset defines the separation point for input color value. The y offset defines the offset for each segment. The slope defines the contrast enhancement ratio for each segment.

For the red and blue components, the bit-width of the offset value is 5. For green, the bit-width of the offset value is 6. For slope of 3 color components, the bit-width is 6.

**OFFX** input value separation point.

**OFFY** output value offset.

**SLP** Slope. Contrast tuning ratio within the segment.

For all the registers of color adjustment, please refer to **Table 6** for detail information.

| Register Address | Register Function                                            | Bit-width | Acronym                  |
|------------------|--------------------------------------------------------------|-----------|--------------------------|
| IMG+0200h        | Color adjustment offset x for 2 <sup>nd</sup> segment, red   | 5         | IMGPROC_COLOR1R_OFFSET_X |
| IMG+0204h        | Color adjustment offset x for 3 <sup>rd</sup> segment, red   | 5         | IMGPROC_COLOR2R_OFFSET_X |
| IMG+0208h        | Color adjustment offset x for 2 <sup>nd</sup> segment, green | 6         | IMGPROC_COLOR1G_OFFSET_X |
| IMG+020Ch        | Color adjustment offset x for 3 <sup>rd</sup> segment, green | 6         | IMGPROC_COLOR2G_OFFSET_X |
| IMG+0210h        | Color adjustment offset x for 2 <sup>nd</sup> segment, blue  | 5         | IMGPROC_COLOR1B_OFFSET_X |
| IMG+0214h        | Color adjustment offset x for 3 <sup>rd</sup> segment, blue  | 5         | IMGPROC_COLOR2B_OFFSET_X |
| IMG+0220h        | Color adjustment offset y for 2 <sup>nd</sup> segment, red   | 5         | IMGPROC_COLOR1R_OFFSET_Y |
| IMG+0224h        | Color adjustment offset y for 3 <sup>rd</sup> segment, red   | 5         | IMGPROC_COLOR2R_OFFSET_Y |
| IMG+0228h        | Color adjustment offset y for 2 <sup>nd</sup> segment, green | 6         | IMGPROC_COLOR1G_OFFSET_Y |
| IMG+022Ch        | Color adjustment offset y for 3 <sup>rd</sup> segment, green | 6         | IMGPROC_COLOR2G_OFFSET_Y |
| IMG+0230h        | Color adjustment offset y for 2 <sup>nd</sup> segment, blue  | 5         | IMGPROC_COLOR1B_OFFSET_Y |
| IMG+0234h        | Color adjustment offset y for 3 <sup>rd</sup> segment, blue  | 5         | IMGPROC_COLOR2B_OFFSET_Y |
| IMG+0240h        | Color adjustment slope for 1 <sup>st</sup> segment, red      | 16        | IMGPROC_COLOR0R_SLOPE    |
| IMG+0244h        | Color adjustment slope for 2 <sup>nd</sup> segment, red      | 16        | IMGPROC_COLOR1R_SLOPE    |
| IMG+0248h        | Color adjustment slope for 3 <sup>rd</sup> segment, red      | 16        | IMGPROC_COLOR2R_SLOPE    |
| IMG+0250h        | Color adjustment slope for 1 <sup>st</sup> segment, green    | 16        | IMGPROC_COLOR0G_SLOPE    |
| IMG+0254h        | Color adjustment slope for 2 <sup>nd</sup> segment, green    | 16        | IMGPROC_COLOR1G_SLOPE    |
| IMG+0258h        | Color adjustment slope for 3 <sup>rd</sup> segment, green    | 16        | IMGPROC_COLOR2G_SLOPE    |
| IMG+0260h        | Color adjustment slope for 1 <sup>st</sup> segment, blue     | 16        | IMGPROC_COLOR0B_SLOPE    |
| IMG+0264h        | Color adjustment slope for 2 <sup>nd</sup> segment, blue     | 16        | IMGPROC_COLOR1B_SLOPE    |
| IMG+0268h        | Color adjustment slope for 3 <sup>rd</sup> segment, blue     | 16        | IMGPROC_COLOR2B_SLOPE    |

**Table 38** Color adjustment offset and slope register list

### IMG+0304h Image frame width

### IMGPROC\_IMG WIDTH

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4   | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|----|-----|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   | IM |     |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |    | R/W |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |    |     | 0 |   |   |   |

This register is the image frame width register. The maximum allowable frame width is 2047. The Image Engine uses it to locate the address for every pixel in the image frame.

**IM** Image frame width

**IMG+0308h Image frame height**
**IMGPROC\_IMGH  
EIGHT**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|-----|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   | IH  |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   | R/W |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   | 0   |   |   |   |   |   |

This register is the image frame height register. The maximum allowable frame height is 2047. The Image Engine uses it to locate the address for every pixel in the image frame.

**IH** Image frame width

**IMG+030Ch Image frame source register**
**IMGPROC\_ADD  
R\_SRC**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24         | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    | SRC[31:16] |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R/W        |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | 0          |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8          | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    | SRC[15:0]  |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R/W        |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | 0          |    |    |    |    |    |    |    |    |

This register defines the starting address of the source image frame. The Image Engine takes this address as that of the top-left pixel in the source image frame, and assumes the image frame is stored continuously, such that, all other pixels in that image frame can be addressed by an offset, which is calculated by the engine.

**SRC** The source address

**IMG+0310h Image frame destination register**
**IMGPROC\_ADD  
R\_DST**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24         | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    | DST[31:16] |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R/W        |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | 0          |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8          | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    | DST[15:0]  |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R/W        |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | 0          |    |    |    |    |    |    |    |    |

This register defines the starting address of the destination image frame. The Image Engine writes the processed image pixel by pixel from the top-left corner into the memory. The target image will be stored in the continuous address in the memory.

**DST** The destination address

**IMG+0314h Dummy pixel**
**IMGPROC\_DUM  
MYPXL**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5     | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|-------|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   | DUMMY |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   | R/W   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   | 0     |   |   |   |   |   |

This register defines the dummy pixel value, which is taken to pad beyond the image frame boundary when performing the ranking (maximum, median, and minimum) filter. The value is unsigned and is applied on all R/G/B color components simultaneously.

For linear filtering, the Image Engine only considers the pixels within the image boundary.

**DUMMY** The dummy pixel.

### 6.12.2 Image effect application

The Image Engine is the hardware coprocessor that performs image effects on video stream or stand-alone image. It provides the following effects:

1. Hue adjustment.
2. Saturation adjustment.
3. Contrast and intensity adjustment.
4. Grayscale and colorization.
5. Gamma correction.
6. Color adjustment.
7. Linear filtering.
8. Nonlinear filtering.

The format of the coefficients is listed in **Table 39**.

| Function                | Parameter group          | Range (normalized factor) | Format         |
|-------------------------|--------------------------|---------------------------|----------------|
| Hue                     | C11, C12, C21, C22       | -64 ~ 64 (64)             | 2's complement |
| Saturation              | SAT                      | 0~255 (32)                | Unsigned       |
| Contrast and brightness | BRI1                     | 0~255                     | Unsigned       |
|                         | BRI2                     | 0~255                     | Unsigned       |
|                         | Contrast                 | 0~255 (32)                | Unsigned       |
| Colorize                | U, V                     | -128~127                  | 2's complement |
| Gamma correction        | Offset                   | 0~63                      | Unsigned       |
|                         | Slope                    | 0~255 (16)                | Unsigned       |
| Color adjustment        | Offset for red           | 0~31                      | Unsigned       |
|                         | Slope for red            | 0~63 (16)                 | Unsigned       |
|                         | Offset for green         | 0~63                      | Unsigned       |
|                         | Slope for green          | 0~63 (16)                 | Unsigned       |
|                         | Offset for blue          | 0~31                      | Unsigned       |
|                         | Slope for blue           | 0~63 (16)                 | Unsigned       |
| Mask                    | C11, C12, C13, C21, C22, | -16~15                    | 2's complement |

|  |                    |      |          |
|--|--------------------|------|----------|
|  | C23, C31, C32, C33 |      |          |
|  | Dummy pixel        | 0~63 | Unsigned |

**Table 39** Coefficients format table

### 6.12.2.1 Gamma correction and color adjustment

Gamma correction is a nonlinear technique. We use linear-approximation scheme for it and the same curve is applied equally on red, green, and blue components.

Two approaches are provided. For the first one, the overall input value is equally divided into 8 segments. It's suitable for the case when gamma is greater than 1. For the second one, the value is divided into 6 unsymmetrical segments. It's suitable for the case when gamma is smaller then 1.

Color adjustment is used to adjust different colors with different curves. For each color, a 3 segment piece-wise linear curve is applied. The user has to decide the offsets and the slopes of these 3 segments. The coefficients should be positive.

Cool tone and warm tone filters are both popular applications for color adjustment.

### 6.12.2.2 Filtering coefficients for linear filter

The filtering operation in Image Engine basically imposes artifacts on the original image and aims to produce a variety of effects.

For low pass filter, the matrix can be defined as

$$H = \left[ \frac{1}{b+2} \right]^2 \cdot \begin{bmatrix} 1 & b & 1 \\ b & b^2 & b \\ 1 & b & 1 \end{bmatrix}, \text{ where } b \text{ is a positive number}$$

$$H_1 = \left[ \frac{1}{9} \right] \cdot \begin{bmatrix} 1 & 1 & 1 \\ 1 & 1 & 1 \\ 1 & 1 & 1 \end{bmatrix}, H_2 = \left[ \frac{1}{10} \right] \cdot \begin{bmatrix} 1 & 1 & 1 \\ 1 & 2 & 1 \\ 1 & 1 & 1 \end{bmatrix}, \text{ and } H_3 = \left[ \frac{1}{16} \right] \cdot \begin{bmatrix} 1 & 2 & 1 \\ 2 & 4 & 2 \\ 1 & 2 & 1 \end{bmatrix} \text{ are all popular examples that could}$$

present blur or softening effects. The concept can be extended to larger size matrix. For  $H_1$ -like matrix, we provided 5x5 and 7x7 option, which we named *blur* and *more blur* effects. The matrices are as follows:

$$H_{5 \times 5} = \left[ \frac{1}{25} \right] \cdot \begin{bmatrix} 1 & 1 & 1 & 1 & 1 \\ 1 & 1 & 1 & 1 & 1 \\ 1 & 1 & 1 & 1 & 1 \\ 1 & 1 & 1 & 1 & 1 \\ 1 & 1 & 1 & 1 & 1 \end{bmatrix}$$

$$H_{7 \times 7} = \left[ \frac{1}{49} \right] \cdot \begin{bmatrix} 1 & 1 & 1 & 1 & 1 & 1 & 1 \\ 1 & 1 & 1 & 1 & 1 & 1 & 1 \\ 1 & 1 & 1 & 1 & 1 & 1 & 1 \\ 1 & 1 & 1 & 1 & 1 & 1 & 1 \\ 1 & 1 & 1 & 1 & 1 & 1 & 1 \\ 1 & 1 & 1 & 1 & 1 & 1 & 1 \\ 1 & 1 & 1 & 1 & 1 & 1 & 1 \end{bmatrix}$$

For high-pass filter, we illustrate some commonly used matrices.

$$H_1 = \begin{bmatrix} 0 & -1 & 0 \\ -1 & 5 & -1 \\ 0 & -1 & 0 \end{bmatrix}, H_2 = \begin{bmatrix} -1 & -1 & -1 \\ -1 & 9 & -1 \\ -1 & -1 & -1 \end{bmatrix}, H_3 = \begin{bmatrix} 1 & -2 & 1 \\ -2 & 5 & -2 \\ 1 & -2 & 1 \end{bmatrix}$$

These filters present edge enhancement effects. They all have the property that the sum of their elements is unity in order to avoid amplitude bias in the processed image. In Image Engine, the user can choose *HP filtering* option for them.

For matrix like  $H = \frac{1}{3} \cdot \begin{bmatrix} 0 & -1 & 0 \\ -1 & 7 & -1 \\ 0 & -1 & 0 \end{bmatrix}$ , a division-by-3 is required since the sum of its elements is not unity. For this case, the user should program the register `IMGPROC_SCALE` and choose *HP filtering with scale down* option.

For matrix like  $H = \begin{bmatrix} -1 & -1 & -1 \\ -1 & 8 & -1 \\ -1 & -1 & -1 \end{bmatrix}$ , the sum of its elements is 0 and no division is required. The user can choose *HP filtering* option for it.

### 6.12.2.3 Nonlinear filter

Median filter is a nonlinear technique that is useful for noise suppression in images. It consists of a 3-by-3 sliding window. The center pixel in the window is replaced by the median of the pixels in the window.

The idea is further extended to maximum filter and minimum filter. The maximum filter presents dilation effects. It puts more emphasis on the brighter point in the image. On the contrary, the minimum filter presents erosion effects.

### 6.12.3 Image process control

For filtering application, the software can initialize, start, and stop the operation of the Image Engine. Setting `START` bit in the register `IMGPROC_CON` starts the operation, and setting `STOP` bit stops the operation. Notice that the user should not restart the next process before the Image Engine returns from BUSY state. The user can check the status by monitoring `BUSY` bit in the register `IMGPROC_STS`.

## 6.13 MPEG-4/H.263 Video CODEC

### 6.13.1 General Description

MPEG-4 is an emerging video coding standard defined in ISO/IEC 14496-2. It is designed to cover a wide range of bit-rates (typically, 5 kbps to 10Mbps). MPEG-4 standard has become one of the enabling factors for mobile multimedia communications. H.263 is another video coding standard that is developed by ITU-T/SG 15 for low-bit-rate applications below 64kbps. H.263 profile 0 level 10 is the mandatory video decoder in 3GPP specification. Therefore, our goal is to design a video codec suited to both MPEG-4 and H.263 standard.

There are two coding modes in MPEG-4 video compression: Intra-frame coding and Inter-frame coding. Intra-frame coding refers to video coding techniques that achieve compression by exploiting the high spatial correlation between neighboring pels within a video frame. Such techniques are also known as spatial redundancy reduction techniques or still-image coding techniques. Inter-frame coding refers to video coding techniques that achieve compression by exploiting the high temporal correlation between the frames of a video sequence. Such methods are also known as temporal redundancy reduction techniques. Note that inter-frame coding may not be appropriate for some applications. For example, it would be necessary to decode the complete inter-frame coded sequence before being able to randomly access individual frames. Thus, a combined approach is normally used in which a number of frames are intra-frame coded (I-frames) at specific intervals within the sequence and the other frames are inter-frame coded (Predicted or P-frames) with reference to those key frames. Moreover, intra-frame coding is allowed in P-frames.

The ISO/IEC 14496 specification is intended to be generic in the sense that it serves a wide range of applications, bit-rates, resolutions, qualities and services. A number of coding tools are defined in the specification. Considering the practicality of implementing the full syntax of this specification, a limited number of subsets of the syntax are also stipulated by means of “profile” and “level”. A “profile” is a defined subset of the entire bitstream syntax that is defined by this specification. A “level” is a defined set of constraints imposed on parameters in the bitstream. Our application is focused on handset devices. Due to restriction of limited resource, only simple profile is supported for most of handset devices. According to 3GPP TS 26.234 specification, H.263 profile 0 level 10 is the mandatory video decoder. MPEG-4 visual simple profile level 0 is an optional video decoder. The MPEG-4/H.263 codec supports both MPEG-4 simple profile and H.263 baseline profile. Generally, the file extension of MPEG-4 video file is .mp4. The file extension of 3GPP video file is .3gp.

The design implements both decoder and encoder. The decoder block diagram is shown in Figure 63. The encoder block diagram is shown in Figure 64

The design specification of our decoder is described as follows:

1. Support ISO/IEC 14496-2 MPEG-4 simple profile @ level 0~3
2. Support H.263 profile 0 level 10 (baseline profile)
3. The following visual tools are supported
  - ◆ I-VOP
  - ◆ P-VOP
  - ◆ AC/DC Prediction
  - ◆ 4-MV

- ◆ Unrestricted MV
- ◆ Error Resilience
  - Slice Resynchronization
  - Data Partitioning
  - Reversible VLC
- ◆ Short Header Mode
- ◆ Full and Half Pel accuracy
- ◆ *fcode* can be 1~7
- ◆ Maximum horizontal luminance pixel resolution can be up to 352
- ◆ Maximum vertical luminance pixel resolution can be up to 288
- ◆ Error Concealment
- ◆ Single object

The design specification of the encoder is described as follows:

4. Support ISO/IEC 14496-2 MPEG-4 simple profile @ level 0, partially support MPEG-4 simple profile @ level 1
5. Support H.263 profile 0 level 10
6. The following visual tools are supported
  - ◆ I-VOP
  - ◆ P-VOP
  - ◆ DC Prediction
  - ◆ Unrestricted MV
  - ◆ Short Header Mode
  - ◆ Full and Half Pel motion estimation
  - ◆ Decision making logic
  - ◆ *fcode* can be 1~3
  - ◆ *intra\_dc\_vlc\_threshold* shall be 0
  - ◆ Maximum horizontal luminance pixel resolution can be up to 352
  - ◆ Maximum vertical luminance pixel resolution can be up to 288



Figure 63 Block Diagram of Decoder



Figure 64 Block Diagram of Encoder

## 6.13.2 Register Definitions

### 6.13.2.1 Main Control

**MP4+0000h Video CODEC Command Register**
**MP4\_CODEC\_C  
OMD**

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16  |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|-----|
| Name | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -    | -   |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |     |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1    | 0   |
| Name | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | STAR | RST |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    | WO   | WO  |

This register is the main command register for video CODEC.

**RST** Software reset control for MPEG-4/H.263 video CODEC. The device driver software must always set this bit to 1 before starting encode or decode procedure.

**START** Start the CODEC operation. Set this bit will trigger encode or decode procedure.

**MP4+0004h Video CODEC Configuration Register**
**MP4\_CODEC\_C  
ONF**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22        | 21  | 20   | 19        | 18  | 17  | 16  |
|-------|----|----|----|----|----|----|----|----|-----|-----------|-----|------|-----------|-----|-----|-----|
| Name  | -  | -  | -  | -  | -  | -  | -  | -  | PMV | DQUA<br>N | FME | HALF |           |     |     |     |
| Type  |    |    |    |    |    |    |    |    | R/W | R/W       | R/W | R/W  | R/W       | R/W | R/W | R/W |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0         | 0   | 0    | 0         | 0   | 0   | 0   |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6         | 5   | 4    | 3         | 2   | 1   | 0   |
| Name  | -  | -  | -  | -  | -  | -  | -  | -  | -   | -         | -   | -    | VPGO<br>B | DCT | IRQ | ENC |
| Type  |    |    |    |    |    |    |    |    |     |           |     |      | R/W       | R/W | R/W | R/W |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0         | 0   | 0    | 0         | 0   | 0   | 0   |

This register is used to configure the operating conditions and modes of video CODEC.

**ENC** Video CODEC Operation Mode

- 0** Decode Mode
- 1** Encode Mode

**IRQ** Control for interrupt request

- 0** Disable the interrupt reporting mechanism
- 1** Enable the interrupt reporting mechanism

**DCT** DCT Control

- 0** Enable JPEG CODEC Operation
- 1** Enable MPEG-4 Video CODEC Operation

**VPGOB** Control for decoding Video Packet Header

- 0** Disable: decoding in Video Packet Level. It means the software will take the responsibility for decoding packet header of each video packet.
- 1** Enable: decoding in Video Object Plan Level

**STEP\_LIMIT** Step limit for Motion Estimation. The total number of steps in a n-step search is STEP\_LIMIT+2.

Increasing STEP\_LIMIT can increase search range of motion vectors.

**HALF** Motion Estimation uses half-pel resolution

- 0** Disable. Perform full pel motion estimation only
- 1** Enable. Perform full pel motion estimation first, then half pel motion estimation

**FME** Fast Motion Enhancement

- 0** Enable Four Step Search motion estimation algorithm
- 1** Enable Mediatek proprietary motion estimation algorithm. This algorithm can improve visual quality in fast motion pictures while maintaining the same quality as Four Step Search in slow motion pictures. Enabling this algorithm does not increase search time. Thus, set FME to 1 is recommended.

**DQUAN** Control for automatic update quantizer\_scale process

- 0** Disable
- 1** Enable

**PMV** Predictive Motion Vector Search. This is a two pass search algorithm. This algorithm can co-operate with both four step search (FME=0) and Mediatek proprietary search (FME=1). The idea is to initially consider several highly likely predictors (starting points), perform motion estimation from these predictors, and choose the best result among these predictors. In our approach, the two predictors approach is adopted. The origin (0,0) is considered as the predictor of first pass. The minimum BDM point found in first pass will be the predictor of the second pass. After finishing two-pass motion estimation, choose the best result between the two minimum BDM points. This algorithm can significantly improve PSNR by about 0.8dB. However, the search time will increase by about 60%. Setting PMV to 1 or 0 is the trade-off between visual quality and search time.

- 0** Disable
- 1** Enable

#### MP4+0008h Decoder Status Register

#### MP4\_DEC\_STS

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>STATE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type         | RO |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>STATE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type         | RO |

This register provides the state information of decoding sequencer for software program. It is a mirror of the HW one-hot sequencer state machine and can be used for debugging or IRQ status judging.

#### MP4+000Ch Encoder Status Register

#### MP4\_ENC\_STS

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>STATE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type         | RO |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>STATE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type         | RO |

This register provides the state information of encoding sequencer for software program. It is a mirror of the HW one-hot sequencer state machine and can be used for debugging or IRQ status judging.

#### MP4+0010h Interrupt Mask Register

#### MP4\_IRQ\_MAS K

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

|       |    |    |    |    |    |    |   |   |     |      |           |     |     |      |     |     |   |   |   |   |
|-------|----|----|----|----|----|----|---|---|-----|------|-----------|-----|-----|------|-----|-----|---|---|---|---|
| Name  | -  | -  | -  | -  | -  | -  | - | - | -   | -    | -         | -   | -   | -    | -   | -   | - | - | - | - |
| Type  |    |    |    |    |    |    |   |   |     |      |           |     |     |      |     |     |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |     |      |           |     |     |      |     |     |   |   |   |   |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6    | 5         | 4   | 3   | 2    | 1   | 0   |   |   |   |   |
| Name  | -  | -  | -  | -  | -  | -  | - | - | DMA | PACK | BLOC<br>K | ENC | DEC | MARK | RLD | VLD |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   | R/W | R/W  | R/W       | R/W | R/W | R/W  | R/W | R/W |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0   | 0    | 0         | 0   | 0   | 0    | 0   | 0   |   |   |   |   |

This register contains mask bit for each interrupt sources in MPEG-4 Video CODEC. It allows each interrupt source to be disabled or masked out separately under software control. After System Reset or software reset, all bit values will be set to '0' to indicate that interrupt requests are enabled.

**DMA** Mask of VLC DMA interrupt.

**PACK** Mask of video packet bit count expire interrupt.

**BLOCK** Mask of block procedure complete interrupt.

**ENC** Mask of encode complete interrupt.

**DEC** Mask of decode complete interrupt.

**MARK** Mask of marker error interrupt in decode.

**RLD** Mask of run length coding error interrupt

**VLD** Mask of VLD error interrupt generated in decoding process.

### MP4+0014h Interrupt Status Register

### MP4\_IRQ\_STS

|      |    |    |    |    |    |    |    |    |     |      |           |     |     |      |     |     |   |   |   |   |
|------|----|----|----|----|----|----|----|----|-----|------|-----------|-----|-----|------|-----|-----|---|---|---|---|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22   | 21        | 20  | 19  | 18   | 17  | 16  |   |   |   |   |
| Name | -  | -  | -  | -  | -  | -  | -  | -  | -   | -    | -         | -   | -   | -    | -   | -   | - | - | - | - |
| Type |    |    |    |    |    |    |    |    |     |      |           |     |     |      |     |     |   |   |   |   |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6    | 5         | 4   | 3   | 2    | 1   | 0   |   |   |   |   |
| Name | -  | -  | -  | -  | -  | -  | -  | -  | DMA | PACK | BLOC<br>K | ENC | DEC | MARK | RLD | VLD |   |   |   |   |
| Type |    |    |    |    |    |    |    |    | RO  | RO   | RO        | RO  | RO  | RO   | RO  | RO  |   |   |   |   |

This register allows software program to poll which interrupt source generates the interrupt request. A bit set to '1' indicates a corresponding active interrupt source. Note that **IRQ** control bit in **CODEC Configuration Register** should be enabled first in order to activate the interrupt reporting mechanism.

**DMA** Mask of VLC DMA interrupt. When decoder detects empty VLD stream buffer, an interrupt will inform the driver SW to refill the VLD stream buffer.

**PACK** Video Packet Bit Count Expired interrupt. If a video packet size is larger than defined the interrupt will happen.

**BLOCK** Block decode or encode complete. A normal complete flag if the SW needs a block-based HW decoding or encoding.

**ENC** Encode complete. A normal condition when encoding procedure is done.

**DEC** Decode complete. A normal condition when decoding procedure is done.

**MARK** Marker decode error occurred.

**RLD** Run length coding error. Generated when the accumulated run value is larger than 64 (the 8x8 block memory size).

**VLD** VLD error of decoding process. Generated when a code can not be correctly referenced in VLD table

### MP4+0018h Interrupt Acknowledge Register

MP4\_IRQ\_ACK

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22   | 21        | 20  | 19  | 18   | 17  | 16  |
|------|----|----|----|----|----|----|----|----|-----|------|-----------|-----|-----|------|-----|-----|
| Name | -  | -  | -  | -  | -  | -  | -  | -  | -   | -    | -         | -   | -   | -    | -   | -   |
| Type |    |    |    |    |    |    |    |    |     |      |           |     |     |      |     |     |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6    | 5         | 4   | 3   | 2    | 1   | 0   |
| Name | -  | -  | -  | -  | -  | -  | -  | -  | DMA | PACK | BLOC<br>K | ENC | DEC | MARK | RLD | VLD |
| Type |    |    |    |    |    |    |    |    | WC  | WC   | WC        | WC  | WC  | WC   | WC  | WC  |

This register provides a mean for software program to acknowledge the interrupt source. Writing a '1' to the specific bit position will result in an acknowledgement to the corresponding interrupt source.

**VLD** Variable Length Decoding Error

**RLD** Run Length Decoding Error

**MARK** Marker Decoding Error

**DEC** Decode Task Complete

**ENC** Encode Task Complete

**BLOCK** Block Task Complete

**PACK** Video Packet Bit Count Expired

**DMA** VLC DMA Buffer Limit Reached

### MP4+001Ch Encoder Configuration Register

MP4\_ENC\_CON  
F

| Bit   | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16   |
|-------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|------|
| Name  | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | PACK |
| Type  |     |     |     |     |     | R/W  |
| Reset |     |     |     |     | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0    |
| Bit   | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0    |
| Name  | -   | -   |     |     |     |     |     |     |     |     |     |     |     |     |     | SKIP |
| Type  | R/W |     |     | R/W | R/W | R/W | R/W | R/W | R/W  |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |     |     | 0   | 0   | 0   | 0   | 0   | 0    |

This register is used specially to configure the desired encode conditions and modes for video CODEC.

**SKIP** Threshold for deciding not\_coded bit. The value of SKIP is programmed by software first. The first round of pattern code (*me\_pattern\_code*) is set to 6'h0 whenever ( $SAD_y + SDA_u + SAD_v \leq \text{skip\_threshold} * 16$ ) not\_coded bit will be set if *pattern\_code* = 6'h0 and motion vector = (0,0)

**INTRA** Threshold for deciding INTRA Coding in P frame. The value of INTRA is programmed by software first. The 3-bits macro-block type (*mb\_type*) is set to 3'h0 (Inter MB) if  $SAD_y < \text{intra\_threshold} * 1024$ . Otherwise, *mb\_type* is set to 3'h3 (Intra\_MB)

**PACK** Use Video Packet Mode

**0** Disable

**1** Enable

**PACKCNT** Desired Bit Counts for a Video Packet. Used in encode mode to define the largest VLE buffer size of a video packet

### 6.13.2.2 Base Addresses

#### MP4+0100h CODEC MSB Base Address Register

MP4\_CODEC\_B  
ASE

|      |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |
|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|
| Bit  | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16 |
| Name |     |     |     |     |     |     |     |     |     |     |     |     |     |     | -   | -  |
| Type | R/W |    |
| Bit  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0  |
| Name | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -  |
| Type |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |

This register describes the MSB address that is used for VLD Data Load-Store and DC/AC Prediction Storage buffers. FOR THE FOLLOWING HW-USED OFFSET ADDRESSES, their MSB's must be confined within 1Mega. In other words, results of (base address + offset addresses) should have the same value in bit range [31, 20].

**CODEC** MPEG-4/H.263 CODEC MSB Base Address

#### MP4+0104h Current VOP Base Address Register

MP4\_VOP\_ADD  
R

|      |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Bit  | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
| Name |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Type | RO  | R/W | R/W |
| Bit  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name |     |     |     |     |     |     |     |     |     |     |     |     |     |     | -   | -   |
| Type | R/W |     |

This register describes the starting address of Current VOP Frame that is going to be encoded. Note that this base address should be 4-byte aligned. And the required frame buffer size should be: numbers of pixel per frame \* 1.5 bytes (YUV420 format).

**VOP** Current VOP Base Address. The high boundary address of current VOP should not cross 1M address boundary because the implementation of address offset counter is 20 bits. i.e. please make sure (the lower 20bits VOP base address + size of VOP frame) <  $2^{20}$

#### MP4+0108h Reference VOP Base Address Register

MP4\_REF\_ADD  
R

|      |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Bit  | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
| Name |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Type | RO  | R/W | R/W |
| Bit  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name |     |     |     |     |     |     |     |     |     |     |     |     |     |     | -   | -   |
| Type | R/W |     |

This register describes the starting address of Reference VOP Frame. Note that this base address should be 4-byte aligned. And the required frame buffer size should be: numbers of pixel per frame \* 1.5 bytes (YUV420 format).

**REF** Reference VOP Base Address. The high boundary address of Reference VOP should not cross 1M address boundary because the implementation of address offset counter is 20 bits. i.e. please make sure (the lower 20bits Reference base address + size of Reference frame) <  $2^{20}$

**MP4+010Ch Reconstructed VOP LSB Base Address Register**
**MP4\_REC\_ADD  
R**

|      |                   |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|------|-------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Bit  | 31                | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
| Name | <b>REC[31:16]</b> |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Type | RO                | RO  | RO  | RO  | RO  | RO  | RO  | RO  | RO  | RO  | RO  | RO  | RO  | RO  | R/W | R/W |
| Bit  | 15                | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name | <b>REC[15:2]</b>  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Type | R/W               | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W |

This register describes the starting address of Reconstructed VOP Frame. Note that this base address should be 4-byte aligned. And the required frame buffer size should be: numbers of pixel per frame \* 1.5 bytes (YUV420 format).

**REC** Reconstructed VOP Base Address. The high boundary address of Reconstructed VOP should not cross 1M address boundary because the implementation of address offset counter is 20 bits. i.e. please make sure (the lower 20bits Reconstructed base address + size of Reconstructed frame) <  $2^{20}$

**MP4+0110h VLC Data Load-Store LSB Base Address Register**
**MP4\_STORE\_ADDR**

|      |              |     |     |     |     |     |     |     |     |     |     |     |     |     |     |              |
|------|--------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|--------------|
| Bit  | 31           | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16           |
| Name | -            | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | <b>STORE</b> |
| Type |              |     |     |     |     |     |     |     |     |     |     |     |     |     | R/W | R/W          |
| Bit  | 15           | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0            |
| Name | <b>STORE</b> |     |     |     |     |     |     |     |     |     |     |     |     |     |     |              |
| Type | R/W          | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W          |

This register describes the LSB address of VLC Data Load-Store buffer in data-partitioned mode. Note that this base address should be 4-byte aligned. And the required buffer size for encoder and decoder should be: 3K bytes and number of macroblock per frame \* 32 bytes, respectively.

**STORE** LSB address of VLC Data Load-Store buffer

**MP4+0114h DC/AC Prediction Storage LSB Base Address Register**
**MP4\_DACP\_AD  
DR**

|      |             |     |     |     |     |     |     |     |     |     |     |     |     |     |     |             |
|------|-------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-------------|
| Bit  | 31          | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16          |
| Name | -           | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | <b>DACP</b> |
| Type |             |     |     |     |     |     |     |     |     |     |     |     |     |     | R/W | R/W         |
| Bit  | 15          | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0           |
| Name | <b>DACP</b> |     |     |     |     |     |     |     |     |     |     |     |     |     |     |             |
| Type | R/W         | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W         |

This register describes the LSB address of DC/AC Prediction Storage buffer. Note that this base address should be 4-byte aligned. And the required buffer size for encoder and decoder should be: 512 bytes and 2K bytes, respectively.

**DACP** LSB address of DC/AC Prediction Storage buffer

### 6.13.2.3 Data Structure

**MP4+0200h VOP Structure 0 Register**
**MP4\_VOP\_STR  
UC0**

|     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

|      |        |     |     |       |     |     |     |     |       |     |       |     |      |      |      |       |
|------|--------|-----|-----|-------|-----|-----|-----|-----|-------|-----|-------|-----|------|------|------|-------|
| Name | -      | -   | -   | -     | -   | -   | -   | -   | -     | -   | -     | -   | -    | -    | -    | ROUND |
| Type |        |     |     |       |     |     |     |     |       |     |       |     |      |      |      | R/W   |
| Bit  | 15     | 14  | 13  | 12    | 11  | 10  | 9   | 8   | 7     | 6   | 5     | 4   | 3    | 2    | 1    | 0     |
| Name | VLCTHR |     |     | QUANT |     |     |     |     | FCODE |     | SHORT | -   | RVLC | DATA | TYPE |       |
| Type | R/W    | R/W | R/W | R/W   | R/W | R/W | R/W | R/W | R/W   | R/W | R/W   | R/W | R/W  | R/W  | R/W  | R/W   |

This register is used to describe the header information of a certain Video Object Plan that is going to be processed by video CODEC.

**TYPE** vop\_coding\_type definition, for encode.

0 This is a P-VOP frame (inter frame)

1 This is an I-VOP frame (intra frame)

**DATA** data\_partitioned, for decode.

0 Data stream is in non-data-partitioned mode

1 Data stream is in data-partitioned mode

**RVLC** resversible\_vlc, for decode.

0 Data stream contains no reversible VLC information

1 Data stream uses reversible VLC tables.

**SHORT** short\_video\_header

0 Normal MPEG-4 format

1 H.263 Compatible format

**FCODE** fcode size setting for encode, ranges from 0 to 7.

**QUANT** vop\_quant. Quantizer scale of the current frame. For variable Q in decode mode, QUANT is an initial setting of the current frame.

**VLCTHR** intra\_dc\_vlc\_thr. According to VLCTHR, the decoder has to switch from intra DC mode to inter DC mode when the quantizer\_scale is larger than a pre-defined value. VLCTHR ranges from 0 to 7.

**ROUND** Rounding type of half-pel motion compensation. ROUND==1 means truncation toward zero (the pixel value is always larger than 0); ROUND==0 means rounding-off addition.

## MP4+0204h VOP Structure 1 Register

MP4\_VOP\_STR  
UC1

|      |     |     |     |     |        |     |     |     |     |     |     |     |     |          |     |     |
|------|-----|-----|-----|-----|--------|-----|-----|-----|-----|-----|-----|-----|-----|----------|-----|-----|
| Bit  | 31  | 30  | 29  | 28  | 27     | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18       | 17  | 16  |
| Name | -   | -   | -   |     | HECBIT |     |     |     | -   | -   | -   | -   |     | MBLENGTH |     |     |
| Type |     |     |     | R/W | R/W    | R/W | R/W | R/W |     |     |     |     | R/W | R/W      | R/W | R/W |
| Bit  | 15  | 14  | 13  | 12  | 11     | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2        | 1   | 0   |
| Name | -   | -   | -   |     | YLIMIT |     |     |     | -   | -   | -   | -   |     | XLIMIT   |     |     |
| Type | R/W | R/W | R/W | R/W | R/W    | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W      | R/W | R/W |

This register is used by software program to control the start position and count limit of macroblock for a certain Video Packet or Video Object Plan that is going to be processed by video CODEC.

**XLIMIT** Macroblock count in X direction of a frame.

**YLIMIT** Macroblock count in Y direction of a frame.

**MBLENGTH** Bit count of Macroblock Number in Video Packet Header. It is a value defined by the following formula:

$$MBCNT = (XLIMIT+15)/16 * (YLIMIT+15)/16. \text{ For larger MBCNT, we have larger MBLENGTH.}$$

MBLENGTH is ranged from 1 to 14.

**HECBIT** Bit count of extension header code in Video Packet Header

**MP4+0208h VOP Structure 2 Register**
**MP4\_VOP\_STR  
UC2**

|      |    |    |    |     |     |     |     |             |     |     |     |     |     |     |     |             |
|------|----|----|----|-----|-----|-----|-----|-------------|-----|-----|-----|-----|-----|-----|-----|-------------|
| Bit  | 31 | 30 | 29 | 28  | 27  | 26  | 25  | 24          | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16          |
| Name | -  | -  | -  | -   | -   | -   | -   |             |     |     |     |     |     |     |     | <b>MBNO</b> |
| Type |    |    |    |     |     |     |     | R/W         | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W         |
| Bit  | 15 | 14 | 13 | 12  | 11  | 10  | 9   | 8           | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0           |
| Name | -  | -  | -  |     |     |     |     | <b>YPOS</b> | -   | -   | -   |     |     |     |     | <b>XPOS</b> |
| Type |    |    |    | R/W | R/W | R/W | R/W | R/W         |     |     |     | R/W | R/W | R/W | R/W | R/W         |

This register is used by software program to control the start position and count limit of macroblock for a certain Video Packet or Video Object Plan that is going to be processed by video CODEC.

**XPOS** Macroblock position in X coordinate that the SW wants to update.

**YPOS** Macroblock position in Y coordinate that the SW wants to update.

**MBNO** Macroblock count limit for a video packet or frame. For a CIF frame the value will be 352.

**MP4+020Ch VOP Structure 3 Register**
**MP4\_VOP\_STR  
UC3**

|      |    |    |    |    |    |    |    |             |    |    |    |    |    |    |    |             |
|------|----|----|----|----|----|----|----|-------------|----|----|----|----|----|----|----|-------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24          | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16          |
| Name | -  | -  | -  | -  | -  | -  | -  |             |    |    |    |    |    |    |    | <b>MBNO</b> |
| Type |    |    |    |    |    |    |    | RO          | RO | RO | RO | RO | RO | RO | RO | RO          |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8           | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0           |
| Name | -  | -  | -  |    |    |    |    | <b>YPOS</b> | -  | -  | -  |    |    |    |    | <b>XPOS</b> |
| Type |    |    |    | RO | RO | RO | RO | RO          |    |    |    | RO | RO | RO | RO | RO          |

This register provides the position and count information of a certain macroblock that is currently under process of video CODEC.

**XPOS** Current Macroblock Position in X coordinate

**YPOS** Current Macroblock Position in Y coordinate

**MBNO** Current Macroblock Count

**MP4+0210h MB Structure 0 Register**
**MP4\_MB\_STRU  
C0**

|      |                  |              |          |           |               |     |     |     |     |     |     |     |     |     |     |                  |
|------|------------------|--------------|----------|-----------|---------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|------------------|
| Bit  | 31               | 30           | 29       | 28        | 27            | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16               |
| Name | -                | -            | -        | -         | -             | -   | -   | -   | -   | -   | -   | -   | -   | -   | -   | <b>QUANTIZER</b> |
| Type |                  |              |          |           |               |     |     |     |     |     |     |     |     |     |     | R/W              |
| Bit  | 15               | 14           | 13       | 12        | 11            | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0                |
| Name | <b>QUANTIZER</b> | <b>DCVLC</b> | <b>C</b> | <b>AC</b> | <b>DQUANT</b> |     |     |     |     |     |     |     |     |     |     | <b>CODED</b>     |
| Type | R/W              | R/W          | R/W      | R/W       | R/W           | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W              |

This register is used to store the header information of current macroblock. This register is mostly used for debugging.

**CODED** not\_coded flag of current macroblock.

**TYPE** mb\_coding\_type of current macroblock.

**PATTERN** pattern\_code of current macroblock.

**DQUANT** dquant. It can be -2, -1, +1 or +2; total 4 possible choices using 2 bits to represent.

**AC** ac\_pred\_flag. It decides whether AC prediction is needed; always 0 in encoder.

**DCVLC** use\_intra\_dc\_vlc. If this bit is 0, intra AC VLC decode is used (no intra DC exists in current macroblock).

**QUANTIZER** quantizer\_scale, ranged from 1 to 31. It can be variable if we have dquant values.

**MP4+0214h MB Structure 1 Register**
**MP4\_MB\_STRU  
C1**

|      |    |    |    |    |     |     |     |     |     |     |     |     |     |     |     |              |
|------|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|--------------|
| Bit  | 31 | 30 | 29 | 28 | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16           |
| Name | -  | -  | -  | -  |     |     |     |     |     |     |     |     |     |     |     | <b>DC[1]</b> |
| Type |    |    |    |    | R/W          |
| Bit  | 15 | 14 | 13 | 12 | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0            |
| Name | -  | -  | -  | -  |     |     |     |     |     |     |     |     |     |     |     | <b>DC[0]</b> |
| Type |    |    |    |    | R/W          |

This register is used to store the DC value set 0 and 1 of current macroblock.

**DC[0]** DC Value for Luminance Block 0

**DC[1]** DC Value for Luminance Block 1

**MP4+0218h MB Structure 2 Register**
**MP4\_MB\_STRU  
C2**

|      |    |    |    |    |     |     |     |     |     |     |     |     |     |     |     |              |
|------|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|--------------|
| Bit  | 31 | 30 | 29 | 28 | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16           |
| Name | -  | -  | -  | -  |     |     |     |     |     |     |     |     |     |     |     | <b>DC[3]</b> |
| Type |    |    |    |    | R/W          |
| Bit  | 15 | 14 | 13 | 12 | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0            |
| Name | -  | -  | -  | -  |     |     |     |     |     |     |     |     |     |     |     | <b>DC[2]</b> |
| Type |    |    |    |    | R/W          |

This register is used to store the DC value set 2 and 3 of current macroblock. For debug purpose or SW encode/decode procedure.

**DC[2]** DC Value for Luminance Block 2

**DC[3]** DC Value for Luminance Block 3

**MP4+021Ch MB Structure 3 Register**
**MP4\_MB\_STRU  
C3**

|      |    |    |    |    |     |     |     |     |     |     |     |     |     |     |     |              |
|------|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|--------------|
| Bit  | 31 | 30 | 29 | 28 | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16           |
| Name | -  | -  | -  | -  |     |     |     |     |     |     |     |     |     |     |     | <b>DC[5]</b> |
| Type |    |    |    |    | R/W          |
| Bit  | 15 | 14 | 13 | 12 | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0            |
| Name | -  | -  | -  | -  |     |     |     |     |     |     |     |     |     |     |     | <b>DC[4]</b> |
| Type |    |    |    |    | R/W          |

This register is used to store the DC value set 4 and 5 of current macroblock. For debug purpose or SW encode/decode procedure.

**DC[4]** DC Value for Chrominance Block 4

**DC[5]** DC Value for Chrominance Block 5

**MP4+0230h MB Structure 4 Register**
**MP4\_MB\_STRU  
C4**

|      |    |    |    |    |    |    |    |    |     |     |     |     |     |     |     |               |
|------|----|----|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|---------------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16            |
| Name | -  | -  | -  | -  | -  | -  | -  | -  |     |     |     |     |     |     |     | <b>MVY[0]</b> |
| Type |    |    |    |    |    |    |    |    | R/W           |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0             |
| Name | -  | -  | -  | -  | -  | -  | -  | -  |     |     |     |     |     |     |     | <b>MVX[0]</b> |

|      |  |  |  |  |  |  |  |     |     |     |     |     |     |     |
|------|--|--|--|--|--|--|--|-----|-----|-----|-----|-----|-----|-----|
| Type |  |  |  |  |  |  |  | R/W |
|------|--|--|--|--|--|--|--|-----|-----|-----|-----|-----|-----|-----|

This register is used to store the motion vector set 0 of current macroblock. For debug purpose or SW encode/decode procedure.

**MVX[0]** X Component of Motion Vector Set 0

**MVY[0]** Y Component of Motion Vector Set 0

#### MP4+0234h MB Structure 5 Register

**MP4\_MB\_STRU  
C5**

|      |    |    |    |    |    |    |    |    |     |     |     |     |     |               |     |     |
|------|----|----|----|----|----|----|----|----|-----|-----|-----|-----|-----|---------------|-----|-----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22  | 21  | 20  | 19  | 18            | 17  | 16  |
| Name | -  | -  | -  | -  | -  | -  | -  | -  |     |     |     |     |     | <b>MVY[1]</b> |     |     |
| Type |    |    |    |    |    |    |    |    | R/W | R/W | R/W | R/W | R/W | R/W           | R/W | R/W |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6   | 5   | 4   | 3   | 2             | 1   | 0   |
| Name | -  | -  | -  | -  | -  | -  | -  | -  |     |     |     |     |     | <b>MVX[1]</b> |     |     |
| Type |    |    |    |    |    |    |    |    | R/W | R/W | R/W | R/W | R/W | R/W           | R/W | R/W |

This register is used to store the motion vector set 1 of current macroblock. For debug purpose or SW encode/decode procedure.

**MVX[1]** X Component of Motion Vector Set 1

**MVY[1]** Y Component of Motion Vector Set 1

#### MP4+0238h MB Structure 6 Register

**MP4\_MB\_STRU  
C6**

|      |    |    |    |    |    |    |    |    |     |     |     |     |     |               |     |     |
|------|----|----|----|----|----|----|----|----|-----|-----|-----|-----|-----|---------------|-----|-----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22  | 21  | 20  | 19  | 18            | 17  | 16  |
| Name | -  | -  | -  | -  | -  | -  | -  | -  |     |     |     |     |     | <b>MVY[2]</b> |     |     |
| Type |    |    |    |    |    |    |    |    | R/W | R/W | R/W | R/W | R/W | R/W           | R/W | R/W |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6   | 5   | 4   | 3   | 2             | 1   | 0   |
| Name | -  | -  | -  | -  | -  | -  | -  | -  |     |     |     |     |     | <b>MVX[2]</b> |     |     |
| Type |    |    |    |    |    |    |    |    | R/W | R/W | R/W | R/W | R/W | R/W           | R/W | R/W |

This register is used to store the motion vector set 2 of current macroblock. For debug purpose or SW encode/decode procedure.

**MVX[2]** X Component of Motion Vector Set 2

**MVY[2]** Y Component of Motion Vector Set 2

#### MP4+023Ch MB Structure 7 Register

**MP4\_MB\_STRU  
C7**

|      |    |    |    |    |    |    |    |    |     |     |     |     |     |               |     |     |
|------|----|----|----|----|----|----|----|----|-----|-----|-----|-----|-----|---------------|-----|-----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22  | 21  | 20  | 19  | 18            | 17  | 16  |
| Name | -  | -  | -  | -  | -  | -  | -  | -  |     |     |     |     |     | <b>MVY[3]</b> |     |     |
| Type |    |    |    |    |    |    |    |    | R/W | R/W | R/W | R/W | R/W | R/W           | R/W | R/W |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6   | 5   | 4   | 3   | 2             | 1   | 0   |
| Name | -  | -  | -  | -  | -  | -  | -  | -  |     |     |     |     |     | <b>MVX[3]</b> |     |     |
| Type |    |    |    |    |    |    |    |    | R/W | R/W | R/W | R/W | R/W | R/W           | R/W | R/W |

This register is used to store the motion vector set 3 of current macroblock. For debug purpose or SW encode/decode procedure.

**MVX[3]** X Component of Motion Vector Set 3

**MVY[3]** Y Component of Motion Vector Set 3

### 6.13.2.4 VLC DMA

**MP4+0300h VLC DMA Command Register**
**MP4\_VLC\_COM  
D**

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19                 | 18                | 17          | 16                |
|------|----|----|----|----|----|----|----|----|----|----|----|----|--------------------|-------------------|-------------|-------------------|
| Name | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -                  | -                 | -           | -                 |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |                    |                   |             |                   |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3                  | 2                 | 1           | 0                 |
| Name | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | <b>RELO<br/>AD</b> | <b>FLUS<br/>H</b> | <b>STOP</b> | <b>STAR<br/>T</b> |
| Type |    |    |    |    |    |    |    |    |    |    |    |    | WO                 | WO                | WO          | WO                |

This register is the main control of VLC DMA.

**START** Start the VLC DMA. Trigger VLC DMA through SW rather than HW state machine.

**STOP** Stop the VLC DMA. Stop VLC DMA activities through SW rather than HW state machine.

**FLUSH** Flush the contents in FIFO. When SW needs the incomplete word (after the entire frame is encoded or for debugging purpose), FLUSH will write out the last word to memory.

**RESUME** Resume the VLC DMA access. VLC DMA state machine will go to a pending state if the maximum allowed write count to target memory is reached and then an interrupt has occurred. After re-allocating the target address, SW writes RESUME to unfreeze the encoding process.

**MP4+0304h VLC DMA Status Register**
**MP4\_VLC\_STS**

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25         | 24         | 23 | 22 | 21 | 20 | 19 | 18           | 17          | 16                |
|------|----|----|----|----|----|----|------------|------------|----|----|----|----|----|--------------|-------------|-------------------|
| Name | -  | -  | -  | -  | -  | -  | -          | -          | -  | -  | -  | -  | -  | -            | <b>FULL</b> | <b>EMPT<br/>Y</b> |
| Type |    |    |    |    |    |    |            |            |    |    |    |    |    |              | RO          | RO                |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9          | 8          | 7  | 6  | 5  | 4  | 3  | 2            | 1           | 0                 |
| Name | -  | -  | -  | -  | -  | -  | <b>VLD</b> | <b>VLE</b> | -  | -  | -  | -  | -  | <b>STATE</b> |             |                   |
| Type |    |    |    |    |    |    | RO         | RO         |    |    |    | RO | RO | RO           | RO          | RO                |

This register provides software program the information of current status of VLD DMA.

**STATE** State of VLC DMA Engine

**VLE** VLE Stream Ready

**VLD** VLD Stream Ready

**EMPTY** FIFO Empty

**FULL** FIFO Full

**MP4+0308h VLC DMA Base Address Register**
**MP4\_VLC\_ADD  
R**

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | WO |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    | -  | -  |
| Type | WO |

This register is used to describe the address of started Code Word for each VLC DMA buffer. Note that this base address should be 4-byte aligned.

**BASE** VLC DMA Base Address

**MP4+030Ch VLC DMA Base Bit Count Register**
**MP4\_VLC\_BIT**

|      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 |    |
| Name | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -   | -  |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0  |    |
| Name | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | BIT |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    | WO | WO  | WO | WO |

This register is used to describe the starting bit position of the 1<sup>st</sup> Code Word in the 1<sup>st</sup> VLC DMA buffer. For the following VLC DMA buffers, it is assumed that they are all 4-byte aligned and always start from bit position “0”.

**BIT** Start of Bit at the 1<sup>st</sup> Code Word of 1<sup>st</sup> DMA Buffer

**MP4+0310h VLC DMA Buffer Limit Register**
**MP4\_VLC\_LIMIT**

|       |     |     |     |     |     |     |     |       |     |     |     |     |     |     |     |     |
|-------|-----|-----|-----|-----|-----|-----|-----|-------|-----|-----|-----|-----|-----|-----|-----|-----|
| Bit   | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24    | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
| Name  | -   | -   | -   | -   | -   | -   | -   | -     | -   | -   | -   | -   | -   | -   | -   | -   |
| Type  |     |     |     |     |     |     |     |       |     |     |     |     |     |     |     |     |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bit   | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8     | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name  |     |     |     |     |     |     |     | LIMIT |     |     |     |     |     |     |     |     |
| Type  | R/W   | R/W | R/W | R/W | R/W | R/W | R/W | R/W | R/W |
| Reset | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1     | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   |

This register is used to describe the buffer size of each VLC DMA buffer. Note that the value is counted in word (32-bit). Whenever the limit is reached and the corresponding interrupt control is enabled, an interrupt request will be generated.

**LIMIT** DMA Buffer Size, Count in Word (32-bit)

**MP4+0314h VLC DMA Current Word Register**
**MP4\_VLC\_WOR  
D**

|      |    |    |    |    |    |    |    |      |    |    |    |    |    |    |    |    |
|------|----|----|----|----|----|----|----|------|----|----|----|----|----|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name |    |    |    |    |    |    |    | ADDR |    |    |    |    |    |    |    |    |
| Type | RO   | RO | RO | RO | RO | RO | RO | RO | RO |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    | ADDR |    |    |    |    |    |    | -  | -  |
| Type | RO   | RO | RO | RO | RO | RO | RO | RO | RO |

This register provides the address information of a certain code word that is under process of video CODEC. SW reads it back after encode of a frame is done.

**ADDR** VLC DMA current Address

**MP4+0318h VLC DMA Current Bit Count Register**
**MP4\_VLC\_BITC  
NT**

|      |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |
|------|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19     | 18 | 17 | 16 |
| Name | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -      | -  | -  | -  |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |        |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3      | 2  | 1  | 0  |
| Name | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | BITCNT |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    | RO     | RO | RO | RO |

This register provides the bit position information of a certain Code Word that is under process of video CODEC.

**BITCNT** Current Bit Count

### 6.13.2.5 Software Decode Mode

#### MP4+0400h Software Decode Mode Command Register

MP4\_SVLD\_CO  
MD

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25    | 24    | 23    | 22  | 21 | 20   | 19 | 18    | 17    | 16   |
|------|----|----|----|----|----|----|-------|-------|-------|-----|----|------|----|-------|-------|------|
| Name | -  | -  | -  | -  | -  | -  | -     | -     | -     | -   | -  | -    | -  | -     | STOP  | STAR |
| Type |    |    |    |    |    |    |       |       |       |     |    |      |    |       | WO    | WO   |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8     | 7     | 6   | 5  | 4    | 3  | 2     | 1     | 0    |
| Name | -  | -  | -  | -  | -  | -  | CODED | MCBPC | QUANT | DCT | AC | CBPY | MV | DMARK | MMARK | PLUS |
| Type |    |    |    |    |    |    | WO    | WO    | WO    | WO  | WO | WO   | WO | WO    | WO    | WO   |

For SW decode mode, the following control bits must be sent to HW for block-based decoding. The sequencer (or header parser) of HW does not decode the following information by itself.

**FLUSH** flush bits

**MMARK** Motion Marker

**DMARK** DC Marker

**MV** Motion Vector

**CBPY** cbpy

**AC** ac\_pred\_flag

**DCT** dct\_coefficient

**QUANT**dquant

**MCBPC** mcbpc

**CODED** not\_coded

**START** Block Decode Start

**STOP** Block Decode Stop

#### MP4+0404h Software Decode Mode Bit Count Register

MP4\_SVLD\_BIT  
CNT

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18     | 17  | 16  |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|-----|-----|
| Name | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -      | -   | -   |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |        |     |     |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2      | 1   | 0   |
| Name | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | BITCNT |     |     |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W    | R/W | R/W |

**BITCNT** Number of Bits should be flushed

#### MP4+0408h Software Decode Mode Marker Indication Register

MP4\_SVLD\_MA  
RK

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

|      |   |   |   |   |   |   |   |   |   |   |   |   |   |    |    |       |
|------|---|---|---|---|---|---|---|---|---|---|---|---|---|----|----|-------|
| Name | - | - | - | - | - | - | - | - | - | - | - | - | - | DC | MV | RESYN |
| Type |   |   |   |   |   |   |   |   |   |   |   |   |   | RO | RO | RO    |

**RESYN** Resync Marker

**MV** Motion Marker

**DC** DC Marker

### MP4+040Ch Software Decode Mode VLD Code Word Register

**MP4\_SVLD\_CODE**

|             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit         | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>CODE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type        | RO |
| Bit         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>CODE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type        | RO |

**CODE** Current Code Word in VLD Stream, MSB Aligned

#### 6.13.2.6 Debug

### MP4+0500h Motion Estimation SAD for Y Component Register

**MP4\_SAD\_Y**

|                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>INTRA_MB_NUM</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                |    |    |    |    |    |    | RO |
| Bit                 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>SADY</b>         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                | RO |

### MP4+0504h Motion Estimation SAD for U Component Register

**MP4\_SAD\_U**

|                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>INTRA_MB_NUM</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit                 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>SADU</b>         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                | RO |

### MP4+0508h Motion Estimation SAD for V Component Register

**MP4\_SAD\_V**

|                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>INTRA_MB_NUM</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit                 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>SADV</b>         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                | RO |

**INTRA\_MB\_NUM** Total number of intra macro-block in a P frame. This register is valid after a P frame finishes encoding. Software can decide whether to re-encode current P frame as I frame by examining this register.

**SADY** SAD of luminance (Y) macroblock, for the purpose of debugging

**SADU** SAD of chrominance (U) macroblock, for the purpose of debugging

**SADV** SAD of chrominance (V) macroblock, for the purpose of debugging

## 7 Audio Front-end

### 7.1 General Description

The audio front-end essentially consists of voice and audio data paths. **Figure 65** shows the block diagram of the audio front-end. The entire voice band data paths comply with the GSM 03.50 specification. In addition, Mono hands-free audio or external FM radio playback path are provided. The audio stereo audio path facilitates audio quality playback, external FM radio, and voice playback through headset.



**Figure 65** Block diagram of audio front-end

**Figure 66** shows the digital circuits block diagram of the audio front-end. The APB register block is an APB peripheral that stores settings from the MCU. The DSP audio port block interfaces with the DSP for control and data communications. The Digital Audio Interface (DAI) block communicates with the System Simulator for FTA or external Bluetooth modules. The digital filter block performs filter operations for voice band and audio band signal processing.



**Figure 66** Block diagram of digital circuits of the audio front-end

## 7.2 Register Definitions

MCU APB bus registers in audio front-end are listed as followings.

### AFE+0000h AFE Voice MCU Control Register

AFE\_VMCU\_CO  
N0

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | VAFE ON |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W     |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0       |

MCU sets this register to start AFE voice operation. A synchronous reset signal will be issued. Then periodical interrupts of 8-KHz frequency will be issued. Clearing this register will stop the interrupt generation.

**VAFEON** turn on audio front-end operations

### AFE+000Ch AFE Voice Analog-Circuit Control Register 1

AFE\_VMCU\_CO  
N1

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---------|---|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   | VRSD ON |   |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   | R/W     |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0       |   |   |   |   |   |   |   |

Set this register for consistency of analog circuit setting. Suggested value is 80h

**VRSDON** voice-band redundant signed digit function on

**0:** 1-bit 2-level mode

**1:** 2-bit 3-level mode

**AFE+0014h AFE Voice DAI Blue Tooth Control Register**
**AFE\_VDB\_CON**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5                  | 4                 | 3                   | 2 | 1 | 0              |
|-------|----|----|----|----|----|----|---|---|---|---|--------------------|-------------------|---------------------|---|---|----------------|
| Name  |    |    |    |    |    |    |   |   |   |   | <b>VDAI<br/>ON</b> | <b>VBTO<br/>N</b> | <b>VBTS<br/>YNC</b> |   |   | <b>VBTSLEN</b> |
| Type  |    |    |    |    |    |    |   |   |   |   | R/W                | R/W               | R/W                 |   |   | R/W            |
| Reset |    |    |    |    |    |    |   |   |   |   | 0                  | 0                 | 0                   |   |   | 000            |

Set this register for DAI test mode and Blue Tooth application.

**VDAION** DAI function on

**VBTON** Blue Tooth function on

**VBTSYNC** Blue Tooth frame sync type

**0:** short

**1:** long

**VBTSLEN** Blue Tooth frame sync length = VBTSLEN+1

**AFE+0018h AFE Voice Look-Back mode Control Register**
**AFE\_VLB\_CON**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3                     | 2                     | 1                     | 0                           |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-----------------------|-----------------------|-----------------------|-----------------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | <b>VBYP<br/>ASSII</b> | <b>VDAPI<br/>NMOD</b> | <b>VINTI<br/>NMOD</b> | <b>VDEC<br/>INMO<br/>RE</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | R/W                   | R/W                   | R/W                   | R/W                         |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0                     | 0                     | 0                     | 0                           |

Set this register for AFE voice digital circuit configuration control. There are several loop back modes implemented for test purposes. Default values correspond to the normal function mode

**VBYPASSIIR** bypass hardware IIR filters

**VDAPINMODE** DSP audio port input mode control

**0:** normal mode

**1:** loop back mode

**VINTINMODE** interpolator input mode control

**0:** normal mode

**1:** loop back mode

**VDECINMODE** decimator input mode control

**0:** normal mode

**1:** loop back mode

**AFE+0020h AFE Audio MCU Control Register 0**
**AFE\_AMCU\_CO**
**N0**

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                  |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------------------|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>AAFE<br/>ON</b> |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W                |

|       |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |   |
|-------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|---|
| Reset |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0 |
|-------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|---|

MCU sets this register to start AFE audio operation. A synchronous reset signal will be issued. Then, periodical interrupts of 1/6 sampling frequency will be issued. Clearing this register will stop the interrupt generation.

### AFE+0024h AFE Audio Control Register 1

AFE\_AMCU\_CO  
N1

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8       | 7        | 6       | 5      | 4      | 3   | 2   | 1   | 0 |
|-------|----|----|----|----|----|----|---|---------|----------|---------|--------|--------|-----|-----|-----|---|
| Name  |    |    |    |    |    |    |   | ADITHON | ADITHVAL | ARAMPSP | AMUTER | AMUTEL |     |     | AFS |   |
| Type  |    |    |    |    |    |    |   | R/W     | R/W      | R/W     | R/W    | R/W    | R/W | R/W |     |   |
| Reset |    |    |    |    |    |    |   | 0       | 00       | 00      | 0      | 0      | 0   | 00  |     |   |

MCU set this register to inform hardware the sampling frequency of audio being played back.

**ADITHON** audio dither function on

**ADITHVAL** dither scaling setting

- 00:** 1/4
- 01:** 1/2
- 10:** 1
- 11:** 2

**ARAMPSP** ramp up/down speed selection

- 00:** 8, 4096/AFS
- 01:** 16, 2048/AFS
- 10:** 24, 1024/AFS
- 11:** 32, 512/AFS

**AMUTER** mute audio R-channel, with soft ramp up/down

**AMUTEL** mute audio L-channel, with soft ramp up/down

**AFS** sampling frequency setting

- 00:** 32-KHz
- 01:** 44.1-KHz
- 10:** 48-KHz
- 11:** reserved

## 7.3 Programming Guide

There are several cases, including speech call, voice memo record, voice memo playback, melody playback and DAI tests, where partial or whole audio front-end need to be turned on.

Following are the recommended voice band path programming procedures to turn on audio front-end:

- MCU programs the AFE\_DAI\_CON, AFE\_LB\_CON, AFE\_VAG\_CON, AFE\_VAC\_CON0, AFE\_VAC\_CON1 and AFE\_VAPDN\_CON registers for specific operation modes. Please also refer to analog chip interface specification.

- MCU clear VAFE bit of PDN\_CON2 register to un-gate the clock for voice band path. Please refer to software power down control specification.
- MCU set AFE\_VMCU\_CON to start the operation of voice band path.

Following are the recommended voice band path programming procedures to turn off audio front-end:

- MCU programs AFE\_VAPDN\_CON to power down voice band path analog blocks.
- MCU clear AFE\_VMCU\_CON to stop the operation of voice band path.
- MCU set VAFE bit of PDN\_CON2 register to gate the clock for voice band path.

To start the DAI test, the MS first receives a GSM Layer 3 TEST\_INTERFACE message from the SS and puts the speech transcoder into one of the following modes:

- Normal mode (VDAIMODE[1:0]: 00)
- Test of speech encoder/DTX functions (VDAIMODE[1:0]: 10)
- Test of speech decoder/DTX functions (VDAIMODE[1:0]: 01)
- Test of acoustic devices and A/D & D/A (VDAIMODE[1:0]: 11)

It then waits for DAIRST# signaling from the SS. Recognizing this, DSP starts to transmit to and/or receive from DSP. For more detail, please refer to GSM 11.10 specification.

Following are the recommended audio band path programming procedures to turn on audio front-end:

- MCU programs the AFE\_MCU\_CON1, AFE\_AAG\_CON, AFE\_AAC\_CON, and AFE\_AAPDN\_CON registers for specific configurations. Please also refer to analog chip interface specification.
- MCU clear AAFE bit of PDN\_CON2 register to un-gate the clock for audio band path. Please refer to software power down control specification.
- MCU set AFE\_AMCU\_CON0 to start the operation of audio band path.

Following are the recommended audio band path programming procedures to turn off audio front-end:

- MCU programs the AFE\_AAPDN\_CON to power down audio band path analog blocks. Please refer to analog block specification for more detail.
- MCU clear AFE\_AMCU\_CON0 to stop the operation of audio band path.
- MCU set AAFE bit of PDN\_CON2 register to gate the clock for audio band path.

## 8 Radio Interface Control

This chapter details the MT6219 interface control with the radio part of a GSM terminal. Providing a comprehensive control scheme, the MT6219 radio interface consists of Baseband Serial Interface (BSI), Baseband Parallel Interface (BPI), Automatic Power Control (APC) and Automatic Frequency Control (AFC) together with APC-DAC and AFC-DAC.

### 8.1 Base-band Serial Interface

The Base-band Serial Interface is used to control the external radio components. It utilizes a 3-wire serial bus to transfer data to RF circuitry for PLL frequency change, reception gain setting, and other radio control purposes. In this unit, BSI data registers are double-buffered in the same way as the TDMA event registers. The user writes data into the write buffer and the data is transferred from the write buffer to the active buffer when TDMA\_EVTVAL signal from the TDMA timer is pulsed.

Each data register **BSI\_Dn\_DAT** is associated with one data control register **BSI\_Dn\_CON**, where  $n$  denotes the index. The data control register with index  $n$  used to identify which events (signaled by TDMA\_BSISTR $n$ ) generated by the TDMA timer would trigger the download process of the word in register **BSI\_Dn\_DAT** through the serial bus, as well as the length of the word in length of bits. A special event is defined. The event is triggered by the operation that the user writes 1 to the **IMOD** flag. It provides immediate download process without programming the TDMA timer.

If more than one data word is to be downloaded on the same BSI event, the word with the lowest address among them will be downloaded first, followed by the next lowest and so on.

The total time to download the words depends on the word length, the number of words to download, and the clock rates. The programmer should space the successive event to provide enough time. If the download process of the previous event isn't complete before the new events come, the later will be suppressed.

The unit supports 2 external components. There are four output pins. BSI\_CLK is the output clock, BSI\_DATA is the serial data port, and BSI\_CS0 and BSI\_CS1 are the select pins for the 2 components, respectively. BSI\_CS1 is multiplexed with other function. Please refer to GPIO table for more detail.

The block diagram of the BSI unit is as depicted in **Figure 67**.



Figure 67 Block diagram of BSI unit.



Figure 68 Timing characteristic of BSI interface

### 8.1.1 Register Definitions

#### BSI+0000h BSI control register

#### BSI\_CON

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9       | 8       | 7       | 6       | 5       | 4    | 3       | 2       | 1 | 0   |
|-------|----|----|----|----|----|----|---------|---------|---------|---------|---------|------|---------|---------|---|-----|
| Name  |    |    |    |    |    |    | SETE_NV | EN1_POL | EN1_LEN | EN0_POL | EN0_LEN | IMOD | CLK_SPD | CLK_POL |   |     |
| Type  |    |    |    |    |    |    | R/W     | R/W     | R/W     | R/W     | R/W     | WO   |         | R/W     |   | R/W |
| Reset |    |    |    |    |    |    | 0       | 0       | 0       | 0       | 0       | N/A  | 0       | 0       |   | 0   |

This register is the control register of the BSI unit. It controls the signal type of the 3-wire interface.

**CLK\_POL** The flag controls the polarity of BSI\_CLK. Refer to Figure 68.

- 0 True clock polarity
- 1 Inverted clock polarity

**CLK\_SPD** The field defines the clock rate of BSI\_CLK. The 3-wire interface provides 4 choices of data bit rate. The default is 13/2 MHz.

- 00 13/2 MHz

- 01** 13/4 MHz
- 10** 13/6 MHz
- 11** 13/8 MHz

**IMOD** The field enables the immediate mode. If the user writes 1 to the flag, the download will be triggered immediately without waiting for the timer events. The words in which the event ID equals to 1Fh will be downloaded following this signal. This flag is write-only. The immediate write can be exercised once. That means the programmer should write the flag again to start another immediate download. Setting the flag won't disable the other events from the timer. In case it's required to turn off all the events, the programmer can disable them by setting BSI\_ENA to all zero.

**ENX\_LEN** The field controls the type of the signal BSI\_CS0 and BSI\_CS1. Refer to **Figure 68**.

- 0** Long enable pulse
- 1** Short enable pulse

**ENX\_POL** The field controls the polarity of the signal BSI\_CS0 and BSI\_CS1.

- 0** True enable pulse polarity
- 1** Inverted enable pulse polarity

**SETENV** The flag enables the write operation of the active buffer.

- 0** The user writes to the write buffer. The data is then latched in the active buffer after TDMA\_EVTVAL is pulsed
- 1** The user directly write data to the active buffer.

### BSI+0004h Control part of data register 0

### BSI\_D0\_CON

| Bit  | 15  | 14 | 13 | 12 | 11 | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|------|-----|----|----|----|----|-----|---|---|---|---|---|---|---|---|---|--------|
| Name | ISB |    |    |    |    | LEN |   |   |   |   |   |   |   |   |   | EVT_ID |
| Type | R/W |    |    |    |    | R/W |   |   |   |   |   |   |   |   |   | R/W    |

This register is the control part of the data register 0. It decides the required length of the download data word, the event to trigger the download process of the word, and which device it targets.

There are 26 data registers of this type as listed in **Table 41**.

**EVT\_ID** This field stores the event ID that the data word is due to be downloaded.

**00000~01111** Synchronously download of the word with the selected EVT\_ID event. The match between this field and the event is listed as **Table 6**.

| Event ID (in binary) – EVT_ID | Event name    |
|-------------------------------|---------------|
| 00000                         | TDMA_BSISTR0  |
| 00001                         | TDMA_BSISTR1  |
| 00010                         | TDMA_BSISTR2  |
| 00011                         | TDMA_BSISTR3  |
| 00100                         | TDMA_BSISTR4  |
| 00101                         | TDMA_BSISTR5  |
| 00110                         | TDMA_BSISTR6  |
| 00111                         | TDMA_BSISTR7  |
| 01000                         | TDMA_BSISTR8  |
| 01001                         | TDMA_BSISTR9  |
| 01010                         | TDMA_BSISTR10 |

|       |               |
|-------|---------------|
| 01011 | TDMA_BSISTR11 |
| 01100 | TDMA_BSISTR12 |
| 01101 | TDMA_BSISTR13 |
| 01110 | TDMA_BSISTR14 |
| 01111 | TDMA_BSISTR15 |

**Table 40** The match between the value of EVT\_ID field in the BSI control registers and the TDMA\_BSISTR events.

**10000~11110** Reserved

**11111** Immediate download

**LEN** The field stores the length of the data word. The actual length is defined as **LEN + 1** in units of bits. The value ranges from 0 to 31, corresponding to 1 to 32 bits in length.

**ISB** The flag selects the target device.

**0** Device 0 is selected.

**1** Device 1 is selected.

### BSI +0008h Data part of data register 0 BSI\_D0\_DAT

|             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit         | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| DAT [31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| DAT [15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| R/W         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

This register is the data part of the data register 0. The illegal length of the data is up to 32 bits. The actual number of bits to be transmitted is specified in **LEN** field in **BSI\_D0\_CON** register.

**DAT** The field signifies the data part of the data register.

There are in total 26 pairs of data registers. The address mapping and function is listed as

| Register Address  | Register Function               | Acronym           |
|-------------------|---------------------------------|-------------------|
| <b>BSI +0004h</b> | Control part of data register 0 | <b>BSI_D0_CON</b> |
| <b>BSI +0008h</b> | Data part of data register 0    | <b>BSI_D0_DAT</b> |
| <b>BSI +000Ch</b> | Control part of data register 1 | <b>BSI_D1_CON</b> |
| <b>BSI +0010h</b> | Data part of data register 1    | <b>BSI_D1_DAT</b> |
| <b>BSI +0014h</b> | Control part of data register 2 | <b>BSI_D2_CON</b> |
| <b>BSI +0018h</b> | Data part of data register 2    | <b>BSI_D2_DAT</b> |
| <b>BSI +001Ch</b> | Control part of data register 3 | <b>BSI_D3_CON</b> |
| <b>BSI +0020h</b> | Data part of data register 3    | <b>BSI_D3_DAT</b> |
| <b>BSI +0024h</b> | Control part of data register 4 | <b>BSI_D4_CON</b> |
| <b>BSI +0028h</b> | Data part of data register 4    | <b>BSI_D4_DAT</b> |
| <b>BSI +002Ch</b> | Control part of data register 5 | <b>BSI_D5_CON</b> |
| <b>BSI +0030h</b> | Data part of data register 5    | <b>BSI_D5_DAT</b> |
| <b>BSI +0034h</b> | Control part of data register 6 | <b>BSI_D6_CON</b> |
| <b>BSI +0038h</b> | Data part of data register 6    | <b>BSI_D6_DAT</b> |
| <b>BSI +003Ch</b> | Control part of data register 7 | <b>BSI_D7_CON</b> |

|                   |                                  |                    |
|-------------------|----------------------------------|--------------------|
| <b>BSI +0040h</b> | Data part of data register 7     | <b>BSI_D7_DAT</b>  |
| <b>BSI +0044h</b> | Control part of data register 8  | <b>BSI_D8_CON</b>  |
| <b>BSI +0048h</b> | Data part of data register 8     | <b>BSI_D8_DAT</b>  |
| <b>BSI +004Ch</b> | Control part of data register 9  | <b>BSI_D9_CON</b>  |
| <b>BSI +0050h</b> | Data part of data register 9     | <b>BSI_D9_DAT</b>  |
| <b>BSI +0054h</b> | Control part of data register 10 | <b>BSI_D10_CON</b> |
| <b>BSI +0058h</b> | Data part of data register 10    | <b>BSI_D10_DAT</b> |
| <b>BSI +005Ch</b> | Control part of data register 11 | <b>BSI_D11_CON</b> |
| <b>BSI +0060h</b> | Data part of data register 11    | <b>BSI_D11_DAT</b> |
| <b>BSI +0064h</b> | Control part of data register 12 | <b>BSI_D12_CON</b> |
| <b>BSI +0068h</b> | Data part of data register 12    | <b>BSI_D12_DAT</b> |
| <b>BSI +006Ch</b> | Control part of data register 13 | <b>BSI_D13_CON</b> |
| <b>BSI +0070h</b> | Data part of data register 13    | <b>BSI_D13_DAT</b> |
| <b>BSI +0074h</b> | Control part of data register 14 | <b>BSI_D14_CON</b> |
| <b>BSI +0078h</b> | Data part of data register 14    | <b>BSI_D14_DAT</b> |
| <b>BSI +007Ch</b> | Control part of data register 15 | <b>BSI_D15_CON</b> |
| <b>BSI +0080h</b> | Data part of data register 15    | <b>BSI_D15_DAT</b> |
| <b>BSI +0084h</b> | Control part of data register 16 | <b>BSI_D16_CON</b> |
| <b>BSI +0088h</b> | Data part of data register 16    | <b>BSI_D16_DAT</b> |
| <b>BSI +008Ch</b> | Control part of data register 17 | <b>BSI_D17_CON</b> |
| <b>BSI +0090h</b> | Data part of data register 17    | <b>BSI_D17_DAT</b> |
| <b>BSI +0094h</b> | Control part of data register 18 | <b>BSI_D18_CON</b> |
| <b>BSI +0098h</b> | Data part of data register 18    | <b>BSI_D18_DAT</b> |
| <b>BSI +009Ch</b> | Control part of data register 19 | <b>BSI_D19_CON</b> |
| <b>BSI +00A0h</b> | Data part of data register 19    | <b>BSI_D19_DAT</b> |
| <b>BSI +00A4h</b> | Control part of data register 20 | <b>BSI_D20_CON</b> |
| <b>BSI +00A8h</b> | Data part of data register 20    | <b>BSI_D20_DAT</b> |
| <b>BSI +00ACh</b> | Control part of data register 21 | <b>BSI_D21_CON</b> |
| <b>BSI +00B0h</b> | Data part of data register 21    | <b>BSI_D21_DAT</b> |
| <b>BSI +00B4h</b> | Control part of data register 22 | <b>BSI_D22_CON</b> |
| <b>BSI +00B8h</b> | Data part of data register 22    | <b>BSI_D22_DAT</b> |
| <b>BSI +00BCh</b> | Control part of data register 23 | <b>BSI_D23_CON</b> |
| <b>BSI +00C0h</b> | Data part of data register 23    | <b>BSI_D23_DAT</b> |
| <b>BSI +00C4h</b> | Control part of data register 24 | <b>BSI_D24_CON</b> |
| <b>BSI +00C8h</b> | Data part of data register 24    | <b>BSI_D24_DAT</b> |
| <b>BSI +00CCh</b> | Control part of data register 25 | <b>BSI_D25_CON</b> |
| <b>BSI +00D0h</b> | Data part of data register 25    | <b>BSI_D25_DAT</b> |

Table 41 BSI data registers

## BSI +0190h BSI event enable register

BSI\_ENA

| Bit   | 15    | 14    | 13    | 12    | 11    | 10    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-------|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|------|------|------|
| Name  | BSI15 | BSI14 | BSI13 | BSI12 | BSI11 | BSI10 | BSI9 | BSI8 | BSI7 | BSI6 | BSI5 | BSI4 | BSI3 | BSI2 | BSI1 | BSI0 |
| Type  | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |
| Reset | 1     | 1     | 1     | 1     | 1     | 1     | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    |

This register could enable the event by setting the corresponding bit. After hardware reset, all bits are initialized as 1. These bits are set as 1 after TDMA\_EVTVAL is pulsed.

**BSIx** The flag enables the downloading of the words that corresponds to the events signaled by TDMA\_BSI.

- 0** The event is not enabled.
- 1** The event is enabled.

## 8.2 Base-band Parallel Interface

### 8.2.1 General description

The Base-band Parallel Interface features 10 control pins, which is used for timing-critical external circuits. These pins are typically used to control front-end components which should be turned on/off at the specified time along the GSM time-base, such as transmit-enable, band switching, TR-switch, and so on.



Figure 69 Block diagram of BPI interface

The user could program 22 sets of 10-bit register to set the output value of **BPI\_BUS0~BPI\_BUSS9**. The data will be stored in the write buffers. Those are then forwarded to the active buffers when **TDMA\_EVTVAL** signal, usually once in one frame, is pulsed. There are 22 corresponding write buffers and active buffer, as well as the TDMA events.

Each **TDMA\_BPISTR** event triggers the transfer of the data in the corresponding active buffer to the output buffer, thus changing the value of the BPI bus. The user can disable the events by programming the enable registers in the TDMA timer.

If the **TDMA\_BPISTR** event is disabled, the corresponding signal **TDMA\_BPISTR** will not be pulsed, and the value on the BPI bus will remain unchanged.

For applications in which BPI signals serve as the switch, typically some current-driving components are added to enhance the driving capability. We provide 4 configurable output pins, which provide current up to 8mA. It's intended to reduce the number of the external components.

The output pins **BPI\_BUS6**, **BPI\_BUS7**, **BPI\_BUS8**, and **BPI\_BUS9** are multiplexed with GPIO. Please refer to the GPIO table for more detailed information.

### 8.2.2 Register Definitions

#### BPI+0000h BPI control register

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2            | 1            | 0            |              |              |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|----|--------------|--------------|--------------|--------------|--------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |    | <b>PINM3</b> | <b>PINM2</b> | <b>PINM1</b> | <b>PINM0</b> | <b>PETEV</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | WO | WO           | WO           | WO           | R/W          |              |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0  | 0            | 0            | 0            | 0            |              |

The register is the control register of the BPI unit. It controls the direct access mode of the active buffer and the current driving capability for the output pins.

The driving capability of **BPI\_BUS0**, **BPI\_BUS1**, **BPI\_BUS2**, and **BPI\_BUS3** can be 2mA or 8mA, determined by the value of **PINM0**, **PINM1**, **PINM2**, and **PINM3**, respectively. This provides higher driving capability and can save some external current-driving components. Aside from those configurable pins, the driving capability of **BPI\_BUS4**, **BPI\_BUS5**, **BPI\_BUS6**, and **BPI\_BUS7** is fixed as 2mA.

**PETEV** The flag is used to enable the direct access to the active buffer.

- 0** The user writes data to the write buffer. The data is latched in the active buffer after the **TDMA\_EVTVAL** signal is pulsed.
- 1** The user directly writes data to the active buffer without waiting for the **TDMA\_EVTVAL** signal.

**PINM0** The field controls the driving capability of **BPI\_BUS0**.

- 0** The output driving capability is 2mA.
- 1** The output driving capability is 8mA.

**PINM1** The field controls the driving capability of **BPI\_BUS1**.

- 0** The output driving capability is 2mA.
- 1** The output driving capability is 8mA.

**PINM2** The field controls the driving capability of **BPI\_BUS2**.

- 0** The output driving capability is 2mA.
- 1** The output driving capability is 8mA.

**PINM3** The field controls the driving capability of **BPI\_BUS3**.

- 0** The output driving capability is 2mA.
- 1** The output driving capability is 8mA.

#### BPI +0004h BPI data register 0

#### BPI\_BUFO

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9          | 8          | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0          |  |
|------|----|----|----|----|----|----|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|--|
| Name |    |    |    |    |    |    | <b>PO9</b> | <b>PO8</b> | <b>PO7</b> | <b>PO6</b> | <b>PO5</b> | <b>PO4</b> | <b>PO3</b> | <b>PO2</b> | <b>PO1</b> | <b>PO0</b> |  |
| Type |    |    |    |    |    |    | R/W        |  |

The register defines the BPI signals that are associated with the event TDMA\_BPI0.

There are 22 registers of the same type as listed in **Table 42**. Each register is associated with one specific event signal from the TDMA timer. The data registers are all double-buffered. When PETEV is set to be 0, the data register links to the write buffer. When PETEV is set to be 1, the data register links to the active buffer.

There is one register **BPI\_BUFI** dedicated to be used in immediate mode. Writing the value to that register change the BPI signals at once. The immediate mode provides an immediate operation on the programming of the BPI bus.

**POx** The flag defines the corresponding signals for BPIx after the TDMA event 0 takes place.

The overall data register definition is listed in **Table 42**.

| Register Address  | Register Function                  | Acronym          |
|-------------------|------------------------------------|------------------|
| <b>BPI +0004h</b> | BPI pin data for event TDMA_BPI 0  | <b>BPI_BUFO</b>  |
| <b>BPI +0008h</b> | BPI pin data for event TDMA_BPI 1  | <b>BPI_BUFI</b>  |
| <b>BPI +000Ch</b> | BPI pin data for event TDMA_BPI 2  | <b>BPI_BUF2</b>  |
| <b>BPI +0010h</b> | BPI pin data for event TDMA_BPI 3  | <b>BPI_BUF3</b>  |
| <b>BPI +0014h</b> | BPI pin data for event TDMA_BPI 4  | <b>BPI_BUF4</b>  |
| <b>BPI +0018h</b> | BPI pin data for event TDMA_BPI 5  | <b>BPI_BUF5</b>  |
| <b>BPI +001Ch</b> | BPI pin data for event TDMA_BPI 6  | <b>BPI_BUF6</b>  |
| <b>BPI +0020h</b> | BPI pin data for event TDMA_BPI 7  | <b>BPI_BUF7</b>  |
| <b>BPI +0024h</b> | BPI pin data for event TDMA_BPI 8  | <b>BPI_BUF8</b>  |
| <b>BPI +0028h</b> | BPI pin data for event TDMA_BPI 9  | <b>BPI_BUF9</b>  |
| <b>BPI +002Ch</b> | BPI pin data for event TDMA_BPI 10 | <b>BPI_BUF10</b> |
| <b>BPI +0030h</b> | BPI pin data for event TDMA_BPI 11 | <b>BPI_BUF11</b> |
| <b>BPI +0034h</b> | BPI pin data for event TDMA_BPI 12 | <b>BPI_BUF12</b> |
| <b>BPI +0038h</b> | BPI pin data for event TDMA_BPI 13 | <b>BPI_BUF13</b> |
| <b>BPI +003Ch</b> | BPI pin data for event TDMA_BPI 14 | <b>BPI_BUF14</b> |
| <b>BPI +0040h</b> | BPI pin data for event TDMA_BPI 15 | <b>BPI_BUF15</b> |
| <b>BPI +0044h</b> | BPI pin data for event TDMA_BPI 16 | <b>BPI_BUF16</b> |
| <b>BPI +0048h</b> | BPI pin data for event TDMA_BPI 17 | <b>BPI_BUF17</b> |
| <b>BPI +004Ch</b> | BPI pin data for event TDMA_BPI 18 | <b>BPI_BUF18</b> |
| <b>BPI +0050h</b> | BPI pin data for event TDMA_BPI 19 | <b>BPI_BUF19</b> |
| <b>BPI +0054h</b> | BPI pin data for event TDMA_BPI 20 | <b>BPI_BUF20</b> |
| <b>BPI +0058h</b> | BPI pin data for event TDMA_BPI 21 | <b>BPI_BUF21</b> |
| <b>BPI +005Ch</b> | BPI pin data for immediate mode    | <b>BPI_BUFI</b>  |

**Table 42** BPI Data Registers

### **BPI +0060h BPI event enable register 0 BPI\_ENA0**

| Bit  | 15           | 14           | 13           | 12           | 11           | 10           | 9           | 8           | 7           | 6           | 5           | 4           | 3           | 2           | 1           | 0           |
|------|--------------|--------------|--------------|--------------|--------------|--------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|
| Name | <b>BEN15</b> | <b>BEN14</b> | <b>BEN13</b> | <b>BEN12</b> | <b>BEN11</b> | <b>BEN10</b> | <b>BEN9</b> | <b>BEN8</b> | <b>BEN7</b> | <b>BEN6</b> | <b>BEN5</b> | <b>BEN4</b> | <b>BEN3</b> | <b>BEN2</b> | <b>BEN1</b> | <b>BEN0</b> |
| Type | R/W          | R/W          | R/W          | R/W          | R/W          | R/W          | R/W         | R/W         | R/W         | R/W         | R/W         | R/W         | R/W         | R/W         | R/W         | R/W         |

|       |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Reset | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|-------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|

The register is used to enable the events that are signaled by the TDMA timer. After hardware reset, all the enable bits defaults to be 1 (enabled). Upon receiving the **TDMA\_EVTVAL** pulse, those bits are also set to 1 (enabled).

**BENn** The flag controls the function of event n.

- 0** The event n is disabled.
- 1** The event n is enabled.

### BPI+0064h BPI event enable register 1

**BPI\_ENA1**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5           | 4           | 3           | 2           | 1           | 0           |
|-------|----|----|----|----|----|----|---|---|---|---|-------------|-------------|-------------|-------------|-------------|-------------|
| Name  |    |    |    |    |    |    |   |   |   |   | <b>BEN2</b> | <b>BEN2</b> | <b>BEN1</b> | <b>BEN1</b> | <b>BEN1</b> | <b>BEN1</b> |
| Type  |    |    |    |    |    |    |   |   |   |   | <b>1</b>    | <b>0</b>    | <b>9</b>    | <b>8</b>    | <b>7</b>    | <b>6</b>    |
| Reset |    |    |    |    |    |    |   |   |   |   | R/W         | R/W         | R/W         | R/W         | R/W         | R/W         |

The register is used to enable the events that are signaled by the TDMA timing generator. After hardware reset, all the enable bits defaults to be 1 (enabled). Upon receiving the **TDMA\_EVTVAL** pulse, those bits are also set to 1 (enabled).

**BENn** The flag controls the function of event n.

- 0** The event n is disabled.
- 1** The event n is enabled.

## 8.3 Automatic Power Control (APC) Unit

### 8.3.1 General description

Automatic Power Control unit is used to control the Power Amplifier (PA) module. Through APC unit, we can set the proper transmit power level of the handset and ensure that the burst power ramping requirements are met. In one TDMA frame, up to 7 TDMA events can be enabled to support multi-slot transmission. In practice, 5 banks of ramp profiles are used in one frame to make up 4 consecutive transmission slots.

The shape and magnitude of the ramp profiles are configurable to fit ramp-up (ramp up from zero), intermediate ramp (ramp between Transmission windows), and ramp-down (ramp down to zero) profiles. Each bank of the ramp profile consists of 16 8-bit unsigned values, which is adjustable for different conditions.

The entries from one bank of the ramp profile are partitioned into two parts, with 8 values in each part. In normal operation, the entries in the left half part are multiplied by a 10-bit left scaling factor, and the entries in the right half part are multiplied by a 10-bit right scaling factor. Those values are then truncated to form 16 10-bit intermediate values. Finally the intermediate ramp profile are linearly interpolated into 32 10-bit values and sequentially used to update the D/A converter. The block diagram of the APC unit is shown in **Figure 70**.

The APB bus interface is 32 bits wide. It takes 4 write accesses to program each bank of ramp profile. The detail register allocations are listed in **Table 43**.



Figure 70 Block diagram of APC unit.

### 8.3.2 Register Definitions

#### APC+0000h APC 1st ramp profile #0

#### APC\_PFA0

|      |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |
|------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|
| Bit  | 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   |
| Name | ENT3 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ENT2 |
| Type | R/W  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W  |
| Bit  | 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0    |
| Name | ENT1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | ENT0 |
| Type | R/W  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W  |

The register stores the first four entries of the first power ramp profile. The first entry resides in the least significant byte [7:0], the second in the second byte [15:8], the third in the third byte [23:16], and the forth in the most significant byte [31:24]. Since this register provides no hardware reset, the programmer should configure it before any APC event takes place.

- ENT3** The field signifies the 4<sup>th</sup> entry of the 1<sup>st</sup> ramp profile.
- ENT2** The field signifies the 3<sup>rd</sup> entry of the 1<sup>st</sup> ramp profile.
- ENT1** The field signifies the 2<sup>nd</sup> entry of the 1<sup>st</sup> ramp profile.
- ENT0** The field signifies the 1<sup>st</sup> entry of the 1<sup>st</sup> ramp profile.

The overall ramp profile register definition is listed in Table 43.

| Register Address | Register Function                   | Acronym  |
|------------------|-------------------------------------|----------|
| APC +0000h       | APC 1 <sup>st</sup> ramp profile #0 | APC_PFA0 |
| APC +0004h       | APC 1 <sup>st</sup> ramp profile #1 | APC_PFA1 |
| APC +0008h       | APC 1 <sup>st</sup> ramp profile #2 | APC_PFA2 |
| APC +000Ch       | APC 1 <sup>st</sup> ramp profile #3 | APC_PFA3 |
| APC +0020h       | APC 2 <sup>nd</sup> ramp profile #0 | APC_PFB0 |
| APC +0024h       | APC 2 <sup>nd</sup> ramp profile #1 | APC_PFB1 |
| APC +0028h       | APC 2 <sup>nd</sup> ramp profile #2 | APC_PFB2 |
| APC +002Ch       | APC 2 <sup>nd</sup> ramp profile #3 | APC_PFB3 |

|            |                                     |          |
|------------|-------------------------------------|----------|
| APC +0040h | APC 3 <sup>rd</sup> ramp profile #0 | APC_PFC0 |
| APC +0044h | APC 3 <sup>rd</sup> ramp profile #1 | APC_PFC1 |
| APC +0048h | APC 3 <sup>rd</sup> ramp profile #2 | APC_PFC2 |
| APC +004Ch | APC 3 <sup>rd</sup> ramp profile #3 | APC_PFC3 |
| APC +0060h | APC 4 <sup>th</sup> ramp profile #0 | APC_PFD0 |
| APC +0064h | APC 4 <sup>th</sup> ramp profile #1 | APC_PFD1 |
| APC +0068h | APC 4 <sup>th</sup> ramp profile #2 | APC_PFD2 |
| APC +006Ch | APC 4 <sup>th</sup> ramp profile #3 | APC_PFD3 |
| APC +0080h | APC 5 <sup>th</sup> ramp profile #0 | APC_PFE0 |
| APC +0084h | APC 5 <sup>th</sup> ramp profile #1 | APC_PFE1 |
| APC +0088h | APC 5 <sup>th</sup> ramp profile #2 | APC_PFE2 |
| APC +008Ch | APC 5 <sup>th</sup> ramp profile #3 | APC_PFE3 |
| APC +00A0h | APC 6 <sup>th</sup> ramp profile #0 | APC_PFF0 |
| APC +00A4h | APC 6 <sup>th</sup> ramp profile #1 | APC_PFF1 |
| APC +00A8h | APC 6 <sup>th</sup> ramp profile #2 | APC_PFF2 |
| APC +00ACh | APC 6 <sup>th</sup> ramp profile #3 | APC_PFF3 |
| APC +00C0h | APC 7 <sup>th</sup> ramp profile #0 | APC_PFG0 |
| APC +00C4h | APC 7 <sup>th</sup> ramp profile #1 | APC_PFG1 |
| APC +00C8h | APC 7 <sup>th</sup> ramp profile #2 | APC_PFG2 |
| APC +00CCh | APC 7 <sup>th</sup> ramp profile #3 | APC_PFG3 |

**Table 43** APC ramp profile registers

APC +0010h APC 1st ramp profile left scaling factor

APC SCAL0L

The register stores the left scaling factor of the 1<sup>st</sup> ramp profile. This factor multiplies the first 8 entries of the 1<sup>st</sup> ramp profile to provide the scaled profile, which is then interpolated to control the D/A converter.

After hardware reset, the initial value of the register is 256. In that case, no scaling is done, that is, each entry of the ramp profile is multiplied by 1. That's because the 8 least significant bits will be truncated after multiplication.

The overall scaling factor register definition is listed in **Table 6**.

**SF** The field is the scaling factor. After hardware reset, the value is 256.

APC +0014h APC 1st ramp profile right scaling factor

APC SCAL0R

The register stores the right scaling factor of the 1<sup>st</sup> ramp profile. This factor multiplies the last 8 entries of the 1<sup>st</sup> ramp profile to provide the scaled profile, which is then interpolated to control the D/A converter.

After hardware reset, the initial value of the register is 256. In that case, no scaling is done, that is, each entry of the ramp profile is multiplied by 1. That's because the 8 least significant bits will be truncated after multiplication.

The overall scaling factor register definition is listed in **Table 6**.

**SF** The field is the scaling factor. After hardware reset, the value is 256.

### APC+0018h APC 1st ramp profile offset value

### APC\_OFFSET0

| Bit   | 15     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | OFFSET |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

There are 7 offset values for the corresponding ramp profile.

The 1<sup>st</sup> offset value also serves as the pedestal value. It's used to power up the APC D/A converter before the RF signals start to transmit. The D/A converter is then biased on the value. It's intended to provide initial control voltage of the external control loop. The exact value depends on the characteristics of the external components. The timing to output the pedestal value is configurable through the **TDMA\_BULCON2** register of the timing generator. It can be set to 0~127 quarter bit time after the base-band D/A converter is powered up.

**OFFSET** The field stores the offset value for the corresponding ramp profile. After hardware reset, the default value is 0.

The overall offset register definition is listed in **Table 6**.

| Register Address | Register Function                                     | Acronym     |
|------------------|-------------------------------------------------------|-------------|
| APC+0010h        | APC 1 <sup>st</sup> ramp profile left scaling factor  | APC_SCAL0L  |
| APC+0014h        | APC 1 <sup>st</sup> ramp profile right scaling factor | APC_SCAL0R  |
| APC+0018h        | APC 1 <sup>st</sup> ramp profile offset value         | APC_OFFSET0 |
| APC+0030h        | APC 2 <sup>nd</sup> ramp profile left scaling factor  | APC_SCAL1L  |
| APC+0034h        | APC 2 <sup>nd</sup> ramp profile right scaling factor | APC_SCAL1R  |
| APC+0038h        | APC 2 <sup>nd</sup> ramp profile offset value         | APC_OFFSET1 |
| APC+0050h        | APC 3 <sup>rd</sup> ramp profile left scaling factor  | APC_SCAL2L  |
| APC+0054h        | APC 3 <sup>rd</sup> ramp profile right scaling factor | APC_SCAL2R  |
| APC+0058h        | APC 3 <sup>rd</sup> ramp profile offset value         | APC_OFFSET2 |
| APC+0070h        | APC 4 <sup>th</sup> ramp profile left scaling factor  | APC_SCAL3L  |
| APC+0074h        | APC 4 <sup>th</sup> ramp profile right scaling factor | APC_SCAL3R  |
| APC+0078h        | APC 4 <sup>th</sup> ramp profile offset value         | APC_OFFSET3 |
| APC+0090h        | APC 5 <sup>th</sup> ramp profile left scaling factor  | APC_SCAL4L  |
| APC+0094h        | APC 5 <sup>th</sup> ramp profile right scaling factor | APC_SCAL4R  |
| APC+0098h        | APC 5 <sup>th</sup> ramp profile offset value         | APC_OFFSET4 |
| APC+00B0h        | APC 6 <sup>th</sup> ramp profile left scaling factor  | APC_SCAL5L  |
| APC+00B4h        | APC 6 <sup>th</sup> ramp profile right scaling factor | APC_SCAL5R  |
| APC+00B8h        | APC 6 <sup>th</sup> ramp profile offset value         | APC_OFFSET5 |
| APC+00D0h        | APC 7 <sup>th</sup> ramp profile left scaling factor  | APC_SCAL6L  |
| APC+00D4h        | APC 7 <sup>th</sup> ramp profile right scaling factor | APC_SCAL6R  |
| APC+00D8h        | APC 7 <sup>th</sup> ramp profile offset value         | APC_OFFSET6 |

**Table 44 APC scaling factor and offset value registers**
**APC+00E0h APC control register**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0       | APC_CON |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------|---------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | GSM FPU |         |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W R/W |         |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 1 0     |         |

**GSM** This field defines the operation mode of the APC module. In GSM mode, since there is only one slot in one frame, only one scaling factor and one offset value is required to be configured. If the bit is set, the programmer needs only to configure [APC\\_SCAL0L](#) and [APC\\_OFFSET0](#). If the bit is not set, the APC module is operating in GPRS mode.

**0** The APC module is operating in GPRS mode.

**1** The APC module is operating in GSM mode. Default value.

**FPU** This field is used to force power on the APC D/A converter. Test only.

**0** The APC D/A converter is not forced power up. It is only powered on when the transmission window is opened. Default value.

**1** The APC D/A converter is forced power up.

### 8.3.3 Ramp profile programming

The first value of the first normalized ramp profile should be written in the least significant byte of the [APC\\_PFA0](#) register. The second value should be written in the second least significant byte of the [APC\\_PFA0](#), and so on.

Each ramp profile can be programmed to form arbitrary shape.

The start of ramping is triggered by one of the TDMA\_APCTR signals. The timing relationship of TDMA\_APCTR and TDMA slots is as depicted in [Figure 71](#) for 4 consecutive time slots case. The power ramping profile should comply with the timing mask defined in GSM SPEC 05.05. The timing offset values for 7 ramp profiles are stored in TDMA timer register from [TDMA\\_APCT0](#) to [TDMA\\_APCT6](#).

Since the APC unit provides more than 5 ramp profiles, it is able to accommodate up to 4 consecutive transmission slots. The additional 2 ramp profiles are used particularly when the timing relation between the last 2 transmission time slots and CTIRQ is uncertain. This provides the possibility to use some of them interchangeably in one and its succeeding frames.


**Figure 71** Timing diagram of TDMA\_APCTR.

In GPRS mode, in order to fit the intermediate ramp profile between different power levels, a simple scheme with scaling is used to synthesize the ramp profile. The equation is as follows:

$$DA_0 = OFF + S_0 \cdot \frac{DN_{15,pre} + DN_0}{2}$$

$$DA_{2k} = OFF + S_l \cdot \frac{DN_{k-1} + DN_k}{2}, k = 1, \dots, 15$$

$$DA_{2k+1} = OFF + S_l \cdot DN_k, k = 0, 1, \dots, 15$$

$$l = \begin{cases} 0, & \text{if } 8 > k \geq 0 \\ 1, & \text{if } 15 \geq k \geq 8 \end{cases}$$

where **DA** represents the data to present to the D/A converter, **DN** represents the normalized data which is stored in the register **APC\_PFn**, **S<sub>0</sub>** represents the left scaling factor stored in register **APC\_SCALnL**, **S<sub>l</sub>** represents the right scaling factor stored in register **APC\_SCALnR**, and **OFF** represents the offset value stored in the register **APC\_OFFSETn**. The subscript **n** denotes the index of the ramp profile.

The ramp calculation before interpolation is as depicted in Figure 72.

During each ramp process, each word of the normalized profile is first multiplied by 10-bit scaling factors and added by an offset value to form a bank of 18-bit words. The first 8 words (in the left half part as in Figure 72) are multiplied by the left scaling factor **S<sub>0</sub>** and the last 8 words (in the right half part as in Figure 72) are multiplied by the right scaling factor **S<sub>l</sub>**. The lowest 8-bit of each word will then be truncated to get a 10-bit result. The scaling factor is 100 in hexadecimal, which represents no scaling on reset. The value smaller than 100 will scale down the ramp profile, and the value larger than 100 will scale up the ramp profile.



Figure 72 The timing diagram of the APC ramp.

The 16 10-bit words are linearly interpolated into 32 10-bit words. A 10-bit D/A converter is then used to convert these 32 ramp values at a rate of 1.0833MHz, that is, quarter bit rate. The timing diagram is shown in **Figure 73** and the final value will be retained on the output until the next event occurs.



**Figure 73** Timing diagram of the APC ramping.

The APC unit will only be powered up when the APC window is opened. The APC window is controlled by configuring the TDMA registers [TDMA\\_BULCON1](#) and [TDMA\\_BULCON2](#). Please refer to TDMA timer unit for more detailed information.

The first offset value stored in the register [APC\\_OFFSET0](#) also serves as the pedestal value, which is used to provide the initial power level for the PA.

Since the profile is not double-buffered, the timing to write the ramping profile would be critical. The programmer should be prevented from writing to the data buffer at the time that the ramping process is taking place. Or it would result in the wrong ramp profile and lead to malfunction.

## 8.4 Automatic Frequency Control (AFC) Unit

### 8.4.1 General description

Automatic Frequency Control unit provides the direct control of the oscillator for frequency offset and Doppler shift compensation. The block diagram is depicted in **Figure 74**. It utilizes a 13-bit D/A converter to achieve high-resolution control. Two modes of operation are supported and described as follows.

In [timer-triggered mode](#), the TDMA timer controls the AFC enabling events. There are at most four events within one TDMA frame. Double buffer architecture is supported. The AFC values can be written to the write buffers. When the signal [TDMA\\_EVTVAL](#) takes place, the values in the write buffers will be latched in the active buffers. However, the AFC values can also be written to the active buffers directly. When a TDMA event triggered by [TDMA\\_AFC](#) takes place, the value in the corresponding active buffer with the same index take effect. Each event is associated with an active buffer. An illustrative timing diagram of AFC events with respect to TX/RX/MX windows is depicted in **Figure 75**. In this mode, the

D/A converter can be either powered on continuously or for a programmable duration (of 256 quarter-bits by default). The later option is for power saving.

In **immediate mode**, the MCU can directly control the AFC value without event triggering. The value written by the MCU immediately takes effect. In this mode, the D/A converter should be powered on continuously. When entering timer-triggered mode from immediate mode (by setting flag **I\_MODE** in the register **AFC\_CON** to be 0), the D/A converter will be kept powered on for a programmable duration (of 256 quarter-bits by default) if the next TDMA\_AFC has not been pulsed in the duration. The duration will be prolonged upon receiving next events.

The two modes provide flexibility when controlling the oscillator. The 13-bit DAC proves to be monotonic. Associated with proper AFC algorithm, MT6219 achieves good tracking of the RF channels and the highest performance.



Figure 74 The block diagram of the AFC controller



Figure 75 The timing diagram of the AFC controller

#### 8.4.2 Register Definitions

##### AFC+0000h AFC control register

##### AFC\_CON

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3      | 2      | 1      | 0      |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|--------|--------|--------|--------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | RDAC_T | F_MODE | FETENV | I_MODE |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | R/W    | R/W    | R/W    | R/W    |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0      | 0      | 0      | 0      |

Four control modes are defined and can be controlled through the AFC control register. **F\_MODE** enables the force power up mode. **FETENV** enables the direct write operation to the active buffer. **I\_MODE** enables the immediate mode. **RDACT** enables the direct read operation from the active buffer.

**RDACT** The flag enables the direct read operation from the active buffer. Note the control flag is only applicable to the four data buffer including **AFC\_DAT0**, **AFC\_DAT1**, **AFC\_DAT2**, and **AFC\_DAT3**.

**0** APB read from the write buffer.

**1** APB read from the active buffer.

**FETENV** The flag enables the direct write operation to the active buffer. Note the control flag is only applicable to the for data buffer including **AFC\_DAT0**, **AFC\_DAT1**, **AFC\_DAT2**, and **AFC\_DAT3**.

**0** APB write to the write buffer.

**1** APB write to the active buffer.

**F\_MODE** The flag enables the force power up mode.

**0** The force power up mode is not enabled.

**1** The force power up mode is enabled.

**I\_MODE** The flag enables the immediate mode. To enable the immediate mode also enable the force power up mode.

**0** The immediate mode is not enabled.

**1** The immediate mode is enabled.

### AFC +0004h AFC data register 0

### AFC\_DAT0

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0           |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>AFCD</b> |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W         |

The register stores the AFC value for the event 0 triggered by the TDMA timer in timer-triggered mode. When **RDACT** or **FETENV** is set, the data transfer operates on the active buffer. On the contrary, when **RDACT** or **FETENV** is not set, the data transfer operates on the write buffer.

There are four registers (**AFC\_DAT0**, **AFC\_DAT1**, **AFC\_DAT2**, **AFC\_DAT3**) of the same type, which corresponds to the event triggered by the TDMA timer. The four registers are summarized in **Table 45**.

Immediate mode can only use **AFC\_DAT0**. In this mode, only the control value in the **AFC\_DAT0** write buffer is used to control the D/A converter. Unlike timer-triggered mode, the control value in **AFC\_DAT0** write buffer could bypass the active buffer stage and is directly coupled to the output buffer in immediate mode. To use immediate mode, it is recommended to program the **AFC\_DAT0** in advance and then enable the immediate mode by setting the flag **I\_MODE** in the register **AFC\_CON**.

The register **AFC\_DATA0**, **AFC\_DAT1**, **AFC\_DAT2**, and **AFC\_DAT3** have no initial values. So it has to be programmed before any AFC event takes place. However, the AFC value for the D/A converter, i.e., the output buffer value, is initially 0 right after power up before any event takes place.

**AFCD** The field is the AFC sample for the D/A converter.

| Register Address  | Register Function | Acronym         |
|-------------------|-------------------|-----------------|
| <b>AFC +0004h</b> | <b>AFCD</b>       | <b>AFC_DAT0</b> |
| <b>AFC +0008h</b> | <b>AFCD</b>       | <b>AFC_DAT1</b> |
| <b>AFC +000Ch</b> | <b>AFCD</b>       | <b>AFC_DAT2</b> |
| <b>AFC +0010h</b> | <b>AFCD</b>       | <b>AFC_DAT3</b> |

**Table 45** AFC Data Registers

### AFC +0014h AFC power up period

### AFC\_PUPER

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0             |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------------|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>PU PER</b> |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W           |

**Reset** ff

The register stores the AFC power up period, which is 13 bits wide. The value ranges from 0 to 8191. If the flag **I\_MODE** or **F\_MODE** is set, this register has no effect since the D/A converter is powered up continuously. If the flag **I\_MODE** and **F\_MODE** is not set, the register controls the power up duration of the D/A converter. During that period, the signal nPDN DAC in **Figure 74** is set to be 1.

**PU\_PER** The field stores the AFC power up period. After hardware power up, the field is initialized as 255.

## 9 Baseband Front End

Baseband Front End is a modem interface between TX/RX mixed-signal modules and digital signal processor (DSP). We can divide this block into two parts (see **Figure 76**). The first is the uplink (transmitting) path, which converts bit-stream from DSP into digital in-phase (I) and quadrature (Q) signals for TX mixed-signal module. The second part is the downlink (receiving) path, which receives digital in-phase (I) and quadrature (Q) signals from RX mixed-signal module, performs FIR filtering and then sends results to DSP. **Figure 76** illustrates interconnection around Baseband Front End. In the figure the shadowed blocks compose the Baseband Front End. The uplink path is mainly composed of GMSK Modulator and uplink parts of Baseband Serial Ports, and the downlink path is mainly composed of RX digital FIR filter and downlink parts of Baseband Serial Ports. Baseband Serial Ports is a serial interface used to communicate with DSP. In addition, there is a set of control registers in Baseband Front End that is intended for control of TX/RX mixed-signal modules, inclusive of calibration of DC offset and gain mismatch of downlink analog-to-digital (A/D) converters as well as uplink digital-to-analog (D/A) converters in TX/RX mixed-signal modules. The timing of bit streaming through Baseband Front End is completely under control of TDMA timer. Usually, only either uplink or downlink paths is active at a time. However, both of the uplink and downlink paths will be active simultaneously when Baseband Front End is in loopback mode.

When either of TX windows in TDMA timer is opened, the uplink path in Baseband Front End will be activated. Accordingly, components on the uplink path such as GMSK Modulator will be powered on, and then TX mixed-signal module is also powered on. The subblock Baseband Serial Ports will sink TX data bits from DSP and then forward them to GMSK Modulator. The outputs from GMSK Modulator are sent to TX mixed-signal module in format of I/Q signals. Finally, D/A conversions are performed in TX mixed-signal module and the output analog signal is output to RF module.

Similarly, while either of RX windows in TDMA timer is opened, the downlink path in Baseband Front End will be activated. Accordingly, components on the downlink path such as RX mixed-signal module and RX digital FIR filter are then powered on. First A/D conversions are performed in RX mixed-signal module, and then the results in format of I/Q signals are sourced to RX digital FIR filter. Low-Pass filtering is performed in RX digital FIR filter. Finally, the results will be sourced to DSP through Baseband Serial Ports.



Figure 76 Block Diagram Of Baseband Front End

## 9.1 Baseband Serial Ports

### 9.1.1 General Description

Baseband Front End communicates with DSP through the sub block of Baseband Serial Ports. Baseband Serial Ports interface with DSP in serial manner. This implies that DSP must be configured carefully in order to have Baseband Serial Ports cooperate with DSP core correctly.

If downlink path is programmed in bypass-filter mode (NOT bypass-filter loopback mode), behavior of Baseband Serial Ports will be completely different from that in normal function mode. The special mode is for testing purpose. Please see the subsequent section of Downlink Path for more details.

TX and RX windows are under control of TDMA timer. Please refer to functional specification of TDMA timer for the details on how to open/close a TX/RX window. Opening/Closing of TX/RX windows have two major effects on Baseband Front End: power on/off of corresponding components, and data souring/sinking. It is worth noticing that Baseband Serial Ports is only intended for sinking TX data from DSP or sourcing data to DSP. It does not involve power on/off of TX/RX mixed-signal modules.

As far as downlink path is concerned, if a RX window is opened by TDMA timer, Baseband Front End will have RX mixed-signal module proceed to make A/D conversion, RX digital filter proceed to perform filtering and Baseband Serial Ports be activated to source data from RX digital filter to DSP no matter the data is meaningful or not. However, the interval between the moment that RX mixed-signal module is powered on and the moment that data proceed to be dumped by Baseband Serial Ports can be well controlled in TDMA timer. Let us denote RX enable window as the interval that RX mixed-signal module is powered on and denote RX dump window as the interval that data is dumped by Baseband Serial Ports. If the first samples from RX digital filter desire to be discarded, the corresponding RX enable window must cover the corresponding RX dump window. Note that RX dump windows always win over RX enable windows. It means that a RX

dump window will always raise a RX enable window. RX enable windows can be raised by TDMA timer or by programming RX power-down bit in global control registers to be ‘0’. This is useful in debugging environment.

Similarly, a TX dump window refers to the interval that Baseband Serial Ports sinks data from DSP on uplink path and a TX enable window refers to the interval that TX mixed-signal module is powered on. A TX window controlled by TDMA timer involves a TX dump window and a TX enable window simultaneously. The interval between the moment that TX mixed-signal module is powered on and the moment that data proceed to be forwarded from DSP to GMSK modulator by Baseband Serial Ports can be well controlled in TDMA timer. TX dump windows always win over TX enable windows. It means that a TX dump window will always raise a TX enable window. TX enable windows can be raised by TDMA timer or by programming TX power-down bit in global control registers to be ‘0’. It is useful in debugging environment.

Accordingly, Baseband Serial Ports are only under the control of TX/RX dump window. Note that if TX/RX dump window is not integer multiple of bit-time, it will be extended to be integer multiples of bit-time. For example, if TX/RX dump window has interval of 156.25 bit-times, then it will be extended to 157 bit-times in Baseband Serial Ports.

### 9.1.2 Register Definitions

**BFE+0000h Base-band Common Control Register**

**BFE\_CON**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

This register is for common control of Baseband Front End. It consists of ciphering encryption control.

**BCIEN** The bit is for ciphering encryption control. If the bit is set to ‘1’, XOR will be performed on some TX bits (payload of Normal Burst) and ciphering pattern bit from DSP, and then the result is forwarded to GMSK Modulator. Meanwhile, Baseband Front End will generate signals to drive DSP ciphering process and produce corresponding ciphering pattern bits if the bit is set to ‘1’. If the bit is set to ‘0’, the TX bit from DSP will be forwarded to GMSK modulator directly. Baseband Front End will not activate DSP ciphering process.

**0** Disable ciphering encryption.

**1** Enable ciphering encryption.

**BFE +0004h Base-band Common Status Register**

**BFE\_STA**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

This register indicates status of Baseband Front End. Under control of TDMA timer, Baseband Front End can be driven in several statuses. If downlink path is enabled, then the bit BDLEN will be ‘1’. Otherwise, the bit BDLEN will be ‘0’. If downlink parts of Baseband Serial Ports is enabled, the bit BDLFS will be ‘1’. Otherwise, the bit BDLFS will be ‘0’. If uplink path is enabled, then the bit BULEN will be ‘1’. Otherwise, the bit BULEN will be 0. If uplink parts of Baseband Serial Ports is enabled, the bit BULFS will be ‘1’. Otherwise, the bit BULFS will be ‘0’. Once downlink path is enabled, RX mixed-signal module will also be powered on. Similarly, once uplink path is enabled, TX mixed-signal module will also be powered on. Furthermore, enabling Baseband Serial Ports for downlink path refers to dumping results from RX digital FIR filter to DSP. Similarly, enabling Baseband Serial Ports for uplink path refers to forwarding TX bit from DSP to

GMSK modulator. BDLEN stands for “**Baseband DownLink ENable**”. BULEN stands for “**Baseband UpLink ENable**”. BDLFS stands for “**Baseband DownLink FrameSync**”. BULFS stands for “**Baseband UpLink FrameSync**”.

**BDLEN** Indicate if downlink path is enabled.

- 0** Disabled
- 1** Enabled

**BDLFS** Indicate if Baseband Serial Ports for downlink path is enabled.

- 0** Disabled
- 1** Enabled

**BULEN** Indicate if uplink path is enabled.

- 0** Disabled
- 1** Enabled

**BULFS** Indicate if Baseband Serial Ports for uplink path is enabled.

- 0** Disabled
- 1** Enabled

## 9.2 Downlink Path (RX Path)

### 9.2.1 General Description

On the downlink path, the subblock between RX mixed-signal module and Baseband Serial Ports is RX Path. It mainly consists of a digital FIR filter, two sets of multiplexing paths for loopback modes, interface for RX mixed-signal module, and interface for Baseband Serial Ports. The block diagram is shown in **Figure 77**.

While RX enable windows are open, RX Path will issue control signals to have RX mixed-signal module proceed to make A/D conversion. As each conversion is finished, one set of I/Q signals will be latched. There exists a digital FIR filter for these I/Q signals. The result of filtering will be dumped to Baseband Serial Ports whenever RX dump windows are opened.

In addition to normal function, there are two loopback modes in RX Path. One is bypass-filter loopback mode, and the other is through-filter loopback mode. They are intended for verification of DSP firmware and hardware. The bypass-filter loopback mode refers to that RX digital FIR filter is not on the loopback path. However, the through-filter loopback mode refers to that RX digital FIR filter is on the loopback path.

The I/Q swap functionality is used to swap I/Q channel signals from RX mixed-signal module before they are latched into RX digital FIR filter. It is intended to provide flexibility for I/Q connection with RF modules.

There is a special data path not shown in **Figure 77**. It is a data path from RX mixed-signal module to Baseband Serial Ports. If downlink path is programmed in “Bypass RX digital FIR filter” mode, ADC outputs out of RX mixed-signal module will be directed into Baseband Serial Ports directly. Therefore, these data can be dumped into DSP and RX FIR filtering will not be performed on them. Limited by bandwidth of the serial interface between Baseband Serial Ports and DSP, only ADC outputs which are from either I-channel or Q-channel ADC can be dumped into DSP. Both I- and Q-channel ADC outputs cannot be dumped simultaneously. Which channel will be dumped is controlled by the register bit SWAP of the register **RX\_CFG** when downlink path is programmed in “Bypass RX digital FIR filter” mode. See register definition below for more details. The mode is for measurement of performance of A/D converters in RX mixed-signal module.



Figure 77 Block Diagram Of RX Path

## 9.2.2 Register Definitions

### BFE +0010h RX Configuration Register

**RX\_CFG**

| Bit   | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2    | 1        | 0     |
|-------|------|----|----|----|----|----|---|---|---|---|---|---|---|------|----------|-------|
| Name  | LPDN |    |    |    |    |    |   |   |   |   |   |   |   | DIV2 | BYPF LTR | SWA P |
| Type  | R/W  |    |    |    |    |    |   |   |   |   |   |   |   | R/W  | R/W      | R/W   |
| Reset | 0000 |    |    |    |    |    |   |   |   |   |   |   |   | 0    | 0        | 0     |

This register is for configuration of downlink path, inclusive of configuration of RX mixed-signal module and RX path in Baseband Front End.

**SWAP** This register bit is for control of whether I/Q channel signals need to swap before they are inputted to Baseband Front End. It provides flexible connection of I/Q channel signals between RF module and baseband module. The register bit has another purpose when the register bit “BYPFLTR” is set to 1. Please see description for the register bit “BYPFLTR”.

- 0 I- and Q-channel signals are not swapped
- 1 I- and Q-channel signals are swapped

**BYPFLTR** Bypass RX FIR filter control. The register bit is used to configure Baseband Front End in the state called “Bypass RX FIR filter state” or not. Once the bit is set to ‘1’, RX FIR filter will be bypassed. That is, ADC outputs of RX mixed-signal module that has 11-bit resolution and sampling rate of 1.083MHz can be dumped into DSP by Baseband Serial Ports and RX FIR filtering will not be performed on them. Limited by bandwidth of the serial interface between Baseband Serial Ports and DSP, these ADC outputs are all from either I-channel or Q-channel ADC. Both of I- and Q-channel ADC outputs cannot be dumped simultaneously. When the bit is set to ‘1’ and the

register bit “SWAP” is set to ‘0’, ADC outputs of I-channel will be dumped. When the bit is set to ‘1’ and the register bit “SWAP” is set to ‘1’, ADC outputs of Q-channel will be dumped.

**0** Not bypass RX FIR filter

**1** Bypass RX FIR filter

**DIV2** The register bit specifies whether outputs of RX FIR filter are divided by 2 before being dumped into DSP or not.

**0** Disabled

**1** Enabled

**LPDN** Late power down control. RX mixed-signal module needs two power down signals. There must exist some delay between them. The register field is used to control the late-arriving power-down signal.

**0000** The delay between two power-down signals is one 13 MHz period.

**0001** The delay between two power-down signals is two 13 MHz period.

**0010** The delay between two power-down signals is three 13 MHz period.

...

**0001** The delay between two power-down signals is 256 13 MHz period.

### BFE +0014h RX Control Register

**RX\_CON**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                 | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-------------------|-----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | <b>BLPEN[1:0]</b> |     |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                   | R/W |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                   | 0   |

This register is for control of downlink path, inclusive of control of RX mixed-signal module and RX path in Baseband Front End module.

**BLPEN** The register field is for loopback configuration selection in Baseband Front End.

**00** Configure Baseband Front End in normal function mode

**01** Configure Baseband Front End in bypass-filter loopback mode

**10** Configure Baseband Front End in through-filter loopback mode

**11** Reserved

### BFE +0020h RX Digital FIR Filter Coefficient Register 0

**RX\_FIR\_COEF0**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9         | 8         | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
|-------|----|----|----|----|----|----|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| Name  |    |    |    |    |    |    | <b>D9</b> | <b>D8</b> | <b>D7</b> | <b>D6</b> | <b>D5</b> | <b>D4</b> | <b>D3</b> | <b>D2</b> | <b>D1</b> | <b>D0</b> |
| Type  |    |    |    |    |    |    | R/W       |
| Reset |    |    |    |    |    |    | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         |

This register is for RX digital FIR filter coefficient 0. It is coded in 2’s complement. That is, its maximum is 255 and its minimum is -256. It will be applied on the latest and the oldest taps of 31 taps. The equivalent process flow of RX digital FIR filtering is shown in **Figure 78**.



Figure 78 Equivalent Process Flow Of RX Digital FIR Filtering

#### BFE +0024h RX Digital FIR Filter Coefficient Register 1 RX\_FIR\_COEF1

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    | D9  | D8  | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| Type  |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

This register is for RX digital FIR filter coefficient 1. It is coded in 2's complement. That is, its maximum is 255 and its minimum is -256.

#### BFE +0028h RX Digital FIR Filter Coefficient Register 2 RX\_FIR\_COEF2

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    | D9  | D8  | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| Type  |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

This register is for RX digital FIR filter coefficient 2. It is coded in 2's complement. That is, its maximum is 255 and its minimum is -256.

**BFE +002Ch RX Digital FIR Filter Coefficient Register 3** RX\_FIR\_COEF3

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    | D9  | D8  | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| Type  |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

This register is for RX digital FIR filter coefficient 3. It is coded in 2's complement. That is, its maximum is 255 and its minimum is -256.

**BFE +0030h RX Digital FIR Filter Coefficient Register 4** RX\_FIR\_COEF4

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    | D9  | D8  | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| Type  |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

This register is for RX FIR filter coefficient 4. It is coded in 2's complement. That is, its maximum is 255 and its minimum is -256.

**BFE +0034h RX Digital FIR Filter Coefficient Register 5** RX\_FIR\_COEF5

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    | D9  | D8  | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| Type  |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

This register is for RX digital FIR filter coefficient 5. It is coded in 2's complement. That is, its maximum is 255 and its minimum is -256.

**BFE +0038h RX Digital FIR Filter Coefficient Register 6** RX\_FIR\_COEF6

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    | D9  | D8  | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| Type  |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

This register is for RX digital FIR filter coefficient 6. It is coded in 2's complement. That is, its maximum is 255 and its minimum is -256.

**BFE +003Ch RX Digital FIR Filter Coefficient Register 7** RX\_FIR\_COEF7

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    | D9  | D8  | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| Type  |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

This register is for RX digital FIR filter coefficient 7. It is coded in 2's complement. That is, its maximum is 255 and its minimum is -256.

**BFE +0040h RX Digital FIR Filter Coefficient Register 8** RX\_FIR\_COEF8

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |    |    |    |    |    |    | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |

| Type  |  |  |  |  |  | R/W |
|-------|--|--|--|--|--|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Reset |  |  |  |  |  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

This register is for RX digital FIR filter coefficient 8. It is coded in 2's complement. That is, its maximum is 255 and its minimum is -256.

**BFE +0044h RX Digital FIR Filter Coefficient Register 9**
**RX\_FIR\_COEF9**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    | D9  | D8  | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| Type  |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

This register is for RX digital FIR filter coefficient 9. It is coded in 2's complement. That is, its maximum is 255 and its minimum is -256.

**BFE +0048h RX Digital FIR Filter Coefficient Register 10**
**RX\_FIR\_COEF10**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    | D9  | D8  | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| Type  |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

This register is for RX digital FIR filter coefficient 10. It is coded in 2's complement. That is, its maximum is 255 and its minimum is -256.

**BFE +004Ch RX Digital FIR Filter Coefficient Register 11**
**RX\_FIR\_COEF11**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    | D9  | D8  | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| Type  |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

This register is for RX digital FIR filter coefficient 11. It is coded in 2's complement. That is, its maximum is 255 and its minimum is -256.

**BFE +0050h RX Digital FIR Filter Coefficient Register 12**
**RX\_FIR\_COEF12**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    | D9  | D8  | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| Type  |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

This register is for RX digital FIR filter coefficient 12. It is coded in 2's complement. That is, its maximum is 255 and its minimum is -256.

**BFE +0054h RX Digital FIR Filter Coefficient Register 13**
**RX\_FIR\_COEF13**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    | D9  | D8  | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| Type  |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

This register is for RX digital FIR filter coefficient 13. It is coded in 2's complement. That is, its maximum is 255 and its minimum is -256.

### BFE +0058h RX Digital FIR Filter Coefficient Register 14

RX\_FIR\_COEF1  
4

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    | D9  | D8  | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| Type  |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

This register is for RX digital FIR filter coefficient 14. It is coded in 2's complement. That is, its maximum is 255 and its minimum is -256.

### BFE +005Ch RX Digital FIR Filter Coefficient Register 15

RX\_FIR\_COEF1  
5

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    | D9  | D8  | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| Type  |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

This register is for RX digital FIR filter coefficient 15. It is coded in 2's complement. That is, its maximum is 255 and its minimum is -256.

## 9.3 Uplink Path (TX Path)

### 9.3.1 General Description

The purpose of the uplink path inside Baseband Front End is to sink TX symbols, one bit for each symbol, from DSP, then perform GMSK modulation on them, then perform offset cancellation on I/Q digital signals out of GMSK modulator, and finally control TX mixed-signal module to make D/A conversion on I/Q signals out of GMSK Modulator with offset cancellation. Accordingly, the uplink path is composed of uplink parts of Baseband Serial Ports, GSM Encryptor, GMSK Modulator, and Offset Cancellation. The block diagram of uplink path is shown in **Figure 79**. On the uplink path, the content of a burst, including tail bits, data bits, and training sequence bits is sent from DSP. Translated by GMSK Modulator, these bits will become I/Q digital signals. Offset cancellation will be performed on these I/Q digital signals to compensate offset error of D/A converters (DAC) in TX mixed-signal module. Finally, the generated I/Q digital signals will be inputted to TX mixed-signal module that contains two DAC for I/Q signal respectively. The details of each subblock will be described in subsequent sections.



**Figure 79** Block Diagram Of Uplink Path

TDMA timer having a quarter-bit timing accuracy gives the timing windows for uplink operation. Uplink operation is controlled by TX enable window and TX dump window of TDMA timer. Usually, TX enable window is opened earlier than TX dump window. When TX enable window of TDMA timer is opened, uplink path in Baseband Front End will power-on GSK TX mixed-signal module and thus drive valid outputs to RF module. However, uplink parts of Baseband Serial Ports still do not sink data from DSP through the serial interface between Baseband Serial Ports and DSP until TX dump window of TDMA timer is opened.

### 9.3.2 Register Definitions

#### BFE +0060h TX Configuration Register

**TX\_CFG**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | APND EN |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W     |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0       |

This register is for configuration of uplink path, inclusive of configuration of TX mixed-signal module and TX path in Baseband Front End.

**APNDEN** Appending Bits Enable. The register bit is used to control the ending scheme of GMSK modulation.

- 0** Suitable for GPRS. If a TX enable window contains several TX dump window, then GMSK modulator will still output in the intervals between two TX dump window and all 1's will be fed into GMSK modulator.
- 1** Suitable for GSM only. After a TX dump window, GMSK modulator will only output for some bit time.

#### BFE +0064h TX Control Register

**TX\_CON**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0        |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | CALR CEN |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W      |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0        |

This register is for control of uplink path, inclusive of control of TX mixed-signal module and TX path in Baseband Front End.

**CALRCEN** Calibration for TX low-pass-filter Enable. The procedure to make calibration processing for smoothing filter in BBTX mixed-signal module is as follows:

1. Write ‘1’ to the register bit CARLC in the register TX\_CON of Baseband Front End in order to activate clock required for calibration process. Initiate calibration process.
2. Write ‘1’ to the register bit STARTCALRC of Analog Chip Interface. Start calibration process.
3. Read the register bit CALRCDONE of Analog Chip Interface. If read as ‘1’, then calibration process finished. Otherwise repeat the step.
4. Write ‘0’ to the register bit STARTCALRC of Analog Chip Interface. Stop calibration process.
5. Write ‘0’ to the register bit CARLC in the register TX\_CON of Baseband Front End in order to deactivate clock required for calibration process. Terminate calibration process.
6. The result of calibration process can be read from the register field CALRCOUT of the register BBTX\_AC\_CON1 of Analog Chip Interface. Software can set the value to the register field CALRCSEL for 3-dB cutoff frequency selection of smoothing filter in DAC of BBTX of Analog Chip Interface.

**0** Deactivate clock required for calibration process.

**1** Activate clock required for calibration process.

**IQSWP** The register bit is for control of I/Q swapping. When the bit is set to ‘1’, phase on I/Q plane will rotate in inverse direction.

**0**: I and Q are not swapped.

**1**: I and Q are swapped.

#### BFE +0068h TX I/Q Channel Offset Compensation Register

**TX\_OFF**

| Bit   | 15 | 14 | 13 | 12 | 11               | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3                | 2 | 1 | 0 |  |
|-------|----|----|----|----|------------------|----|---|---|---|---|---|---|------------------|---|---|---|--|
| Name  |    |    |    |    | <b>OFFQ[5:0]</b> |    |   |   |   |   |   |   | <b>OFFI[5:0]</b> |   |   |   |  |
| Type  |    |    |    |    | R/W              |    |   |   |   |   |   |   | R/W              |   |   |   |  |
| Reset |    |    |    |    | 000000           |    |   |   |   |   |   |   | 000000           |   |   |   |  |

This register is for offset cancellation of I-channel DAC in TX mixed-signal module. It is for compensation of offset error caused by I/Q-channel DAC in TX mixed-signal module. It is coded in 2’s complement, that is, with maximum 31 and minimum -32.

**OFFI** Value of offset cancellation for I-channel DAC in TX mixed-signal module

**OFFQ** Value of offset cancellation for Q-channel DAC in TX mixed-signal module

#### 9.4 Register Definitions Summary

#### BFE+0000h Base-band Common Control Register

**BFE\_CON**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0            |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>BCIEN</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W          |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0            |

#### BFE +0004h Base-band Common Status Register

**BFE\_STA**

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2            | 1                      | 0                      |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|--------------|------------------------|------------------------|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>BULFS</b> | <b>BU<br/>LE<br/>N</b> | <b>BD<br/>LF<br/>S</b> |

|       |  |  |  |  |  |  |  |  |  |  |  |  |    |    |    |    |
|-------|--|--|--|--|--|--|--|--|--|--|--|--|----|----|----|----|
| Type  |  |  |  |  |  |  |  |  |  |  |  |  | RO | RO | RO | RO |
| Reset |  |  |  |  |  |  |  |  |  |  |  |  | 0  | 0  | 0  | 0  |

**BFE +0010h RX Configuration Register**
**RX\_CFG**

| Bit   | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1               | 0        |
|-------|------|----|----|----|----|----|---|---|---|---|---|---|---|---|-----------------|----------|
| Name  | LPDN |    |    |    |    |    |   |   |   |   |   |   |   |   | BYP<br>FLT<br>R | SWA<br>P |
| Type  | R/W  |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W             | R/W      |
| Reset | 0001 |    |    |    |    |    |   |   |   |   |   |   |   |   | 0               | 0        |

**BFE +0014h RX Control Register**
**RX\_CON**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1          | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|------------|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | BLPEN[1:0] |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W        |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0          |   |

**BFE +0020-005Ch RX Digital FIR Filter Coefficient Register 0-15**
**RX\_FIR\_COEF0-15**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    | D9  | D8  | D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| Type  |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

**BFE +0060h TX Configuration Register**
**TX\_CFG**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1          | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|------------|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | APN<br>DEN |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W        |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0          |   |

**BFE +0064h TX Control Register**
**TX\_CON**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1           | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-------------|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | CALR<br>CEN | IQSW<br>P |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W         | R/W       |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0           | 0         |

**BFE +0068h TX I/Q Channel Offset Compensation Register**
**TX\_OFF**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9         | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1         | 0 |
|-------|----|----|----|----|----|----|-----------|---|---|---|---|---|---|---|-----------|---|
| Name  |    |    |    |    |    |    | OFFQ[5:0] |   |   |   |   |   |   |   | OFFI[5:0] |   |
| Type  |    |    |    |    |    |    | R/W       |   |   |   |   |   |   |   | R/W       |   |
| Reset |    |    |    |    |    |    | 000000    |   |   |   |   |   |   |   | 000000    |   |

## 10 Timing Generator

Timing is the most critical issue in GSM/GPRS applications. The TDMA timer provides a simple interface for the MCU to program all the timing-related events for receive event control, transmit event control and the timing adjustment. Detailed descriptions are mentioned in Section 10.1.

In pause mode, the 13MHz reference clock may be switched off temporarily for the purpose of power saving and the synchronization to the base-station is maintained by using a low power 32KHz crystal oscillator. The 32KHz oscillator is not accurate and therefore it should be calibrated prior to entering pause mode. The calibration sequence, pause begin sequence and the wake up sequence are described in Section 10.2.

### 10.1 TDMA timer

The TDMA timer unit is composed of three major blocks: Quarter bit counter, Signal generator and Event registers.



Figure 80 The block diagram of TDMA timer

By default, the quarter-bit counter continuously counts from 0 to the wrap position. In order to apply to cell synchronization and neighboring cell monitoring, the wrap position can be changed by the MCU to shorten or lengthen a TDMA frame. The wrap position is held in the TDMA\_WRAP register and the current value of the TDMA quarter bit counter may be read by the MCU via the TDMA\_TQCNT register.

The signal generator handles the overall comparing and event-generating processes. When a match has occurred between the quarter bit counter and the event register, a predefined control signal is generated. These control signals may be used for on-chip and off-chip purposes. Signals that change state more than once per frame make use of more than one event register.

The event registers are programmed to contain the quarter bit position of the event that is to occur. The event registers are double buffered. The MCU writes into the first register, and the event TDMA\_EVTVAL transfers the data from the write buffer to the active buffer, which is used by the signal generator for comparison with the quarter bit count. The TDMA\_EVTVAL signal itself may be programmed at any quarter bit position. These event registers could be classified into four groups:

#### On-chip Control Events

#### TDMA\_EVTVAL

This event allows the data values written by the MCU to pass through to the active buffers.

#### **TDMA\_WRAP**

TDMA quarter bit counter wrap position. This sets the position at which the TDMA quarter bit counter resets back to zero. The default value is 4999, changing this value will advance or retard the timing events in the frame following the next TDMA\_EVTVAL signal.

#### **TDMA\_DTIRQ**

DSP TDMA interrupt requests. DTIRQ triggers the DSP to read the command from the MCU/DSP Shard RAM to schedule the activities that will be executed in the current frame.

#### **TDMA\_CTIRQ1/CTIRQ2**

MCU TDMA interrupt requests.

#### **TDMA\_AUXADC [1:0]**

This signal triggers the monitoring ADC to measure the voltage, current, temperature, device id etc..

#### **TDMA\_AFC [3:0]**

This signal powers up the automatic frequency control DAC for a programmed duration after this event.

*Note: For both MCU and DSP TDMA interrupt requests, these signals are all active Low during one quarter bit duration and they should be used as edge sensitive events by the respective interrupt controllers.*

### **On-chip Receive Events**

#### **TDMA\_BDLON [5:0]**

These registers are a set of six which contain the quarter bit event that initiates the receive window assertion sequence which powers up and enables the receive ADC, and then enables loading of the receive data into the receive buffer.

#### **TDMA\_BDLOFF [5:0]**

These registers are a set of six which contain the quarter bit event that initiates the receive window de-assertion sequence which disables loading of the receive data into the receive buffer, and then powers down the receive ADC.

#### **TDMA\_RXWIN[5:0]**

DSP TDMA interrupt requests. TDMA\_RXWIN is usually used to initiate the related RX processing including two modes. In single-shot mode, TDMA\_RXWIN is generated when the BRXFS signal is de-asserted. In repetitive mode, TDMA\_RXWIN will be generated both regularly with a specific interval after BRXFS signal is asserted and when the BRXFS signal is de-asserted.



**Figure 81** The timing diagram of BRXEN and BRXFS

*Note: TDMA\_BDLON/OFF event registers, together with TDMA\_BDLCON register, generate the corresponding BRXEN and BRXFS window used to power up/down baseband downlink path and control the duration of data transmission to the DSP, respectively.*

### **On-chip Transmit Events**

#### **TDMA\_AP[6:0]**

These registers initiate the loading of the transmit burst shaping values from the transmit burst shaping RAM into the transmit power control DAC.

#### **TDMA\_BULON [3:0]**

This register contains the quarter bit event that initiates the transmit window assertion sequence which powers up the modulator DAC and then enables reading of bits from the transmit buffer into the GMSK modulator.

#### TDMA\_BULOFF [3:0]

This register contains the quarter bit event that initiates the transmit window de-assertion sequence which disables the reading of bits from the transmit buffer into the GMSK modulator, and then power down the modulator DAC.



**Figure 82** The timing diagram of BTXEN and BTXFS

*Note: TDMA\_BULON/OFF event registers, together with TDMA\_BULCON1, TDMA\_BULCON2 register, generate the corresponding BTXEN, BTXFS and APCEN window used to power up/down the baseband uplink path, control the duration of data transmission from the DSP and power up/down the APC DAC, respectively.*

#### Off-chip Control Events

##### TDMA\_BSI [15:0]

The quarter bit positions of these 16 BSI events are used to initiate the transfer of serial words to the transceiver and synthesizer for gain control and frequency adjustment.

##### TDMA\_BPI [21:0]

The quarter bit positions of these 22 BPI events are used to generate changes of state on the output pins to control the external radio components.

#### 10.1.1 Register Definitions

##### TDMA+0150h Event Enable Register 0

TDMA\_EVTENA  
0

| Bit   | 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6    | 5 | 4 | 3 | 2      | 1      | 0      |
|-------|------|------|------|------|------|------|------|------|------|------|---|---|---|--------|--------|--------|
| Name  | AFC3 | AFC2 | AFC1 | AFC0 | BDL5 | BDL4 | BDL3 | BDL2 | BDL1 | BDL0 |   |   |   | CTIRQ2 | CTIRQ1 | DTIRQ0 |
| Type  | R/W  |   |   |   | R/W    | R/W    | R/W    |
| Reset | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |   |   |   | 0      | 0      | 0      |

**DTIRQ** Enable TDMA\_DTIRQ

**CTIRQ<sub>n</sub>** Enable TDMA\_CTIRQ<sub>n</sub>

**AFC<sub>n</sub>** Enable TDMA\_AFC<sub>n</sub>

**BDL<sub>n</sub>** Enable TDMA\_BDLON<sub>n</sub> and TDMA\_BDLOFF<sub>n</sub>

For all these bits,

**0** function is disabled

**1** function is enabled

##### TDMA+0154h Event Enable Register 1

TDMA\_EVTENA  
1

| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|

| Name  | GPRS |  |  |     | BUL3 | BUL2 | BUL1 | BUL0 |     | APC6 | APC5 | APC4 | APC3 | APC2 | APC1 | APC0 |
|-------|------|--|--|-----|------|------|------|------|-----|------|------|------|------|------|------|------|
| Type  | R/W  |  |  | R/W | R/W  | R/W  | R/W  |      | R/W | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |      |
| Reset | 0    |  |  | 0   | 0    | 0    | 0    |      | 0   | 0    | 0    | 0    | 0    | 0    | 0    |      |

**APCn** Enable TDMA\_APCh

**BULn** Enable TDMA\_BULONn and TDMA\_BULOFFn

For all these bits,

0 function is disabled

1 function is enabled

### TDMA +0158h Event Enable Register 2

TDMA\_EVTENA  
2

| Bit   | 15    | 14    | 13    | 12    | 11    | 10    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-------|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|------|------|------|
| Name  | BSI15 | BSI14 | BSI13 | BSI12 | BSI11 | BSI10 | BSI9 | BSI8 | BSI7 | BSI6 | BSI5 | BSI4 | BSI3 | BSI2 | BSI1 | BSI0 |
| Type  | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

**BSIn** BSI event enable control

0 Disable TDMA\_BSiN

1 Enable TDMA\_BSiN

### TDMA +015Ch Event Enable Register 3

TDMA\_EVTENA  
3

| Bit   | 15    | 14    | 13    | 12    | 11    | 10    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-------|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|------|------|------|
| Name  | BPI15 | BPI14 | BPI13 | BPI12 | BPI11 | BPI10 | BPI9 | BPI8 | BPI7 | BPI6 | BPI5 | BPI4 | BPI3 | BPI2 | BPI1 | BPI0 |
| Type  | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

### TDMA+0160h Event Enable Register 4

TDMA\_EVTENA  
4

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|----|----|----|----|----|----|---|---|---|---|-------|-------|-------|-------|-------|-------|
| Name  |    |    |    |    |    |    |   |   |   |   | BPI21 | BPI20 | BPI19 | BPI18 | BPI17 | BPI16 |
| Type  |    |    |    |    |    |    |   |   |   |   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   |
| Reset |    |    |    |    |    |    |   |   |   |   | 0     | 0     | 0     | 0     | 0     | 0     |

**BPIIn** BPI event enable control

0 Disable TDMA\_BPiN

1 Enable TDMA\_BPiN

### TDMA+0164h Event Enable Register 5

TDMA\_EVTENA  
5

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2    | 1    | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|------|------|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | AUX1 | AUX0 |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | R/W  | R/W  |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0    | 0    |   |

**AUX** Auxiliary ADC event enable control

0 Disable Auxiliary ADC event

1 Enable Auxiliary ADC event

**TDMA +0170h Qbit Timer Offset Control Register**
**TDMA\_WRAPOF  
S**

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------------|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0               |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>TOI[1:0]</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W             |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0               |

**TOI** This register defines the value used to advance the Qbit timer in unit of 1/4 quarter bit; the timing advance will be take place as soon as the TDMA\_EVTVAL is occurred, and it will be cleared automatically.

**TDMA +0174h Qbit Timer Biasing Control Register**
**TDMA\_REGBIA  
S**

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                      |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------------------|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                    |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>TQ_BIAS[13:0]</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W                  |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0                    |

**TQ\_BIAS** This register defines the Qbit offset value which will be added to the registers being programmed. It only takes effects on AFC, BDLON/OFF, BULON/OFF, APC, AUXADC, BSI and BPI event registers.

**TDMA +0180h DTX Control Register**
**TDMA\_DTXCON**

|      |    |    |    |    |    |    |   |   |   |   |   |   |   |             |             |             |             |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|-------------|-------------|-------------|-------------|
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2           | 1           | 0           |             |
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>DTX3</b> | <b>DTX2</b> | <b>DTX1</b> | <b>DTX0</b> |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |             |             | R/W         |             |

**DTX** DTX flag is used to disable the associated transmit signals

**0** BULON0, BULOFF0, APC\_EV0 & APC\_EV1 are controlled by TDMA\_EVTENA1 register

**1** BULON0, BULOFF0, APC\_EV0 & APC\_EV1 are disabled

**TDMA +0184h Receive Interrupt Control Register**
**TDMA\_RXCON**

|      |             |             |             |             |             |             |   |   |   |   |   |   |   |   |   |                      |
|------|-------------|-------------|-------------|-------------|-------------|-------------|---|---|---|---|---|---|---|---|---|----------------------|
| Bit  | 15          | 14          | 13          | 12          | 11          | 10          | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                    |
| Name | <b>MOD5</b> | <b>MOD4</b> | <b>MOD3</b> | <b>MOD2</b> | <b>MOD1</b> | <b>MOD0</b> |   |   |   |   |   |   |   |   |   | <b>RXINTCNT[9:0]</b> |
| Type | R/W         | R/W         | R/W         | R/W         | R/W         | R/W         |   |   |   |   |   |   |   |   |   | R/W                  |

**RXINTCNT** TDMA\_RXWIN interrupt generation interval in quarter bit unit

**MODn** Mode of Receive Interrupts

**0** Single shot mode for the corresponding receive window

**1** Repetitive mode for the corresponding receive window

**TDMA +0188h Baseband Downlink Control Register**
**TDMA\_BDLCON**

|      |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |               |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------------|
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0             |
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>ADC_ON</b> |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W           |

**ADC\_ON** BRXEN to BRXFS setup up time in quarter bit unit.

**ADC\_OFF** BRXEN to BRXFS hold up time in quarter bit unit.

**TDMA +018Ch Baseband Uplink Control Register 1**
**TDMA\_BULCON  
1**

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | DAC_ON |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W    |

**DAC\_ON** BTXEN to BTXFS setup up time in quarter bit unit.

**DAC\_OFF** BTXEN to BTXFS hold up time in quarter bit unit.

**TDMA +0190h Baseband Uplink Control Register 2**
**TDMA\_BULCON  
2**

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0       |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | APC_HYS |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W     |

**APC\_HYS** APCEN to BTXEN hysteresis time in quarter bit unit.

| Address | Type | Width  | Reset Value | Name         | Description                                        |
|---------|------|--------|-------------|--------------|----------------------------------------------------|
| +0000h  | R    | [13:0] | —           | TDMA_TQCNT   | Read quarter bit counter                           |
| +0004h  | R/W  | [13:0] | 0x1387      | TDMA_WRAP    | Latched Qbit counter reset position                |
| +0008h  | R/W  | [13:0] | 0x1387      | TDMA_WRAPIMD | Direct Qbit counter reset position                 |
| +000Ch  | R/W  | [13:0] | 0x0000      | TDMA_EVTVAL  | Event latch position                               |
| +0010h  | R/W  | [13:0] | —           | TDMA_DTIRQ   | DSP software control                               |
| +0014h  | R/W  | [13:0] | —           | TDMA_CTIRQ1  | MCU software control 1                             |
| +0018h  | R/W  | [13:0] | —           | TDMA_CTIRQ2  | MCU software control 2                             |
| +0020h  | R/W  | [13:0] | —           | TDMA_AFC0    | The 1 <sup>st</sup> AFC control                    |
| +0024h  | R/W  | [13:0] | —           | TDMA_AFC1    | The 2 <sup>nd</sup> AFC control                    |
| +0028h  | R/W  | [13:0] | —           | TDMA_AFC2    | The 3 <sup>rd</sup> AFC control                    |
| +002Ch  | R/W  | [13:0] | —           | TDMA_AFC3    | The 4 <sup>th</sup> AFC control                    |
| +0030h  | R/W  | [13:0] | —           | TDMA_BDLON0  | Data serialization of the 1 <sup>st</sup> RX block |
| +0034h  | R/W  | [13:0] | —           | TDMA_BDLOFF0 |                                                    |
| +0038h  | R/W  | [13:0] | —           | TDMA_BDLON1  | Data serialization of the 2 <sup>nd</sup> RX block |
| +003Ch  | R/W  | [13:0] | —           | TDMA_BDLOFF1 |                                                    |
| +0040h  | R/W  | [13:0] | —           | TDMA_BDLON2  | Data serialization of the 3 <sup>rd</sup> RX block |
| +0044h  | R/W  | [13:0] | —           | TDMA_BDLOFF2 |                                                    |
| +0048h  | R/W  | [13:0] | —           | TDMA_BDLON3  | Data serialization of the 4 <sup>th</sup> RX block |
| +004Ch  | R/W  | [13:0] | —           | TDMA_BDLOFF3 |                                                    |
| +0050h  | R/W  | [13:0] | —           | TDMA_BDLON4  | Data serialization of the 5 <sup>th</sup> RX block |
| +0054h  | R/W  | [13:0] | —           | TDMA_BDLOFF4 |                                                    |
| +0058h  | R/W  | [13:0] | —           | TDMA_BDLON5  | Data serialization of the 6 <sup>th</sup> RX block |
| +005Ch  | R/W  | [13:0] | —           | TDMA_BDLOFF5 |                                                    |
| +0060h  | R/W  | [13:0] | —           | TDMA_BULON0  | Data serialization of the 1 <sup>st</sup> TX slot  |
| +0064h  | R/W  | [13:0] | —           | TDMA_BULOFF0 |                                                    |
| +0068h  | R/W  | [13:0] | —           | TDMA_BULON1  | Data serialization of the 2 <sup>nd</sup> TX slot  |
| +006Ch  | R/W  | [13:0] | —           | TDMA_BULOFF1 |                                                    |
| +0070h  | R/W  | [13:0] | —           | TDMA_BULON2  | Data serialization of the 3 <sup>rd</sup> TX slot  |
| +0074h  | R/W  | [13:0] | —           | TDMA_BULOFF2 |                                                    |
| +0078h  | R/W  | [13:0] | —           | TDMA_BULON3  | Data serialization of the 4 <sup>th</sup> TX slot  |
| +007Ch  | R/W  | [13:0] | —           | TDMA_BULOFF3 |                                                    |
| +0090h  | R/W  | [13:0] | —           | TDMA_APCT0   | The 1 <sup>st</sup> APC control                    |

|         |     |        |        |              |                                 |
|---------|-----|--------|--------|--------------|---------------------------------|
| +0094h  | R/W | [13:0] | —      | TDMA_APPC1   | The 2 <sup>nd</sup> APC control |
| +0098h  | R/W | [13:0] | —      | TDMA_APPC2   | The 3 <sup>rd</sup> APC control |
| +009Ch  | R/W | [13:0] | —      | TDMA_APPC3   | The 4 <sup>th</sup> APC control |
| +00A0h  | R/W | [13:0] | —      | TDMA_APPC4   | The 5 <sup>th</sup> APC control |
| +00A4h  | R/W | [13:0] | —      | TDMA_APPC5   | The 6 <sup>th</sup> APC control |
| +00A8h  | R/W | [13:0] | —      | TDMA_APPC6   | The 7 <sup>th</sup> APC control |
| +00B0h  | R/W | [13:0] | —      | TDMA_BSI0    | BSI event 0                     |
| +00B4h  | R/W | [13:0] | —      | TDMA_BSI1    | BSI event 1                     |
| +00B8h  | R/W | [13:0] | —      | TDMA_BSI2    | BSI event 2                     |
| +00BCh  | R/W | [13:0] | —      | TDMA_BSI3    | BSI event 3                     |
| +00C0h  | R/W | [13:0] | —      | TDMA_BSI4    | BSI event 4                     |
| +00C4h  | R/W | [13:0] | —      | TDMA_BSI5    | BSI event 5                     |
| +00C8h  | R/W | [13:0] | —      | TDMA_BSI6    | BSI event 6                     |
| +00CCCh | R/W | [13:0] | —      | TDMA_BSI7    | BSI event 7                     |
| +00D0h  | R/W | [13:0] | —      | TDMA_BSI8    | BSI event 8                     |
| +00D4h  | R/W | [13:0] | —      | TDMA_BSI9    | BSI event 9                     |
| +00D8h  | R/W | [13:0] | —      | TDMA_BSI10   | BSI event 10                    |
| +00DCh  | R/W | [13:0] | —      | TDMA_BSI11   | BSI event 11                    |
| +00E0h  | R/W | [13:0] | —      | TDMA_BSI12   | BSI event 12                    |
| +00E4h  | R/W | [13:0] | —      | TDMA_BSI13   | BSI event 13                    |
| +00E8h  | R/W | [13:0] | —      | TDMA_BSI14   | BSI event 14                    |
| +00ECh  | R/W | [13:0] | —      | TDMA_BSI15   | BSI event 15                    |
| +0100h  | R/W | [13:0] | —      | TDMA_BPI0    | BPI event 0                     |
| +0104h  | R/W | [13:0] | —      | TDMA_BPI1    | BPI event 1                     |
| +0108h  | R/W | [13:0] | —      | TDMA_BPI2    | BPI event 2                     |
| +010Ch  | R/W | [13:0] | —      | TDMA_BPI3    | BPI event 3                     |
| +0110h  | R/W | [13:0] | —      | TDMA_BPI4    | BPI event 4                     |
| +0114h  | R/W | [13:0] | —      | TDMA_BPI5    | BPI event 5                     |
| +0118h  | R/W | [13:0] | —      | TDMA_BPI6    | BPI event 6                     |
| +011Ch  | R/W | [13:0] | —      | TDMA_BPI7    | BPI event 7                     |
| +0120h  | R/W | [13:0] | —      | TDMA_BPI8    | BPI event 8                     |
| +0124h  | R/W | [13:0] | —      | TDMA_BPI9    | BPI event 9                     |
| +0128h  | R/W | [13:0] | —      | TDMA_BPI10   | BPI event 10                    |
| +012Ch  | R/W | [13:0] | —      | TDMA_BPI11   | BPI event 11                    |
| +0130h  | R/W | [13:0] | —      | TDMA_BPI12   | BPI event 12                    |
| +0134h  | R/W | [13:0] | —      | TDMA_BPI13   | BPI event 13                    |
| +0138h  | R/W | [13:0] | —      | TDMA_BPI14   | BPI event 14                    |
| +013Ch  | R/W | [13:0] | —      | TDMA_BPI15   | BPI event 15                    |
| +0140h  | R/W | [13:0] | —      | TDMA_BPI16   | BPI event 16                    |
| +0144h  | R/W | [13:0] | —      | TDMA_BPI17   | BPI event 17                    |
| +0148h  | R/W | [13:0] | —      | TDMA_BPI18   | BPI event 18                    |
| +014Ch  | R/W | [13:0] | —      | TDMA_BPI19   | BPI event 19                    |
| +01A0h  | R/W | [13:0] | —      | TDMA_BPI20   | BPI event 20                    |
| +01A4h  | R/W | [13:0] | —      | TDMA_BPI21   | BPI event 21                    |
| +01B0h  | R/W | [13:0] | —      | TDMA_AUXEV0  | Auxiliary ADC event 0           |
| +01B4h  | R/W | [13:0] | —      | TDMA_AUXEV1  | Auxiliary ADC event 1           |
| +0150h  | R/W | [15:0] | 0x0000 | TDMA_EVTENA0 | Event Enable Control 0          |
| +0154h  | R/W | [15:0] | 0x0000 | TDMA_EVTENA1 | Event Enable Control 1          |
| +0158h  | R/W | [15:0] | 0x0000 | TDMA_EVTENA2 | Event Enable Control 2          |
| +015Ch  | R/W | [15:0] | 0x0000 | TDMA_EVTENA3 | Event Enable Control 3          |

|        |     |        |        |              |                                    |
|--------|-----|--------|--------|--------------|------------------------------------|
| +0160h | R/W | [5:0]  | 0x0000 | TDMA_EVTENA4 | Event Enable Control 4             |
| +0164h | R/W | [0]    | 0x0000 | TDMA_EVTENA5 | Event Enable Control 5             |
| +0170h | R/W | [1:0]  | 0x0000 | TDMA_WRAPOFS | TQ Counter Offset Control Register |
| +0174h | R/W | [13:0] | 0x0000 | TDMA_REGBIAS | Biasing Control Register           |
| +0180h | R/W | [3:0]  | —      | TDMA_DTXCON  | DTX Control Register               |
| +0184h | R/W | [15:0] | —      | TDMA_RXCON   | Receive Interrupt Control Register |
| +0188h | R/W | [15:0] | —      | TDMA_BDLCON  | Downlink Control Register          |
| +018Ch | R/W | [15:0] | —      | TDMA_BULCON1 | Uplink Control Register 1          |
| +0190h | R/W | [7:0]  | —      | TDMA_BULCON2 | Uplink Control Register 2          |

Table 46 TDMA Timer Register Map

## 10.2 Slow Clocking Unit



Figure 83 The block diagram of the slow clocking unit

The slow clocking unit is provided to maintain the synchronization to the base-station timing using a 32KHz crystal oscillator while the 13MHz reference clock is switched off. As shown in Figure 83, this unit is composed of frequency measurement unit, pause unit, and clock management unit.

Because of the inaccuracy of the 32KHz oscillator, a frequency measurement unit is provided to calibrate the 32KHz crystal taking the accurate 13MHz source as the reference. The calibration procedure always takes place prior to the pause period.

The pause unit is used to initiate and terminate the pause mode procedure and it also works as a coarse time-base during the pause period.

The clock management unit is used to control the system clock while switching between the normal mode and the pause mode. SRCLKENA is used to turn on/off the clock squarer, DSP PLL and off-chip TCVCXO. CLOCK\_OFF signal is used

for gating the main MCU and DSP clock, and VCXO\_OFF is used as the acknowledgement signal of the CLOCK\_OFF request.

### 10.2.1 Register Definitions

#### TDMA +0218h Slow clocking unit control register

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1         | 0       | SM_CON |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----------|---------|--------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | PAUSE_STA | FM_STAR |        |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RT        | T       |        |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | W         | W       |        |

**FM\_START** Initiate the frequency measurement procedure

**PAUSE\_START** Initiate the pause mode procedure at the next timer wrap position

#### TDMA +0220h Slow clocking unit status register

SM\_STA

| Bit  | 15           | 14        | 13        | 12          | 11 | 10 | 9 | 8 | PAUSE_ABO |         |
|------|--------------|-----------|-----------|-------------|----|----|---|---|-----------|---------|
| Name |              |           |           |             |    |    |   |   | RT        |         |
| Type |              |           |           |             |    |    |   |   | R         |         |
| Bit  | 7            | 6         | 5         | 4           | 3  | 2  | 1 | 0 |           |         |
| Name | SETTLE_CPL_L | PAUSE_CPL | PAUSE_INT | PAUSE_RQS_T |    |    |   |   | FM_CPL    | FM_RQST |
| Type | R            | R         | R         | R           |    |    |   |   | R         | R       |

**FM\_RQST** Frequency measurement procedure is requested

**FM\_CPL** Frequency measurement procedure is completed

**PAUSE\_RQST** Pause mode procedure is requested

**PAUSE\_INT** Asynchronous wake up from pause mode

**PAUSE\_CPL** Pause period is completed

**SETTLE\_CPL** Settling period is completed

**PAUSE\_ABORT** Pause mode is aborted because of the reception of interrupt prior to entering pause mode

#### TDMA +022Ch Slow clocking unit configuration register

SM\_CNF

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   | MSDC | RTC | EINT | KP  | SM  | FM |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|------|-----|------|-----|-----|----|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W | R/W  | R/W | R/W  | R/W | R/W |    |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0   | 0    | 0   | 0    | 1   | 1   |    |

**FM** Enable interrupt generation upon completion of frequency measurement procedure

**SM** Enable interrupt generation upon completion of pause mode procedure

**KP** Enable asynchronous wake-up from pause mode by key press

**EINT** Enable asynchronous wake-up from pause mode by external interrupt

**RTC** Enable asynchronous wake-up from pause mode by real time clock interrupt

**MSDC** Enable asynchronous wake-up from pause mode by memory card insertion interrupt

| Address | Type | Width  | Reset Value | Name          | Description                     |
|---------|------|--------|-------------|---------------|---------------------------------|
| +0200h  | R/W  | [2:0]  | —           | SM_PAUSE_M    | MSB of pause duration           |
| +0204h  | R/W  | [15:0] | —           | SM_PAUSE_L    | 16 LSB of pause duration        |
| +0208h  | R/W  | [13:0] | —           | SM_CLK_SETTLE | Off-chip VCXO settling duration |

|        |     |           |        |                  |                                          |
|--------|-----|-----------|--------|------------------|------------------------------------------|
| +020Ch | R   | [2:0]     | —      | SM_FINAL_PAUSE_M | MSB of final pause count                 |
| +0210h | R   | [15:0]    | —      | SM_FINAL_PAUSE_L | 16 LSB of final pause count              |
| +0214h | R   | [13:0]    | —      | SM_QBIT_START    | TQ_COUNT value at the start of the pause |
| +0218h | W   | [1:0]     | 0x0000 | SM_CON           | SM control register                      |
| +021Ch | R   | [7:3,1:0] | 0x0000 | SM_STA           | SM status register                       |
| +0220h | R/W | [15:0]    | —      | SM_FM_DURATION   | 32KHz measurement duration               |
| +0224h | R   | [9:0]     | —      | SM_FM_RESULT_M   | 10 MSB of frequency measurement result   |
| +0228h | R   | [15:0]    | —      | SM_FM_RESULT_L   | 16 LSB of frequency measurement result   |
| +022Ch | R/W | [4:0]     | 0x0000 | SM_CNF           | SM configuration register                |

## 10.2.2 Frequency Measurement



Figure 84 Block Diagram of Frequency Measurement Unit

The MCU writes into the SM\_FM\_DURATION register the number of clock cycles, during which the 32768 Hz clock will be measured. Then, the MCU sets the FM\_START bit in the SM\_CON register, the hardware sets the FM\_RQST flag and resets the FM\_CPL flag automatically, and the 32kHz and 13MHz counters are simultaneously started from zero.

When the 32kHz counter reaches the terminal value determined by the SM\_FM\_DURATION register, the current value of the 13MHz counter is stored in the SM\_FM\_RESULT register, the counters are stopped, the FM\_RQST is reset, and the FM\_CPL flag is set.

The SM\_FM\_DURATION is 16 bits wide, and the 32K counter counts  $2 \times (N + 1)$  cycles of 32768Hz. This gives a maximum of almost 4.00s measurement duration.

$$\text{Measured\_frequency} = \frac{2 \times (\text{SM\_FM\_DURATION} + 1) \times 13 \times 10^6}{\text{SM\_FM\_RESULT}}$$

## 10.2.3 Pause Mode Operation

The MCU writes the pause and settling time into the SM\_PAUSE\_M, SM\_PAUSE\_L and SM\_CLK\_SETTLE registers and the sum of the pause time and settling time must be as close as possible to the TDMA frame boundary, taking into account the frequency measurement result.

The MCU should set the PAUSE\_START bit ahead of the TDMA\_EVTVAL event. The hardware sets the PAUSE\_RQST flag and resets the PAUSE\_INT, PAUSE\_CPL, SETTLE\_CPL, PAUSE\_ABORT flags automatically, and the pause mode operation will be initiated at the next timer wrap position.

When the pause duration reaches the programmed terminal value or the asynchronous wake up event is received, the pause mode operation is ended/stopped/aborted and the corresponding flag is set (PAUSE\_CPL, PAUSE\_INT and PAUSE\_ABORT). Then, the MCU calculates the timing offset and adjusts the TDMA\_WRAPIMD position accordingly.

The number of quarter bit time elapsed during the pause operation is:

*Nb \_quarter \_bit = Kqbit × (SM \_FINAL \_PAUSE + SM \_CLK \_SETTLE) – Δqbit*

*Δqbit = TQ \_WRAP – SM \_QBIT \_START*

$$Kqbit = \frac{32k\_period\_duration}{quarter\_bit\_duration} = \frac{SM\_FM\_RESULT}{24 \times (SM\_FM\_DURATION + I)}$$

## 11 Power, Clocks and Reset

This chapter describes about the power, clock and reset management functions provided by MT6219. Together with Power Management IC (PMIC), MT6219 offers both fine and coarse resolutions of power control through software programming. With this efficient method, the developer can turn on selective resources accordingly in order to achieve optimized power consumption. The operating modes of MT6219 as well as main power states provided by the PMIC are shown in **Figure 85**.



**Figure 85** Major Phone Power States and Operating Modes for MT6219 based terminal

### 11.1 B2PSI

#### 11.1.1 General Description

MT6219 uses a 3-wire B2PSI interface to connect to PMIC. This bi-directional serial bus interface allows baseband to write to or read from PMIC. The bus protocol utilizes a 16 bit format. B2PSICK is the serial bus clock and is driven by the master. B2PSIDAT is the serial data; master or slave can drive it. B2PSICS is the bus selection signal. Once the B2PSICS goes low, baseband starts to transfer the 4 register bits followed by a read/write bit, then wait for 3 clocks for PMIC B2PSI state machine to decode the operation for the next succeeding 8 data bits. The state machine should count for 16 clocks to complete the data transfer.



**Figure 86** B2PSI bus timing

### 11.1.2 Register Definitions

#### B2PSI+0000h B2PSI data register

| Bit                      | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>B2PSI_DATA [15:0]</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| R/W                      |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 0                        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**B2PSI\_DATA** The B2PSI DATA format contains 4 bit register + 3 bit do not care + write / read bit + 8 bit data.

Write / read bit: 0 for read operation; 1 for write operation.

To prevent writing error, it needs to write B2PSI\_DATA = 'h8216 ahead of the real data write.

#### B2PSI+0008h B2PSI baud rate divider register

| Bit                     | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>B2PSI_DIV [15:0]</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| R/W                     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 0                       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**B2PSI\_DIV** B2PSI clock rate divisor. B2PSICK = system clock rate / div.

#### B2PSI+0010h B2PSI status register

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                       | 0                  |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-------------------------|--------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | <b>WRIT E SU CCES S</b> | <b>READ REA DT</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RC                      | RC                 |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0                       | 0                  |

**READ\_READY** Read data ready.

0 Read data isn't ready yet.

**1** Read data is ready. It will be cleared by reading B2PSI\_STAT register or if B2PSI initializes a new transmit.  
**WRITE\_SUCCESS** B2PSI write successfully.

**0** B2PSI write isn't finish yet.

**1** B2PSI write finish. It will be cleared by reading B2PSI\_STAT register or if B2PSI initializes a new transmit

### B2PSI+0014h B2PSI CS to CK time register

### B2PSI\_TIME

| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | B2PSI_TIME |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**B2PSI\_TIME** The time interval that first B2PSICK will be started after the B2PSICS is active low.

Time interval = 1/system clock \* B2PSI\_time.

## 11.2 Clocks

There are two major time bases in MT6219. The faster one is the 13 MHz clock originating from an off-chip temperature-compensated voltage controlled oscillator (TCVCXO) that can be either 13MHz or 26MHz. This signal is the input from the SYSCLK pad that is then converted to the square-wave signal by the clock squarer. The other time base is the 32768 Hz clock generated by an on-chip oscillator connected to an external crystal. **Figure 87** shows the clock sources as well as their utilizations inside the chip.



**Figure 87** Clock distributions inside the MT6219.

### 11.2.1 32.768 KHz Time Base

The 32768 Hz clock is always running. It's mainly used as the time base of the Real Time Clock (RTC) module, which maintains time and date with counters. Therefore, both the 32768Hz oscillator and the RTC module is powered by separate voltage supplies that shall not be powered down when the other power supplies do.

In low power mode, the 13 MHz time base is turned off, so the 32768 Hz clock shall be employed to update the critical TDMA timer and Watchdog Timer. This time base is also used to clock the keypad scanner logic.

### 11.2.2 13 MHz Time Base

Two 1/2-dividers, one for MCU Clock and the other for DSP Clock, exist to allow usage of either 26 or 13 MHz TCVCXO as clock input.

Three phase-locked loops (MPLL, DPLL and UPLL) are used to generate three primary clocks, *MCU\_CLOCK*, *DSP\_CLOCK* and *USB\_CLOCK*, and to clock modules in the MCU Clock Domain and DSP Clock Domain and USB, respectively. These PLLs require no off-chip components for operations and can be turned off independently in order to save power. After power-on, all the PLLs are off by default and the source clock signal is selected through multiplexers. The software shall take care of the PLL lock time while changing the clock selections. The PLLs and their usages are listed below.

**DPLL** provides the DSP system clock, *DSP\_CLOCK*. DPLL can be programmed to provide 1X to 6X output of the 13 MHz reference. The MCU software could set the clock multiplier according to the DSP performance requirement.

**MPLL** provides the MCU system clock, *MCU\_CLOCK*, which clocks the MCU core, MCU memory system, and MCU peripherals as well. MPLL has a programmable clock multiplier, which supports 2X and 4X clock multiplication. The MCU software could change the multiplier setting according to different workload conditions.

**UPLL** provides the USB clock, *USB\_CLOCK*. The UPLL input is a 4 MHz clock, which comes from 52 MHz clock generated by MPLL and then divided by 13. UPLL pumps the input clock source 12 times to generate 48 MHz for USB module.

Note that PLLs need some time to become stable after being powered up. The software shall take care of the PLL lock time before switching them to the proper frequency. Usually, a software loop longer than the PLL lock time is employed to deal with the problem.

For power management, the MCU software program may stop MCU Clock by setting the Sleep Control Register. Any interrupt requests to MCU can terminate the sleep mode, and thus returning MCU to the running mode.

AHB can also be stopped by setting the Sleep Control Register. However, the behavior of AHB in sleep mode is a little different from that of MCU. After entering Sleep Mode, it can be temporarily waken up by any “hreq” (bus request), and then goes back to sleep automatically after all “hreqs” de-assert. Therefore, any transactions can still take place as usual during AHB sleep mode, and power will be saved when there are no transactions. The penalty associated with this is that the system will lose some efficiency due to switching on and off of the bus clock, but this impact is small.

### 11.2.3 Register Definitions

#### CONFIG+0100h MPLL Frequency Register

**MPLL**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10   | 9   | 8   | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|-------|----|----|----|----|----|------|-----|-----|-----|---|---|---|---|---|---|-----|
| Name  |    |    |    |    |    | CALI |     | RST |     |   |   |   |   |   |   | SPD |
| Type  |    |    |    |    |    |      | R/W |     | R/W |   |   |   |   |   |   | R/W |
| Reset |    |    |    |    |    |      | 0   |     | 0   |   |   |   |   |   |   | 0   |

**SPD** Select the Output Clock Rate for MPLL

**00** power down

**01** 13MHz x 2

**10** Not used

**11** 13MHz x 4

**RST** Reset Control of MPLL

**0** Normal Operation

**1** Reset the MPLL

**CALI** Calibration Control for MPLL

### CONFIG+104h DPLL Frequency register

DPLL

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6   | 5 | 4 | 3 | 2 | 1 | 0   |
|-------|----|----|----|----|----|----|---|---|------|-----|---|---|---|---|---|-----|
| Name  |    |    |    |    |    |    |   |   | CALI | RST |   |   |   |   |   | SPD |
| Type  |    |    |    |    |    |    |   |   |      | R/W |   |   |   |   |   | R/W |
| Reset |    |    |    |    |    |    |   |   | 0    | 0   |   |   |   |   |   | 0   |

**SPD** Select the Output Clock Rate for DPLL

**000** power down

**001** 13MHz x 2

**010** 13MHz x 3

**011** 13MHz x 4

**100** 13MHz x 5

**101** 13MHz x 6

**RST** Reset Control of DPLL

**0** Normal Operation

**1** Reset the DPLL

**CALI** Calibration Control for DPLL

### CONFIG+110h DPLL Frequency register

UPLL

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6   | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|------|-----|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   | CALI | RST |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |      | R/W |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0    | 0   |   |   |   |   |   |   |

**RST** Reset Control of DPLL

**0** Normal Operation

**1** Reset the UPLL

**CALI** Calibration Control for UPLL

### CONFIG+108h Clock Control Register

CLK\_CON

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7        | 6        | 5        | 4           | 3        | 2    | 1    | 0        |
|-------|----|----|----|----|----|----|---|---|----------|----------|----------|-------------|----------|------|------|----------|
| Name  |    |    |    |    |    |    |   |   | UPLL_TMA | MPLL_TMA | DPLL_TMA | CLKS_Q_PL_D | MCU_DIV2 | DPLL | MPLL | DSP_DIV2 |
| Type  |    |    |    |    |    |    |   |   | R/W      | R/W      | R/W      | R/W         | R/W      | R/W  | R/W  | R/W      |
| Reset |    |    |    |    |    |    |   |   | 0        | 0        | 0        | 0           | 0        | 0    | 0    | 0        |

**DSP\_DIV2** Control the x2 clock divider for DPLL input

**0** Divider bypassed

**1** Divider not bypassed

**MPLL** Select MCU Clock

**0** MPLL bypassed  
**1** Using MPLL Clock

**DPLL** Select DSP Clock  
**0** DPLL bypassed  
**1** Using DPLL Clock

**MCU\_DIV2** Control the x2 clock divider for MCU clock domain

**0** Divider bypassed  
**1** Divider not bypassed

**CLKSQ\_PLD** Pull Down Control  
**0** Disable  
**1** Enables

**DPLL\_TMADPLL** test mode

**0** Disable  
**1** Enables

**MPLL\_TMA** MPLL test mode

**0** Disable  
**1** Enable

**UPLL\_TMA** UPLL test mode

**0** Disable  
**1** Enable

### CONFIG+10Ch Sleep Control Register

### SLEEP\_CON

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**MCU** Stop the MCU Clock to force MCU Processor to enter sleep mode. MCU clock will be resumed as long as there is an interrupt request or system is reset.

**0** MCU Clock is running  
**1** MCU Clock is stopped

**AHB** Stop the AHB Bus Clock to force the entire bus to enter sleep mode. AHB clock will be resumed as long as there is an interrupt request or system is reset.

**0** AHB Bus Clock is running  
**1** AHB Bus Clock is stopped

**DSP** Stop the DSP Clock.

**0** DSP Bus Clock is running  
**1** DSP Bus Clock is stopped

## 11.3 Reset Management

Figure 88 shows the reset scheme used in MT6219. There are three kinds of resets in the MT6219: hardware reset, watchdog reset, and software reset.



Figure 88 Reset Scheme Used in MT6219

### 11.3.1 General Description

#### 11.3.1.1 Hardware Reset

This reset is inputted through the SYSRST# pin, which shall be driven to low during power-on. The hardware reset has a global effect on the chip; it initializes all digital and analog circuits except the Real Time Clock module. The initial states of the MT6219 sub-blocks are listed below.

- All analog circuits are turned off.
- All PLLs are turned off and bypassed. The 13MHz system clock is the default time base.
- Special Trap States in GPIO

#### 11.3.1.2 Watchdog Reset

A watchdog reset is generated when the Watchdog Timer expires as the MCU software failed to re-program the timer counter in time. This situation is typically induced by abnormal software execution, which can be aborted by a hardwired watchdog reset. Hardware blocks that are affected by the watchdog reset are

- MCU subsystem
- DSP subsystem
- External Components (by software program)

#### 11.3.1.3 Software Resets

These are local reset signals that initialize specific hardware. For example, the MCU or DSP software may write to software reset trigger registers to reset hardware modules to their initial states, when hardware failures are detected.

The following modules have software resets.

- DSP Core

- DSP Coprocessors

### 11.3.2 Register Definitions

#### RGU +0000h Watchdog Timer Control register

| Bit   | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4            | 3   | 2     | 1      | 0      | WDT_MODE |
|-------|----------|----|----|----|----|----|---|---|---|---|---|--------------|-----|-------|--------|--------|----------|
| Name  | KEY[7:0] |    |    |    |    |    |   |   |   |   |   | AUTO-RESTART | IRQ | EXTEN | EXTPOL | ENABLE |          |
| Type  |          |    |    |    |    |    |   |   |   |   |   | R/W          | R/W | R/W   | R/W    | R/W    |          |
| Reset |          |    |    |    |    |    |   |   |   |   |   | 0            | 0   | 0     | 0      | 1      |          |

##### ENABLE

- 0 Disable Watchdog Timer  
1 Enable Watchdog Timer

##### EXTPOL

Define the polarity of the external watchdog pin

- 0 Active low  
1 Active high

##### EXTEN

- 0 The watchdog can not generate an external watchdog reset signal  
1 If the watchdog counter reaches zero, an external watchdog signal is generated

##### IRQ

issue interrupt instead of WDT reset. For debug purpose, RGU issues an interrupt to MCU instead of resetting system.

- 0 Disable  
1 Enable

##### AUTO-RESTART

Re-start watchdog timer counter with the value of WDT\_LENGTH while task ID is written into Software Debug Unit.

- 0 Disable. Counter re-starts by writing KEY into WDT\_RESTART register.  
1 Enable. Counter re-starts by writing KEY into WDT\_RESTART register or by writing task ID into software debug unit.

##### KEY

Write access is allowed if KEY=0x22

#### RGU +0004h Watchdog Time-Out Interval register

##### WDT\_LENGTH

| Bit   | 15             | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 | WDT_LENGTH |
|-------|----------------|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|------------|
| Name  | TIMEOUT[10:0]  |    |    |    |    |    |   |   | KEY[4:0] |   |   |   |   |   |   |   |            |
| Type  | WO             |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |            |
| Reset | 111_1111_1111b |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |            |

##### KEY

Write access is allowed if KEY=08h

##### TIMEOUT

The counter is restarted with {TIMEOUT [10:0], 1\_1111\_1111b}. So the Watchdog Timer time-out period is a multiple of  $512 \cdot T_{32k} = 15.6\text{ms}$

#### RGU +0008h Watchdog Timer Restart register

##### WDT\_RESTART

| Bit   | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | WDT_RESTART |
|-------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|-------------|
| Name  | KEY[15:0] |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |             |
| Type  |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |             |
| Reset |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |             |

**KEY** Restart the counter if KEY=1971h

### RGU +000Ch Watchdog Timer Status register

**WDT\_STA**

| Bit   | 15  | 14     | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----|--------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | WDT | SW_WDT |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RO  | RO     |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0   | 0      |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

#### WDT

- 0 Reset not due to Watchdog Timer
- 1 Reset due to that Watchdog Timer time-out period is reached

#### SW\_WDT

- 0 Reset not due to Software-triggered Watchdog Timer
- 1 Reset due to Software-triggered Watchdog Timer

**NOTE:** The system reset does not affect this register. This bit is cleared when the bit ENABLE of WTU\_MODE register is written.

### RGU +0010h CPU Peripheral Software Reset Register

**SW\_PERIPH\_RS TN**

| Bit   | 15 | 14      | 13      | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|-------|----|---------|---------|----|----|----|---|---|---|---|---|---|---|---|---|-----|
| Name  |    | DAMR ST | USBR ST |    |    |    |   |   |   |   |   |   |   |   |   | KEY |
| Type  |    | R/W     | R/W     |    |    |    |   |   |   |   |   |   |   |   |   |     |
| Reset | 0  | 0       |         |    |    |    |   |   |   |   |   |   |   |   |   |     |

**KEY** Write access is allowed if KEY=0x37

**DMARST** Reset the DMA peripheral

- 0: No Reset
- 1: Reset Activated

**USBRST** Reset USB

- 0 No Reset
- 1 Reset Activated

### RGU +0014h DSP Software Reset Register

**SW\_DSP\_RSTN**

| Bit   | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | RST |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R/W |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

**RST** Controls the DSP System Reset Control

- 0: No reset
- 1: Reset activate

### RGU +0018h Watchdog Timer Reset Signal Duration register

**WDT\_RSTINTRE VAL**

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0            |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------------|
| Name |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | LENGTH[11:0] |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W          |

|       |       |
|-------|-------|
| Reset | FFFFh |
|-------|-------|

**LENGTH** This register indicates the reset duration when watchdog timer timeout. However, if bit IRQ in WDT\_MODE register is set to “1”, an interrupt will issue instead of a reset.

### RGU+001Ch Watchdog Timer Software Reset Register

WDT\_SWRST

| Bit   | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | KEY[15:0] |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset |           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

Software-triggered watchdog timer reset. If the register content matches the KEY, a watchdog reset is issued. However, if bit IRQ in WDT\_MODE register is set to “1”, an interrupt will issue instead of a reset.

**KEY** 1209h

## 11.4 Software Power Down Control

In addition to Pause Mode capability during Standby State, the software program can also put each peripheral independently into Power Down Mode during Active State by gating off their clock. The typical logic implementation is depicted as in **Figure 89**. For all of the configuration bits, 1 means that the function is in Power Down Mode and 0 means that it is in the Active Mode.



Figure 89 Power Down Control at Block Level

### 11.4.1 Register Definitions

#### CONFIG+300h Power Down Control 0 Register

PDN\_CON0

| Bit   | 15       | 14   | 13   | 12       | 11     | 10   | 9 | 8 | 7 | 6 | 5 | 4 | 3          | 2   | 1   | 0   |     |
|-------|----------|------|------|----------|--------|------|---|---|---|---|---|---|------------|-----|-----|-----|-----|
| Name  | DSP_DIV2 | MPLL | DPLL | MCU_DIV2 | CLKS_Q | UPLL |   |   |   |   |   |   | WAVE_TABLE |     | GCU | USB | DMA |
| Type  | R/W      | R/W  | R/W  | R/W      | R/W    | R/W  |   |   |   |   |   |   | R/W        | R/W | R/W | R/W |     |
| Reset | 1        | 1    | 1    | 1        | 0      | 1    |   |   |   |   |   |   | 1          | 1   | 1   | 1   |     |

**DMA** Controls the DMA Controller Power Down

**USB** Controls the USB Controller Power Down

**GCU** Controls the GCU Controller Power Down

**WAVETABLE** Controls the DSP WaveTable DMA Power Down

**JPEG** Controls the JPEG Decoder Power Down

**RESZ** Controls the Image Resizer Power Down

**CLKSQ** Controls the Clock squarer Power Down

**MCU\_DIV2** Controls the MUC DIV2 Power Down

**DPLL** Controls the DPLL Power Down

**MPLL** Controls the MPLL Power Down

**DSP\_DIV2** Controls the DSP DIV2 Power Down

### CONFIG +304h Power Down Control 1 Register

| Bit   | 15   | 14     | 13    | 12  | 11  | 10   | 9    | 8      | 7   | 6     | 5   | 4   | 3      | 2    | 1   | 0   | PDN_CON1 |
|-------|------|--------|-------|-----|-----|------|------|--------|-----|-------|-----|-----|--------|------|-----|-----|----------|
| Name  | IRDA | UART 3 | B2PSI | NFI | TRC | PWM2 | MSDC | UART 2 | LCD | ALTER | PWM | SIM | UART 1 | GPIO | KP  | GPT |          |
| Type  | R/W  | R/W    | R/W   | R/W | R/W | R/W  | R/W  | R/W    | R/W | R/W   | R/W | R/W | R/W    | R/W  | R/W | R/W |          |
| Reset | 1    | 1      | 1     | 1   | 1   | 1    | 1    | 1      | 1   | 1     | 1   | 1   | 0      | 1    | 1   | 1   |          |

**GPT** Controls the General Purpose Timer Power Down

**KP** Controls the Keypad Scanner Power Down

**GPIO** Controls the GPIO Power Down

**UART1** Controls the UART1 Controller Power Down

**SIM** Controls the SIM Controller Power Down

**PWM** Controls the PWM Generator Power Down

**ALTER** Controls the Alerter Generator Power Down

**LCD** Controls the Serial LCD Controller Power Down

**UART2** Controls the UART2 Controller Power Down

**MSDC** Controls the MS/SD Controller Power Down

**PWM2** Controls the PWM2 Generator Power Down

**TRC** Controls the MCU Tracer Power Down

**NFI** Controls the NAND FLASH Interface Power Down

**B2PSI** Controls the Serial Port Interface Power Down

**UART3** Controls the UART3 Controller Power Down

**IRDA** Controls the IrDA Framer Power Down

### CONFIG +308h Power Down Control 2 Register

| Bit   | 15   | 14   | 13   | 12   | 11  | 10  | 9   | 8    | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0    | PDN_CON2 |
|-------|------|------|------|------|-----|-----|-----|------|-------|-----|-----|-----|-----|-----|-----|------|----------|
| Name  | GMSK | BBRX | SCCB | AAFE | DIV | GCC | BFE | VAFE | AUXAD | FCS | APC | AFC | BPI | BSI | RTC | TDMA |          |
| Type  | R/W  | R/W  | R/W  | R/W  | R/W | R/W | R/W | R/W  | R/W   | R/W | R/W | R/W | R/W | R/W | R/W | R/W  |          |
| Reset | 1    | 1    | 1    | 1    | 1   | 1   | 1   | 1    | 1     | 1   | 1   | 1   | 1   | 1   | 1   | 1    |          |

**TDMA** Controls the TDMA Power Down

**RTC** Controls the RTC Power Down

**BSI** Controls the BSI Power Down. This control will not be updated until both tdma\_evtval and qbit\_en are asserted.

**BPI** Controls the BPI Power Down. This control will not be updated until both tdma\_evtval and qbit\_en are asserted.

**AFC** Controls the AFC Power Down. This control will not be updated until both tdma\_evtval and qbit\_en are asserted.

**APC** Controls the APC Power Down. This control will not be updated until both tdma\_evtval and qbit\_en are asserted.

**FCS** Controls the FCS Power Down

**AUXAD** Controls the AUX ADC Power Down

**VAFE** Controls the Audio Front End of VBI Power Down

**BFE** Controls the Base-Band Front End Power Down

**GCU** Controls the GCU Power Down

- DIV** Controls the Divider Power Down  
**AAFE** Controls the Audio Front End of MP3 Power Down  
**SCCB** Controls the SCCB Power Down  
**BBRX** Controls the BB RX Power Down  
**GMSK** Controls the GMSK Power Down

### CONFIG +30Ch Power Down Control 3 Register

**PDN\_CON3**

| Bit   | 15  | 14            | 13         | 12         | 11          | 10          | 9          | 8          | 7           | 6          | 5 | 4              | 3 | 2 | 1 | 0          |
|-------|-----|---------------|------------|------------|-------------|-------------|------------|------------|-------------|------------|---|----------------|---|---|---|------------|
| Name  |     | <b>IMGDMA</b> | <b>DCT</b> | <b>ISP</b> | <b>RESZ</b> | <b>JPEG</b> | <b>MP4</b> | <b>G2D</b> | <b>GCMQ</b> | <b>GIF</b> |   | <b>IMGPROC</b> |   |   |   | <b>ICE</b> |
| Type  | R/W | R/W           | R/W        | R/W        | R/W         | R/W         | R/W        | R/W        | R/W         | R/W        |   | R/W            |   |   |   | R/W        |
| Reset | 1   | 1             | 1          | 1          | 1           | 1           | 1          | 1          | 1           | 1          |   | 1              |   |   |   | 1          |

**ICE** Enables the debug feature of the ARM7EJS core. It controls the DBGEN pin of the ICEBreaker.

**IMGPROC** Controls the Image Processor Power Down

**GIF** Controls the GIF Decoder Power Down

**GCMQ** Controls the Graphic Command Queue Power Down

**G2D** Controls the 2D Accelerator Power Down

**MP4** Controls the MPEG-4 Power Down

**JPEG** Controls the JPEG Power Down

**RESZ** Controls the Resizer Power Down

**ISP** Controls the Image Signal Processor Power Down

**DCT** Controls the DCT Power Down

**IMGDMA** Controls the Image DMA Power Down

### CONFIG+0310h Power Down Set 0 Register

**PDN\_SET0**

| Bit  | 15              | 14          | 13          | 12              | 11            | 10          | 9   | 8   | 7   | 6   | 5   | 4   | 3                 | 2   | 1          | 0          |            |
|------|-----------------|-------------|-------------|-----------------|---------------|-------------|-----|-----|-----|-----|-----|-----|-------------------|-----|------------|------------|------------|
| Name | <b>DSP_DIV2</b> | <b>MPLL</b> | <b>DPLL</b> | <b>MCU_DIV2</b> | <b>CLKS_Q</b> | <b>UPLL</b> |     |     |     |     |     |     | <b>WAVE_TABLE</b> |     | <b>GCU</b> | <b>USB</b> | <b>DMA</b> |
| Type | W1S             | W1S         | W1S         | W1S             | W1S           | W1S         | W1S | W1S | W1S | W1S | W1S | W1S | W1S               | W1S | W1S        | W1S        |            |

### CONFIG+0314h Power Down Set 1 Register

**PDN\_SET1**

| Bit  | 15          | 14           | 13           | 12         | 11         | 10          | 9           | 8            | 7          | 6            | 5          | 4          | 3            | 2           | 1         | 0          |
|------|-------------|--------------|--------------|------------|------------|-------------|-------------|--------------|------------|--------------|------------|------------|--------------|-------------|-----------|------------|
| Name | <b>IRDA</b> | <b>UART3</b> | <b>B2PSI</b> | <b>NFI</b> | <b>TRC</b> | <b>PWM2</b> | <b>MSDC</b> | <b>UART2</b> | <b>LCD</b> | <b>ALTER</b> | <b>PWM</b> | <b>SIM</b> | <b>UART1</b> | <b>GPIO</b> | <b>KP</b> | <b>GPT</b> |
| Type | W1S         | W1S          | W1S          | W1S        | W1S        | W1S         | W1S         | W1S          | W1S        | W1S          | W1S        | W1S        | W1S          | W1S         | W1S       | W1S        |

### CONFIG+0318h Power Down Set 2 Register

**PDN\_SET2**

| Bit  | 15          | 14          | 13          | 12          | 11         | 10         | 9          | 8           | 7            | 6          | 5          | 4          | 3          | 2          | 1          | 0           |
|------|-------------|-------------|-------------|-------------|------------|------------|------------|-------------|--------------|------------|------------|------------|------------|------------|------------|-------------|
| Name | <b>GMSK</b> | <b>BBRX</b> | <b>SCCB</b> | <b>AAFE</b> | <b>DIV</b> | <b>GCC</b> | <b>BFE</b> | <b>VAFE</b> | <b>AUXAD</b> | <b>FCS</b> | <b>APC</b> | <b>AFC</b> | <b>BPI</b> | <b>BSI</b> | <b>RTC</b> | <b>TDMA</b> |
| Type | W1S         | W1S         | W1S         | W1S         | W1S        | W1S        | W1S        | W1S         | W1S          | W1S        | W1S        | W1S        | W1S        | W1S        | W1S        | W1S         |

### CONFIG+031C Power Down Set 3 Register

**PDN\_SET3**

| Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Name |     | IMGD MA | DCT | CAM | RESZ | JPEG | MP4 | G2D | GCMQ | GIFDE C |  | IMGP ROC |     |     |     | ICE |
|------|-----|---------|-----|-----|------|------|-----|-----|------|---------|--|----------|-----|-----|-----|-----|
| Type | W1S | W1S     | W1S | W1S | W1S  | W1S  | W1S | W1S | W1S  | W1S     |  | W1S      | W1S | W1S | W1S | W1S |

These registers are used to individually set power down control bit. Only the bits set to 1 are in effect. Setting the bits to 1 also sets the corresponding power down control bits will to 1. Otherwise, the bits keep their original value.

**EACH BIT** Set the Associated Power Down Control Bit to 1.

0 no effect

1 Set corresponding bit to 1

### CONFIG+0320h Power Down Clear 0 Register

PDN\_CLR0

| Bit  | 15       | 14   | 13   | 12       | 11     | 10   | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2           | 1   | 0   |     |
|------|----------|------|------|----------|--------|------|-----|-----|-----|-----|-----|-----|-----|-------------|-----|-----|-----|
| Name | DSP DIV2 | MPLL | DPLL | MCU DIV2 | CLKS Q | UPLL |     |     |     |     |     |     |     | WAVE TABL E | GCU | USB | DMA |
| Type | W1C      | W1C  | W1C  | W1C      | W1C    | W1C  | W1C | W1C | W1C | W1C | W1C | W1C | W1C | W1C         | W1C | W1C |     |

### CONFIG+0324h Power Down Clear 1 Register

PDN\_CLR1

| Bit  | 15   | 14     | 13    | 12  | 11  | 10   | 9    | 8      | 7   | 6      | 5    | 4   | 3      | 2    | 1   | 0   |
|------|------|--------|-------|-----|-----|------|------|--------|-----|--------|------|-----|--------|------|-----|-----|
| Name | IRDA | UART 3 | B2PSI | NFI | TRC | PWM2 | MSDC | UART 2 | LCD | ALTE R | PWM1 | SIM | UART 1 | GPIO | KP  | GPT |
| Type | W1C  | W1C    | W1C   | W1C | W1C | W1C  | W1C  | W1C    | W1C | W1C    | W1C  | W1C | W1C    | W1C  | W1C | W1C |

### CONFIG+0328h Power Down Clear 2 Register

PDN\_CLR2

| Bit  | 15   | 14   | 13   | 12   | 11  | 10  | 9   | 8    | 7      | 6   | 5   | 4   | 3   | 2   | 1   | 0    |
|------|------|------|------|------|-----|-----|-----|------|--------|-----|-----|-----|-----|-----|-----|------|
| Name | GMSK | BBRX | SCCB | AAFE | DIV | GCC | BFE | VAFE | AUXA D | FCS | APC | AFC | BPI | BSI | RTC | TDMA |
| Type | W1C  | W1C  | W1C  | W1C  | W1C | W1C | W1C | W1C  | W1C    | W1C | W1C | W1C | W1C | W1C | W1C | W1C  |

These registers are used to individually clear power down control bit. Only the bits set to 1 are in effect. Setting the bits to 1 also sets the corresponding power down control bits to 0. Otherwise, the bits keep their original value.

**EACH BIT** Clear the Associated Power Down Control Bit.

0 no effect

1 Set corresponding bit to 0

## 12 Analog Front-end Interface

### 12.1 General Description

To communicate with analog front-end, a common control interface for all analog blocks is implemented. In addition, there are some dedicated interfaces for data transfer. The common control interface translates APB bus write and read cycle for specific addresses related to analog front-end control. During writing or reading of any of these control registers, there is a latency associated with transferring of data to or from the analog front-end. Dedicated data interface of each analog block is implemented in the corresponding digital block.

### 12.2 Register Definitions

**MIXED+0000h Analog Front-end Driving Strength Control Register** **AC\_ODS\_CON**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2   | 1   | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|-----|-----|-----|-----|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   | AUX | ERX | VTX | CCI |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | R/W | R/W | R/W | R/W |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 0   | 0   | 0   | 0   |   |

Set this register for timing critical round trip path

**AUX** AUX ADC output pins

**ERX** EDGE RX output pins

**VTX** VBI TX output pins

**CCI** Common Control Interfaces output pins

#### 12.2.1.1 Voice Front-end

MCU APB bus registers for speech are listed as followings.

**MIXED+0100h AFE Voice Analog Gain Control Register** **AFE\_VAG\_CON**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8 | 7 | 6     | 5 | 4 | 3     | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|------|---|---|-------|---|---|-------|---|---|---|
| Name  |    |    |    |    |    |    | VUPG |   |   | VDPG0 |   |   | VDPG1 |   |   |   |
| Type  |    |    |    |    |    |    | R/W  |   |   | R/W   |   |   | R/W   |   |   |   |
| Reset |    |    |    |    |    |    | 0000 |   |   | 0000  |   |   | 0000  |   |   |   |

Set this register for analog PGA gains. VUPG is set for microphone input volume control. And VDPG0 and VDPG1 are set for two output volume controls

**VUPG** voice-band up-link PGA gain control bits

| VCFG [2] = '0' |       | VCFG [2] = '1' |       |
|----------------|-------|----------------|-------|
| VUPG [4:0]     | Gain  | VUPG [4:0]     | Gain  |
| 11111          | 42 dB | XX111          | -21dB |
| 11110          | 40 dB | XX110          | -18dB |
| 11101          | 38 dB | XX101          | -15dB |
| 11100          | 36 dB | XX100          | -12dB |

|       |        |       |      |
|-------|--------|-------|------|
| 11011 | 34 dB  | XX011 | -9dB |
| 11010 | 32 dB  | XX010 | -6dB |
| 11001 | 30 dB  | XX001 | -3dB |
| 11000 | 28 dB  | XX000 | 0dB  |
| 10111 | 26 dB  |       |      |
| 10110 | 24 dB  |       |      |
| 10101 | 22 dB  |       |      |
| 10100 | 20 dB  |       |      |
| 10011 | 18 dB  |       |      |
| 10010 | 16 dB  |       |      |
| 10001 | 14 dB  |       |      |
| 10000 | 12 dB  |       |      |
| 01111 | 10 dB  |       |      |
| 01110 | 8 dB   |       |      |
| 01101 | 6 dB   |       |      |
| 01100 | 4 dB   |       |      |
| 01011 | 2 dB   |       |      |
| 01010 | 0 dB   |       |      |
| 01001 | -2 dB  |       |      |
| 01000 | -4 dB  |       |      |
| 00111 | -6 dB  |       |      |
| 00110 | -8 dB  |       |      |
| 00101 | -10 dB |       |      |
| 00100 | -12 dB |       |      |
| 00011 | -14 dB |       |      |
| 00010 | -16 dB |       |      |
| 00001 | -18 dB |       |      |
| 00000 | -20 dB |       |      |

**VDPG0** voice-band down-link PGA0 gain control bits

**VDPG1** voice-band down-link PGA1 gain control bits

| VDPG0 [3:0] / VDPG1 [3:0] | Gain |
|---------------------------|------|
| 1111                      | 8dB  |
| 1110                      | 6dB  |
| 1101                      | 4dB  |
| 1100                      | 2dB  |
| 1011                      | 0dB  |
| 1010                      | -2dB |
| 1001                      | -4dB |
| 1000                      | -6dB |

|      |       |
|------|-------|
| 0111 | -8dB  |
| 0110 | -10dB |
| 0101 | -12dB |
| 0100 | -14dB |
| 0011 | -16dB |
| 0010 | -18dB |
| 0001 | -20dB |
| 0000 | -22dB |

**MIXED+0104h AFE Voice Analog-Circuit Control Register 0 AFE\_VAC\_CON0**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8 | 7      | 6 | 5 | 4     | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|------|---|--------|---|---|-------|---|---|---|---|
| Name  |    |    |    |    |    |    | VCFG |   | VDSEND |   |   | VCALI |   |   |   |   |
| Type  |    |    |    |    |    |    | R/W  |   | R/W    |   |   | R/W   |   |   |   |   |
| Reset |    |    |    |    |    |    | 0000 |   | 00     |   |   | 00000 |   |   |   |   |

Set this register for analog circuit configuration controls.

**VCFG[3]** microphone biasing control

- 0** differential biasing
- 1** single-ended biasing

**VCFG[2]** gain mode control

- 0** amplification
- 1** attenuation

**VCFG[1]** coupling control

- 0** AC
- 1** DC

**VCFG[0]** input select control

- 0** input 0
- 1** input 1

**VDSEND[1]** single-ended configuration control for out1

**VDSEND[0]** single-ended configuration control for out0

**VCALI** biasing current control, in 2's complement format

**MIXED+0108h AFE Voice Analog-Circuit Control Register 1 AFE\_VAC\_CON1**

| Bit   | 15 | 14 | 13 | 12 | 11       | 10           | 9       | 8       | 7       | 6         | 5 | 4        | 3 | 2            | 1            | 0   |
|-------|----|----|----|----|----------|--------------|---------|---------|---------|-----------|---|----------|---|--------------|--------------|-----|
| Name  |    |    |    |    | VBG_CTRL | VPDN_CHP_UMP | VFLO_AT | VRSD_ON | VRES_SW | VBUF_0SEL |   | VBUF1SEL |   | VADC_INMO_DE | VDAC_INMO_DE |     |
| Type  |    |    |    |    | R/W      | R/W          | R/W     | R/W     | R/W     | R/W       |   | R/W      |   | R/W          | R/W          | R/W |
| Reset |    |    |    |    | 000      | 0            | 0       | 0       | 0       | 0         |   | 000      |   | 0            | 0            |     |

Set this register for analog circuit configuration controls. There are several loop back modes and test modes implemented for test purposes. Suggested value is 0084h.

**VBG\_CTRL** voice-band band-gap control

**VPDN\_CHPUMP** voice-band charge pump power down

- 0**: power down (normal operating mode)

**1:** charge pump on (for fab. process)

**VFLOAT** voice-band output driver float

**0:** normal operating mode

**1:** float mode

**VRSDON** voice-band redundant signed digit function on

**0:** 1-bit 2-level mode

**1:** 2-bit 3-level mode

**VRESSW** voice-band output buffer 1 output DC voltage control.

**VBUF0SEL** voice buffer 0 input selection (reserved.)

**VBUF1SEL** voice buffer 1 input selection

**001:** voice DAC output

**010:** external FM radio input

**100:** audio DAC output

**OTHERS:** reserved.

**VADCINMODE** Voice-band ADC output mode.

**0:** normal operating mode

**1:** the ADC input from the DAC output

**VDACINMODE** Voice-band DAC input mode.

**0:** normal operating mode

**1:** the DAC input from the ADC output

### MIXED+010Ch AFE Voice Analog Power Down Control Register

**AFE\_VAPDN\_C  
ON**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5                | 4               | 3               | 2               | 1                | 0                |
|-------|----|----|----|----|----|----|---|---|---|---|------------------|-----------------|-----------------|-----------------|------------------|------------------|
| Name  |    |    |    |    |    |    |   |   |   |   | <b>VPDN_BIAS</b> | <b>VPDN_LNA</b> | <b>VPDN_ADC</b> | <b>VPDN_DAC</b> | <b>VPDN_OUT1</b> | <b>VPDN_OUT0</b> |
| Type  |    |    |    |    |    |    |   |   |   |   | R/W              | R/W             | R/W             | R/W             | R/W              | R/W              |
| Reset |    |    |    |    |    |    |   |   |   |   | 0                | 0               | 0               | 0               | 0                | 0                |

Set this register to power up analog blocks. 0: power down, 1: power up.

**VPDN\_BIAS** bias block

**VPDN\_LNA** low noise amplifier block

**VPDN\_ADC** ADC block

**VPDN\_DAC** DAC block

**VPDN\_OUT1** OUT1 buffer block

**VPDN\_OUT0** OUT0 buffer block

### MIXED+0110h AFE Voice AGC Control Register

**AFE\_VAGC\_CO  
N**

| Bit   | 15 | 14 | 13             | 12                  | 11                  | 10 | 9 | 8                | 7                | 6               | 5               | 4               | 3            | 2   | 1   | 0 |
|-------|----|----|----------------|---------------------|---------------------|----|---|------------------|------------------|-----------------|-----------------|-----------------|--------------|-----|-----|---|
| Name  |    |    | <b>AGCTEST</b> | <b>RELNOIDURSEL</b> | <b>RELNOILEVSEL</b> |    |   | <b>FRELCKSEL</b> | <b>SRELCKSEL</b> | <b>ATTHDCAL</b> | <b>ATTCKSEL</b> | <b>HYSTEREN</b> | <b>AGCEN</b> |     |     |   |
| Type  |    |    | R/W            | R/W                 | R/W                 |    |   | R/W              | R/W              | R/W             | R/W             | R/W             | R/W          | R/W | R/W |   |
| Reset |    |    | 0              | 00                  | 00                  |    |   | 00               | 00               | 00              | 00              | 0               | 0            | 0   | 0   |   |

Set this register for analog circuit configuration controls. There are several loop back modes and test modes implemented for test purposes. Suggested value is 0dcfh.

**AGCEN** AGC function enable

**HYSSTEREN** AGC hysteresis function enable

**ATTCKSEL** attack clock selection

**0:** 16 KHz

**1:** 32 KHz

**ATTHDCAL** attack threshold calibration

**SRELCKSEL** release slow clock selection

**00:** 1000/512 Hz

**01:** 1000/256 Hz

**10:** 1000/128 Hz

**11:** 1000/64 Hz

**FRELCKSEL** release fast clock selection

**00:** 1000/64 Hz

**01:** 1000/32 Hz

**10:** 1000/16 Hz

**11:** 1000/8 Hz

**RELNOILEVSEL** release noise level selection

**00:** -8 dB

**01:** -14 dB

**10:** -20 dB

**11:** -26 dB

**RELNOIDURSEL** release noise duration selection

**00:** 64 ms

**01:** 32 ms

**10:** 16 ms

**11:** 8 ms, 32768/4096

### 12.2.1.2 Audio Front-end

MCU APB bus registers for audio are listed as followings.

**MIXED+0200h AFE Audio Analog Gain Control Register** **AFE\_AAG\_CON**

| Bit   | 15 | 14 | 13 | 12 | 11            | 10            | 9   | 8 | 7    | 6 | 5           | 4 | 3    | 2 | 1           | 0 |  |  |
|-------|----|----|----|----|---------------|---------------|-----|---|------|---|-------------|---|------|---|-------------|---|--|--|
| Name  |    |    |    |    | <b>AMUTER</b> | <b>AMUTEL</b> |     |   |      |   | <b>APGR</b> |   |      |   | <b>APGL</b> |   |  |  |
| Type  |    |    |    |    | R/W           |               | R/W |   | R/W  |   |             |   | R/W  |   |             |   |  |  |
| Reset |    |    |    |    | 0             |               | 0   |   | 0000 |   |             |   | 0000 |   |             |   |  |  |

Set this register for analog PGA gains.

**AMUTER** audio PGA L-channel mute control

**AMUTEL** audio PGA R-channel mute control

**APGR** audio PGA R-channel gain control

**APGL**

audio PGA L-channel gain control

| <b>APGR [3:0] / APGL [3:0]</b> | <b>Gain</b> |
|--------------------------------|-------------|
| 1111                           | 23dB        |
| 1110                           | 20dB        |
| 1101                           | 17dB        |
| 1100                           | 14dB        |
| 1011                           | 13dB        |
| 1010                           | 8dB         |
| 1001                           | 5dB         |
| 1000                           | 2dB         |
| 0111                           | -1dB        |
| 0110                           | -4dB        |
| 0101                           | -7dB        |
| 0100                           | -10dB       |
| 0011                           | -13dB       |
| 0010                           | -16dB       |
| 0001                           | -19dB       |
| 0000                           | -22dB       |

### **MIXED+0204h AFE Audio Analog-Circuit Control Register      AFE\_AAC\_CON**

| Bit   | 15 | 14 | 13 | 12           | 11              | 10              | 9 | 8 | 7 | 6 | 5 | 4 | 3            | 2 | 1 | 0 |
|-------|----|----|----|--------------|-----------------|-----------------|---|---|---|---|---|---|--------------|---|---|---|
| Name  |    |    |    | <b>ARCON</b> | <b>ABUFSELR</b> | <b>ABUFSELL</b> |   |   |   |   |   |   | <b>ACALI</b> |   |   |   |
| Type  |    |    |    | R/W          | R/W             | R/W             |   |   |   |   |   |   | R/W          |   |   |   |
| Reset |    |    |    | 0            | 000             | 000             |   |   |   |   |   |   | 00000        |   |   |   |

Set this register for analog circuit configuration controls.

**ARCON**      audio external RC control

**ABUFSELR**      audio buffer R-channel input selection

- 000:** audio DAC R/L-channel output; stereo to mono
- 001:** audio DAC R-channel output
- 010:** voice DAC output
- 100:** external FM R/L-channel radio output, stereo to mono
- 101:** external FM R-channel radio output

**OTHERS:** reserved.

**ABUFSELL** audio buffer L-channel input selection

- 000:** audio DAC R/L-channel output; stereo to mono
- 001:** audio DAC L-channel output
- 010:** voice DAC output
- 100:** external FM R/L-channel radio output, stereo to mono
- 101:** external FM L-channel radio output

**OTHERS:** reserved.

**ACALI**      audio bias current control, in 2's complement format

**MIXED+0208h AFE Audio Analog Power Down Control Register**
**AFE\_AAPDN\_C  
ON**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4                | 3                 | 2                 | 1                 | 0                 |
|-------|----|----|----|----|----|----|---|---|---|---|---|------------------|-------------------|-------------------|-------------------|-------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   | <b>APDN_BIAS</b> | <b>APDN_DAC_R</b> | <b>APDN_DAC_L</b> | <b>APDN_OUT_R</b> | <b>APDN_OUT_L</b> |
| Type  |    |    |    |    |    |    |   |   |   |   |   | R/W              | R/W               | R/W               | R/W               | R/W               |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 000000           | 0                 | 0                 | 0                 | 0                 |

Set this register to power up analog blocks. 0: power down, 1: power up. Suggested value is 00ffh.

**ACNR** audio click noise reduction

**APDN\_BIAS** BIAS block

**APDN\_DACR** R-channel DAC block

**APDN\_DACL** L-channel DAC block

**APDN\_OUTR** R-channel OUT buffer block

**APDN\_OUTL** L-channel OUT buffer block

### 12.2.1.3 BB RX

MCU APB bus registers for BBRX ADC are listed as followings.

**MIXED+0300h BBRX ADC Analog-Circuit Control Register**
**BBRX\_AC\_CON**

| Bit   | 15 | 14 | 13 | 12 | 11          | 10          | 9          | 8              | 7           | 6 | 5 | 4 | 3 | 2 | 1 | 0              |
|-------|----|----|----|----|-------------|-------------|------------|----------------|-------------|---|---|---|---|---|---|----------------|
| Name  |    |    |    |    | <b>QSEL</b> | <b>ISEL</b> | <b>RSV</b> | <b>PDNC_HP</b> | <b>GAIN</b> |   |   |   |   |   |   | <b>CALBIAS</b> |
| Type  |    |    |    |    | R/W         | R/W         | R/W        | R/W            | R/W         |   |   |   |   |   |   | R/W            |
| Reset |    |    |    |    | 00          | 00          | 0          | 0              | 0           |   |   |   |   |   |   | 00000          |

Set this register for analog circuit configuration controls.

**CALBIAS** The register field is for control of biasing current in BBRX mixed-signal module. It is coded in 2's complement.

That is, its maximum is 15 and minimum is -16. Biasing current in BBRX mixed-signal module has impact on the performance of A/D conversion. The larger the value of the register field, the larger the biasing current in BBRX mixed-signal module, and the larger the SNR.

**GAIN** The register bit is for configuration of gain control of analog inputs in GSM RX mixed-signal module. When the bit is set to 1, gain control for analog inputs will be turned on and thus GSM RX mixed-signal module can provide higher resolutions. When the bit is set to 0, gain control for analog inputs will be turned off and thus GSM RX mixed-signal module can only provide lower resolutions.

**0** Gain control for analog inputs in GSM RX mixed-signal module will be turned off.

**1** Gain control for analog inputs in GSM RX mixed-signal module will be turned on.

**PDNCHP** Power down control for charge pumping of GSM RX ADC.

**0** Power down charge pumping of GSM RX ADC.

**1** Power up charge pumping of GSM RX ADC.

**ISEL** Loopback configuration selection for I-channel in BBRX mixed-signal module

**00** Normal mode

**01** Loopback TX analog I

**10** Loopback TX analog Q

**11** Select the grounded input

**QSEL** Loopback configuration selection for Q-channel in BBRX mixed-signal module

**00** Normal mode

**01** Loopback TX analog Q

**10** Loopback TX analog I

**11** Select the grounded input

#### 12.2.1.4 BB TX

MCU APB bus registers for BBTX DAC are listed as followings.

**MIXED+0400h BBTX DAC Analog-Circuit Control Register 0** BBTX\_AC\_CON  
0

| Bit   | 15                | 14                 | 13          | 12 | 11              | 10 | 9 | 8            | 7 | 6 | 5            | 4 | 3 | 2 | 1 | 0 |
|-------|-------------------|--------------------|-------------|----|-----------------|----|---|--------------|---|---|--------------|---|---|---|---|---|
| Name  | CALR<br>CDON<br>E | STAR<br>TCAL<br>RC | <b>GAIN</b> |    | <b>CALRCSEL</b> |    |   | <b>TRIMI</b> |   |   | <b>TRIMQ</b> |   |   |   |   |   |
| Type  | R                 | R/W                | R/W         |    | R/W             |    |   | R/W          |   |   | R/W          |   |   |   |   |   |
| Reset | 0                 | 0                  | 000         |    | 000             |    |   | 0000         |   |   | 0000         |   |   |   |   |   |

Set this register for analog circuit configuration controls. The procedure to perform calibration processing for smoothing filter in BBTX mixed-signal module is as follows:

7. Write 1 to the register bit CARLC in the register TX\_CON of Baseband Front End in order to activate clock required for calibration process. Initiate calibration process.
8. Write 1 to the register bit STARTCALRC. Start calibration process.
9. Read the register bit CALRCDONE. If read as 1, then calibration process finished. Otherwise repeat the step.
10. Write 0 to the register bit STARTCALRC. Stop calibration process.
11. Write 0 to the register bit CARLC in the register TX\_CON of Baseband Front End in order to deactivate clock required for calibration process. Terminate calibration process.
12. The result of calibration process can be read from the register field CALRCOUT of the register BBTX\_AC\_CON1. Software can set the value to the register field CALRCSEL for 3-dB cutoff frequency selection of smoothing filter in DAC of BBTX.

Remember to set the register field CALRCCONT of the register BBTX\_AC\_CON1 to 0xb before the calibration process. It only needs to be set once.

**TRIMQ** The register field is used to control gain trimming of Q-channel DAC in BBTX mixed-signal module. It is coded in 2's complement, that is, with maximum 15 and minimum -16.

**TRIMI** The register field is used to control gain trimming of I-channel DAC in BBTX mixed-signal module. It is coded in 2's complement, that is, with maximum 15 and minimum -16.

**CALRCSEL** The register field is for selection of cutoff frequency of smoothing filter in BBTX mixed-signal module. It is coded in 2's complement. That is, its maximum is 3 and minimum is -4.

**GAIN** The register field is used to control gain of DAC in BBTX mixed-signal module. It has impact on both of I- and Q-channel DAC in BBTX mixed-signal module. It is coded in 2's complement, that is, with maximum 3 and minimum -4.

**STARTCALRC** Whenever 1 is writing to the bit, calibration process for smoothing filter in BBTX mixed-signal module will be triggered. Once the calibration process is completed, the register bit CARLDONE will be read as 1.

**CALRCDONE** The register bit indicates if calibration process for smoothing filter in BBTX mixed-signal module has finished. When calibration processing finishes, the register bit will be 1. When the register bit STARTCALRC is set to 0, the register bit becomes 0 again.

### MIXED+0404h BBTX DAC Analog-Circuit Control Register 1

BBTX\_AC\_CON  
1

| Bit   | 15              | 14           | 13 | 12              | 11 | 10 | 9 | 8 | 7              | 6 | 5 | 4 | 3 | 2          | 1 | 0 |
|-------|-----------------|--------------|----|-----------------|----|----|---|---|----------------|---|---|---|---|------------|---|---|
| Name  | <b>CALRCOUT</b> | <b>FLOAT</b> |    | <b>CALRCCNT</b> |    |    |   |   | <b>CALBIAS</b> |   |   |   |   | <b>CMV</b> |   |   |
| Type  | R               | R/W          |    | R/W             |    |    |   |   | R/W            |   |   |   |   | R/W        |   |   |
| Reset | -               | 0            |    | 0000            |    |    |   |   | 00000          |   |   |   |   | 000        |   |   |

Set this register for analog circuit configuration controls.

**CMV** The register field is used to control common voltage in BBTX mixed-signal module. It is coded in 2's complement, that is, with maximum 3 and minimum -4.

**CALBIAS** The register field is for control of biasing current in BBTX mixed-signal module. It is coded in 2's complement. That is, its maximum is 15 and minimum is -16. Biasing current in BBTX mixed-signal module has impact on performance of D/A conversion. Larger the value of the register field, the larger the biasing current in BBTX mixed-signal module.

**CALRCCNT** Parameter for calibration process of smoothing filter in BBTX mixed-signal module. Default value is eleven. Note that it is NOT coded in 2's complement. Therefore the range of its value is from 0 to 15. Remember to set it to 0xb before BBTX calibration process. It only needs to be set once.

**FLOAT** The register field is used to have the outputs of DAC in BBTX mixed-signal module float or not.

**CALRCOUT** After calibration processing for smoothing filter in BBTX mixed-signal module, a set of 3-bit value is obtained. It is coded in 2's complement.

### 12.2.1.5 AFC DAC

MCU APB bus registers for AFC DAC are listed as follows.

### MIXED+0500h AFC DAC Analog-Circuit Control Register

AFC\_AC\_CON

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7           | 6 | 5                 | 4 | 3 | 2           | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|-------------|---|-------------------|---|---|-------------|---|---|
| Name  |    |    |    |    |    |    |   |   | <b>TEST</b> |   | <b>PDN_CHPUMP</b> |   |   | <b>CALI</b> |   |   |
| Type  |    |    |    |    |    |    |   |   | R/W         |   | R/W               |   |   | R/W         |   |   |
| Reset |    |    |    |    |    |    |   |   | 0           |   | 0                 |   |   | 0           |   |   |

Set this register for analog circuit configuration controls. Please refer to analog functional specification for more details.

**TEST** test control

**PDN\_CHPUMP** charge pump power down

**CALI** biasing current control

### 12.2.1.6 APC DAC

MCU APB bus registers for APC DAC are listed as followings.

**MIXED+0600h APC DAC Analog-Circuit Control Register**
**APC\_AC\_CON**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4 | 3 | 2    | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|-----|---|---|------|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   | BYP |   |   | CALI |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   | R/W |   |   | R/W  |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   | 0   |   |   | 0    |   |   |

Set this register for analog circuit configuration controls. Please refer to analog functional specification for more details.

**BYP** bypass output buffer

**CALI** biasing current control

**12.2.1.7 Auxiliary ADC**

MCU APB bus registers for AUX ADC are listed as followings.

**MIXED+0700h Auxiliary ADC Analog-Circuit Control Register**
**AUX\_AC\_CON**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5    | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|------|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   | CALI |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   | R/W  |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   | 0    |   |   |   |   |   |

Set this register for analog circuit configuration controls. Please refer to analog functional specification for more details.

**CALI** biasing current control

**12.2.1.8 Reserved**

Some registers are reserved for further extensions.