# MT6228 GSM/GPRS Baseband Processor Data Sheet

Revision 1.02

**September 09, 2005** 



# **Revision History**

| Revision | Date         | Comments                                                                                                                                                                                                                                                                                              |
|----------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1.00     | Jun 28, 2005 | First Release                                                                                                                                                                                                                                                                                         |
| 1.01     | Aug 30, 2005 | <ol> <li>Correct typo in "Flow Control" section of Post Resize</li> <li>Change IRQ_STA and IRQ_STA2 registers to RO type in Interrupt-Controller</li> <li>Additional core power ball, VDDK, is added in ball map diagram.</li> <li>Updated package thickness to 1.2 in product description</li> </ol> |
| 1.02     | Sep 09, 2005 | <ol> <li>Fixed ball count description from 313 to 314 balls.</li> <li>Typo fixed.</li> </ol>                                                                                                                                                                                                          |



# **TABLE OF CONTENTS**

| R | evisi           | on History                                 | 2   |
|---|-----------------|--------------------------------------------|-----|
| P | refac           | Ce                                         | 5   |
| 1 | C <sub>T7</sub> | stem Overview                              |     |
| 1 | 1.1             | Platform Features                          |     |
|   | 1.1             | MODEM Features                             |     |
|   | 1.2             | Multi-Media Features                       |     |
|   | 1.3             | General Description                        |     |
|   | 1.4             | General Description                        | 13  |
| 2 | Pro             | oduct Description                          | 17  |
|   | 2.1             | Pin Outs                                   |     |
|   | 2.2             | Top Marking Definition                     |     |
|   | 2.3             | DC Characteristics                         | 21  |
|   | 2.4             | Pin Description.                           | 22  |
|   | 2.5             | Power Description.                         | 31  |
| 3 | Mi              | icro-Controller Unit Subsystem             | 37  |
| J | 3.1             | Processor Core                             | 20  |
|   | 3.1             | Memory Management                          |     |
|   | 3.3             | Bus System                                 |     |
|   | 3.4             | Direct Memory Access                       |     |
|   | 3.5             | Interrupt Controller                       |     |
|   | 3.6             | Code Cache Controller                      |     |
|   | 3.7             | MPU                                        |     |
|   | 3.8             | Data Cache                                 |     |
|   | 3.9             | Internal Memory Interface                  |     |
|   |                 | External Memory Interface                  |     |
|   |                 | ·                                          |     |
| 4 |                 | icrocontroller Peripherals                 |     |
|   | 4.1             | Pulse-Width Modulation Outputs             |     |
|   | 4.2             | Alerter                                    |     |
|   | 4.3             | SIM Interface                              |     |
|   | 4.4             | Keypad Scanner                             |     |
|   | 4.5             | General Purpose Inputs/Outputs             |     |
|   | 4.6             | General Purpose Timer                      |     |
|   | 4.7             | UART                                       |     |
|   | 4.8             | IrDA Framer                                |     |
|   | 4.9             | Real Time Clock                            |     |
|   |                 | SCCB                                       |     |
|   |                 | Cipher Hash Engine                         |     |
|   |                 |                                            |     |
| 5 | Mi              | icrocontroller Coprocessors                |     |
|   | 5.1             | Divider                                    |     |
|   | 5.2             | CSD Accelerator                            |     |
|   | 5.3             | FCS Codec                                  |     |
|   | 5.4             | PPP Framer Coprocessor                     | 199 |
| 6 | Mı              | ulti-Media Subsystem                       | 206 |
|   | 6.1             | LCD Interface                              |     |
|   | 6.2             | NAND FLASH interface                       |     |
|   | 6.3             | USB OTG Controller                         |     |
|   | 6.4             | Memory Stick and SD Memory Card Controller | 259 |



|    | 6.5    | Graphic Memory Controller              | 281 |
|----|--------|----------------------------------------|-----|
|    | 6.6    | 2D acceleration                        |     |
|    | 6.7    | Capture Resize                         |     |
|    | 6.8    | Drop Resize                            | 313 |
|    | 6.9    | Post Resize                            | 317 |
|    | 6.10   | JPEG Decoder                           | 330 |
|    | 6.11   | JPEG Encoder                           | 340 |
|    |        | GIF Decoder                            |     |
|    |        | PNG Decoder                            |     |
|    |        | Camera Interface                       |     |
|    |        | Image DMA                              |     |
|    |        | Image Engine                           |     |
|    |        | MPEG-4/H.263 Video CODEC               |     |
|    |        | TV Controller                          |     |
|    |        | TV encoder                             |     |
| 7  | Δ11    | dio Front-End                          | 512 |
| 1  | 7.1    | General Description                    |     |
|    | 7.1    | Register Definitions                   |     |
|    | 7.3    | Programming Guide                      |     |
|    |        |                                        |     |
| 8  | Ra     | dio Interface Control                  | 521 |
|    | 8.1    | Baseband Serial Interface              | 521 |
|    | 8.2    | Baseband Parallel Interface            | 527 |
|    | 8.3    | Automatic Power Control (APC) Unit     |     |
|    | 8.4    | Automatic Frequency Control (AFC) Unit |     |
| 9  | Ra     | seband Front End                       | 540 |
|    | 9.1    | Baseband Serial Ports                  |     |
|    | 9.2    | Downlink Path (RX Path)                |     |
|    | 9.3    | Uplink Path (TX Path)                  |     |
|    |        | op (1111 u.u.)                         |     |
| 1  | 0 Tir  | ning Generator                         | 552 |
|    | 10.1   | TDMA timer                             | 552 |
|    | 10.2   | Slow Clocking Unit                     | 559 |
| 11 | 1 Pos  | wer, Clocks and Reset                  | 563 |
|    | 11 1   | B2PSI                                  | 563 |
|    |        | Clocks                                 |     |
|    |        | Reset Generation Unit (RGU)            |     |
|    |        | Software Power Down Control            |     |
|    |        |                                        |     |
| 12 |        | alog Front-end & Analog Blocks         |     |
|    | 12.1   | General Description                    | 579 |
|    |        | MCU Register Definitions               |     |
|    | 12.3   | Programming Guide                      | 601 |
| 1  | 3 Die  | gital Pin Electrical Characteristics   | 603 |
| -  | والعاد | #1001 T TIT TITO OF 1 000              |     |



## **Preface**

## **Acronym for Register Type**

**R/W** Capable of both read and write access

RO Read only

RC Read only. After reading the register bank, each bit which is HIGH(1) will be cleared to LOW(0)

automatically.

**WO** Write only

W1S 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.

W1C 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

MT6228 is a feature-rich and extremely powerful single-chip solution for high-end GSM/GPRS mobile phones. Based on the 32-bit ARM7EJ-S<sup>TM</sup> RISC processor, MT6228's superb processing power, along with high bandwidth architecture and dedicated hardware support, provides an unprecedented platform for high performance GPRS Class 12 MODEM and leading-edge multimedia applications. Overall, MT6228 presents a revolutionary platform for multimedia-centric mobile devices.

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

#### Platform

MT6228 is capable of running the ARM7EJ-S<sup>TM</sup> RISC processor at up to 104 MHz, thus providing fast data processing capabilities. In addition to the high clock frequency, separate CODE and DATA caches are also added to further improve the overall system efficiency.

For large amounts of data transfer, high performance DMA (Direct Memory Access) with hardware flow control is implemented, which greatly enhances the data movement speed while reducing MCU processing load.

Targeted as a media-rich platform for mobile applications, MT6228 also provides hardware security digital rights management for copyright protection. For further safeguarding, and to protect the manufacturer's development investment, hardware flash content protection is provided to prevent unauthorized porting of the software load.

#### Memory

To provide the greatest capacity for expansion and maximum bandwidth for data intensive applications such as multimedia features, MT6228 supports up to 4 external state-of-the-art devices through its 8/16-bit host interface. High performance devices such as Mobile RAM and Cellular RAM are supported for maximum bandwidth. Traditional devices such as burst/page mode flash, page mode SRAM, and Pseudo SRAM are also supported. For greatest compatibility, the memory interface can also be

used to connect to legacy devices such as Color/Parallel LCD, and multi-media companion chips 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 the 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 a turn over.

#### Multi-media

The MT6228 multi-media subsystem provides a connection to a CMOS image sensor and supports a resolution up to 3Mpixels. With its advanced image signal and data processing technology, MT6228 allows efficient processing of image and video data. Built-in JPEG CODEC and MPEG-4 CODEC enable real-time recording and playback of high-quality images and video. A hardware MPEG4 accelerator supports playback in VGA mode at 15fps and encoding in CIF at 15fps. Videophone functionality is also provided. Moreover, a high quality de-blocking filter is removes blocking artifacts in video playback. GIF and PNG decoders are implemented for fast image decoding. MT6228 supports a TV-OUT capability, allowing the mobile handset to connect to a TV screen via an NTSC or PAL connection.

In addition to advanced image and video features, MT6228 utilizes high resolution DAC, digital audio, and audio synthesis technology to provide superior audio features for all future multi-media needs.

#### Connectivity and Storage

To take advantage of its incredible multimedia strengths, MT6228 incorporates myriads of advanced connectivity and storage options for data storage and communication. MT6228 supports UART, Fast IrDA, USB 1.1 Full Speed OTG, SDIO, Bluetooth and WIFI Interface, and MMC/SD/MS/MS Pro storage systems. These interfaces provide MT6228 users with the highest degree of flexibility in implementing solutions suitable for the targeted application.



To achieve a complete user interface, MT6228 also brings together all the necessary peripheral blocks for a multi-media GSM/GPRS phone. The peripheral blocks include 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.

Furthermore, to provide more better configurability and bandwidth for multi-media products, an additional 18-bit parallel interface is incorporated. This interface enables connection to LCD panels as well as NAND flash devices for additional multi-media data storage.

#### <u>Audio</u>

Using a highly integrated mixed-signal Audio Front-End, the MT6228 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, MT6228 also provides Stereo Input and Analog MUX.

MT6228 supports AMR codec to adaptively optimize speech and audio quality. Moreover, HE-AAC codec is implemented to deliver CD-quality audio at low bit rates.

On the whole, MT6228's audio features provide a rich solution for multi-media applications.

#### Radio

MT6228 integrates a mixed-signal baseband front-end in order to provide a well-organized radio interface with flexibility for efficient customization. The front-end contains gain and offset calibration mechanisms, and filters with programmable coefficients for comprehensive compatibility control on RF modules. This approach allows the usage of a high resolution D/A Converter for controlling VCXO or crystal, reducing the need for an expensive TCVCXO. MT6228 achieves great MODEM performance by utilizing a 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 the software program with the ARM7EJ-S core. With this standardized debugging interface, MT6228 provides developers with a wide set of options in choosing ARM development kits from different third party vendors.

#### Power Management

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

#### Package

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





Figure 1 Typical application of MT6228



## 1.1 Platform Features

#### General

- Integrated voice-band, audio-band and base-band analog front ends
- TFBGA 13mm×13mm, 314-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/104 MHz
- Dedicated DMA bus
- 14 DMA channels
- 1M bits on-chip SRAM
- 1M bits MCU dedicated Tightly Coupled memory
- 256K bits CODE cache
- 64K bits DATA cache
- On-chip boot ROM for Factory Flash Programming
- Watchdog timer for system crash recovery
- 3 sets of General Purpose Timer
- Circuit Switch Data coprocessor
- Division coprocessor
- PPP Framer coprocessor

#### **External Memory Interface**

- Supports up to 4 external devices
- Supports 8-bit or 16-bit memory components with maximum size of up to 64M Bytes each
- Supports Mobile RAM and Cellular RAM
- Supports Flash and SRAM/PSRAM with page mode or burst mode

- 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

#### <u>User Interfaces</u>

- 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
- Real Time Clock (RTC) operating with a separate power supply
- General Purpose I/Os (GPIOs)
- 2 sets of Pulse Width Modulation (PWM) output
- Alerter output with Enhanced PWM or PDM
- 8 external interrupt lines

#### Security

- Cipher: supports AES, DES/3DES
- Hash: supports MD5, SHA-1
- Supports security key and 27 bit chip unique ID

#### Connectivity

- 3 UARTs with hardware flow control and speeds up to 921600 bps
- IrDA modulator/demodulator with hardware framer. Supports SIR/MIR/FIR operating speeds.
- Full-speed USB 1.1 OTG capability. Supports device mode, limited host mode, and dual-role OTG mode.



- Multi Media Card, Secure Digital Memory Card, Memory Stick, Memory Stick Pro host controller with flexible I/O voltage power
- Supports SDIO interface for SDIO peripherals as well as WIFI connectivity
- DAI/PCM and I2S interface for Audio application

#### Power Management

- Power Down Mode for analog and digital circuits
- Processor Sleep Mode
- Pause Mode of 32 KHz clocking in 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 MODEM Features

#### 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
- Bi-directional BSI interface. RF chip register read access with 3-wire or 4-wire interface.
- 10-Pin Baseband Parallel Interface (BPI) with programmable driving strength
- Multi-band support

#### **Voice 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 GEA1 and GEA2 ciphering
- Programmable GSM/GPRS modem
- Packet Switched Data with CS1/CS2/CS3/CS4 coding schemes
- GSM Circuit Switch Data
- GPRS Class 12

#### **Voice Interface and Voice Front End**

- Two microphone inputs sharing one low noise amplifier with programmable gain and automatic gain control (AGC) mechanisms
- Voice power amplifier 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



## 1.3 Multi-Media Features

#### LCD/NAND Flash Interface

- Dedicated Parallel Interface supports 3 external devices with 8-/16-bit NAND flash interface, 8-/9-/16-/18-bit Parallel interface, and Serial interface for LCM
- Built-in NAND Flash Controller with 1-bit ECC for mass storage

#### LCD Controller

- Supports simultaneous connection to up to 3 parallel LCD and 2 serial LCD modules
- Supports LCM format: RGB332, RGB444, RGB565, RGB666, RGB888
- Supports LCD module with maximum resolution up to 800x600 at 24bpp
- Per pixel alpha channel
- True color engine
- Supports hardware display rotation
- Capable of combining display memories with up to 6 blending layers

#### Image Signal Processor

- 8/10 bit Bayer format image input
- Capable of processing image of size up to 3M pixels
- Color correction matrix
- Gamma correction
- Automatic exposure (AE) control
- Automatic white balance (AWB) control
- Programmable AE/AWB windows
- Edge enhancement support
- Histogram equalization logic
- Horizontal and vertical sync information on separate pins

- Shading compensation
- Defect Pixel compensation

#### Graphic Compression

- GIF Decoder
- PNG Decoder

#### 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 a restart interval
- Supports SOS, DHT, DQT and DRI marker parsing
- IEEE Std 1180-1990 IDCT standards compliance
- 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 YUV420 and grayscale formats
- Supports JFIF
- Standard DC and AC Huffman tables
- Provides 4 levels of encode quality
- Supports continuous shooting

#### Image Data Processing

Supports Digital Zoom



- Supports RGB888/565, YUV444 image processing
- High throughput hardware scaler. Capable of tailoring an image to an 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/sepia-tone effects
- Programmable spatial filtering: linear filter, non-linear filter and multi-pass artistic effects
- Hardware accelerated image editing
- Photo frame capability
- RGB thumbnail data output

#### <u>MPEG-4/H.263 CODEC</u>

- Hardware Video CODEC
- ISO/IEC 14496-2 simple profile: decode @ level 0/1/2/3

encode @ level 0

- ITU-T H.263 profile 0 @ level 10
- Max decode speed is VGA @ 15fps
- Max encode speed is CIF @ 15fps
- Support VGA mode encoding
- Horizontal and vertical de-blocking filter in video playback
- Encoder resync marker and HEC
- 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
- HE-AAC decode support
- AAC/AMR/WB-AMR audio decode support
- AMR/WB-AMR audio encode support

#### TV-OUT

- Supports NTSC/PAL formats (interlaced mode)
- 10 bit video DAC with 2x oversampling
- Supports one composite video output

#### 2D Accelerator

- Supports 32-bpp ARGB8888, 24-bpp RGB888, 16-bpp RGB565, and 8-bpp index color modes
- Supports SVG Tiny
- Rectangle gradient fill
- BitBlt: multi-BitBlt with 7 rotation, 16 binary ROP
- Alpha blending with 7 rotation
- Line drawing: normal line, dotted line, anti-aliasing
- Circle drawing
- Bezier curve drawing
- Triangle flat fill
- Font caching: normal font, italic font
- Command queue with max depth of 2047

#### Audio CODEC

- Supports HE-AAC codec decode
- Supports AAC codec decode
- 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

#### Audio Interface and Audio Front End

- Supports I2S interface
- High resolution D/A Converters for Stereo Audio playback
- Stereo analog input for stereo audio source
- Analog multiplexer for stereo audio
- Stereo to mono conversion



## 1.4 General Description

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

MT6228 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: the junction at which 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 the 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 to and from digital speech;
- Audio Front End: the data path for converting stereo audio from an audio source;
- Video Front End: the data path for converting a video signal to NTSL/PAL format;
- Baseband Front End: the data path for converting a digital signal to and from an analog signal from the RF modules;
- Timing Generator: generates the control signals related to the TDMA frame timing; and,
- Power, Reset and Clock Subsystem: manages the power, reset, and clock distribution inside MT6228.

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





Figure 2 MT6228 block diagram.



# **2 Product Description**

## 2.1 Pin Outs

One type of package for this product, TFBGA 13mm\*13mm, 314-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**.





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



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

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

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



## 2.2 Top Marking Definition



<u>ARM</u>

MT6228T DDDD-### LLLLL KKKKK

S

MT6228T: Part No. DDDD: Date Code

###: Subcontractor Code
LLLLL: U1 Die Lot No.
KKKKK: U2 Die Lot No.
S: Special Code



## 2.3 DC Characteristics

## 2.3.1 Absolute Maximum Ratings

Prolonged exposure to absolute maximum ratings may reduce device reliability. Functional operation at these maximum ratings is not implied.

| Item                  | Symbol | Min  | Max       | Unit    |
|-----------------------|--------|------|-----------|---------|
| IO power supply       | VDD33  | -0.3 | VDD33+0.3 | V       |
| I/O input voltage     | VDD33I | -0.3 | VDD33+0.3 | V       |
| Operating temperature | Topr   | -20  | 80        | Celsius |
| Storage temperature   | Tstg   | -55  | 125       | Celsius |



# 2.4 Pin Description

| Ball  |          |     |                                                 |        |          |             |              | PU/ | Rese  |
|-------|----------|-----|-------------------------------------------------|--------|----------|-------------|--------------|-----|-------|
| 13X13 | Name     | Dir | Description                                     | Mode0  | Mode1    | Mode2       | Mode3        | PD  | t     |
|       |          |     | JTAG Port                                       | 1      |          |             | 1            | 7   |       |
| E4    | JTRST#   | I   | JTAG test port reset input                      |        |          |             |              | PD  | Input |
| F5    | JTCK     | I   | JTAG test port clock input                      |        |          |             |              | PU  | Input |
| F4    | JTDI     | I   | JTAG test port data input                       |        |          |             |              | PU  | Input |
| F3    | JTMS     | I   | JTAG test port mode switch                      |        |          |             |              | PU  | Input |
| F2    | JTDO     | О   | JTAG test port data output                      |        |          |             | (0)          |     | 0     |
| F1    | JRTCK    | О   | JTAG test port returned clock output            |        |          |             | X            |     | 0     |
|       | 1 -      |     | RF Parallel Control Unit                        |        |          |             |              |     |       |
| G5    | BPI_BUS0 | О   | RF hard-wire control bus 0                      |        |          |             |              |     | 0     |
| G4    | BPI_BUS1 | О   | RF hard-wire control bus 1                      |        |          |             |              |     | 0     |
| G3    | BPI_BUS2 | О   | RF hard-wire control bus 2                      |        |          |             |              |     | 0     |
| Gl    | BPI_BUS3 | О   | RF hard-wire control bus 3                      |        |          | (5)         |              |     | 0     |
| J6    | BPI_BUS4 | О   | RF hard-wire control bus 4                      |        |          |             |              |     | 0     |
| H5    | BPI_BUS5 | О   | RF hard-wire control bus 5                      |        |          | 70          |              |     | 0     |
| H4    | BPI_BUS6 | Ю   | RF hard-wire control bus 6                      | GPIO16 | BPI_BUS6 |             |              | PD  | Input |
| Н3    | BPI_BUS7 | Ю   | RF hard-wire control bus 7                      | GPIO17 | BPI_BUS7 | 13MHz       | 26MHz        | PD  | Input |
| H2    | BPI_BUS8 | Ю   | RF hard-wire control bus 4                      | GPIO18 | BPI_BUS8 | 6.5MHz      | 32KHz        | PD  | Input |
| J5    | BPI_BUS9 | Ю   | RF hard-wire control bus 5                      | GPIO19 | BPI_BUS9 | BSI_CS1     | BFEPRB<br>O  | PD  | Input |
|       | _        |     | RF Serial Control Unit                          |        |          |             |              |     |       |
| J4    | BSI_CS0  | О   | RF 3-wire interface chip select 0               |        |          |             |              |     | 0     |
| Ј3    | BSI_DATA | О   | RF 3-wire interface data output                 |        |          |             |              |     | 0     |
| J2    | BSI_CLK  | О   | RF 3-wire interface clock output                |        |          |             |              |     | 0     |
|       | _        |     | PWM Interface                                   |        |          |             |              |     |       |
| R4    | PWM1     | IO  | Pulse width modulated signal 1                  | GPIO32 | PWM1     | TBTXFS      | DSP_TID 2    | PD  | Input |
| R3    | PWM2     | Ю   | Pulse width modulated signal 2                  | GPIO33 | PWM2     | TBRXEN      | DSP_TID 3    | PD  | Input |
| R2    | ALERTER  | Ю   | Pulse width modulated signal for buzzer         | GPIO34 | ALERTER  | TBRXFS      | DSP_TID<br>4 | PD  | Input |
|       |          |     | Serial LCD/PM IC Interface                      |        |          |             |              |     |       |
| J1    | LSCK     | IO  | Serial display interface data output            | GPIO20 | LSCK     | TDMA_C<br>K | TBTXEN       | PU  | Input |
| K5    | LSA0     | Ю   | Serial display interface address output         | GPIO21 | LSA0     | TDMA_D1     | TDTIRQ       | PU  | Input |
| K4    | LSDA     | IO  | Serial display interface clock output           | GPIO22 | LSDA     | TDMA_D0     | TCTIRQ2      | PU  | Input |
| К3    | LSCE0#   | Ю   | Serial display interface chip select 0 output   | GPIO23 | LSCE0#   | TDMA_FS     | TCTIRQ1      | PU  | Input |
| K2    | LSCE1#   | Ю   | Serial display interface chip select 1 output   | GPIO24 | LSCE1#   | LPCE2#      | TEVTVA<br>L  | PU  | Input |
|       | 4        |     | Parallel LCD/NAND-Flash<br>Interface            |        |          |             |              | -   |       |
| K6    | LPCE1#   | IO  | Parallel display interface chip select 1 output | GPIO25 | LPCE1#   | NCE1#       | DSP_TID<br>0 | PU  | Input |
| L5    | LPCE0#   | О   | Parallel display interface chip select 0 output |        |          |             |              |     | 1     |
| L4    | LRST#    | О   | Parallel display interface Reset Signal         |        |          |             |              |     | 1     |
| L3    | LRD#     | О   | Parallel display interface Read Strobe          |        |          |             |              | İ   | 1     |
|       |          |     |                                                 |        |          |             |              |     |       |



|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | MEDIATEK | i e     |    |                                 |        |          |       |        |    |       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------|----|---------------------------------|--------|----------|-------|--------|----|-------|
| Strobe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | L2       | LPA0    | О  |                                 |        |          |       |        |    | 1     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | L1       | LWR#    | О  |                                 |        |          |       |        |    | 1     |
| N.D.   N.D.   10   Parallel L.CD/NAND-Flash Data   15   N.D.   15   GPIO61   DIMS   PD   Ingul   10   N.D.   10   Parallel L.CD/NAND-Flash Data   13   N.D.   13   GPIO60   DICK   PD   Ingul   10   Parallel L.CD/NAND-Flash Data   13   N.D.   13   GPIO59   SWDBGR   PD   Ingul   N.D.   14   GPIO60   DICK   PD   Ingul   10   Parallel L.CD/NAND-Flash Data   13   N.D.   13   GPIO59   SWDBGR   PD   Ingul   N.D.   10   Parallel L.CD/NAND-Flash Data   14   N.D.   10   Parallel L.CD/NAND-Flash Data   15   N.D.   10   GPIO56   SWDBGR   PD   Ingul   N.D.   10   Parallel L.CD/NAND-Flash Data   10   N.D.   10   GPIO56   SWDBGR   PD   Ingul   N.D.   10   Parallel L.CD/NAND-Flash Data   10   N.D.   10   GPIO56   SWDBGR   PD   Ingul   N.D.   10   Parallel L.CD/NAND-Flash Data   10   N.D.   10   GPIO55   SWDBGR   PD   Ingul   N.D.   10   Parallel L.CD/NAND-Flash Data   10   N.D.   10   Parallel L.CD/NAND-Flash Data   10   PD   Ingul   N.D.      | G7       | NLD17   | Ю  | Parallel LCD/NAND-Flash Data 17 | GPIO11 | NLD17    | MCDA4 | I . —  | PD | Input |
| Dig                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | J9       | NLD16   | Ю  | Parallel LCD/NAND-Flash Data 16 | GPIO10 | NLD16    | MCDA5 | DID    | PD | Input |
| L9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | K9       | NLD15   | IO | Parallel LCD/NAND-Flash Data 15 | NLD15  | GPIO61   |       | DIMS   | PD | Input |
| KIO   NLD12   IO   Parallel LCD/NAND-Flash Data 12   NLD12   GPIOS8   SWDBGR   PD   Input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | J10      | NLD14   | Ю  | Parallel LCD/NAND-Flash Data 14 | NLD14  | GPIO60   |       | DICK   | PD | Input |
| NLD11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | L9       | NDL13   | Ю  | Parallel LCD/NAND-Flash Data 13 | NLD13  | GPIO59   |       |        | PD | Input |
| NLD10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | K10      | NLD12   | Ю  | Parallel LCD/NAND-Flash Data 12 | NLD12  | GPIO58   |       |        | PD | Input |
| NLD9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | J11      | NLD11   | Ю  | Parallel LCD/NAND-Flash Data 11 | NLD11  | GPIO57   |       |        | PD | Input |
| Lili   NLD8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | L10      | NLD10   | Ю  | Parallel LCD/NAND-Flash Data 10 | NLD10  | GPIO56   |       |        | PD | Input |
| NLD7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | K11      | NLD9    | Ю  | Parallel LCD/NAND-Flash Data 9  | NLD9   | GPIO55   | 60    |        | PD | Input |
| MS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | L11      | NLD8    | Ю  | Parallel LCD/NAND-Flash Data 8  | NLD8   | GPIO54   |       |        | PD | Input |
| M4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | L6       | NLD7    | Ю  | Parallel LCD/NAND-Flash Data 7  |        |          |       |        | PD | Input |
| M3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | M5       | NLD6    | Ю  | Parallel LCD/NAND-Flash Data 6  |        |          |       |        | PD | Input |
| NLD3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | M4       | NLD5    | Ю  | Parallel LCD/NAND-Flash Data 5  |        |          |       |        | PD | Input |
| NA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | M3       | NLD4    | IO | Parallel LCD/NAND-Flash Data 4  |        |          |       |        | PD | Input |
| Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | N5       | NLD3    | IO | Parallel LCD/NAND-Flash Data 3  |        |          |       |        | PD | Input |
| NLD0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | N4       | NLD2    | IO | Parallel LCD/NAND-Flash Data 2  |        |          |       |        | PD | Input |
| NRNB IO NAND-Flash Read/Busy Flag NRNB GPIO26 USBSESS VLD 2  PS NCLE IO NAND-Flash Command Latch Signal NCLE GPIO27 USBVBUS SWDBGD PD VLD 1  P4 NALE IO NAND-Flash Address Latch Signal NALE GPIO28 USBSESS SWDBGD PD 0  P3 NWE# IO NAND-Flash Write Strobe NWE# GPIO29 END 0  P4 NRE# IO NAND-Flash Read Strobe NRE# GPIO30 USBVBUS SWDBGD PD DSC K  P5 NRE# IO NAND-Flash Chip select output NCE# GPIO31 USBVBUS SWDBGC PU DSC K  P6 NRE# IO NAND-Flash Chip select output NCE# GPIO31 USBVBUS SWDBGC PU DSC K  P7 NRE# IO NAND-Flash Chip select output NCE# GPIO31 USBVBUS SWDBGC PU DSC K  P8 SIMCARD Interface  M19 SIMRST O SIM card reset output ID ID SIMCARD IN ID SIMCARD | N3       | NLD1    | Ю  | Parallel LCD/NAND-Flash Data 1  |        |          |       |        | PD | Input |
| P5   NCLE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | N2       | NLD0    | IO | Parallel LCD/NAND-Flash Data 0  |        |          |       |        | PD | Input |
| NALE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | N1       | NRNB    | IO | NAND-Flash Read/Busy Flag       | NRNB   | GPIO26   |       |        | PU |       |
| P3 NWE# IO NAND-Flash Write Strobe P4 NRE# IO NAND-Flash Read Strobe P5 NRE# IO NAND-Flash Chip select output P6 NCE# IO NAND-Flash Chip select output P7 NCE# IO NAND-Flash Chip select output P8 NCE# IO NAND-Flash Chip select output P9 NCE# IO NAND-Flash Chip select output NCE# GPIO31 P1 NCE# IO NAND-Flash Chip select output NCE# GPIO31 P1 NCE# IO NAND-Flash Chip select output NCE# GPIO31 P1 NCE# IO NAND-Flash Chip select output NCE# GPIO31 P1 NCE# IO NAND-Flash Chip select output NCE# GPIO31 P1 NCE# IO NAND-Flash Chip select output NCE# GPIO31 NCE# GPIO31 NCE# GPIO3 IO SIM card select output NCE# GPIO48 NCE# GPIO34 NCE# GPIO35 NCE# GPIO35 NCE# GPIO35 NCE# GPIO36 NCE# G | P5       | NCLE    | Ю  | NAND-Flash Command Latch Signal | NCLE   | GPIO27   |       | l .    | PD |       |
| NRE#   IO   NAND-Flash Read Strobe   NRE#   GPIO30   USBVBUS   SWDBGC   PU   NCE#   IO   NAND-Flash Chip select output   NCE#   GPIO31   PU   SIM Card Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | P4       | NALE    | Ю  | NAND-Flash Address Latch Signal | NALE   | GPIO28   |       |        | PD |       |
| PI NCE# IO NAND-Flash Chip select output NCE# GPIO31 PU  SIM Card Interface  M19 SIMRST O SIM card reset output 0 0  L16 SIMCLK O SIM card clock output 0 0  L17 SIMVCC O SIM card supply power control 0 0  L18 SIMSEL O SIM card supply power select GPIO48 SIMSEL PD Input 0 0  L19 SIMDATA IO SIM card data input/output 0 0  Dedicated GPIO Interface  U3 GPIO0 IO General purpose input/output 0 GPIO0 CMFLAS H SSIMSEL PD Input 5  U1 GPIO1 IO General purpose input/output 1 GPIO1 BSI_RFIN PD Input 5  U1 GPIO2 IO General purpose input/output 2 GPIO2 SCL PU Input 10  C19 GPIO3 IO General purpose input/output 3 GPIO3 SDA PU Input 10  C18 GPIO4 IO General purpose input/output 4 GPIO4 EDICK URXD2 SWDBGD 7  C17 GPIO5 IO General purpose input/output 5 GPIO5 EDIWS UTXD2 SWDBGD 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | P3       | NWE#    | Ю  | NAND-Flash Write Strobe         | NWE#   | GPIO29   |       |        | PU |       |
| SIM Card Interface  M19 SIMRST O SIM card reset output  L16 SIMCLK O SIM card clock output  L17 SIMVCC O SIM card supply power control  L18 SIMSEL O SIM card supply power select  L19 SIMDATA IO SIM card data input/output  Dedicated GPIO Interface  U3 GPIO0 IO General purpose input/output 1 GPIO1 BSI_RFIN  D17 GPIO2 IO General purpose input/output 2 GPIO2 SCL  C19 GPIO3 IO General purpose input/output 3 GPIO3 SDA  C18 GPIO4 IO General purpose input/output 4 GPIO4 EDICK URXD2 SWDBGD  C17 GPIO5 IO General purpose input/output 5 GPIO5 EDIWS UTXD2 SWDBGD  C17 GPIO5 IO General purpose input/output 5 GPIO5 EDIWS UTXD2 SWDBGD  C17 GPIO5 IO General purpose input/output 5 GPIO5 EDIWS UTXD2 SWDBGD  C18 GPIO5 IO General purpose input/output 5 GPIO5 EDIWS UTXD2 SWDBGD  C19 GPIO5 IO General purpose input/output 5 GPIO5 EDIWS UTXD2 SWDBGD  C10 GPIO5 IO General purpose input/output 5 GPIO5 EDIWS UTXD2 SWDBGD  C10 GPIO5 IO GENERAL SUPPLIES SWDBGD  C11 GPIO5 IO GENERAL SUPPLIES SWDBGD  C12 GPIO5 IO GENERAL SUPPLIES SWDBGD  C13 GPIO5 IO GENERAL SUPPLIES SWDBGD  C14 GPIO5 IO GENERAL SUPPLIES SWDBGD  C15 GPIO5 EDIWS UTXD2 SWDBGD  C16 GPIO5 IO GENERAL SUPPLIES SWDBGD  C17 GPIO5 IO GENERAL SUPPLIES SWDBGD  C18 GPIO5 IO GENERAL SUPPLIES SWDBGD  C19 GPIO5 IO GENERAL SUPPLIES SWDBGD  C10 GPIO5 IO GENERAL SUPPLIES SWDBGD  C10 GPIO5 IO GENERAL SUPPLIES SWDBGD  C10 GPIO5 IO GENERAL SUPPLIES SWDBGD  C11 GPIO5 IO GENERAL SUPPLIES SWDBGD  C12 GPIO5 IO GENERAL SUPPLIES SWDBGD  C13 GPIO5 IO GENERAL SUPPLIES SWDBGD  C14 GPIO5 IO GENERAL SUPPLIES SWDBGD  C15 GPIO5 IO GENERAL SUPPLIES SWDBGD  C16 GPIO5 IO GENERAL SUPPLIES SWDBGD  C17 GPIO5 IO GENERAL SUPPLIES SWDBGD  C17 GPIO5 IO GENERAL SUPPLIES SWDBGD  C18 GPIO5 IO GENERAL SUPPLIES SWDBGD  C19 GPIO5 IO GENERAL SUPPLIES SWDBGD  C19 GPIO5 IO GENERAL SUPPLIES SWDBGD  C10 GPIO5 II GPIO5 II GO  C10 GPIO5 II GPIO5 II GO  C10 GPIO5 II GP | P2       | NRE#    | Ю  | NAND-Flash Read Strobe          | NRE#   | GPIO30   |       |        | PU |       |
| M19 SIMRST O SIM card reset output 0 L16 SIMCLK O SIM card clock output 0 L17 SIMVCC O SIM card supply power control 0 L18 SIMSEL O SIM card supply power select CPIO48 SIMSEL PD Input 0 L19 SIMDATA IO SIM card data input/output 0 Dedicated GPIO Interface  U3 GPIO0 IO General purpose input/output 1 GPIO1 BSI_RFIN D17 GPIO2 IO General purpose input/output 2 GPIO2 SCL PU Input Input IO GPIO3 IO General purpose input/output 3 GPIO3 SDA PU Input Input IO GPIO4 IO General purpose input/output 4 GPIO4 EDICK URXD2 SWDBGD 7 C17 GPIO5 IO General purpose input/output 5 GPIO5 EDIWS UTXD2 SWDBGD 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | P1       | NCE#    | Ю  | NAND-Flash Chip select output   | NCE#   | GPIO31   |       |        | PU |       |
| L16 SIMCLK O SIM card clock output 0 L17 SIMVCC O SIM card supply power control 0 L18 SIMSEL O SIM card supply power select GPIO48 SIMSEL PD Input L19 SIMDATA IO SIM card data input/output 0  Dedicated GPIO Interface  U3 GPIO0 IO General purpose input/output 0 GPIO0 CMFLAS DSP_TID PD Input 5  U1 GPIO1 IO General purpose input/output 1 GPIO1 BSI_RFIN PD Input D17 GPIO2 IO General purpose input/output 2 GPIO2 SCL PU Input C19 GPIO3 IO General purpose input/output 3 GPIO3 SDA PU Input C18 GPIO4 IO General purpose input/output 4 GPIO4 EDICK URXD2 SWDBGD 7  C17 GPIO5 IO General purpose input/output 5 GPIO5 EDIWS UTXD2 SWDBGD 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          | _       |    | SIM Card Interface              | -      |          |       |        | _  |       |
| L17 SIMVCC O SIM card supply power control L18 SIMSEL O SIM card supply power select L19 SIMDATA IO SIM card data input/output  Dedicated GPIO Interface  U3 GPIO0 IO General purpose input/output 0 GPIO0 CMFLAS H SDSP_TID PD Input 5  U1 GPIO1 IO General purpose input/output 1 GPIO1 BSI_RFIN PD Input 5  U1 GPIO2 IO General purpose input/output 2 GPIO2 SCL PU Input 10 C19 GPIO3 IO General purpose input/output 3 GPIO3 SDA PU Input 10 C18 GPIO4 IO General purpose input/output 4 GPIO4 EDICK URXD2 SWDBGD 7  C17 GPIO5 IO General purpose input/output 5 GPIO5 EDIWS UTXD2 SWDBGD 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | M19      | SIMRST  | О  | SIM card reset output           |        |          |       |        |    | 0     |
| L18 SIMSEL O SIM card supply power select L19 SIMDATA IO SIM card data input/output  Dedicated GPIO Interface  U3 GPIO0 IO General purpose input/output 0 GPIO0 CMFLAS H 5  U1 GPIO1 IO General purpose input/output 1 GPIO1 BSI_RFIN PD Input D17 GPIO2 IO General purpose input/output 2 GPIO2 SCL PU Input C19 GPIO3 IO General purpose input/output 3 GPIO3 SDA PU Input C18 GPIO4 IO General purpose input/output 4 GPIO4 EDICK URXD2 SWDBGD 7  C17 GPIO5 IO General purpose input/output 5 GPIO5 EDIWS UTXD2 SWDBGD 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | L16      | SIMCLK  | О  | SIM card clock output           |        |          |       |        |    | 0     |
| SIMDATA   IO   SIM card data input/output   Dedicated GPIO Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | L17      | SIMVCC  | 0  |                                 |        |          |       |        |    | 0     |
| Dedicated GPIO Interface  U3 GPIO0 IO General purpose input/output 0 GPIO0 CMFLAS H S SWDBGD G SPIO1 IO General purpose input/output 1 GPIO1 BSI_RFIN PD Input S SUD IO General purpose input/output 2 GPIO2 SCL PU Input Input IO GPIO3 IO General purpose input/output 3 GPIO3 SDA PU Input IO GPIO4 IO General purpose input/output 4 GPIO4 EDICK URXD2 SWDBGD T SWDBGD T IO General purpose input/output 5 GPIO5 EDIWS UTXD2 SWDBGD T IO GENERAL PURD SWDB | L18      | SIMSEL  | О  |                                 | GPIO48 | SIMSEL   |       |        | PD | Input |
| GPIO0   IO   General purpose input/output 0   GPIO0   CMFLAS   DSP_TID   FD   Input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | L19      | SIMDATA | IO |                                 |        |          |       |        |    | 0     |
| H 5 D17 GPIO1 IO General purpose input/output 1 GPIO1 BSI_RFIN PD Input Input Input IO GPIO3 IO General purpose input/output 3 GPIO3 SDA PU Input IO GPIO4 IO General purpose input/output 4 GPIO4 EDICK URXD2 SWDBGD 7 C17 GPIO5 IO General purpose input/output 5 GPIO5 EDIWS UTXD2 SWDBGD 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |          |         |    | <b>Dedicated GPIO Interface</b> |        |          |       |        |    |       |
| D17 GPIO2 IO General purpose input/output 2 GPIO2 SCL PU Input C19 GPIO3 IO General purpose input/output 3 GPIO3 SDA PU Input C18 GPIO4 IO General purpose input/output 4 GPIO4 EDICK URXD2 SWDBGD 7 C17 GPIO5 IO General purpose input/output 5 GPIO5 EDIWS UTXD2 SWDBGD 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | U3       |         | Ю  | General purpose input/output 0  | GPIO0  | Н        |       |        | PD | Input |
| C19 GPIO3 IO General purpose input/output 3 GPIO3 SDA PU Input C18 GPIO4 IO General purpose input/output 4 GPIO4 EDICK URXD2 SWDBGD 7 C17 GPIO5 IO General purpose input/output 5 GPIO5 EDIWS UTXD2 SWDBGD 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | U1       |         | IO |                                 | GPIO1  | BSI_RFIN |       |        | PD | Input |
| C18 GPIO4 IO General purpose input/output 4 GPIO4 EDICK URXD2 SWDBGD 7 C17 GPIO5 IO General purpose input/output 5 GPIO5 EDIWS UTXD2 SWDBGD 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | D17      |         | Ю  |                                 |        | SCL      |       |        |    | Input |
| C17 GPIO5 IO General purpose input/output 5 GPIO5 EDIWS UTXD2 SWDBGD 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | C19      |         | IO |                                 | GPIO3  | SDA      |       |        | PU | Input |
| 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | C18      | GPIO4   | IO | General purpose input/output 4  | GPIO4  | EDICK    | URXD2 |        |    |       |
| A19 GPIO6 IO General purpose input/output 6 GPIO6 EDIDAT SWDBGD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | C17      | GPIO5   | Ю  | General purpose input/output 5  | GPIO5  | EDIWS    | UTXD2 |        |    |       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | A19      | GPIO6   | IO | General purpose input/output 6  | GPIO6  | EDIDAT   |       | SWDBGD |    |       |



| MEDIATE                                                                  | •                                                    |                                       |                                                                                                                                                                                                                                                                                                                                       |                  |               |                 |                 |                |                                                                                     |
|--------------------------------------------------------------------------|------------------------------------------------------|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------|-----------------|-----------------|----------------|-------------------------------------------------------------------------------------|
|                                                                          |                                                      |                                       |                                                                                                                                                                                                                                                                                                                                       |                  |               |                 | 5               |                |                                                                                     |
| B18                                                                      | GPIO7                                                | Ю                                     | General purpose input/output 7                                                                                                                                                                                                                                                                                                        | GPIO7            |               | USBVBUS<br>ON   | SWDBGD<br>4     |                |                                                                                     |
| A18                                                                      | GPIO8                                                | Ю                                     | General purpose input/output 19                                                                                                                                                                                                                                                                                                       | GPIO8            | 32KHz         | USBVBUS<br>CHG  | SWDBGF          |                |                                                                                     |
| A17                                                                      | GPIO9                                                | Ю                                     | General purpose input/output 21                                                                                                                                                                                                                                                                                                       | GPIO9            | 26MHz         | 13MHz           | SWDBGE          |                |                                                                                     |
|                                                                          | <u> </u>                                             |                                       | Miscellaneous                                                                                                                                                                                                                                                                                                                         |                  |               |                 |                 |                |                                                                                     |
| T2                                                                       | SYSRST#                                              | I                                     | System reset input active low                                                                                                                                                                                                                                                                                                         |                  |               |                 |                 |                | Input                                                                               |
| R16                                                                      | WATCHDO                                              | 0                                     | Watchdog reset output                                                                                                                                                                                                                                                                                                                 |                  |               |                 |                 |                | 1                                                                                   |
| TD1                                                                      | G#                                                   |                                       | E / ITOYO II / /                                                                                                                                                                                                                                                                                                                      | CDO1             | CDCLVE        |                 |                 |                | 0                                                                                   |
| T1                                                                       | SRCLKENA<br>N                                        | О                                     | External TCXO enable output active low                                                                                                                                                                                                                                                                                                | GPO1             | SRCLKE<br>NAN |                 |                 |                | 0                                                                                   |
| T4                                                                       | SRCLKENA                                             | О                                     | External TCXO enable output active high                                                                                                                                                                                                                                                                                               | GPO0             | SRCLKE<br>NA  |                 | X               |                | 1                                                                                   |
| T3                                                                       | SRCLKENAI                                            | Ю                                     | External TCXO enable input                                                                                                                                                                                                                                                                                                            | GPIO31           | SRCLKEN<br>AI |                 |                 | PD             | Input                                                                               |
| E5                                                                       | TESTMODE                                             | I                                     | TESTMODE enable input                                                                                                                                                                                                                                                                                                                 |                  |               |                 |                 | PD             | Input                                                                               |
| D15                                                                      | ESDM_CK                                              | О                                     | Internal Monitor Clock                                                                                                                                                                                                                                                                                                                |                  |               |                 | 1               |                |                                                                                     |
|                                                                          |                                                      |                                       | Keypad Interface                                                                                                                                                                                                                                                                                                                      | •                |               |                 |                 |                |                                                                                     |
| H17                                                                      | KCOL6                                                | I                                     | Keypad column 6                                                                                                                                                                                                                                                                                                                       |                  |               |                 |                 | PU             | Input                                                                               |
| H18                                                                      | KCOL5                                                | I                                     | Keypad column 5                                                                                                                                                                                                                                                                                                                       |                  |               |                 |                 | PU             | Input                                                                               |
| H19                                                                      | KCOL4                                                | I                                     | Keypad column 4                                                                                                                                                                                                                                                                                                                       |                  | . 7           |                 |                 | PU             | Input                                                                               |
| G15                                                                      | KCOL3                                                | I                                     | Keypad column 3                                                                                                                                                                                                                                                                                                                       |                  | 1             |                 |                 | PU             | Input                                                                               |
| G16                                                                      | KCOL2                                                | I                                     | Keypad column 2                                                                                                                                                                                                                                                                                                                       |                  |               |                 |                 | PU             | Input                                                                               |
| G17                                                                      | KCOL1                                                | I                                     | Keypad column 1                                                                                                                                                                                                                                                                                                                       |                  |               |                 |                 | PU             | Input                                                                               |
| G18                                                                      | KCOL0                                                | I                                     | Keypad column 0                                                                                                                                                                                                                                                                                                                       | 70               |               |                 |                 | PU             | Input                                                                               |
| G19                                                                      | KROW5                                                | О                                     | Keypad row 5                                                                                                                                                                                                                                                                                                                          | KROW5            | GPIO44        | ARM CK          | TV CK           |                | 0                                                                                   |
| F15                                                                      | KROW4                                                | О                                     | Keypad row 4                                                                                                                                                                                                                                                                                                                          | KROW4            | GPIO45        | AHB CK          | DSP CK          |                | 0                                                                                   |
| F16                                                                      | KROW3                                                | О                                     | Keypad row 3                                                                                                                                                                                                                                                                                                                          | KROW3            | GPIO46        | FTV CK          | SLOW<br>CK      |                | 0                                                                                   |
| F17                                                                      | KROW2                                                | О                                     | Keypad row 2                                                                                                                                                                                                                                                                                                                          | KROW2            | GPIO47        | FMCU CK         | FUSB CK         |                | 0                                                                                   |
| E16                                                                      | KROW1                                                | О                                     | Keypad row 1                                                                                                                                                                                                                                                                                                                          |                  |               |                 |                 |                | 0                                                                                   |
| E17                                                                      | KROW0                                                | О                                     | Keypad row 0                                                                                                                                                                                                                                                                                                                          |                  |               |                 |                 |                | 0                                                                                   |
|                                                                          | <u> </u>                                             |                                       | External Interrupt Interface                                                                                                                                                                                                                                                                                                          | L                |               |                 |                 |                |                                                                                     |
| U2                                                                       | EINT0                                                | I                                     | External interrupt 0                                                                                                                                                                                                                                                                                                                  |                  |               |                 |                 | PU             | Input                                                                               |
| V1                                                                       | EINT1                                                | I                                     | External interrupt 1                                                                                                                                                                                                                                                                                                                  |                  |               |                 |                 | PU             | Input                                                                               |
| W1                                                                       | EINT2                                                | I                                     | External interrupt 2                                                                                                                                                                                                                                                                                                                  |                  |               |                 |                 | PU             | Input                                                                               |
|                                                                          |                                                      |                                       | External interrupt 2                                                                                                                                                                                                                                                                                                                  |                  |               |                 |                 |                |                                                                                     |
| V2                                                                       |                                                      | _                                     | •                                                                                                                                                                                                                                                                                                                                     |                  |               |                 |                 | PU             | Input                                                                               |
| V2<br>U4                                                                 | EINT3                                                | I                                     | External interrupt 3                                                                                                                                                                                                                                                                                                                  | GPIO36           | MIRO          | 6.5MHz          | 32KHz           | PU<br>PU       | Input                                                                               |
| V2<br>U4<br>B17                                                          |                                                      | _                                     | •                                                                                                                                                                                                                                                                                                                                     | GPIO36<br>GPIO63 | MIRQ<br>MFIQ  | 6.5MHz<br>USBID | 32KHz<br>SWDBGD | PU<br>PU<br>PU | Input<br>Input<br>Input                                                             |
| U4                                                                       | EINT3<br>MIRQ                                        | I<br>I                                | External interrupt 3 Interrupt to MCU Interrupt to MCU                                                                                                                                                                                                                                                                                |                  |               |                 |                 | PU             | Input                                                                               |
| U4<br>B17                                                                | EINT3<br>MIRQ<br>MFIQ                                | I<br>I<br>I                           | External interrupt 3 Interrupt to MCU Interrupt to MCU External Memory Interface                                                                                                                                                                                                                                                      |                  |               |                 | SWDBGD          | PU             | Input                                                                               |
| U4<br>B17<br>R15                                                         | EINT3 MIRQ MFIQ ED0                                  | I<br>I<br>I                           | External interrupt 3 Interrupt to MCU Interrupt to MCU  External Memory Interface  External memory data bus 0                                                                                                                                                                                                                         |                  |               |                 | SWDBGD          | PU             | Input<br>Input<br>Input                                                             |
| U4<br>B17<br>R15<br>T19                                                  | EINT3 MIRQ MFIQ ED0 ED1                              | I<br>I<br>I<br>IO<br>IO               | External interrupt 3 Interrupt to MCU Interrupt to MCU  External Memory Interface  External memory data bus 0 External memory data bus 1                                                                                                                                                                                              |                  |               |                 | SWDBGD          | PU             | Input Input Input Input                                                             |
| U4<br>B17<br>R15<br>T19<br>T18                                           | EINT3 MIRQ MFIQ  ED0 ED1 ED2                         | I I I I I I I I I I I I I I I I I I I | External interrupt 3 Interrupt to MCU Interrupt to MCU  External Memory Interface  External memory data bus 0 External memory data bus 1 External memory data bus 2                                                                                                                                                                   |                  |               |                 | SWDBGD          | PU             | Input Input Input Input Input                                                       |
| U4<br>B17<br>R15<br>T19<br>T18<br>U19                                    | EINT3 MIRQ MFIQ  ED0 ED1 ED2 ED3                     | I I I I I I I I I I I I I I I I I I I | External interrupt 3 Interrupt to MCU Interrupt to MCU  External Memory Interface External memory data bus 0 External memory data bus 1 External memory data bus 2 External memory data bus 3                                                                                                                                         |                  |               |                 | SWDBGD          | PU             | Input Input Input Input Input Input Input                                           |
| U4 B17 R15 T19 T18 U19 U18                                               | EINT3 MIRQ MFIQ  ED0 ED1 ED2 ED3 ED4                 | I I I I I I I I I I I I I I I I I I I | External interrupt 3 Interrupt to MCU Interrupt to MCU  External Memory Interface External memory data bus 0 External memory data bus 1 External memory data bus 2 External memory data bus 3 External memory data bus 4                                                                                                              |                  |               |                 | SWDBGD          | PU             | Input Input Input Input Input Input Input Input Input                               |
| U4<br>B17<br>R15<br>T19<br>T18<br>U19<br>U18<br>V19                      | EINT3 MIRQ MFIQ  ED0 ED1 ED2 ED3 ED4 ED5             | I I I I I I I I I I I I I I I I I I I | External interrupt 3 Interrupt to MCU Interrupt to MCU  External Memory Interface  External memory data bus 0 External memory data bus 1 External memory data bus 2 External memory data bus 3 External memory data bus 4 External memory data bus 5                                                                                  |                  |               |                 | SWDBGD          | PU             | Input                         |
| R15<br>T19<br>T18<br>U19<br>U18<br>V19<br>W19                            | EINT3 MIRQ MFIQ  ED0 ED1 ED2 ED3 ED4 ED5 ED6         | I I I I I I I I I I I I I I I I I I I | External interrupt 3 Interrupt to MCU Interrupt to MCU  External Memory Interface  External memory data bus 0 External memory data bus 1 External memory data bus 2 External memory data bus 3 External memory data bus 4 External memory data bus 5 External memory data bus 6                                                       |                  |               |                 | SWDBGD          | PU             | Input                   |
| U4<br>B17<br>R15<br>T19<br>T18<br>U19<br>U18<br>V19<br>W19<br>W19        | EINT3 MIRQ MFIQ  ED0 ED1 ED2 ED3 ED4 ED5 ED6 ED7     | I I I I I I I I I I I I I I I I I I I | External interrupt 3 Interrupt to MCU Interrupt to MCU  External Memory Interface  External memory data bus 0 External memory data bus 1 External memory data bus 2 External memory data bus 3 External memory data bus 4 External memory data bus 5 External memory data bus 6 External memory data bus 7                            |                  |               |                 | SWDBGD          | PU             | Input             |
| U4<br>B17<br>R15<br>T19<br>T18<br>U19<br>U18<br>V19<br>W19<br>W18<br>U17 | EINT3 MIRQ MFIQ  ED0 ED1 ED2 ED3 ED4 ED5 ED6 ED7 ED8 | I I I I I I I I I I I I I I I I I I I | External interrupt 3 Interrupt to MCU Interrupt to MCU  External Memory Interface  External memory data bus 0 External memory data bus 1 External memory data bus 2 External memory data bus 3 External memory data bus 4 External memory data bus 5 External memory data bus 6 External memory data bus 7 External memory data bus 8 |                  |               |                 | SWDBGD          | PU             | Input |
| U4<br>B17<br>R15<br>T19<br>T18<br>U19<br>U18<br>V19<br>W19<br>W19        | EINT3 MIRQ MFIQ  ED0 ED1 ED2 ED3 ED4 ED5 ED6 ED7     | I I I I I I I I I I I I I I I I I I I | External interrupt 3 Interrupt to MCU Interrupt to MCU  External Memory Interface  External memory data bus 0 External memory data bus 1 External memory data bus 2 External memory data bus 3 External memory data bus 4 External memory data bus 5 External memory data bus 6 External memory data bus 7                            |                  |               |                 | SWDBGD          | PU             | Input             |



| T15   ED13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | MEDIATEK | Č      |    |                                       |       |          |          |        |    |       |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------|----|---------------------------------------|-------|----------|----------|--------|----|-------|
| U15   ED14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | V16      | ED12   | IO | External memory data bus 12           |       |          |          |        |    | Input |
| RIDIS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | T15      | ED13   | IO | External memory data bus 13           |       |          |          |        | ı  | Input |
| PI   END#   O   External memory read strobe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | U15      | ED14   | Ю  | External memory data bus 14           |       |          |          |        |    | Input |
| Title   EWR#   O   External memory write strobe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | W15      | ED15   | IO | External memory data bus 15           |       |          |          |        |    | Input |
| U12   ECS0#   O   External memory chip select 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | P12      | ERD#   | О  | External memory read strobe           |       |          |          |        |    | 1     |
| VI   VI   ECS1#   O   External memory chip select 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | T12      | EWR#   | О  | External memory write strobe          |       |          |          |        |    | 1     |
| P11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | U12      | ECS0#  | О  | External memory chip select 0         |       |          |          |        |    | 1     |
| R11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | V12      | ECS1#  | О  | External memory chip select 1         |       |          |          |        |    | 1     |
| R14   EWAIT   O   Flash, PSRAM and CellularRAM   data ready                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | P11      | ECS2#  | О  | External memory chip select 2         |       |          |          |        |    | 1     |
| data ready                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | R11      | ECS3#  | О  | External memory chip select 3         |       |          |          |        |    | 1     |
| W14   ERAS#   O   MobileRAM row address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R14      | EWAIT  | О  | l ·                                   |       |          |          | (6)    | PU | Input |
| R13   ECKE   O   MobileRAM clock enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | T14      | ECAS#  | О  | MobileRAM column address              |       |          |          |        |    | 1     |
| T13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | W14      | ERAS#  | О  | MobileRAM row address                 |       |          |          |        |    | 1     |
| N13   ELB#   O   External memory lower byte strobe     1   1   1   1   1   1   1   1   1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | R13      | ECKE   | О  | MobileRAM clock enable                |       |          |          |        |    | 1     |
| NT1   EPDN#                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | T13      | EDCLK  | О  | MobileRAM clock                       |       |          |          |        |    |       |
| NT1   EPDN#                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | V13      | ELB#   | 0  | External memory lower byte strobe     |       |          |          |        |    | 1     |
| Till   EPDN#                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |          |        | _  |                                       |       |          |          |        |    | _     |
| Section                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |          |        |    |                                       | GPO2  | EPDN#    | 26Mhz    | 13MHz  |    |       |
| P10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | W11      |        | -  | Flash, PSRAM and CellularRAM          | 01 02 | EI DIVII | 201ville | TSWITE |    | -     |
| T10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | V11      | ECLK   | О  |                                       |       |          |          |        |    | 0     |
| T10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | P10      | EA0    | О  | External memory address bus 0         |       | To A     |          |        |    | 0     |
| U10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | T10      | EA1    | О  | -                                     |       |          |          |        |    | 0     |
| W10   EA3   O   External memory address bus 3   O   O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | U10      | EA2    | 0  | · ·                                   | 7     |          |          |        |    | 0     |
| R9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | W10      | EA3    | 0  | •                                     |       |          |          |        |    | 0     |
| T9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |        | -  | · ·                                   |       |          |          |        |    | -     |
| U9         EA6         O         External memory address bus 6         0           V9         EA7         O         External memory address bus 7         0           R8         EA8         O         External memory address bus 8         0           T8         EA9         O         External memory address bus 10         0           W8         EA10         O         External memory address bus 10         0           P8         EA11         O         External memory address bus 12         0           U7         EA12         O         External memory address bus 12         0           U7         EA13         O         External memory address bus 13         0           V7         EA14         O         External memory address bus 14         0           W7         EA15         O         External memory address bus 15         0           T6         EA16         O         External memory address bus 16         0           W6         EA18         O         External memory address bus 19         0           R5         EA19         O         External memory address bus 20         0           W5         EA20         O         External memory address bus 21         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          |        | -  | -                                     |       |          |          |        |    | -     |
| V9         EA7         O         External memory address bus 8         0           R8         EA8         O         External memory address bus 8         0           T8         EA9         O         External memory address bus 9         0           W8         EA10         O         External memory address bus 10         0           P8         EA11         O         External memory address bus 11         0           R7         EA12         O         External memory address bus 12         0           U7         EA13         O         External memory address bus 13         0           V7         EA14         O         External memory address bus 14         0           W7         EA15         O         External memory address bus 15         0           T6         EA16         O         External memory address bus 16         0           U6         EA17         O         External memory address bus 17         0           W6         EA18         O         External memory address bus 19         0           T5         EA20         O         External memory address bus 20         0           U5         EA21         O         External memory address bus 21         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |        | -  | ·                                     |       |          |          |        |    | -     |
| R8       EA8       O       External memory address bus 9       0         T8       EA9       O       External memory address bus 9       0         W8       EA10       O       External memory address bus 10       0         P8       EA11       O       External memory address bus 11       0         R7       EA12       O       External memory address bus 12       0         U7       EA13       O       External memory address bus 13       0         V7       EA14       O       External memory address bus 14       0         W7       EA15       O       External memory address bus 15       0         T6       EA16       O       External memory address bus 16       0         U6       EA17       O       External memory address bus 17       0         W6       EA18       O       External memory address bus 18       0         R5       EA19       O       External memory address bus 20       0         U5       EA20       O       External memory address bus 21       0         V5       EA22       O       External memory address bus 23       0         V4       EA23       O       External memory address bus 25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          | -      | -  |                                       |       |          |          |        |    | -     |
| T8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |        | -  |                                       |       |          |          |        |    | -     |
| W8         EA10         O         External memory address bus 10         O           P8         EA11         O         External memory address bus 11         O           R7         EA12         O         External memory address bus 12         O           U7         EA13         O         External memory address bus 13         O           V7         EA14         O         External memory address bus 14         O           W7         EA15         O         External memory address bus 15         O           T6         EA16         O         External memory address bus 16         O           U6         EA17         O         External memory address bus 17         O           W6         EA18         O         External memory address bus 18         O           R5         EA19         O         External memory address bus 20         O           U5         EA20         O         External memory address bus 21         O           V5         EA21         O         External memory address bus 23         O           V4         EA23         O         External memory address bus 23         O           V4         EA24         O         External memory address bus 25         O </td <td></td> <td></td> <td>_</td> <td>-</td> <td></td> <td></td> <td></td> <td></td> <td></td> <td>-</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |          |        | _  | -                                     |       |          |          |        |    | -     |
| P8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          | · ·    |    | ·                                     |       |          |          |        |    | -     |
| R7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          | -      |    |                                       |       |          |          |        |    | -     |
| U7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |        |    |                                       |       |          |          |        |    | -     |
| V7         EA14         O         External memory address bus 14         0           W7         EA15         O         External memory address bus 15         0           T6         EA16         O         External memory address bus 16         0           U6         EA17         O         External memory address bus 17         0           W6         EA18         O         External memory address bus 18         0           R5         EA19         O         External memory address bus 19         0           T5         EA20         O         External memory address bus 20         0           U5         EA21         O         External memory address bus 21         0           V5         EA22         O         External memory address bus 22         0           W4         EA23         O         External memory address bus 23         0           V4         EA24         O         External memory address bus 25         0           W3         EA25         O         External memory address bus 25         0           R18         USB_DP         IO         USB D+ Input/Output         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |        | _  | · · · · · · · · · · · · · · · · · · · |       |          |          |        |    |       |
| W7         EA15         O         External memory address bus 15         0           T6         EA16         O         External memory address bus 16         0           U6         EA17         O         External memory address bus 17         0           W6         EA18         O         External memory address bus 18         0           R5         EA19         O         External memory address bus 19         0           T5         EA20         O         External memory address bus 20         0           U5         EA21         O         External memory address bus 21         0           V5         EA22         O         External memory address bus 22         0           W4         EA23         O         External memory address bus 23         0           V4         EA24         O         External memory address bus 25         0           W3         EA25         O         External memory address bus 25         0           WB Interface           R18         USB_DP         IO         USB D- Input/Output         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          |        | _  |                                       |       |          |          |        |    | _     |
| T6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |        | _  |                                       |       |          |          |        |    |       |
| U6         EA17         O         External memory address bus 17         0           W6         EA18         O         External memory address bus 18         0           R5         EA19         O         External memory address bus 19         0           T5         EA20         O         External memory address bus 20         0           U5         EA21         O         External memory address bus 21         0           V5         EA22         O         External memory address bus 22         0           W4         EA23         O         External memory address bus 23         0           V4         EA24         O         External memory address bus 24         0           W3         EA25         O         External memory address bus 25         0           WB Interface           R18         USB_DP         IO         USB D+ Input/Output         IO           R19         USB_DM         IO         USB D- Input/Output         IO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |          |        | _  |                                       |       |          |          |        |    | _     |
| W6         EA18         O         External memory address bus 18         0           R5         EA19         O         External memory address bus 19         0           T5         EA20         O         External memory address bus 20         0           U5         EA21         O         External memory address bus 21         0           V5         EA22         O         External memory address bus 22         0           W4         EA23         O         External memory address bus 23         0           V4         EA24         O         External memory address bus 24         0           W3         EA25         O         External memory address bus 25         0           USB Interface           R18         USB_DP         IO         USB D+ Input/Output         IO           R19         USB_DM         IO         USB D- Input/Output         IO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |        |    |                                       |       |          |          |        |    |       |
| R5         EA19         O         External memory address bus 19         0           T5         EA20         O         External memory address bus 20         0           U5         EA21         O         External memory address bus 21         0           V5         EA22         O         External memory address bus 22         0           W4         EA23         O         External memory address bus 23         0           V4         EA24         O         External memory address bus 24         0           W3         EA25         O         External memory address bus 25         0           USB Interface           R18         USB_DP         IO         USB D+ Input/Output         IO           R19         USB_DM         IO         USB D- Input/Output         IO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          | +      |    |                                       |       |          |          |        |    |       |
| T5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |        |    | ·                                     |       |          |          |        |    | _     |
| USB_DP   IO   USB_DP   IO   USB_D- Input/Output   USB_DM   IO   USB_D- Input/Output   USB_DM   IO   USB_D- Input/Output   USB_DM   IO   USB_D- Input/Output   USB_DM   IO   USB_D- Input/Output   IO   USB_D- In |          |        |    |                                       |       |          |          |        |    | _     |
| V5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |        |    |                                       |       |          |          |        |    | _     |
| W4         EA23         O         External memory address bus 23         0           V4         EA24         O         External memory address bus 24         0           W3         EA25         O         External memory address bus 25         0           USB Interface           R18         USB_DP         IO         USB D+ Input/Output                     R19         USB_DM         IO         USB D- Input/Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          |        |    |                                       |       |          |          |        |    |       |
| V4         EA24         O         External memory address bus 24         0           W3         EA25         O         External memory address bus 25         0           USB Interface           R18         USB_DP         IO         USB D+ Input/Output                     R19         USB_DM         IO         USB D- Input/Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |          | +      | -  | •                                     |       |          |          |        |    |       |
| W3   EA25   O   External memory address bus 25   O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |          |        |    | -                                     |       |          |          |        |    |       |
| USB Interface           R18         USB_DP         IO         USB D+ Input/Output         IO           R19         USB_DM         IO         USB D- Input/Output         IO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |          |        |    | -                                     |       |          |          |        |    |       |
| R18         USB_DP         IO         USB D+ Input/Output           R19         USB_DM         IO         USB D- Input/Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | W3       | EA25   | 0  | •                                     |       |          |          |        |    | 0     |
| R19 USB_DM IO USB D- Input/Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |          |        |    | USB Interface                         |       |          |          |        |    |       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | R18      | USB_DP | IO | USB D+ Input/Output                   |       |          |          |        |    |       |
| Memory Card Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | R19      | USB_DM | IO | USB D- Input/Output                   |       |          |          |        |    |       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |        |    | Memory Card Interface                 |       |          |          |        |    |       |



| MEDIATEK | `         |    |                                           |            |               |       |              |           |       |
|----------|-----------|----|-------------------------------------------|------------|---------------|-------|--------------|-----------|-------|
| P17      | МССМ0     | Ю  | SD Command/MS Bus State Output            |            |               |       |              | PU/<br>PD |       |
| P18      | MCDA0     | Ю  | SD Serial Data IO 0/MS Serial Data IO     |            |               |       |              | PU/<br>PD |       |
| P19      | MCDA1     | Ю  | SD Serial Data IO 1                       |            |               |       |              | PU/<br>PD |       |
| N17      | MCDA2     | Ю  | SD Serial Data IO 2                       |            |               |       |              | PU/<br>PD |       |
| N18      | MCDA3     | Ю  | SD Serial Data IO 3                       |            |               |       |              | PU/<br>PD |       |
| M18      | MCCK      | О  | SD Serial Clock/MS Serial Clock<br>Output |            |               |       |              |           |       |
| N19      | MCPWRON   | О  | SD Power On Control Output                |            |               |       |              |           |       |
| M16      | MCWP      | I  | SD Write Protect Input                    |            |               |       | *            | PU/<br>PD | Input |
| M17      | MCINS     | I  | SD Card Detect Input                      |            |               |       |              | PU/<br>PD | Input |
|          |           |    | UART/IrDA Interface                       |            |               |       |              |           |       |
| K15      | URXD1     | I  | UART 1 receive data                       |            |               |       |              | PU        | Input |
| K16      | UTXD1     | 0  | UART 1 transmit data                      |            |               |       |              |           | 1     |
| K17      | UCTS1     | I  | UART 1 clear to send                      |            |               | 707   |              | PU        | Input |
| K18      | URTS1     | О  | UART 1 request to send                    |            | 0             |       |              |           | 1     |
| K19      | URXD2     | Ю  | UART 2 receive data                       | GPIO37     | URXD2         | UCTS3 |              | PU        | Input |
| J15      | UTXD2     | Ю  | UART 2 transmit data                      | GPIO38     | UTXD2         | URTS3 |              | PU        | Input |
| J16      | URXD3     | Ю  | UART 3 receive data                       | GPIO39     | URXD3         |       |              | PU        | Input |
| J17      | UTXD3     | Ю  | UART 3 transmit data                      | GPIO40     | UTXD3         |       | DSP_TID 6    | PU        | Input |
| J19      | IRDA_RXD  | Ю  | IrDA receive data                         | GPIO41     | IRDA_RX<br>D  | UCTS2 | SWDBGD<br>15 | PU        | Input |
| H15      | IRDA_TXD  | Ю  | IrDA transmit data                        | GPIO42     | IRDA_TX<br>D  | URTS2 | SWDBG1<br>4  | PU        | Input |
| H16      | IRDA_PDN  | Ю  | IrDA Power Down Control                   | GPIO43     | IRDA_PD<br>N  |       | SWDBG1       | PU        | Input |
|          |           |    | Digital Audio Interface                   |            |               |       |              |           |       |
| E18      | DAICLK    | Ю  | DAI clock output                          | GPIO49     | DAICLK        |       | SWDBGD<br>12 | PU        | Input |
| E19      | DAIPCMOUT | Ю  | DAI pcm data out                          | GPIO50     | DAIPCMO<br>UT |       | SWDBGD<br>11 | PD        | Input |
| D16      | DAIPCMIN  | Ю  | DAI pcm data input                        | GPIO51     | DAIPCMI<br>N  |       | SWDBGD<br>10 | PU        | Input |
| D19      | DAIRST    | IO | DAI reset signal input                    | GPIO52     | DAIRST        |       | SWDBG9       | PU        | Input |
| D18      | DAISYNC   | Ю  | DAI frame synchronization signal output   | GPIO53     | DAISYNC       |       | SWDBG8       | PU        | Input |
|          |           |    | CMOS Sensor Interface                     |            |               |       |              |           |       |
| J12      | CMRST     | IO | CMOS sensor reset signal output           | GPIO12     | CMRST         |       |              | PD        | Input |
| K12      | CMPDN     | Ю  | CMOS sensor power down control            | GPIO13     | CMPDN         |       |              | PD        | Input |
| H12      | CMVREF    | I  | Sensor vertical reference signal input    |            |               |       |              | PD        | Input |
| H11      | CMHREF    | I  | Sensor horizontal reference signal input  |            |               |       |              | PD        | Input |
| Н9       | CMPCLK    | I  | CMOS sensor pixel clock input             |            |               |       |              | PD        | Input |
| H10      | CMMCLK    | 0  | CMOS sensor master clock output           |            |               |       |              |           | 0     |
| Н8       | CMDAT9    | I  | CMOS sensor data input 9                  | CMDAT<br>9 | GPIO74        |       |              | PD        | Input |
| J8       | CMDAT8    | I  | CMOS sensor data input 8                  | CMDAT<br>8 | GPIO73        |       |              | PD        | Input |
| K8       | CMDAT7    | I  | CMOS sensor data input 7                  | CMDAT      | GPIO72        |       |              | PD        | Input |
|          |           |    | 1                                         |            |               |       |              |           |       |



| MEDIATEK |                  |    |                                               |            |        |   |    |       |
|----------|------------------|----|-----------------------------------------------|------------|--------|---|----|-------|
|          |                  |    |                                               | 7          |        |   |    |       |
| L8       | CMDAT6           | I  | CMOS sensor data input 6                      | CMDAT<br>6 | GPIO71 |   | PD | Input |
| M8       | CMDAT5           | I  | CMOS sensor data input 5                      | CMDAT<br>5 | GPIO70 |   | PD | Input |
| M9       | CMDAT4           | I  | CMOS sensor data input 4                      | CMDAT<br>4 | GPIO69 |   | PD | Input |
| M10      | CMDAT3           | I  | CMOS sensor data input 3                      | CMDAT<br>3 | GPIO68 |   | PD | Input |
| M11      | CMDAT2           | I  | CMOS sensor data input 2                      | CMDAT 2    | GPIO62 | 4 | PD | Input |
| M12      | CMDAT1           | Ю  | CMOS sensor data input 1                      | GPIO50     | CMDAT1 |   | PD | Input |
| L12      | CMDAT0           | IO | CMOS sensor data input 0                      | GPIO51     | CMDAT0 |   | PD | Input |
|          |                  |    | Analog Interface                              |            |        |   |    |       |
| 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            |            |        | 1 |    |       |
| 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<br>S_P |    | Microphone bias supply (+)                    |            |        |   |    |       |
| D12      | AU_MICBIA<br>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   |            |        |   |    |       |
| В9       | 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  |            |        |   |    |       |
| В7       | 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 |   |   |     |   | A |   |
|     |              |   | VCXO Interface                                     |   |   |     |   |   |   |
| B1  | SYSCLK       |   | 13MHz or 26MHz system clock input                  |   |   |     |   |   |   |
| F6  | PLLOUT       |   | PLL reference voltage output                       |   |   |     | A |   |   |
|     | 122001       |   | RTC Interface                                      |   |   |     |   |   |   |
| D1  | XIN          |   | 32.768 KHz crystal input                           |   |   |     |   |   |   |
| D2  | XOUT         |   | 32.768 KHz crystal output                          |   |   |     |   |   |   |
| E1  | BBWAKEUP     | 0 | Baseband power on/off control                      |   |   |     |   |   | 1 |
|     | DDWARECI     |   | TV Interface                                       |   |   |     |   |   | 1 |
| A2  | TVOUT        |   | TV DAC Output                                      |   |   | 0   |   |   |   |
| C2  | FSRES        |   | 1. 2.10 Guiput                                     |   |   |     |   |   |   |
|     | - 521245     |   | Supply Voltages                                    |   |   | -63 |   |   |   |
| E3  | VDDK         |   | Supply voltage of internal logic                   |   |   |     |   |   |   |
| M2  | VDDK         |   | Supply voltage of internal logic                   |   |   |     |   |   |   |
| V8  | VDDK<br>VDDK |   | Supply voltage of internal logic                   |   |   |     |   |   |   |
| V14 | VDDK         |   | Supply voltage of internal logic                   |   |   | )—— |   |   |   |
| F18 | VDDK         |   | Supply voltage of internal logic                   |   |   |     |   |   |   |
| F11 | VDDK         |   | Supply voltage of internal logic                   |   | 7 |     |   |   |   |
| V3  | VDD33_EMI    |   | Supply voltage of memory interface driver          |   |   |     |   |   |   |
| V6  | VDD33_EMI    |   | Supply voltage of memory interface driver          |   |   |     |   |   |   |
| T7  | VDD33_EMI    |   | Supply voltage of memory interface driver          |   |   |     |   |   |   |
| W9  | VDD33_EMI    |   | Supply voltage of memory interface driver          | 5 |   |     |   |   |   |
| R10 | VDD33_EMI    |   | Supply voltage of memory interface driver          |   |   |     |   |   |   |
| W12 | VDD33_EMI    |   | Supply voltage of memory interface driver          |   |   |     |   |   |   |
| U13 | VDD33_EMI    |   | Supply voltage of memory interface driver          |   |   |     |   |   |   |
| V15 | VDD33_EMI    |   | Supply voltage of memory interface driver          |   |   |     |   |   |   |
| T17 | VDD33_EMI    |   | Supply voltage of memory interface driver          |   |   |     |   |   |   |
| V17 | VDD33_EMI    |   | Supply voltage of memory interface driver          |   |   |     |   |   |   |
| W5  | VSS33_EMI    |   | Ground of memory interface driver                  |   |   |     |   |   |   |
| R6  | VSS33_EMI    |   | Ground of memory interface driver                  |   |   |     |   |   |   |
| U8  | VSS33_EMI    |   | Ground of memory interface driver                  |   |   |     |   |   |   |
| V10 | VSS33_EMI    |   | Ground of memory interface driver                  |   |   |     |   |   |   |
| U11 | VSS33_EMI    |   | Ground of memory interface driver                  |   |   |     |   |   |   |
| R12 | VSS33_EMI    |   | Ground of memory interface driver                  |   |   |     |   |   |   |
| U14 | VSS33_EMI    |   | Ground of memory interface driver                  |   |   |     |   |   |   |
| W16 | VSS33_EMI    |   | Ground of memory interface driver                  |   |   |     |   |   |   |
| R17 | VSS33_EMI    |   | Ground of memory interface driver                  |   |   |     |   |   |   |
| V18 | VSS33_EMI    |   | Ground of memory interface driver                  |   |   |     |   |   |   |



| MEDIATE | K         |                                                                            |   |  |  |
|---------|-----------|----------------------------------------------------------------------------|---|--|--|
| P16     | VDD33_AUX | Supply voltage of drivers for USB                                          |   |  |  |
| N16     | VDD33_AUX | Supply Voltage of MS/MMC/SD                                                |   |  |  |
| G2      | VDD33     | Supply voltage of drivers except<br>memory interface, USB and<br>MS/MMC/SD |   |  |  |
| K1      | VDD33     | Supply voltage of drivers except<br>memory interface, USB and<br>MS/MMC/SD |   |  |  |
| R1      | VDD33     | Supply voltage of drivers except<br>memory interface, USB and<br>MS/MMC/SD |   |  |  |
| J18     | VDD33     | Supply voltage of drivers except<br>memory interface, USB and<br>MS/MMC/SD |   |  |  |
| B19     | VDD33     | Supply voltage of drivers except<br>memory interface, USB and<br>MS/MMC/SD | 7 |  |  |
| E15     | VDD33     | Supply voltage of drivers except<br>memory interface, USB and<br>MS/MMC/SD |   |  |  |
| E13     | VDD33     | Supply voltage of drivers except<br>memory interface, USB and<br>MS/MMC/SD |   |  |  |
| E11     | VDD33     | Supply voltage of drivers except<br>memory interface, USB and<br>MS/MMC/SD |   |  |  |
| F9      | VDD33     | Supply voltage of drivers except<br>memory interface, USB and<br>MS/MMC/SD |   |  |  |
| E6      | VDD33     | Supply voltage of drivers except<br>memory interface, USB and<br>MS/MMC/SD |   |  |  |
| D4      | VDD33     | Supply voltage of drivers except<br>memory interface, USB and<br>MS/MMC/SD |   |  |  |
| В3      | VDD33     | Supply voltage of drivers except<br>memory interface, USB and<br>MS/MMC/SD |   |  |  |
| W2      | VSS33     | Ground of drivers except memory interface, USB and MS/MMC/SD               |   |  |  |
| E2      | VSS33     | Ground of drivers except memory interface, USB and MS/MMC/SD               |   |  |  |
| H1      | VSS33     | Ground of drivers except memory interface, USB and MS/MMC/SD               |   |  |  |
| M1      | VSS33     | Ground of drivers except memory interface, USB and MS/MMC/SD               |   |  |  |
| L15     | VSS33     | Ground of drivers except memory interface, USB and MS/MMC/SD               |   |  |  |
| F19     | VSS33     | Ground of drivers except memory interface, USB and MS/MMC/SD               |   |  |  |
| B16     | VSS33     | Ground of drivers except memory interface, USB and MS/MMC/SD               |   |  |  |
| A16     | VSS33     | Ground of drivers except memory interface, USB and MS/MMC/SD               |   |  |  |
| E14     | VSS33     | Ground of drivers except memory interface, USB and MS/MMC/SD               |   |  |  |
| E12     | VSS33     | Ground of drivers except memory interface, USB and MS/MMC/SD               |   |  |  |



| MEDIATE |                  |                                                                  |   |     |   |  |   |
|---------|------------------|------------------------------------------------------------------|---|-----|---|--|---|
| F10     | VSS33            | Ground of drivers except memory interface, USB and MS/MMC/SD     |   |     |   |  |   |
| E7      | VSS33            | Ground of drivers except memory interface, USB and MS/MMC/SD     |   |     |   |  |   |
| D5      | VSS33            | Ground of drivers except memory interface, USB and MS/MMC/SD     |   |     |   |  |   |
| A3      | VSS33            | Ground of drivers except memory interface, USB and MS/MMC/SD     |   |     |   |  | T |
| A1      | AVDD_PLL         | Supply voltage for PLL                                           |   |     |   |  |   |
| C1      | AVSS_PLL         | Ground for PLL supply                                            |   |     |   |  |   |
| B2      | AVDD_TV          | Supply voltage for TV out                                        |   |     |   |  |   |
| C3      | AVSS_TV          | Ground for TV out                                                |   |     |   |  |   |
| D3      | AVDD_RTC         | Supply voltage for Real Time Clock                               |   |     |   |  |   |
|         |                  | Analog Supplies                                                  |   |     |   |  |   |
| C15     | AVDD_MBU<br>F    | Supply Voltage for Audio band section                            |   |     |   |  |   |
| D14     | AVSS_MBUF        | GND for Audio band section                                       |   |     |   |  |   |
| B13     | AVDD_BUF         | Supply voltage for voice band transmit section                   |   |     | 6 |  |   |
| A13     | AVSS_BUF         | GND for voice band transmit section                              |   |     |   |  |   |
| D11     | AVDD_AFE         | Supply voltage for voice band receive section                    |   | . 0 |   |  |   |
| A11     | AGND_AFE         | GND reference voltage for voice band section                     |   |     |   |  |   |
| E10     | AVSS_AFE         | GND for voice band receive section                               |   | 7/1 |   |  |   |
| E9      | AGND_RFE         | GND reference voltage for baseband section, APC, AFC and AUXADC  |   |     |   |  |   |
| E8      | AVSS_GSMR<br>FTX | GND for baseband transmit section                                |   | ,   |   |  |   |
| D7      | AVDD_GSM<br>RFTX | Supply voltage for baseband transmit section                     |   |     |   |  |   |
| C7      | AVSS_RFE         | GND for baseband receive section, APC, AFC and AUXADC            | 5 |     |   |  |   |
| A7      | AVDD_RFE         | Supply voltage for baseband receive section, APC, AFC and AUXADC | , |     |   |  |   |

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



# 2.5 Power Description

| Ball  |          |           | 1          | 1           |          | 1         |
|-------|----------|-----------|------------|-------------|----------|-----------|
| 13X13 | Name     | IO Supply | IO GND     | Core Supply | Core GND | Remark    |
| A16   | VSS33    |           |            |             |          |           |
| E15   | VDD33    |           |            |             |          | Typ. 2.8V |
| E14   | VSS33    |           |            |             |          | -71       |
| E13   | VDD33    |           |            |             |          | Typ. 2.8V |
| E12   | VSS33    |           |            |             |          | 71        |
| E11   | VDD33    |           |            |             |          | Typ. 2.8V |
| F11   | VDDK     |           |            |             |          | Typ. 1.2V |
| F10   | VSS33    |           |            |             |          | X         |
| F9    | VDD33    |           |            |             |          | Typ. 2.8V |
| E7    | VSS33    |           |            |             |          |           |
| E6    | VDD33    |           |            |             |          | Typ. 2.8V |
| D5    | VSS33    |           |            |             |          |           |
| J12   | CMRST    | VDD33     | VSS33      | VDDK        | VSSK     |           |
| K12   | CMPDN    | VDD33     | VSS33      | VDDK        | VSSK     |           |
| H12   | CMVREF   | VDD33     | VSS33      | VDDK        | VSSK     |           |
| H11   | CMHREF   | VDD33     | VSS33      | VDDK        | VSSK     |           |
| Н9    | CMPCLK   | VDD33     | VSS33      | VDDK        | VSSK     |           |
| H10   | CMMCLK   | VDD33     | VSS33      | VDDK        | VSSK     |           |
| D4    | VDD33    |           |            |             |          | Typ. 2.8V |
| H8    | CMDAT9   | VDD33     | VSS33      | VDDK        | VSSK     |           |
| J8    | CMDAT8   | VDD33     | VSS33      | VDDK        | VSSK     |           |
| K8    | CMDAT7   | VDD33     | VSS33      | VDDK        | VSSK     |           |
| L8    | CMDAT6   | VDD33     | VSS33      | VDDK        | VSSK     |           |
| M8    | CMDAT5   | VDD33     | VSS33      | VDDK        | VSSK     |           |
| A3    | VSS33    |           | . (2)      |             |          |           |
| M9    | CMDAT4   | VDD33     | VSS33      | VDDK        | VSSK     |           |
| M10   | CMDAT3   | VDD33     | VSS33      | VDDK        | VSSK     |           |
| M11   | CMDAT2   | VDD33     | VSS33      | VDDK        | VSSK     |           |
| M12   | CMDAT1   | VDD33     | VSS33      | VDDK        | VSSK     |           |
| L12   | CMDAT0   | VDD33     | VSS33      | VDDK        | VSSK     |           |
| В3    | VDD33    |           | • <u> </u> |             |          | Typ. 2.8V |
| B2    | AVDD_TV  |           |            |             |          | Typ. 2.8V |
| A2    | TVOUT    | AVDD_TV   | AVSS_TV    | AVDD_TV     | AVSS_TV  |           |
| C2    | FSRES    | AVDD_TV   | AVSS_TV    | AVDD_TV     | AVSS_TV  |           |
| C3    | AVSS_TV  |           |            |             |          |           |
| A1    | AVDD_PLL |           |            |             |          | Typ. 2.8V |
| B1    | SYSCLK   | AVDD_PLL  | AVSS_PLL   | AVDD_PLL    | AVSS_PLL |           |
| F6    | PLLOUT   | AVDD_PLL  | AVSS_PLL   | AVDD_PLL    | AVSS_PLL |           |
| C1    | AVSS_PLL |           |            |             |          |           |
| D3    | AVDD_RTC |           |            |             |          | Typ. 1.2V |
| D2    | XOUT     | AVDD_RTC  | VSS33      | AVDD_RTC    | VSS33    |           |
| D1    | XIN      | AVDD_RTC  | VSS33      | AVDD_RTC    | VSS33    |           |
| E1    | BBWAKEUP | AVDD_RTC  | VSS33      | AVDD_RTC    | VSS33    |           |
| E2    | VSS33    |           |            | 1           |          |           |
| E5    | TESTMODE | VDD33     | VSS33      | VDDK        | VSSK     |           |
| E3    | VDDK     |           |            |             |          | Typ. 1.2V |
| E4    | JTRST#   | VDD33     | VSS33      | VDDK        | VSSK     |           |
| F5    | JTCK     | VDD33     | VSS33      | VDDK        | VSSK     |           |



| MEDIATER | •        |       |       |      |      |           |
|----------|----------|-------|-------|------|------|-----------|
| F4       | JTDI     | VDD33 | VSS33 | VDDK | VSSK |           |
| F3       | JTMS     | VDD33 | VSS33 | VDDK | VSSK |           |
| F2       | JTDO     | VDD33 | VSS33 | VDDK | VSSK |           |
| F1       | JRTCK    | VDD33 | VSS33 | VDDK | VSSK |           |
| G5       | BPI_BUS0 | VDD33 | VSS33 | VDDK | VSSK |           |
| G4       | BPI_BUS1 | VDD33 | VSS33 | VDDK | VSSK |           |
| G2       | VDD33    |       |       |      |      | Typ. 2.8V |
| G3       | BPI_BUS2 | VDD33 | VSS33 | VDDK | VSSK |           |
| G1       | BPI_BUS3 | VDD33 | VSS33 | VDDK | VSSK |           |
| J6       | BPI_BUS4 | VDD33 | VSS33 | VDDK | VSSK |           |
| H5       | BPI_BUS5 | VDD33 | VSS33 | VDDK | VSSK |           |
| H4       | BPI_BUS6 | VDD33 | VSS33 | VDDK | VSSK |           |
| Н3       | BPI_BUS7 | VDD33 | VSS33 | VDDK | VSSK | 7         |
| H2       | BPI_BUS8 | VDD33 | VSS33 | VDDK | VSSK |           |
| H1       | VSS33    |       |       |      |      |           |
| J5       | BPI_BUS9 | VDD33 | VSS33 | VDDK | VSSK |           |
| J4       | BSI_CS0  | VDD33 | VSS33 | VDDK | VSSK |           |
| J3       | BSI_DATA | VDD33 | VSS33 | VDDK | VSSK |           |
| J2       | BSI_CLK  | VDD33 | VSS33 | VDDK | VSSK |           |
| J1       | LSCK     | VDD33 | VSS33 | VDDK | VSSK |           |
| K5       | LSA0     | VDD33 | VSS33 | VDDK | VSSK |           |
| K4       | LSDA     | VDD33 | VSS33 | VDDK | VSSK |           |
| K3       | LSCE0#   | VDD33 | VSS33 | VDDK | VSSK |           |
| K2       | LSCE1#   | VDD33 | VSS33 | VDDK | VSSK |           |
| K1       | VDD33    |       |       |      |      | Typ. 2.8V |
| K6       | LPCE1#   | VDD33 | VSS33 | VDDK | VSSK |           |
| L5       | LPCE0#   | VDD33 | VSS33 | VDDK | VSSK |           |
| L4       | LRST#    | VDD33 | VSS33 | VDDK | VSSK |           |
| L3       | LRD#     | VDD33 | VSS33 | VDDK | VSSK |           |
| L2       | LPA0     | VDD33 | VSS33 | VDDK | VSSK |           |
| L1       | LWR#     | VDD33 | VSS33 | VDDK | VSSK |           |
| L6       | NLD7     | VDD33 | VSS33 | VDDK | VSSK |           |
| M5       | NLD6     | VDD33 | VSS33 | VDDK | VSSK |           |
| M4       | NLD5     | VDD33 | VSS33 | VDDK | VSSK |           |
| M1       | VSS33    |       |       |      |      |           |
| M2       | VDDK     |       |       |      |      | Typ. 1.2V |
| M3       | NLD4     | VDD33 | VSS33 | VDDK | VSSK |           |
| N5       | NLD3     | VDD33 | VSS33 | VDDK | VSSK |           |
| N4       | NLD2     | VDD33 | VSS33 | VDDK | VSSK |           |
| N3       | NLD1     | VDD33 | VSS33 | VDDK | VSSK |           |
| N2       | NLD0     | VDD33 | VSS33 | VDDK | VSSK |           |
| N1       | NRNB     | VDD33 | VSS33 | VDDK | VSSK |           |
| P5       | NCLE     | VDD33 | VSS33 | VDDK | VSSK |           |
| P4       | NALE     | VDD33 | VSS33 | VDDK | VSSK |           |
| P3       | NWE#     | VDD33 | VSS33 | VDDK | VSSK |           |
| P2       | NRE#     | VDD33 | VSS33 | VDDK | VSSK |           |
| P1       | NCE#     | VDD33 | VSS33 | VDDK | VSSK |           |
| R1       | VDD33    |       |       |      |      | Typ. 2.8V |
| R4       | PWM1     | VDD33 | VSS33 | VDDK | VSSK | V 1       |
| R3       | PWM2     | VDD33 | VSS33 | VDDK | VSSK |           |
| R2       |          | -     |       | VDDK |      |           |
|          | ALERTER  | VDD33 | VSS33 | -    | VSSK |           |
| T4       | SRCLKENA | VDD33 | VSS33 | VDDK | VSSK |           |



| M             |                    | MT6228 G               | iSM/GPRS Ba | seband Proc | essor Data S | Sheet Revisi     |
|---------------|--------------------|------------------------|-------------|-------------|--------------|------------------|
| EDIATER 1     | SRCLKENAN          | VDD33                  | VSS33       | VDDK        | VSSK         |                  |
| 3             | SRCLKENAI          | VDD33                  | VSS33       | VDDK        | VSSK         |                  |
| 72            | SYSRST#            | VDD33                  | VSS33       | VDDK        | VSSK         |                  |
| J3            | GPIO0              | VDD33                  | VSS33       | VDDK        | VSSK         |                  |
| J1            | GPIO1              | VDD33                  | VSS33       | VDDK        | VSSK         |                  |
| J2            | EINTO              | VDD33                  | VSS33       | VDDK        | VSSK         |                  |
| 71            | EINT1              | VDD33                  | VSS33       | VDDK        | VSSK         |                  |
| V1<br>V1      |                    |                        |             |             | +            |                  |
| v 1<br>72     | EINT2              | VDD33                  | VSS33       | VDDK        | VSSK         |                  |
|               | EINT3              | VDD33                  | VSS33       | VDDK        | VSSK         |                  |
| V2            | VSS33              |                        |             |             | -            | <b>*</b> 100 011 |
| 73            | VDD33_EMI          | WDD00 F1 F             | Magaz E. S  | VDDV        | MOCH         | Typ. 1.8/2.8V    |
| J4            | MIRQ               | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| V3            | EA25               | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 4             | EA24               | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| V4<br>V5      | EA23               | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 5             | VSS33_EMI<br>EA22  | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| <u></u><br>15 | EA21               | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 5<br>5        | EA20               | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 5             | EA19               | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 6             | VDD33_EMI          | 1 11=                  |             |             |              | Typ. 1.8/2.8V    |
| /6            | EA18               | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         | 31               |
| 6             | EA17               | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 5             | EA16               | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 26            | VSS33_EMI          |                        |             |             |              |                  |
| V7            | EA15               | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 77            | EA14               | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 7             | EA13               | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 7             | VDD33_EMI          |                        |             |             |              | Typ. 1.8/2.8V    |
| 7             | EA12               | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 3             | EA11               | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 8             | EA10               | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         | T 1 2V           |
| 8             | VDDK<br>VSS33_EMI  |                        |             |             |              | Typ. 1.2V        |
| 8             | EA9                | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 8             | EA8                | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 9             | EA7                | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 79            | VDD33_EMI          |                        |             |             |              | Typ. 1.8/2.8V    |
| 9             | EA6                | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         | 71               |
| 9             | EA5                | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 9             | EA4                | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 10            | VSS33_EMI          |                        |             |             |              |                  |
| 10            | EA3                | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 10            | EA2                | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 10            | EA1                | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 10            | VDD33_EMI          |                        |             |             |              | Typ. 1.8/2.8V    |
| 10            | EA0                | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 11            | EADV#              | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 11            | ECLK               | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 11            | VSS33_EMI<br>EPDN# | VDD33_EMI              | VSS33_EMI   | VDDK        | VSSK         |                  |
| 11            | ECS3#              | VDD33_EMI<br>VDD33_EMI | VSS33_EMI   | VDDK        | VSSK         |                  |
| VII           | EC35#              | ND33_EMII              | A 2022 EIMI | אטטא        | Acca         |                  |



| MEDIATEK |            |            |            |        |       |               |
|----------|------------|------------|------------|--------|-------|---------------|
| P11      | ECS2#      | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| W12      | VDD33_EMI  |            |            |        |       | Typ. 1.8/2.8V |
| V12      | ECS1#      | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| U12      | ECS0#      | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| T12      | EWR#       | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| R12      | VSS33_EMI  |            |            |        |       |               |
| P12      | ERD#       | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| W13      | EUB#       | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| V13      | ELB#       | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| U13      | VDD33_EMI  |            |            |        |       | Typ. 1.8/2.8V |
| T13      | EDCLK      | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  | 71            |
| R13      | ECKE       | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  | 2.0           |
| W14      | ERAS#      | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| V14      | VDDK       | VBB33_ENH  | V 5555_ENT | , DDII | VSSIL | Typ. 1.2V     |
| U14      | VSS33_EMI  |            |            |        |       | 1yp. 1.2 v    |
| T14      | ECAS#      | VDD33_EMI  | VSS33_EMI  |        | -0    |               |
| R14      | EWAIT      | VDD33_EMI  | VSS33_EMI  |        |       |               |
| W15      |            | _          | _          | VDDK   | VSSK  |               |
|          | ED15       | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  | T 1 0/2 0V    |
| V15      | VDD33_EMI  | VDD22 EMI  | MCC22 EMI  | VDDV   | VCCK  | Typ. 1.8/2.8V |
| U15      | ED14       | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| T15      | ED13       | VDD33_EMI  | VSS33_EMI  |        | VSSK  |               |
| V16      | ED12       | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| W16      | VSS33_EMI  |            |            |        |       |               |
| U16      | ED11       | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| T16      | ED10       | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| W17      | ED9        | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| V17      | VDD33_EMI  |            |            |        |       | Typ. 1.8/2.8V |
| U17      | ED8        | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| W18      | ED7        | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| W19      | ED6        | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| V18      | VSS33_EMI  |            |            |        |       |               |
| V19      | ED5        | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  | 1.2V          |
| U18      | ED4        | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| U19      | ED3        | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| T17      | VDD33_EMI  |            |            |        |       | Typ. 1.8/2.8V |
| T18      | ED2        | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| T19      | ED1        | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| R15      | ED0        | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| R16      | WATCHDOG   | VDD33_EMI  | VSS33_EMI  | VDDK   | VSSK  |               |
| R17      | VSS33_EMI  |            |            |        |       |               |
| R18      | USB_DP     | VDD33_AUX2 | VSS33      | VDDK   | VSSK  |               |
| R19      | USB_DM     | VDD33_AUX2 | VSS33      | VDDK   | VSSK  |               |
| P16      | VDD33_AUX2 |            |            |        |       | Typ. 3.3V     |
| N16      | VDD33_AUX1 |            |            |        |       | Typ. 3.3V     |
| P17      | MCCM0      | VDD33_AUX1 | VSS33      | VDDK   | VSSK  |               |
| P18      | MCDA0      | VDD33_AUX1 | VSS33      | VDDK   | VSSK  |               |
| P19      | MCDA1      | VDD33_AUX1 | VSS33      | VDDK   | VSSK  |               |
| N17      | MCDA2      | VDD33_AUX1 | VSS33      | VDDK   | VSSK  |               |
| N18      | MCDA3      | VDD33_AUX1 | VSS33      | VDDK   | VSSK  |               |
| N19      | MCPWRON    | VDD33_AUX1 | VSS33      | VDDK   | VSSK  |               |
| M16      | MCWP       | VDD33_AUX1 | VSS33      | VDDK   | VSSK  |               |
| M17      | MCINS      | VDD33_AUX1 | VSS33      | VDDK   | VSSK  |               |
| M18      | MCCK       | VDD33_AUX1 | VSS33      | VDDK   | VSSK  |               |
| 14110    | MCCK       | AUVI       | 4 CCOO 4   | 4 DUK  | A DOL |               |



| MEDIATEK      |           |         |       |                                         |                                         |           |
|---------------|-----------|---------|-------|-----------------------------------------|-----------------------------------------|-----------|
| L15           | VSS33     |         |       |                                         |                                         |           |
| M19           | SIMRST    | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| L16           | SIMCLK    | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| L17           | SIMVCC    | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| L18           | SIMSEL    | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| L19           | SIMDATA   | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| K15           | URXD1     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| K16           | UTXD1     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| K17           | UCTS1     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| K18           | URTS1     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| K19           | URXD2     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| J15           | UTXD2     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| J16           | URXD3     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| J17           | UTXD3     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| J18           | VDD33     |         |       |                                         |                                         | Typ. 2.8V |
| J19           | IRDA_RXD  | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| H15           | IRDA_TXD  | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| H16           | IRDA_PDN  | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| H17           | KCOL6     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| H18           | KCOL5     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| H19           | KCOL4     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| G15           | KCOL3     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| G16           | KCOL2     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| G17           | KCOL1     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| G18           | KCOL0     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| G19           | KROW5     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| F15           | KROW4     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| F16           | KROW3     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| F17           | KROW2     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| F18           | VDDK      | , , , , | 10000 | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | Typ. 1.2V |
| F19           | VSS33     |         | 70    |                                         |                                         | -51       |
| E16           | KROW1     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| E17           | KROW0     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| E18           | DAICLK    | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| E19           | DAIPCMOUT | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| D16           | DAIPCMIN  | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| D19           | DAIRST    | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| D18           | DAISYNC   | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| D17           | GPIO2     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| C19           | GPIO3     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| C18           | GPIO4     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| B19           | VDD33     |         | -     |                                         |                                         | Typ. 2.8V |
| C17           | GPIO5     | VDD33   | VSS33 | VDDK                                    | VSSK                                    | 31        |
| A19           | GPIO6     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| B18           | GPIO7     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| B17           | MFIQ      | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| A18           | GPIO8     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| A17           | GPIO9     | VDD33   | VSS33 | VDDK                                    | VSSK                                    |           |
| B16           | VSS33     |         |       |                                         |                                         |           |
| C15           | AVDD_MBUF |         |       |                                         |                                         | Typ. 2.8V |
| B15           | AU_MOUTL  |         |       |                                         |                                         |           |
| A15           | AU_MOUTR  |         |       |                                         |                                         |           |
| D14           | AVSS_MBUF |         |       |                                         |                                         |           |
| $\rightarrow$ |           |         |       |                                         | I.                                      |           |



| C14 | AU_M_BYP     |          |    |           |
|-----|--------------|----------|----|-----------|
| B14 | AU_FMINL     |          |    |           |
| A14 | AU_FMINR     |          |    |           |
| D13 | AU_OUT1_P    |          |    |           |
| C13 | AU_OUT1_N    |          |    | 7         |
| B12 | AU_OUT0_N    |          |    |           |
| B13 | AVDD_BUF     |          |    | Typ. 2.8V |
| A12 | AU_OUT0_P    |          |    |           |
| A13 | AVSS_BUF     |          |    |           |
| C12 | AU_MICBIAS_P |          |    |           |
| D12 | AU_MICBIAS_N |          |    |           |
| D11 | AVDD_AFE     |          |    | Typ. 2.8V |
| C11 | AU_VREF_N    |          |    |           |
| B11 | AU_VREF_P    |          |    |           |
| A11 | AGND_AFE     |          |    | ,         |
| D10 | AU_VIN0_P    |          |    |           |
| C10 | AU_VIN0_N    |          |    |           |
| B10 | AU_VIN1_N    |          |    |           |
| A10 | AU_VIN1_P    |          | 70 |           |
| E10 | AVSS_AFE     |          |    |           |
| D9  | BDLAQP       |          |    |           |
| C9  | BDLAQN       |          |    |           |
| E9  | AGND_RFE     |          |    |           |
| A9  | BDLAIN       |          |    |           |
| В9  | BDLAIP       |          |    |           |
| E8  | AVSS_GSMRFTX |          |    |           |
| В8  | BUPAIP       |          |    |           |
| A8  | BUPAIN       |          |    |           |
| D7  | AVDD_GSMRFTX |          |    | Typ. 2.8V |
| C8  | BUPAQN       |          |    |           |
| D8  | BUPAQP       |          |    |           |
| C7  | AVSS_RFE     |          |    |           |
| B7  | APC          |          |    |           |
| A7  | AVDD_RFE     |          |    | Typ. 2.8V |
| D6  | AUXADIN0     | <u> </u> |    |           |
| C6  | AUXADIN1     |          |    |           |
| В6  | AUXADIN2     |          |    |           |
| A6  | AUXADIN3     |          |    |           |
| C5  | AUXADIN4     |          |    |           |
| B5  | AUXADIN5     |          |    |           |
| A5  | AUXADIN6     |          |    |           |
| C4  | AUX_REF      |          |    |           |
| B4  | AFC          |          |    |           |
| A4  | AFC_BYP      |          |    |           |
|     |              |          |    |           |
|     |              |          | •  | •         |

 Table 3 Power Descriptions



# 3 Micro-Controller Unit Subsystem

**Figure 5** illustrates the block diagram of the Micro-Controller Unit Subsystem in MT6228. The subsystem utilizes a main 32-bit ARM7EJ-S RISC processor, which plays the role of the main bus master controlling the whole subsystem. All processor transactions go to code cache first. The code cache controller accesses TCM (128KB memory dedicated to ARM7EJS core), cache memory, or bus according to the processor's request address. If the requested content is found in TCM or in cache, no bus transaction is required. If the code cache hit rate is high enough, bus traffic can be effectively reduced and processor core performance maximized. In addition to the benefits of reuse of memory contents, code cache also has a MPU (Memory Protection Unit), which allows cacheable and protection settings of predefined regions. The contents of code cache are only accessible to MCU, and only MCU instructions are kept in the cache memory (thus the name "code" cache).

The bus comprises of two-level system buses: Advanced High-Performance Bus (AHB) and Advanced Peripheral Bus (APB). All bus transactions originate from bus masters, while slaves can only respond to requests from bus masters. Before data transfer can be established, the bus master must ask for bus ownership, 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. APB Bus supports 16-bit addressing and both 16-bit and 32-bit data paths. APB Bus is also optimized for minimal power consumption by turning off the clock when there is no APB bus activity.

During operation, if the target slave is located on 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 MT6228 MCU subsystem supports only memory addressing method. Therefore all components are mapped onto the MCU 32-bit address space. A Memory Management Unit is employed to allow for a central decode scheme. The MMU generates appropriate selection signals for each memory-addressed module 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, the controller generates 2 levels of interrupt requests, FIQ and IRQ, to the processor.

A 128K 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. This interface supports both synchronous and asynchronous components, such as Flash, SRAM and parallel LCD. This interface supports page and burst mode type of Flash, Cellular RAM, as well as high performance MobileRAM. In order to take advantages of burst- or page-type devices, a data cache is introduced and placed between AHB Bus and EMI, allowing the data cache to issue burst requests to EMI whenever possible. Since AHB Bus is 32-bit wide, all data transfers are converted into several 8-bit or 16-bit cycles depending on the data width of the target device. In contrast to code cache, contents in data cache are queried when MCU issues data requests, or when other AHB bus masters issue memory requests to EMI.





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

## 3.1 Processor Core

# 3.1.1 General Description

The Micro-Controller Unit Subsystem in MT6228 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 with the 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 MT6228 supports only a memory addressing method for instruction fetch and data access. The core manages a 32-bit address space that has addressing capability of up to 4 GB. 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<br>Addressing<br>Space |            | Reserved          |                                 |
|-----------------------------------|------------|-------------------|---------------------------------|
| AFFF_FFFh<br> <br>A000_0000h      |            | TCM               | +                               |
| 9FFF_FFFh                         | 9800_0000h | Reserved          |                                 |
| 9000_0000h                        | 9000_0000h | LCD               |                                 |
| 8FFF_FFFFh<br> <br>8000_0000h     |            | APB Peripherals   | <b>40</b>                       |
| 7FFF_FFFFh                        | 7800_0000h | Virtual FIFO      |                                 |
| 7000_0000h                        | 7000_0000h | USB               | C/A                             |
| 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]<br>Addressing<br>Space |

Figure 6 The Memory Layout of MT6228

The address space is organized into blocks of 256 MB each. Memory blocks 0-AFFFFFFh 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 MT6228 outputs 26 bits (A25-A0) of address lines along with 4 selection signals that correspond to associated memory blocks. That is, MT6228 can support up to 4 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. MT6228 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. The mechanism 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 are swapped accordingly. Furthermore, it allows system to boot from System ROM 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, the system 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 after a system reset. In this special boot mode, External Memory Controller does not access external memory; instead, the EMI Controller send predefined Boot Code back to the ARM7EJS-S core, which instructs the processor to execute the program in System ROM. This configuration can be changed by programming bit value of RM1 in register EMI\_REMAP directly.

MT6228 system provides one boot up scheme:

• Start up system of running codes from Boot Code for factory programming or NAND flash boot.

#### **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. A jump instruction leads the processor to run the code starting at address 48000000h where the System ROM is placed.

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

#### **Factory Programming**

The configuration for factory programming is shown in **Figure 7**. Usually the Factory Programming Host connects with MT6228 via the UART interface. The download speed can be up to 921K bps while MCU is running at 26MHz.

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

Further information is detailed in the MT6228 Software Programming Specification.



Figure 7 System configuration required for factory programming



#### **NAND Flash Booting**

If MT6228 cannot receive data from UART1 for a certain amount of time, the program in System ROM checks if any valid boot loader exists in NAND flash. If found, the boot loader code is copied from NAND flash to RAM (internal or external) and executed to start the real application software. If no valid boot loader can be found in NAND flash, MT6228 starts executing code in EMI bank0 memory. The whole boot sequence is shown in the following figure.



Figure 8 Boot sequence

#### 3.2.1.4 Little Endian Mode

The MT6228 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 MT6228. 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 or half the clock rate of 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 the 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 is associated with select signals, the address bus on APB contains only the value of offset address.

The maximum address space that can be allocated to a single APB slave is 64 KB, i.e. 16-bit address lines. The width of the data bus is mainly constrained to 16 bits to minimize the design complexity and power consumption while some use 32-bit data buses 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**.

| — each peripherar |                                                                   |               | T                |  |  |
|-------------------|-------------------------------------------------------------------|---------------|------------------|--|--|
| Base Address      | Description                                                       | Data<br>Width | Software Base ID |  |  |
| 8000_0000h        | Configuration Registers<br>(Clock, Power Down, Version and Reset) | 16            | CONFG Base       |  |  |
| 8001_0000h        | External Memory Interface                                         | 32            | 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        | Data cache controller                                             | 32            | DATACACHE Base   |  |  |
| 8006_0000h        | GPRS Cipher Unit                                                  | 32            | GCU Base         |  |  |
| 8007_0000h        | Software Debug                                                    | 32            | SWDBG Base       |  |  |
| 8008_0000h        | Reserved                                                          |               |                  |  |  |
| 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        | Cipher Hash Engine                                                | 32            | CHE Base         |  |  |
| 8018_0000h        | UART 2                                                            | 16            | UART2 Base       |  |  |
| 8019_0000h        | PPP Framer                                                        | 32            | PFC Base         |  |  |
| 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                                                        | 32            | 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       |  |  |
|                   |                                                                   |               |                  |  |  |



| Audio Front End                  | 16                                                                                                                                                                                                                                                                                     | AFE Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Base-Band Front End              | 16                                                                                                                                                                                                                                                                                     | BFE Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Analog Chip Interface Controller | 16                                                                                                                                                                                                                                                                                     | MIXED Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| JPEG Decoder                     | 32                                                                                                                                                                                                                                                                                     | JPEG Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Post Processing Resizer          | 32                                                                                                                                                                                                                                                                                     | PRZ Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Camera Interface                 | 32                                                                                                                                                                                                                                                                                     | CAM Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Image Engine                     | 32                                                                                                                                                                                                                                                                                     | IMG Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| PNG Decoder                      | 32                                                                                                                                                                                                                                                                                     | PNGDEC Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| GIF Decoder                      | 32                                                                                                                                                                                                                                                                                     | GIFDEC Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2D Command Queue                 | 32                                                                                                                                                                                                                                                                                     | GCMQ Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2D Accelerator                   | 32                                                                                                                                                                                                                                                                                     | G2D Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| MPEG4 Codec                      | 32                                                                                                                                                                                                                                                                                     | MP4 Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Image DMA                        | 32                                                                                                                                                                                                                                                                                     | IMGDMA Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Capture Resizer                  | 32                                                                                                                                                                                                                                                                                     | CRZ Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Drop Resizer                     | 32                                                                                                                                                                                                                                                                                     | DRZ Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| TV Encoder                       | 32                                                                                                                                                                                                                                                                                     | TVENC Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| TV Controller                    | 32                                                                                                                                                                                                                                                                                     | TVCON Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Graphics Memory Controller       | 32                                                                                                                                                                                                                                                                                     | GMC Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Code cache controller and MPU    | 32                                                                                                                                                                                                                                                                                     | CODECAHE Base                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                  | Base-Band Front End Analog Chip Interface Controller JPEG Decoder Post Processing Resizer Camera Interface Image Engine PNG Decoder GIF Decoder 2D Command Queue 2D Accelerator MPEG4 Codec Image DMA Capture Resizer Drop Resizer TV Encoder TV Controller Graphics Memory Controller | Base-Band Front End         16           Analog Chip Interface Controller         16           JPEG Decoder         32           Post Processing Resizer         32           Camera Interface         32           Image Engine         32           PNG Decoder         32           GIF Decoder         32           2D Command Queue         32           2D Accelerator         32           MPEG4 Codec         32           Image DMA         32           Capture Resizer         32           Drop Resizer         32           TV Encoder         32           TV Controller         32           Graphics Memory Controller         32 |

Table 4 Register Base Addresses for MCU Peripherals

| REGISTER ADDRESS | REGISTER NAME             | SYNONYM |
|------------------|---------------------------|---------|
| CONFG + 0000h    | Hardware Version Register | HW_VER  |
| CONFG + 0004h    | Software Version Register | SW_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+0000

h

# Hardware Version Register

#### **HW\_VERSION**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8 | 7 | 6 | 5 | 4   | 3   | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|------|---|---|---|---|-----|-----|---|---|---|
| Name  |    | EX | TP |    |    | MA | JREV |   |   |   |   | MIN | REV |   |   |   |
| Type  | RO |    |    | RO |    |    |      |   | R | 0 |   |     | RO  |   |   |   |
| Reset |    | 3  | 3  |    |    |    | Α    |   |   | ( | ) |     |     | ( | ) |   |

This register is used by software to determine the hardware version of the chip. The register contains a new value whenever each metal fix or major step is performed. All values are incremented by a step of 1.

MINREV Minor Revision of the chip
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+0004**

# **Software Version Register**

### **SW\_VERSION**

| Bit   | 15   | 14 | 13 | 12 | 11     | 10 | 9   | 8 | 7      | 6 | 5 | 4 | 3  | 2 | 1 | 0 |
|-------|------|----|----|----|--------|----|-----|---|--------|---|---|---|----|---|---|---|
| Name  | EXTP |    |    |    | MAJREV |    |     |   | MINREV |   |   |   |    |   |   |   |
| Type  | RO   |    |    | RO |        |    |     |   | R      | 0 |   |   | RO |   |   |   |
| Reset | 8    |    |    | A  |        |    | 0 ( |   |        |   | ( |   |    |   |   |   |

This register is used by software to determine the software version used with this chip. All values are incremented by a step of 1.

MINREV Minor Revision of the Software
MAJREV Major Revision of the Software

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

#### **CONFG+0008**

# Hardware Code Register

**HW\_CODE** 

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

This register presents the Hardware ID.

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

#### **CONFG+0400**

h

# **APB Bus Control Register**

APB\_CON

| Bit   | 15 | 14  | 13 | 12  | 11  | 10  | 9               | 8   | 7 | 6    | 5 | 4           | 3           | 2           | 1           | 0           |
|-------|----|-----|----|-----|-----|-----|-----------------|-----|---|------|---|-------------|-------------|-------------|-------------|-------------|
| Mama  |    | APB |    | APB | APB | APB | APB             | APB |   | APBR |   | <b>APBR</b> | <b>APBR</b> | <b>APBR</b> | <b>APBR</b> | <b>APBR</b> |
| Name  |    | W6  |    | W4  | W3  | W2  | W1 <sup>◀</sup> | W0  |   | 6    |   | 4           | 3           | 2           | 1           | 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         |
| Reset |    | 0   |    | 0   | 0   | 0   | 0               | 0   |   | 1    |   | 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 complete until an 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 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 modules 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 9 Variety Data Paths of DMA Transfers

Up to fourteen channels of simultaneous data transfers 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 10**.



Figure 10 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 a full-size DMA channel, the second one is called a half-size DMA channel, and the last is Virtual FIFO DMA. Channels 1 through 3 are full-size DMA channels; channels 4 through 10 are half-size ones; and channels 11 through 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 the address of one side 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. Refer to the Register Definition section for more detail.

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

DMA channels 1 through 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 11** illustrates how this function works. Once the transfer counter reaches the value of WPPT, the next address jumps to the WPTO address after completing the WPPT data transfer. 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 11 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 is truncated to 00b. If programmers do not notice this, it may cause an 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 byte by byte. This results in four read and four write transfers on the bus.

To improve bus efficiency, unaligned-word access is provided in DMA4~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, reducing the number of transfers on the bus by three.





Figure 12 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 pointers are kept in the Virtual FIFO DMA. During a read from the FIFO, the read pointer points to the address of the next data. During a write to the FIFO, the write pointer moves to the next address. If the FIFO is empty, a FIFO read is not allowed. Similarly, data is not written into the FIFO if the FIFO is full. Due to UART flow control requirements, an alert length is programmed. Once the FIFO Space is less than this value, an alert signal is issued to enable UART flow control. The type of flow control 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 informs MCU that there is 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 data must be removed from or put into the FIFO.

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



Figure 13 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 | Туре         | Ring Buffer | Two Buffer | Burst Mode | Unaligned Word<br>Access |
|------------|--------------|-------------|------------|------------|--------------------------|
| DMA1       | Full Size    | •           | •          | •          |                          |
| DMA2       | Full Size    | •           | •          | •          |                          |
| DMA3       | Full Size    | •           | •          | •          | 7.(0)                    |
| DMA4       | Half Size    | •           | •          | •          |                          |
| DMA5       | Half Size    | •           | •          | •          | •                        |
| DMA6       | Half Size    | •           | •          | •          | 7. ·                     |
| DMA7       | Half Size    | •           | •          | •          | <b>V</b> •               |
| DMA8       | Half Size    | •           | •          | • 6        | •                        |
| DMA9       | Half Size    | •           | •          | • 7        | •                        |
| DMA10      | Half Size    | •           | •          |            | •                        |
| DMA11      | Virtual FIFO | •           | 4          |            |                          |
| 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 + 0028h      | DMA Global Bandwidth Limiter Register              | DMA_GLBLIMITER |
| 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       |



| N.          |                                                    |              |
|-------------|----------------------------------------------------|--------------|
| 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  |



| EK                   |      |                                                        |              |
|----------------------|------|--------------------------------------------------------|--------------|
| DMA + 0              | 620h | DMA Channel 6 Interrupt Acknowledge Register           | DMA6_ACKINT  |
| DMA + 0              | 624h | DMA Channel 6 Remaining Length of Current Transfer     | DMA6_RLCT    |
| DMA + 0              | 628h | DMA Channel 6 Bandwidth Limiter Register               | DMA6_LIMITER |
| DMA + 0              | 62Ch | DMA Channel 6 Programmable Address Register            | DMA6_PGMADDR |
| DMA + 0              | 708h | DMA Channel 7 Wrap Point Address Register              | DMA7_WPPT    |
| DMA + 0              | 70Ch | DMA Channel 7 Wrap To Address Register                 | DMA7_WPTO    |
| DMA + 0              | 710h | DMA Channel 7 Transfer Count Register                  | DMA7_COUNT   |
| DMA + 0              | 714h | DMA Channel 7 Control Register                         | DMA7_CON     |
| DMA + 0              | 718h | DMA Channel 7 Start Register                           | DMA7_START   |
| DMA + 0              | 71Ch | DMA Channel 7 Interrupt Status Register                | DMA7_INTSTA  |
| DMA+0                | 720h | DMA Channel 7 Interrupt Acknowledge Register           | DMA7_ACKINT  |
| DMA + 0              | 724h | DMA Channel 7 Remaining Length of Current Transfer     | DMA7_RLCT    |
| DMA + 0              | 728h | DMA Channel 7 Bandwidth Limiter Register               | DMA7_LIMITER |
| DMA + 0              | 72Ch | DMA Channel 7 Programmable Address Register            | DMA7_PGMADDR |
| DMA + 0              | 808h | DMA Channel 8 Wrap Point Address Register              | DMA8_WPPT    |
| DMA + 0              | 80Ch | DMA Channel 8 Wrap To Address Register                 | DMA8_WPTO    |
| DMA + 0              | 810h | DMA Channel 8 Transfer Count Register                  | DMA8_COUNT   |
| DMA + 0              | 814h | DMA Channel 8 Control Register                         | DMA8_CON     |
| DMA + 0              | 818h | DMA Channel 8 Start Register                           | DMA8_START   |
| DMA + 0              | 81Ch | DMA Channel 8 Interrupt Status Register                | DMA8_INTSTA  |
| DMA + 0              | 820h | DMA Channel 8 Interrupt Acknowledge Register           | DMA8_ACKINT  |
| DMA + 0              | 824h | DMA Channel 8 Remaining Length of Current Transfer     | DMA8_RLCT    |
| DMA + 0              | 828h | DMA Channel 8 Bandwidth Limiter Register               | DMA8_LIMITER |
| DMA + 0              | 82Ch | DMA Channel 8 Programmable Address Register            | DMA8_PGMADDR |
| DMA + 0              | 908h | DMA Channel 9 Wrap Point Address Register              | DMA9_WPPT    |
| DMA + 0              | 90Ch | DMA Channel 9 Wrap To Address Register                 | DMA9_WPTO    |
| DMA + 0              | 910h | DMA Channel 9 Transfer Count Register                  | DMA9_COUNT   |
| DMA + 0              | 914h | DMA Channel 9 Control Register                         | DMA9_CON     |
| DMA + 0              | 918h | DMA Channel 9 Start Register                           | DMA9_START   |
| DMA + 0              | 91Ch | DMA Channel 9 Interrupt Status Register                | DMA9_INTSTA  |
| DMA + 0              | 920h | DMA Channel 9 Interrupt Acknowledge Register           | DMA9_ACKINT  |
| DMA + 0              | 924h | DMA Channel 9 Remaining Length of Current Transfer     | DMA9_RLCT    |
| DMA + 0              | 928h | DMA Channel 9 Bandwidth Limiter Register               | DMA9_LIMITER |
| DMA + 0              | 92Ch | DMA Channel 9 Programmable Address Register            | DMA9_PGMADDR |
| DMA + 0              | A08h | DMA Channel 10 Wrap Point Address Register             | DMA10_WPPT   |
| DMA + 0.             | A0Ch | DMA Channel 10 Wrap To Address Register                | DMA10_WPTO   |
| DMA + 0              | A10h | DMA Channel 10 Transfer Count Register                 | DMA10_COUNT  |
| DMA + 0              | A14h | DMA Channel 10 Control Register                        | DMA10_CON    |
| $\overline{DMA} + 0$ | A18h | DMA Channel 10 Start Register                          | DMA10_START  |
| $\overline{DMA} + 0$ | A1Ch | DMA Channel 10 Interrupt Status Register               | DMA10_INTSTA |
| $\overline{DMA+0}$   | A20h | DMA Channel 10 Interrupt Acknowledge Register          | DMA10_ACKINT |
| DMA + 0              | A24h | DMA Channel 10 Remaining Length of Current<br>Transfer | DMA10_RLCT   |
|                      |      |                                                        |              |



| IEK         |                                               |               |
|-------------|-----------------------------------------------|---------------|
| 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

Register 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 and double-buffer memory data movement can be activated on 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       | IT13 | RUN1<br>3 | IT12 | RUN1<br>2 | IT11 | RUN1<br>1 | IT10 | RUN1<br>0 | IT9 | RUN9 |
| Type  |     |      |     |      | RO   | RO         | RO   | RO        | RO   | RO        | RO   | RO        | RO   | RO        | RO  | RO   |
| Reset |     |      |     |      | 0    | $\sqrt{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 keep track 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

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



## DMA+0028h DMA Global Bandwidth limiter Register

# DMA\_GLBLIMIT ER

| 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>GLBLI</b> | MITER |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    | W            | O     |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    | •  |    | (            | )     |    |    |    |

Please refer to the expression in DMAn\_LIMITER for detailed note. The value of DMA\_GLBLIMITER is set to all DMA channels, from 1 to 14.

#### DMA+0n00h DMA Channel n Source Address Register

DMAn\_SRC

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20       | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|-------|--------|----|----|----------|----|----|----|----|
| Name  |    |    |    |    |    |    |    | SRC[3 | 31:16] |    |    | $\neg a$ |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R/    | W      |    |    |          |    |    |    |    |
| Reset |    |    |    |    |    |    |    | (     | )      |    |    | 942      |    |    |    |    |
| 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 |    |    |    |    |    |    |    | (     | )      |    |    |          |    |    |    |    |
|       |    |    |    |    |    |    |    |       |        |    |    |          |    |    |    |    |

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 DMAn\_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 from which the DMA is reading.

Note that n is from 1 to 3.

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** Address from which DMA is reading

#### DMA+0n04h DMA Channel n Destination Address Register

**DMAn DST** 

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|-------|--------|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    | DST[3 | 31:16] |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R/    | W      |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | (     | )      |    |    |    |    |    |    |    |
| 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 |    |    |    |    |    |    |    | (     | )      |    |    |    |    |    |    |    |

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 DMAn\_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 to which the DMA is writing.

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** Address to which DMA is writing.

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

**DMAn WPPT** 

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

The above registers are to specify the transfer count required to perform before the jump point. This can be used to support ring buffer or double buffer style memory accesses. To enable this function, two control bits, WPEN and WPSD, in DMA control register must be programmed. See the following register description for more details. If the transfercounter in the DMA engine matches this value, an address jump occurs, and the next address is the address specified in DMAn\_WPTO. Before programming these registers, the software should make sure that STR in DMAn\_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 is 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** Address of the jump point.

**READ** Value set by the programmer.

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

**DMAn WPTO** 

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

The above registers 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, set the two control bits, WPEN and WPSD, in the DMA control register. See the following register description for more details. Before programming these registers, the software should make sure that STR in DMAn\_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** Address of the jump destination.

**READ** Value set by the programmer.

#### DMA+0n10h DMA Channel n Transfer Count Register

**DMAn COUNT** 

|     |    |   |      |    |    |    |    |    |    | _  |    |    |    |    |    |    |
|-----|----|---|------|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit | 3: | 3 | ) 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |



| III. L. Direct Live | •  |    |    |    |    |    |   |    |    |   |   |   |   |   |   |    |
|---------------------|----|----|----|----|----|----|---|----|----|---|---|---|---|---|---|----|
| Name                |    |    |    |    |    |    |   |    |    |   |   |   |   |   |   |    |
| Type                |    |    |    |    |    |    |   |    |    |   |   |   |   |   |   |    |
| Reset               |    |    |    |    |    |    |   |    |    |   |   |   |   |   |   |    |
| Bit                 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0  |
| Name                |    |    |    |    |    |    |   | LE | EN |   |   |   |   |   |   | ҆— |
| 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 DMAn\_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 DMAn\_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 is issued.

Note that n is from 1 to 14.

**LEN** The amount of total transfer count

## DMA+0n14h DMA Channel n Control Register

DMAn\_CON

| Bit   | 31   | 30 | 29 | 28 | 27 | 26 | 25           | 24 | 23 | 22             | 21  | 20  | 19   | 18   | 17   | 16       |
|-------|------|----|----|----|----|----|--------------|----|----|----------------|-----|-----|------|------|------|----------|
| Name  |      |    |    |    |    |    |              |    |    | MAS            |     |     |      | DIR  | WPEN | WPS<br>D |
| Туре  |      |    |    |    |    |    |              |    |    | R/W            | 4   |     |      | R/W  | R/W  | R/W      |
| Reset |      |    |    |    |    |    |              |    |    | $\overline{0}$ |     |     |      | 0    | 0    | 0        |
| Bit   | 15   | 14 | 13 | 12 | 11 | 10 | 9            | 8  | 7  | 6              | 5   | 4   | 3    | 2    | 1    | 0        |
| Name  | ITEN |    |    |    |    |    | <b>BURST</b> |    |    |                | B2W | DRQ | DINC | SINC | SIZ  | ZE       |
| Type  | R/W  |    |    |    |    |    | R/W          |    |    |                | R/W | R/W | R/W  | R/W  | R/   | W        |
| Reset | 0    |    |    |    |    |    | 0            |    |    |                | 0   | 0   | 0    | 0    | ( C  | )        |

This register contains all the available control schemes for a DMA channel that is ready for software programmer to configure. Note that all these fields cannot be changed while DMA transfer is in progress or an 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 Iif Word, increase by 4.

- 0 Disable
- 1 Enable



**DREQ** Throttle and handshake control for DMA transfer

- O 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 is set to 4-beat burst while enabling this function, and the SIZE is set to Byte.

NO effect on channel 1 - 3 & 11 - 14.

- 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 does not stop until all of the beats in a burst are completed or transfer length is reached. FIFO threshold of peripherals must be configured carefully while being used 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

0104-beat incrementing burst

011 Reserved

100 8-beat incrementing burst

101 Reserved

110 16-beat incrementing burst

111 Reserved

**ITEN** DMA transfer completion interrupt enable.

- O 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.

- O Address-wrapping on source
- Address-wrapping on destination.

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

NO effect on channel 11 -14.

- 0 Disable
- 1 Enable

DIR Directions of DMA transfer for half-size and Virtual FIFO DMA channels, i.e. channels 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, the corresponding DREQ and DACK are connected. For half-size and Virtual FIFO DMA channels, i.e. channels  $4 \sim 14$ , a predefined address is 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** Re

# DMA+0n18h DMA Channel n Start Register

Reserved

#### **DMAn 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  |
| Bit<br>Name |    | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7  | 6  | 5  | 4  |    | 2  | 1  | 0  |
|             |    | 14 | 13 | 12 | 11 | 10 | 9  | 8_  | 7  | 6  | 5  | 4  |    | 2  | 1  | 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 does not clear it automatically no matter if the DMA channel accomplishes the DMA transfer or not. In other works, the value of STR stays "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.

- O The DMA channel is stopped.
- 1 The DMA channel is started and running.

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

## DMAn\_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  | INT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 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

- No interrupt request is generated.
- 1 One interrupt request is pending and waiting for service.

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

|        | A         | $\wedge$      |     |     |
|--------|-----------|---------------|-----|-----|
| 1 11// | Δn        | A1 -          | ĸ   | N . |
|        | <b>An</b> | $\overline{}$ | IVI |     |

| 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  | ACK |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 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 returns 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

DMAn\_RLCT

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24         | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|------------|------|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |            |      |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | <b>Z</b> I | 7, — |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |            |      |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8          | 7    | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    | RLC        | CT   |    |    |    |    |    |    |    |
| 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

#### **DMAn 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  |    |    |    |    |    |    |    |    |    |    |    | LIMI | TER |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    | R/   | W   |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    | (    | )   |    |    |    |

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 increases the latency of response to the masters, and the transfer rate decreases as well. Before using it, programmer must make sure that the bus masters have some protective mechanism to avoid entering 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 mean Bus access permission every (4 X n) AHB clock.

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

DMAn\_PGMAD DR

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

The above registers specify the address for a half-size DMA channel. This address represents a source address if DIR in DMA\_CON is set to 0, and represents a 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 DMAn\_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** Address of the jump destination.

**READ** Current address of the transfer.

#### DMA+0n30h DMA Channel n Virtual FIFO Write Pointer Register DMAn\_WRPTR

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25                     | 24    | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|------------------------|-------|----------|----|----|----|----|----|----|----|
| Name |    |    |    |    |    |    | V                      | VRPTE | R[31:16] |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    | $\mathbb{Z} \subseteq$ | R     | 0        |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9                      | 8     | 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    | 77                     | WRPTI | R[15:0]  |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |                        | R     | 0        |    |    |    |    |    |    |    |

Note that n is from 11 to 14.

WRPTR Virtual FIFO Write Pointer.

#### DMA+0n34h DMA Channel n Virtual FIFO Read Pointer Register DMAn\_RDPTR

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

Note that n is from 11 to 14.

**RDPTR** Virtual FIFO Read Pointer.



## DMA+0n38h DMA Channel n Virtual FIFO Data Count Register

| DMAn FFC | 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 |    | FFCNT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 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.

#### DMA+0n3Ch DMA Channel n Virtual FIFO Status Register

## DMAn\_FFSTA

| 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  |    |    |    |    |    |    |    |    |    |    |    | 107 |    | ALT | EMPT<br>Y | FULL |
| Type  |    |    |    |    |    |    |    |    |    |    |    |     |    | RO  | RO        | RO   |
| Reset |    |    |    |    |    |    |    |    |    |    |    |     |    | 0   | 1         | 0    |

Note that n is from 11 to 14.

**FULL** To indicate FIFO is full.

- 0 Not Full
- 1 Full

**EMPTY** To indicate FIFO is empty.

- O Not Empty
- 1 Empty

ALT To indicate FIFO Count is larger than ALTLEN. DMA issues an 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 DMAn\_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  |    |    |    | T T |    |    |    |    |    |    | R/W    |    |    |    |    |    |  |  |
| Reset |    |    |    |     |    |    |    |    |    |    | 0      |    |    |    |    |    |  |  |

Note that n is from 11 to 14

ALTLEN Specifies the Alert Length of Virtual FIFO DMA. Once the remaining FIFO space is less than ALTLEN, an alert signal is 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

DMAn\_FFSIZE

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





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 14** 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 generates two request signals: FIQ for fast, low latency interrupt request and IRQ for more general interrupts with lower priority.



Figure 15 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 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 to 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 taking advantage of this, it should also take the binary coded version of End of Interrupt Register coincidently.

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

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

Table 10 Interrupt Table of ARM7EJ-S

## **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 no earlier than 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 going to Interrupt Service Routine and polling Status Register (IRQ\_STA or IRQ\_STA2), but the register shows there is no interrupt. This might cause MCU malfunction.

There are two ways for programmer 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 doing Interrupt Masking, and then clear it after Interrupt Masking done.

Both avoid the problem, but the first item recommended to have in the ISR.

#### **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, and 4 WakeUp interrupt requests, i.e. EINT4~7, coming from peripherals used to inform system to resume the system clock.

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

Since the external event may be unstable in a certain period, a de-bounce mechanism is introduced to ensure the 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 changes to the desired state. Note that, because it uses the 32 KHz slow clock for performing the de-bounce process, the parameter of de-bounce period and de-bounce enable takes effect no sooner than one 32 KHz clock cycle (~31.25us) after the software program sets them. However, the polarities of EINTs are clocked with the system clock. Any changes to them take effect immediately. Note also that this External Interrupt Controller handles only level sensitive type of interrupt sources.





Figure 16 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     | IRQ Selection 6 Register              | IRQ_SEL6      |
| CIRQ + 001ch     | IRQ Selection 7 Register              | IRQ_SEL7      |
| CIRQ + 0034h     | FIQ Selection Register                | FIQ_SEL       |
| CIRQ + 0038h     | IRQ Mask Register (LSB)               | IRQ_MASKL     |
| CIRQ + 003ch     | IRQ Mask Register (MSB)               | IRQ_MASKH     |
| CIRQ + 0040h     | IRQ Mask Clear Register (LSB)         | IRQ_MASK_CLRL |
| CIRQ + 0044h     | IRQ Mask Clear Register (MSB)         | IRQ_MASK_CLRH |
| CIRQ + 0048h     | IRQ Mask Set Register (LSB)           | IRQ_MASK_SETL |
| CIRQ + 004ch     | IRQ Mask Set Register (MSB)           | IRQ_MASK_SETH |
| CIRQ + 0050h     | IRQ Status Register (LSB)             | IRQ_STAL      |
| CIRQ + 0054h     | IRQ Status Register (MSB)             | IRQ_STAH      |
| CIRQ + 0058h     | IRQ End of Interrupt Register (LSB)   | IRQ_EOIL      |
| CIRQ + 005ch     | IRQ End of Interrupt Register (MSB)   | IRQ_EOIH      |
| CIRQ + 0060h     | IRQ Sensitive Register (LSB)          | IRQ_SENSL     |
| CIRQ + 0064h     | IRQ Sensitive Register (MSB)          | IRQ_SENSH     |
| CIRQ + 0068h     | IRQ Software Interrupt Register (LSB) | IRQ_SOFTL     |
| CIRQ + 006ch     | IRQ Software Interrupt Register (MSB) | IRQ_SOFTH     |
| CIRQ + 0070h     | FIQ Control Register                  | FIQ_CON       |
| CIRQ + 0074h     | FIQ End of Interrupt Register         | FIQ_EOI       |



| Reset | С | b | a |
|-------|---|---|---|
|       |   |   |   |

# 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  |         |     |     |    | IRO | 213 |     |     |    |    | IRO | 212 |    |    | IRQ1 | 1  |
| Type  |         |     |     |    | R/  | W   |     |     |    |    | R/  | W   |    |    | R/W  |    |
| Reset |         |     |     |    |     |     |     |     |    |    | 1   | 2   |    |    | 11   |    |
| Bit   | 15      | 14  | 13  | 12 | 11  | 10  | 9   | 8   | 7  | 6  | 5   | 4   | 3  | 2  | 1    | 0  |
| Name  |         | IRC | 211 |    |     |     | IRO | 210 |    |    |     |     | IR | QF |      |    |
| Type  | R/W R/W |     |     |    |     |     |     |     |    |    |     |     | R/ | W  |      |    |
| Reset | 11 10   |     |     |    |     |     |     | 0   |    | •  |     | •   |    | Í  |      |    |
|       |         |     |     |    |     |     |     |     | •  |    |     |     |    |    |      |    |

# 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  |    |       |         |    | IRC | 218 |     |             |     |    | IRO   | 217 |     |     | IRC | 116 |
| Type  |    |       |         |    | R/  | W   |     |             | R/W |    |       |     |     |     |     |     |
| Reset |    |       |         |    | 1   | 8   |     |             |     |    | 17 16 |     |     |     |     |     |
| Bit   | 15 | 14    | 13      | 12 | 11  | 10  | 9   | 8           | 7   | 6  | 5     | 1   | 0   |     |     |     |
| Name  |    | IRC   | 216     |    |     |     | IRO | <b>Q</b> 15 |     |    |       |     | IRC | 214 |     |     |
| Type  |    | R/    | R/W R/W |    |     |     |     |             |     |    |       | 7.5 | R/  | W   |     |     |
| Reset |    | 16 15 |         |    |     |     |     |             |     |    |       |     | 1   | 4   |     |     |
|       |    |       |         |    |     |     |     |             |     |    |       |     |     |     |     |     |

## 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  |         |              |     |    | IRC | )1D |     |               |    |    | IRC | )1C |     |    | IRC | )1B |
| Type  |         |              |     |    | R/  | W   |     |               |    |    | R/  | W   |     |    | R/  | W   |
| Reset |         |              |     |    | 1   | d   |     |               |    |    | 1   | С   |     |    | 1   | b   |
| Bit   | 15      | 14           | 13  | 12 | 11  | 10  | 9   | 8             | 7  | 6  | 5   | 4   | 3   | 2  | 1   | 0   |
| Name  |         | IRC          | 21B |    |     |     | IRC | 21A           |    |    |     |     | IRG | 19 |     |     |
| Type  | R/W R/W |              |     |    |     |     |     |               |    |    |     |     | R/  | W  |     |     |
| Reset |         | 1b <u>1a</u> |     |    |     |     |     |               |    |    |     |     | 19  | 9  |     |     |
|       |         |              |     |    |     |     |     | $\overline{}$ | 7  |    |     |     |     |    |     |     |

# CIRQ+0018h IRQ Selection 6 Register

#### **IRQ\_SEL6**

|       |         |     |     |    |     |     | _  |     |    |    |     |     |     |    |     |     |
|-------|---------|-----|-----|----|-----|-----|----|-----|----|----|-----|-----|-----|----|-----|-----|
| Bit   | 31      | 30  | 29  | 28 | 27  | 26  | 25 | 24  | 23 | 22 | 21  | 20  | 19  | 18 | 17  | 16  |
| Name  |         |     |     |    | IRC | 222 |    |     |    |    | IRO | 221 |     |    | IRC | 220 |
| Type  |         |     |     |    | R/  | W   |    |     |    |    | R   | /W  |     |    | R/  | W   |
| Reset |         |     |     |    | 2   | 2   |    |     |    |    | 2   | 21  |     |    | 2   | 0   |
| Bit   | 15      | 14  | 13  | 12 | 11  | 10  | 9  | 8   | 7  | 6  | 5   | 4   | 3   | 2  | 1   | 0   |
| Name  |         | IRO | 220 |    |     |     | IR | Q1F |    |    |     |     | IRC | 1E |     |     |
| Type  | R/W R/W |     |     |    |     |     |    |     |    |    |     |     | R/  | W  |     |     |
| Reset | 20 1f   |     |     |    |     |     |    | 1f  |    | •  |     |     | 1   | е  | •   |     |
|       |         |     |     |    |     |     |    |     |    |    |     |     |     |    |     |     |

# CIRQ+001ch IRQ Selection 7 Register

# **IRQ\_SEL7**

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

# CIRQ+0020h IRQ Selection 8 Register

## **IRQ\_SEL8**

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Dit | 9. |    | 20 |    |    |    |    |    | 2  |    |    |    | 10 | 10 | ., | 10 |



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

## CIRQ+0034h 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  |    |    |    |    |    |    |    |    |    |    |    |    | FIC | <u>)</u> |    | -  |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    | R/V | ٧        |    |    |
| 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. The registers allow 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 share IRQs by mapping them onto IRQ0 to IRQ1F connected to IRQ controller. The priority sequence 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. Five-bit Interrupt Source Codes for all interrupt sources are fixed and defined.

| Interrupt Source | STA2 (Hex) | STAH_STAL    |
|------------------|------------|--------------|
| GPI_FIQ          | 0          | 000_00000001 |
| TDMA_CTIRQ1      | 1          | 000_00000002 |
| TDMA_CTIRQ2      | 2          | 000_00000004 |
| DSP2CPU          | 2 3        | 000_00000008 |
| SIM              | 4          | 000_00000010 |
| DMA              | 5          | 000_00000020 |
| TDMA             | 6          | 000_00000040 |
| UART1            | 7          | 000_00000080 |
| KeyPad           | 8          | 000_00000100 |
| UART2            | 9          | 000_00000200 |
| GPTimer          | a          | 000_00000400 |
| EINT             | b          | 000_00000800 |
| USB              | с          | 000_00001000 |
| MSDC             | d          | 000_00002000 |
| RTC              | e          | 000_00004000 |
| IrDA             | f          | 000_00008000 |
| LCD              | 10         | 000_00010000 |
| UART3            | 11         | 000_00020000 |
| GPI              | 12         | 000_00040000 |
| WDT              | 13         | 000_00080000 |
| SWDBG            | 14         | 000_00100000 |
| CHE              | 15         | 000_00200000 |



| NFI         | 16 | 000_00400000 |
|-------------|----|--------------|
| B2PSI       | 17 | 000_00800000 |
| Image DMA   | 18 | 000_01000000 |
| GIF         | 19 | 000_02000000 |
| PNG         | 1a | 000_04000000 |
| SCCB        | 1b | 000_08000000 |
| G2D         | 1c | 000_10000000 |
| Image Porc  | 1d | 000_20000000 |
| CAM         | 1e | 000_40000000 |
| PFC         | 1f | 000_80000000 |
| MPEG4_DEC   | 20 | 001_00000000 |
| MPEG4_ENC   | 21 | 002_00000000 |
| JPEG_DEC    | 22 | 004_00000000 |
| JPEG_ENC    | 23 | 008_00000000 |
| Resizer_crz | 24 | 010_00000000 |
| Resizer_drz | 25 | 020_00000000 |
| Resizer_prz | 26 | 040_00000000 |
| TVE         | 27 | 080_00000000 |
|             |    |              |

Table 12 Interrupt Source Code for Interrupt Sources

FIQ, IRQ0-26 The 5-bit content of this field corresponds to an Interrupt Source Code shown above.

#### CIRQ+0038h IRQ Mask Register (LSB)

## IRQ\_MASKL

| Bit   | 31          | 30    | 29        | 28        | 27        | 26          | 25    | 24    | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
|-------|-------------|-------|-----------|-----------|-----------|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name  | IRQ1F       | IRQ1E | IRQ1<br>D | IRQ1<br>C | IRQ1<br>B | IRQ1<br>A   | IRQ19 | IRQ18 | IRQ17 | IRQ16 | IRQ15 | IRQ14 | IRQ13 | IRQ12 | IRQ11 | IRQ10 |
| 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.    | J     | 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  | <b>IRQF</b> | IRQE  | IRQD      | IRQC      | IRQB      | <b>IRQA</b> | IRQ9  | IRQ8  | IRQ7  | IRQ6  | IRQ5  | IRQ4  | IRQ3  | IRQ2  | IRQ1  | IRQ0  |
| 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     |

# CIRQ+003ch IRQ Mask Register (MSB)

#### IRQ\_MASKH

| 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  |    |    |    |    |    |    |    |    | IRQ27 | IRQ26 | IRQ25 | IRQ24 | IRQ23 | IRQ22 | IRQ21 | IRQ20 |
| Type  |    |    |    |    |    |    |    |    | R/W   |
| Reset |    |    |    |    |    |    |    |    | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |

This register contains a mask bit for each interrupt line in IRQ Controller. The register allows each interrupt source IRQ0 to IRQ1F to be disabled or masked separately under software control. After a system reset, all bit values are set to 1 to indicate that interrupt requests are prohibited.

**IRQ0-27** Mask control for the associated interrupt source in the IRQ controller

- Interrupt is enabled.
- 1 Interrupt is disabled.



# CIRQ+0040h IRQ Mask Clear Register (LSB)

## IRQ\_MASK\_CL RL

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

## CIRQ+0044h IRQ Mask Clear Register (MSB)

RQ\_MASK\_CL

| 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 |    |    |    |    |    |    |    |    | IRQ27 | IRQ26 | IRQ25 | IRQ24 | IRQ23 | IRQ22 | IRQ21 | IRQ20 |
| Type |    |    |    |    |    |    |    |    | W1C   |

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

**IRQ0-27** Clear corresponding bits in IRQ Mask Register.

- No effect
- 1 Disable the corresponding MASK bit.

## CIRQ+0048h IRQ Mask SET Register (LSB)

IRQ\_MASK\_SE

TI

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

# CIRQ+004ch IRQ Mask SET Register (MSB)

IRQ\_MASK\_SE

TH

| 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 |    |    |    |    |    |    |    |    | IRQ27 | IRQ26 | IRQ25 | IRQ24 | IRQ23 | IRQ22 | IRQ21 | IRQ20 |
| 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 cause the corresponding bits in IRQ Mask Register to be set. Data bits that are LOW have no effect on the corresponding bits in IRQ Mask Register.

**IRQ0-27** Set corresponding bits in IRQ Mask Register.

- O No effect.
- 1 Enable corresponding MASK bit.



#### CIRQ+0050h IRQ Source Status Register (LSB)

# IRQ\_STAL

| Bit   | 31          | 30          | 29          | 28        | 27          | 26          | 25    | 24    | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
|-------|-------------|-------------|-------------|-----------|-------------|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name  | IRQ1F       | IRQ1E       | IRQ1<br>D   | IRQ1<br>C | IRQ1<br>B   | IRQ1<br>A   | IRQ19 | IRQ18 | IRQ17 | IRQ16 | IRQ15 | IRQ14 | IRQ13 | IRQ12 | IRQ11 | IRQ10 |
| Туре  | 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     |
| 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> | IRQC      | <b>IRQB</b> | <b>IRQA</b> | IRQ9  | IRQ8  | IRQ7  | IRQ6  | IRQ5  | IRQ4  | IRQ3  | IRQ2  | IRQ1  | IRQ0  |
| 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 4   | 0     | 0     |

#### CIRQ+0054h IRQ SouROe Status Register (MSB)

#### **IRQ STAH**

| 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  |    |    |    |    |    |    |    |    | IRQ27 | IRQ26 | IRQ25 | IRQ24 | IRQ23 | IRQ22 | IRQ21 | IRQ20 |
| Type  |    |    |    |    |    |    |    |    | RO    |
| Reset |    |    |    |    |    |    |    |    | 0     | 0     | 0     | 0 2   | 0     | 0     | 0     | 0     |

This Register allows software to poll which interrupt line has generated an 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 has no effect on the content.

**IRQ0-27** Interrupt indicator for the associated interrupt source.

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

#### CIRQ+0058h IRQ End of Interrupt Register (LSB)

#### IRQ\_EOIL

| Bit   | 31          | 30    | 29          | 28        | 27          | 26          | 25    | 24    | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
|-------|-------------|-------|-------------|-----------|-------------|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name  | IRQ1F       | IRQ1E | IRQ1<br>D   | IRQ1<br>C | IRQ1<br>B   | IRQ1<br>A   | IRQ19 | IRQ18 | IRQ17 | IRQ16 | IRQ15 | IRQ14 | IRQ13 | IRQ12 | IRQ11 | IRQ10 |
| Type  | WO          | WO    | WO          | WO        | WO          | WO          | WO    | WO    | WO    | WO    | WO    | WO    | WO    | WO    | WO    | 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> | IRQE  | <b>IRQD</b> | IRQC      | <b>IRQB</b> | <b>IRQA</b> | IRQ9  | IRQ8  | IRQ7  | IRQ6  | IRQ5  | IRQ4  | IRQ3  | IRQ2  | IRQ1  | IRQ0  |
| Type  | WO          | WO    | WO          | WO        | WO          | WO          | WO    | WO    | WO    | WO    | WO    | WO    | WO    | WO    | WO    | WO    |
| Reset | 0           | 0     | 0           | 0         | 0           | 0           | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

# CIRQ+005ch IRQ End of Interrupt Register (MSB)

#### IRQ\_EOIH

| 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  |    |    |    |    |    |    |    |    | IRQ27 | IRQ26 | IRQ25 | IRQ24 | IRQ23 | IRQ22 | IRQ21 | IRQ20 |
| Type  |    |    |    |    |    |    |    |    | WO    |
| Reset |    | A  |    |    |    |    |    |    | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

This register provides a mean for software to relinquish and to refresh the interrupt controller. Writing a 1 to a specific bit position results in an End of Interrupt command issued internally to the corresponding interrupt line.

**IRQ0-27** End of Interrupt command for the associated interrupt line.

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



#### CIRQ+0060h IRQ Sensitive Register (LSB)

# **IRQ SENSL**

| Bit   | 31          | 30    | 29        | 28        | 27          | 26          | 25    | 24    | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
|-------|-------------|-------|-----------|-----------|-------------|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name  | IRQ1F       | IRQ1E | IRQ1<br>D | IRQ1<br>C | IRQ1<br>B   | IRQ1<br>A   | IRQ19 | IRQ18 | IRQ17 | IRQ16 | IRQ15 | IRQ14 | IRQ13 | IRQ12 | IRQ11 | IRQ10 |
| 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>IRQF</b> | IRQE  | IRQD      | IRQC      | <b>IRQB</b> | <b>IRQA</b> | IRQ9  | IRQ8  | IRQ7  | IRQ6  | IRQ5  | IRQ4  | IRQ3  | IRQ2  | IRQ1  | IRQ0  |
| 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 4   | 0     | 0     |

#### CIRQ+0064h IRQ Sensitive Register (MSB)

#### **IRQ SENSH**

| 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  |    |    |    |    |    |    |    |    | IRQ27 | IRQ26 | IRQ25 | IRQ24 | IRQ23 | IRQ22 | IRQ21 | IRQ20 |
| Type  |    |    |    |    |    |    |    |    | R/W   |
|       |    |    |    |    |    |    |    |    | _     | _     | 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 is not accepted until the EOI command is given. However, level sensitive interrupts trigger 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 is triggered if the signal level remain LOW after an EOI command. Note that in edge sensitive mode, even if the signal level remains LOW after EOI command, another interrupt request is not triggered. That is because edge sensitive interrupt is only triggered at the falling edge.

**IRQ0-27** Sensitivity type of the associated Interrupt Source

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

#### CIRQ+0068h IRQ Software Interrupt Register (LSB)

#### **IRQ SOFTL**

| Bit   | 31          | 30    | 29        | 28          | 27          | 26   | 25_   | 24    | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
|-------|-------------|-------|-----------|-------------|-------------|------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name  | IRQ1F       | IRQ1E | IRQ1<br>D | IRQ1<br>C   | IRQ1        | IRQ1 | IRQ19 | IRQ18 | IRQ17 | IRQ16 | IRQ15 | IRQ14 | IRQ13 | IRQ12 | IRQ11 | IRQ10 |
| 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          | <u> 11 </u> | 10   | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| Name  | <b>IRQF</b> | IRQE  | IRQD      | <b>IRQC</b> | IRQB        | IRQA | IRQ9  | IRQ8  | IRQ7  | IRQ6  | IRQ5  | IRQ4  | IRQ3  | IRQ2  | IRQ1  | IRQ0  |
| 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     |

# CIRQ+006ch IRQ Software Interrupt Register (MSB)

#### IRQ\_SOFTH

| 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  |    |    |    |    |    |    |    |    | IRQ27 | IRQ26 | IRQ25 | IRQ24 | IRQ23 | IRQ22 | IRQ21 | IRQ20 |
| Type  |    |    |    |    |    |    |    |    | R/W   |
| Reset |    |    |    |    |    |    |    |    | 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-IRQ27 Software Interrupt

## CIRQ+0070h 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>T</b> e  | SENS | MAS<br>K |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    | <u>.</u> ₹≟ | R/W  | R/W      |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |             | 0    | 1        |

This register provides a means 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** Sensitivity type of the FIQ Interrupt Source

- D Edge sensitivity with active LOW
- 1 Level sensitivity with active LOW

#### CIRQ+0074h 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  |    |    |    |    |    |    |    |    | $\sum$ |    |    |    |    |    |    | EOI |
| Type  |    |    |    |    |    |    |    | M  |        |    |    |    |    |    |    | WO  |
| Reset |    |    |    |    |    |    | -  |    |        |    |    |    |    |    |    | 0   |

This register provides a means for software to relinquish and to refresh the FIQ controller. Writing a '1' to the specific bit position results in an End of Interrupt command issued internally to the corresponding interrupt line.

**EOI** End of Interrupt command

# CIRQ+0078h 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 | 717 | 10 | 9  | 8         | 7  | 6  | 5                  | 4  | 3  | 2  | 1  | 0  |  |
| Name  |    |    |    |    |     |    |    | NOIR<br>Q |    |    | 5 4 3 2 1 0<br>STS |    |    |    |    |    |  |
| Type  |    |    |    |    |     |    |    | RO        |    |    |                    |    | R  | 0  |    |    |  |
| Reset |    |    |    |    |     |    |    | 0         |    |    |                    |    | (  | )  |    |    |  |

This Register is a binary coded version of IRQ\_STA. It is used by the software program to poll which interrupt line has 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 on 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 is HIGH, and the value of STS is 00\_0000b.

#### CIRQ+007ch 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  |    |    |    |    |    |    |    |    |    |    | 5 4 3 2 1 0<br>EOI |    |    |    |    |    |  |  |  |
| Type  |    |    |    |    |    |    |    |    |    |    | WO                 |    |    |    |    |    |  |  |  |
| Reset |    |    |    |    | _  |    |    |    |    |    |                    |    | (  | )  |    |    |  |  |  |

This register is a binary coded version of IRQ\_EOI. It provides an easier way for software program to relinquish and to refresh the interrupt controller. Writing a specific code results in an End of Interrupt command issued 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+0080h Binary Coded Value of IRQ\_SOFT

**IRQ SOFT2** 

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

This register is a binary coded version of IRQ\_SOFT.

**SOFT** Binary Coded Value of IRQ\_SOFT

#### 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 that which EINT Source generates the interrupt request. If EINT sources are set to edge sensitivity, EINT\_IRQ is de-asserted while this register is read.

#### **EINTO-EINT7** Interrupt status

- **0** No interrupt request is generated.
- 1 Interrupt request is pending.

## CIRQ+0104h EINT Interrupt Mask Register

**EINT MASK** 

|       |    |    |    |    |    |    | - 3 |    |       |       |       |       |       |       | _     | _     |
|-------|----|----|----|----|----|----|-----|----|-------|-------|-------|-------|-------|-------|-------|-------|
| 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 or not EINT Source is allowed to generate an interrupt request. Setting a "1" to the specific bit position prohibits the external interrupt line from becoming active.

#### **EINTO-EINT7** Interrupt Mask

- Interrupt request is enabled.
- 1 Interrupt request is disabled.

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

EINT MASK C

LR

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22    | 21    | 20    | 19    | 18    | 17         | 16    |
|------|----|----|----|----|----|----|----|----|-------|-------|-------|-------|-------|-------|------------|-------|
| Name |    |    |    |    |    |    |    |    |       |       |       |       |       |       | , <u> </u> |       |
| 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        | W1C   |

This register is used to clear individual mask bits. Only the bits set to 1 are in effect, and interrupt masks for which the mask bit is set are cleared (set to 0). Otherwise the interrupt mask bit retains its original value.

**EINTO-EINT7** Disable mask for the associated external interrupt source.

- 0 No effect.
- 1 Disable the corresponding MASK bit.

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

**EINT\_MASK\_S** 

FΤ

| 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 |
|      |    |    |    |    |    |    |    |    | W1S   |

This register is used to set individual mask bits. Only the bits set to 1 are in effect, and interrupt masks for which the mask bit is set are set to 1. Otherwise the interrupt mask bit retains its original value.

**EINTO-EINT7** Disable mask for the associated external interrupt source.

- O 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 acknowledge the interrupt request correspondingly to the external interrupt line source.

**EINTO-EINT7** Interrupt acknowledgement

- 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  |    | -  |    |    |    |    |    |    |    |    |    |    | EINT3 | EINT2 | EINT1 | <b>EINTO</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.

**EINTO-3** Sensitivity type of the associated external interrupt source.

O Edge sensitivity

1 Level sensitivity

### 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  |     |    |    |    |     |    |    |    |    |    | · · | 764 |    |    |    |    |
| Type  |     |    |    |    |     |    |    |    |    |    |     |     |    |    |    |    |
| Reset |     |    |    |    |     |    |    |    |    |    |     |     |    |    |    |    |
| Bit   | 15  | 14 | 13 | 12 | 11  | 10 | 9  | 8  | 7  | 6  | 5   | 4   | 3  | 2  | 1  | 0  |
| Name  | EN  |    |    |    | POL |    |    |    |    |    | CNT |     |    |    |    |    |
| 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 + 2.

CNT De-bounce duration in terms of number of 32 KHz clock cycles.

**POL** Activation type of the EINT source

Negative polarity

1 Positive polarity

**EN** De-bounce control circuit

O Disable

1 Enable

# 3.6 Code Cache Controller

# 3.6.1 General Description

A new subsystem consisting of cache and TCM (tightly coupled memory) is implemented in MT6228. This subsystem is placed between MCU core and AHB bus interface, as shown in **Figure 17**.





Figure 17 Cache and TCM subsystem

TCM is a high-speed (zero wait state) dedicated memory accessed by MCU exclusively. Because MCU can run at 104 MHz and on-chip bus runs at maximum of 52 MHz, latency occurs when MCU accesses memory or peripherals through the on-chip bus. By moving timing critical code and data into TCM, MCU performance is increased and the response to particular events can be guaranteed.

Another method to increase MCU performance is the introduction of cache. Cache is a small memory, keeping the copy of external memory. If MCU reads a portion of cacheable data, the data is copied to cache. If MCU needs the same data at a later time, it can retrieve the data directly from cache (called cache hit) instead of from external memory, which takes a long time compared to accessing high-speed (zero wait state) cache memory.

Since a large external memory maps to a small cache, cache can hold only a small portion of external memory. If MCU accesses data not found in cache (called cache miss), some contents of cache must be dropped (flushed) and the required data is transferred from external memory (called cache line fill) and stored in cache. On the other hand, TCM is not a copy of external memory. The best way to use TCM is to put critical code/data in TCM in the memory usage plan. After power on reset, the boot loader copies TCM contents from external storage (such as flash) to internal TCM. If necessary, MCU can replace a portion of TCM content with other data on external storage in the runtime to implement an "overlay" mechanism. TCM is also an ideal place to put stack data.

The sizes of TCM and cache can be set to one of 4 configurations:



Figure 18 Configurations of TCM and cache



- 128KB TCM, 32KB cache
- 144KB TCM, 16KB cache
- 152KB TCM, 8KB cache
- 160KB TCM, 0KB cache

These configurations provide flexibility for software to adjust for optimum system performance.

The address mapping of these memories is as follows:



Figure 19 Memory mapping of TCM and cache

In Figure 19, MCU could only access TCM explicitly. Cache is transparent to MCU.

### 3.6.2 Organization of Cache

The cache system has the following features:

- Write through (no write allocation)
- Configurable 1/2/4 way set associative (8K/16K/32K)
- Each way has 256 cache lines with 8 word line size (256\*8\*4=8KB)
- 19 bit tag address, 1 valid bit, for one cache line.

One way of cache comprises of two memories: tag memory and data memory. Tag memory stores each line's valid bit, dirty bit and tag (upper part of address). Data memory stores line data. When MCU accesses memory, the address is compared to the contents of tag memory. First the line index (address bit [12:5]) is used to locate a line, and then the tag of the line is compared to upper part of address (bit [31:13]). If two parts match and valid bit is 1, it is a cache hit and data from that particular way is sent back to MCU. This process is illustrated in the following figure:





Figure 20 Tag comparison of 4-way cache

If most memory accesses are cache hit, MCU could get data immediately without wait states and the overall system performance is higher. There are several factors that may affect cache hit rate:

#### • Cache size and the organization

The larger the cache size is, the higher the hit rate is. However the hit rate starts to saturate when cache size is larger than a threshold size. Normally a cache size of 16KB and above and two or four ways achieve a good hit rate.

#### Program behavior

If the system has several tasks that switch data quickly, it may cause cache contents to be flushed frequently. Each time a new task is run, the cache holds the data. If the next task uses data in memory that occupies the same cache entries as the previous task, the cache contents are flushed to store the data for the new task. Interrupts also cause program flow to change dynamically. The interrupt handler code itself and the data it processes may cause cache to flush some data used by the current task. Thus after exiting the interrupt handler and returning to the current task, the flushed data may need to be re-cached, resulting performance degradation.

To help a software engineer tune system performance, the cache controller in MT6228 records the number of cache hits and cacheable memory accesses. The cache hit rate can be obtained from these two numbers.

The cache sub system also has a module called MPU (memory protection unit). MPU can prevent illegal memory access and specify which memory region is cacheable or non-cacheable. Two fields in CACHE\_CON register control the enable of MPU functions. MPU has its own registers to define memory region and associated regions. These



settings only take effect after the enable bits in CACHE\_CON are set to 1. For more details on the settings, refer to MPU portion of the specification.

### 3.6.3 Cache Operations

Upon power on, cache memory contains random numbers and cannot be used by MCU. Therefore MCU must have some means to "clean" cache memory before enabling it. The cache controller provides a register which, when written, can perform operations on cache memory. These are called cache operations, and include

Invalidate one cache line

The user must give a memory address. If it is found within cache, that particular line is invalidated (valid bit set to 0). Alternatively, the user can specify which set/way of cache to be invalidated.

Invalidate all cache lines

The user needs not to specify an address. The cache controller hardware automatically clears all valid bits in each tag memory.

### 3.6.4 Cache Controller Register Definition

CACHE base address is assumed 0x80700000 (subject to change).

#### CACHE+00h Cache General Control Register

**CACHE CON** 

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8     | 7 | 6 | 5_5 | 4 | 3          | 2          | 1    | 0        |
|-------|----|----|----|----|----|----|------|-------|---|---|-----|---|------------|------------|------|----------|
| Name  |    |    |    |    |    |    | CACH | ESIZE | K |   |     |   | CNTE<br>N1 | CNTE<br>N0 | MPEN | MCE<br>N |
| Type  |    |    |    |    |    |    | R'   | W     |   |   |     |   | RW         | RW         | R/W  | R/W      |
| Reset |    |    |    |    |    |    | 0    | 0     |   |   |     |   | 0          | 0          | 0    | 0        |

This register determines the cache size, cache hit counter and the enabling of MPU.

**CACHESIZE** Cache Size Select

00 no cache (128KB TCM)

**01** 8KB, 1-way cache (120KB TCM)

**10** 16KB, 2-way cache (112KB TCM)

11 32KB, 4-way cache (96KB TCM)

#### **CNTEN1** Enable cache hit counter 1.

If enabled, cache controller increments a 48-bit counter each time a cache hit occurs. This number can provide a reference for performance measurement for tuning of application programs. This counter increments only when the cacheable information is from MPU cacheable regions 4~7.

0 Disable

1 Enable

#### **CNTENO** Enable cache hit counter 0

If enabled, cache controller increments a 48-bit counter each time a cache hit occurs. This number can provide a reference for performance measurement for tuning of application programs. This counter increments only when the cacheable information is from MPU cacheable regions 0~3.

0 Disable

1 Enable

#### MPEN Enable MPU comparison of read/write permission setting.

If disabled, MCU can access any memory segment without any restriction. If enabled, MPU compares the address of MCU to its setting. If an address falls into a restricted region, MPU stops this memory access and sends an "ABORT" signal to MCU. Refer to the MPU portion of the specification for more details.



- Disable
- 1 Enable

#### **MCEN** Enable MPU comparison of cacheable/non-cacheable setting.

If disabled, MCU memory accesses are all non-cacheable, i.e., they go through AHB bus (except for TCM). If enabled, the setting in MPU takes effect. If MCU accesses a cacheable memory region, the cache controller returns the data in cache if found in cache, and retrieves the data through the AHB bus only if a cache miss occurs. Refer to the MPU portion of the specification for more details.

- 0 Disable
- 1 Enable

### **CACHE+04h** Cache Operation

**CACHE OP** 

| Bit   | 31 | 30 | 29 | 28 | 27 | 26    | 25   | 24           | 23      | 22 | 21 | 20 | 19  | 18   | 17 | 16 |
|-------|----|----|----|----|----|-------|------|--------------|---------|----|----|----|-----|------|----|----|
| Name  |    |    |    |    |    |       | •    | <b>TADDR</b> | [31:16] |    |    |    |     |      |    |    |
| Type  |    |    |    |    |    |       |      | R/           | W       |    |    |    |     |      |    |    |
| Reset |    |    |    |    |    |       |      |              |         |    |    |    |     |      |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10    | 9    | 8            | 7       | 6  | 5  | 4  | \ 3 | 2    | 1  | 0  |
| Name  |    |    |    |    | TA | DDR[1 | 5:5] |              |         |    |    |    | OP[ | 3:0] |    | EN |
| Type  |    |    |    |    |    | R/W   |      |              |         |    |    |    | V   | I    |    | W1 |
| Reset |    |    |    |    |    | 0     |      | •            |         |    |    |    | C   | )    |    | 0  |

This register defines the address and/or which kind of cache operations to perform. When MCU writes this register, the pipeline of MCU is stopped for the cache controller to complete the operation. Bit 0 of the register must be written 1 to enable the command.

#### **TADDR[31:5]** Target Address

This field contains the address of invalidation operation. If OP[3:0]=0010, TADDR[31:5] is the address[31:5] of a memory whose line is invalidated if it exists in the cache. If OP[3:0]=0100, TADDR[12:5] indicates the set, while TADDR[19:16] indicates which way to clear:

**0001** Way #0

**0010** Way #1

**0100** Way #2

**1000** Way #3

#### **OP[3:0]**Operation

This field determines which cache operations are performed.

**0001** Invalidate all cache lines

**0010** Invalidate one cache line using address

**0100** Invalidate one cache line using set/way

#### **EN** Enable command

This enable bit must be written 1 to enable the command.

- 0 Disabled
- 1 Enabled

#### CACHE+08h Cache Hit Count 0 Lower Part

CACHE\_HCNT0

L

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



### CACHE+0Ch Cache Hit Count 0 Upper Part

## CACHE\_HCNT0

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24     | 23     | 22  | 21 | 20 | 19 | 18         | 17 | 16 |
|-------|----|----|----|----|----|----|----|--------|--------|-----|----|----|----|------------|----|----|
| Name  |    |    |    |    |    |    |    | RESE   | RVED   |     |    |    |    |            |    |    |
| Type  |    |    |    |    |    |    |    |        |        |     |    |    |    |            |    |    |
| Reset |    |    |    |    |    |    |    |        |        |     |    |    |    |            |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8      | 7      | 6   | 5  | 4  | 3  | 2          | 1  | 0  |
| Name  |    |    |    |    |    |    | CH | IIT_CN | T0[47: | 32] |    |    |    |            |    |    |
| Type  |    |    |    |    |    |    |    | R/     | /W     |     |    |    |    |            |    |    |
| Reset |    |    |    |    |    |    |    |        | 0      |     |    |    |    | $\sqrt{N}$ |    |    |

When the CNTEN0 bit in CACHE\_CON register is set to 1 (enabled), this register counts each cache hit until it is disabled. If the value increases over the maximum value (0xffffffffff), the counter rolls over to 0 and continues The 48-bit counter provides a recording time of 31 days even if MCU runs at 104 MHz and every cycle is a cache hit.

Note that before enabling the counter, it is recommended to write the initial value of zero to the counter.

**CHIT CNT0[47:0]** Cache Hit Count 0

WRITE Writing any value to CACHE\_HCNT0L or CACHE\_HCNT0U clears CHIT\_CNT0 to all zeros **READ** Current counter value

### CACHE+10h Cacheable Access Count 0 Lower Par

CACHE\_CCNT0

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24          | 23      | 22   | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|-------------|---------|------|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    | CA | CC_CI       | IT0[31: | :16] |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R/          | W       |      |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | (           |         |      |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | <u>_8</u> ∫ | 7       | 6    | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    | ÇA | CC_CI       | NT0[15  | :0]  |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    | 3) | R/          | W       | _    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |             | )       |      |    |    |    |    |    |    |

### Cacheable Access Count 0 Upper Part

CACHE\_CCNT0

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

When the CNTEN0 bit in CACHE\_CON register is set to 1 (enabled), this register is incremented at each cacheable memory access (whether a cache hit or cache miss). If the value increases over the maximum value (0xffffffffff), the counter rolls over to 0 and continues counting. For 104 MHz MCU speed, if all memory accesses are cacheable and cache hits, this counter overflows after  $(2^48) * 9.6$ ns = 31 days (the shortest time for the counter to overflow). In a more realistic case, the system encounters cache misses, non-cacheable accesses, and idle mode that delay the counter overflow.

CACC CNT0[47:0] Cache Access Count 0



**WRITE** Writing any value to CACHE\_CCNT0L or CACHE\_CCNT0U clears CACC\_CNT0 to all zeros **READ** Current counter value

The best way to use CACHE\_HCNT0 and CACHE\_CCNT0 is to set zero as initial value in both registers, enable both counters (set CNTEN0 to 1), run a portion of program to be benchmarked, stop the counters and retrieve their values. During this period,

$$Cache\ hit\ rate = \frac{CACHE\ \_HCNT}{CACHE\ \_CCNT} \times 100\%\ .$$

The cache hit rate value may help tune the performance of an application program.

Note that CHIT\_CNT0 and CACC\_CNT0 only increment if the cacheable attribute is defined in MPU cacheable regions 0~3.

#### CACHE+18h Cache Hit Count 1 Lower Part

CACHE\_HCNT1

. . .

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

### CACHE+1Ch Cache Hit Count 1 Upper Part

CACHE\_HCNT1

U

| Bit   | 31  | 30   | 29 | 28 | 27 | 26 | 25 24 | 4 23    | 22   | 21 | 20 | 19 | 18 | 17 | 16 |  |
|-------|-----|------|----|----|----|----|-------|---------|------|----|----|----|----|----|----|--|
| Name  |     | -    | -  | -  | _  | -  | RE    | SERVED  | )    | -  | -  | -  | -  | -  |    |  |
| Type  |     | 4.50 |    |    |    |    |       |         |      |    |    |    |    |    |    |  |
| Reset |     |      |    |    |    |    |       |         |      |    |    |    |    |    |    |  |
| Bit   | 15  |      |    |    |    |    |       |         |      |    |    |    |    |    |    |  |
| Name  |     |      |    |    |    |    | CHIT  | CNT1[47 | :32] |    |    |    |    |    |    |  |
| Type  |     |      |    |    |    |    |       |         |      |    |    |    |    |    |    |  |
| Reset | d 0 |      |    |    |    |    |       |         |      |    |    |    |    |    |    |  |

When the CNTEN1 bit in CACHE\_CON register is set to 1 (enabled), this register counts each cache hit until it is disabled. If the value increases over the maximum value (0xfffffffffff), the counter rolls over to 0 and continues counting. The 48-bit counter provides a recording time of 31 days even if MCU runs at 104 MHz and every cycle is a cache hit.

Note that before enabling the counter, it is recommended to write the initial value of zero to the counter.

#### CHIT\_CNT1[47:0] Cache Hit Count

**WRITE** Writing any value to CACHE\_HCNT1L or CACHE\_HCNT1U clears CHIT\_CNT1 to all zeros. **READ** Current counter value

#### 

CACHE\_CCNT1

ı

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23      | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|-------|---------|-----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    | CA | CC_C1 | NT1[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  | CACC_CNT1[15:0] |
|-------|-----------------|
| Type  | R/W             |
| Reset | 0               |

### CACHE+24h Cacheable Access Count 1 Upper Part

CACHE CCNT1

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23      | 22  | 21 | 20 | 19 | 18 | 17 | 16   |
|-------|----|----|----|----|----|----|----|-------|---------|-----|----|----|----|----|----|------|
| Name  |    |    |    |    |    |    |    |       | RVED    |     |    |    |    |    |    | - 12 |
| Type  |    |    |    |    |    |    |    |       |         |     |    |    |    |    |    |      |
| Reset |    |    |    |    |    |    |    |       |         |     |    |    |    |    |    |      |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7       | 6   | 5  | 4  | 3  | 2  | 1  | 0    |
| Name  |    |    |    |    |    |    | CA | CC_CN | IT1[47: | 32] |    |    |    | 77 |    |      |
| Type  |    |    |    |    |    |    |    | R/    |         |     |    |    |    |    |    |      |
| Reset |    | •  | •  | •  |    | •  |    | (     | )       | •   | •  |    | •  |    | •  | -    |

When the CNTEN1 bit in CACHE\_CON register is set to 1 (enabled), this register is incremented at each cacheable memory access (whether a cache hit or a cache miss). If the value increases over the maximum value (0xfffffffffff), the counter rolls over to 0 and continues counting. For 104 MHz MCU speed, if all memory accesses are cacheable and cache hits, this counter overflows after  $(2^48) * 9.6$ ns = 31 days (the shortest time for the counter to overflow). In a more realistic case, the system encounters cache misses, non-cacheable accesses, and idle mode that delay the counter overflow.

CACC\_CNT1[47:0] Cache Access Count 1

WRITE Writing any value to CACHE\_CCNT1L or CACHE\_CCNT1U clears CACC\_CNT1 to all zeros READ Current counter value

The best way to use CACHE\_HCNT1 and CACHE\_CCNT1 is to set zero as initial value in both registers, enable both counters (set CNTEN1 to 1), run a portion of program to be benchmarked, stop the counters and retrieve their values. During this period,

Cache hit rate = 
$$\frac{CACHE}{CACHE} - \frac{HCNT}{CCNT} \times 100\%$$
.

The cache hit rate value may help tune the performance of application program.

Note that CHIT\_CNT1 and CACC\_CNT1 only increment if the cacheable attribute is defined in MPU cacheable regions 4~7.

### 3.7 **MPU**

## 3.7.1 General Description

The purpose of MPU is to provide protection mechanism and cacheable indication of memory. The features of MPU include

• 8-entry protection settings.

Determine if MCU can read/write a memory region. If the setting does not allow MCU access to a particular memory address, MPU stops the memory access and issues an "ABORT" signal to MCU, forcing it to enter "abort" mode. The exception handler must then process the situation.

• 8-entry cacheable settings.



Determine if a memory region is cacheable or not. If cacheable, MCU keeps a small copy in its cache after read accesses. If MCU requires the same data later, it can retrieve the data from the high-speed local copy, instead of from low-speed external memory.

Normally the protection and cacheable attributes are combined together for the same address range, as in the example of ARM946E. For greater flexibility, the MPU in MT6228 provides independent protection and cacheable settings. That is to say, the memory regions defined for memory protection and for cacheable region are different and independent of each other.

The 4GB memory space is divided to 16 memory blocks of 256 MB, i.e., MB0~MB15. EMI uses MB0~MB3; SYSRAM uses MB4; IDMA uses MB5; peripherals and other hardware occupy MB6~MB9; TCM (tightly-coupled memory used by MCU exclusively) uses MB10. The characteristics of these memory blocks are listed below:

• Read/write protection setting

MB5 and above (except MB10) are always readable/writeable.

MB0~MB4 and MB10 are determined by MPU.

• Cacheable setting

MB4 and above are always non-cacheable.

MB0~MB3 are determined by MPU.



### 3.7.2 Protection Settings



Figure 21 Protection setting

**Figure 21** shows the protection setting in each memory block. Five regions are defined in the figure. Note that each region can be continuous or non-continuous to each other, and those address ranges not covered by any region are set to be readable/writeable automatically. One restriction exists: different regions must not overlap.

The user can define maximum 8 regions in MB0~MB4 and MB10. Each region has its own setting defined in a 32-bit register:



- Region base address (22 bits)
- Region size (5 bits)
- Region protection attribute (2 bits)



• Enable bit (1 bit)

MPU aborts MCU if it accesses MB11~MB15 regions.

### 3.7.2.1 Region base address

The region base address defines the start of the memory region. The user needs only to specify several upper address bits. The number of valid address bits depends on the region size. The user must align the base address to a region-size boundary. For example, if a region size is 8 KB, its base address must be a multiple of 8KB.

### 3.7.2.2 Region size

The bit encoding of region size and its relationship with base address are listed as follows.

| Region size | Bit encoding | Base address                        |
|-------------|--------------|-------------------------------------|
| 1KB         | 00000        | Bit [31:10] of region start address |
| 2KB         | 00001        | Bit [31:11] of region start address |
| 4KB         | 00010        | Bit [31:12] of region start address |
| 8KB         | 00011        | Bit [31:13] of region start address |
| 16KB        | 00100        | Bit [31:14] of region start address |
| 32KB        | 00101        | Bit [31:15] of region start address |
| 64KB        | 00110        | Bit [31:16] of region start address |
| 128KB       | 00111        | Bit [31:17] of region start address |
| 256KB       | 01000        | Bit [31:18] of region start address |
| 512KB       | 01001        | Bit [31:19] of region start address |
| 1MB         | 01010        | Bit [31:20] of region start address |
| 2MB         | 01011        | Bit [31:21] of region start address |
| 4MB         | 01100        | Bit [31:22] of region start address |

Table 13 Region size and bit encoding

### 3.7.2.3 Region protection attribute

This attribute has two bits. The MSB determines read access permission, and the LSB write access permission.

| Bit encoding | Permission                   |
|--------------|------------------------------|
| 00           | non-readable / non-writeable |
| 10           | readable / non-writeable     |
| 01           | non-readable / writeable     |
| 11           | readable / writeable         |

Table 14 Region protection attribute bit encoding

Note that bit encoding 11b allows full read/write permission, which is the case when no region is specified. So it is recommended to only specify regions with protection attribute 00b, 10b or 01b.



### 3.7.3 Cacheable Settings



Figure 22 Cacheable setting

**Figure 22** shows the cacheable setting in each memory block. Three regions are defined in the figure. Note that each region can be continuous or non-continuous to each other, and those address ranges not covered by any region are set to be non-cacheable automatically. One restriction exists: different regions must not overlap.

The user can define maximum 8 regions in MB0~MB3. Each region has its own setting defined in a 32-bit register:



- Region base address (22 bits)
- Region size (5 bits)
- Region cacheable attribute (1 bit)
- Enable bit (1 bit)

The region base address and region size bit encoding are the same as those of protection setting. The user must also align the base address to a region-size boundary. The cacheable attribute has the following meaning.

| Bit encoding | Attribute   |
|--------------|-------------|
| 0            | uncacheable |
| 1            | cacheable   |



Table 15 Region cacheable attribute bit encoding

### 3.7.4 MPU Register Definition

MPU base address is assumed 0x80701000 (subject to change).

### MPU+0000h Protection setting for region 0

MPU PROTO

| Bit   | 31 | 30 | 29    | 28     | 27  | 26 | 25 | 24    | 23       | 22     | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|-------|--------|-----|----|----|-------|----------|--------|----|----|----|----|----|----|
| Name  |    |    |       |        |     |    | BA | SEADI | DR[31:   | 16]    |    |    |    |    |    |    |
| Type  |    |    |       |        |     |    |    | R     | W        |        |    |    |    |    |    |    |
| Reset |    |    |       |        |     |    |    |       |          |        |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13    | 12     | 11  | 10 | 9  | 8     | 7        | 6      | 5  | 4  | 1  | 0  |    |    |
| Name  |    | BA | SEADI | DR[15: | 10] |    |    |       | ATTF     | R[1:0] |    | S  |    | ΕN |    |    |
| Type  |    |    | R     | W      |     |    |    |       | RW RW    |        |    |    |    |    | RW |    |
| Reset |    | •  |       | •      | •   |    |    |       | 11 00000 |        |    |    |    | 0  |    |    |

This register sets protection attributes for region 0.

**BASEADDR** Base address of this region

**ATTR** Protection attribute

00 non-readable / non-writeable

01 non-readable / writeable

10 readable / non-writeable

11 readable / writeable

**SIZE** Size of this region

00000 1 KB

00001 2 KB

00010 4 KB

00011 8 KB

**00100** 16 KB

**00101** 32 KB

00110 64 KB

**00111** 128 KB

01000 256 KB

**01001** 512 KB

**01010** 1 MB

**01011** 2 MB

**01100** 4 MB

Enable this region

0 Disable

#### Enable

EN

### MPU+0004h Protection setting for region 1

MPU\_PROT1

| Bit   | 31 30 | 29              | 28    | 27   | 26 | 25 | 24 | 23      | 22       | 21 | 20 | 19      | 18 | 17 | 16 |  |
|-------|-------|-----------------|-------|------|----|----|----|---------|----------|----|----|---------|----|----|----|--|
| Name  |       | BASEADDR[31:16] |       |      |    |    |    |         |          |    |    |         |    |    |    |  |
| Type  |       | R W             |       |      |    |    |    |         |          |    |    |         |    |    |    |  |
| Reset |       |                 |       |      |    |    |    |         |          |    |    |         |    |    |    |  |
| Bit   | 15 14 | 13              | 12    | 11   | 10 | 9  | 8  | 7       | 6        | 5  | 4  | 3       | 2  | 1  | 0  |  |
| Name  |       | BASEAD          | DR[15 | :10] |    |    |    | ATT     | R[1:0]   |    | S  | IZE[4:0 | 0] |    | ΕN |  |
| Type  |       | F               | ₹ W   |      |    |    |    | R W R W |          |    |    |         |    |    | RW |  |
| Reset |       |                 |       |      |    |    |    | 1       | 11 00000 |    |    |         |    |    | 0  |  |



This register sets protection attributes for region 1.

### MPU+0008h Protection setting for region 2

#### MPU PROT2

| Bit   | 31 | 30 | 29    | 28     | 27  | 26 | 25 | 24    | 23       | 22     | 21 | 20 | 19       | 18 | 17 | _16 |
|-------|----|----|-------|--------|-----|----|----|-------|----------|--------|----|----|----------|----|----|-----|
| Name  |    |    |       |        |     |    | BA | SEAD  | DR[31:   | 16]    |    |    |          |    | 1  |     |
| Type  |    |    |       |        |     |    |    | R     | W        |        |    |    |          |    |    |     |
| Reset |    |    |       |        |     |    |    |       |          |        |    |    |          |    |    |     |
| Bit   | 15 | 14 | 13    | 12     | 11  | 10 | 9  | 8     | 7        | 6      | 5  | 4  | 3        | 2  | 1  | 0   |
| Name  |    | BA | SEADI | DR[15: | 10] |    |    |       | ATTI     | R[1:0] |    | S  | SIZE[4:0 | 0] |    | EN  |
| Type  |    |    | R     | W      |     |    |    | RW RW |          |        |    |    |          | 4  |    | RW  |
| Reset |    |    |       |        |     |    |    |       | 11 00000 |        |    |    |          |    | 0  |     |

This register sets protection attributes for region 2.

### MPU+000Ch Protection setting for region 3

### MPU\_PROT3

| Bit   | 31 | 30 | 29    | 28     | 27  | 26 | 25 | 24    | 23        | 22  | 21 | 20 | 19      | 18 | 17 | 16 |
|-------|----|----|-------|--------|-----|----|----|-------|-----------|-----|----|----|---------|----|----|----|
| Name  |    |    |       |        |     |    | BA | SEADI | DR[31:    | 16] |    |    |         |    |    |    |
| Type  |    |    |       |        |     |    |    | R     | W         |     |    |    |         |    |    |    |
| Reset |    |    |       |        |     |    |    |       |           |     |    |    |         |    |    |    |
| Bit   | 15 | 14 | 13    | 12     | 11  | 10 | 9  | 8     | 7         | 6   | 5  | 4  | 3       | 2  | 1  | 0  |
| Name  |    | BA | SEADI | DR[15: | 10] |    |    |       | ATTR[1:0] |     |    |    | SIZE[4: | 0] |    | ΕN |
| Type  |    |    | R     | W      |     |    |    |       | R         | W   |    | RW |         |    |    |    |
| Reset |    |    |       |        |     |    |    | 11    |           |     |    |    | 00000   | )  |    | 0  |

This register sets protection attributes for region 3.

### MPU+0010h Protection setting for region 4

#### MPU\_PROT4

| Bit   | 31 | 30 | 29    | 28     | 27  | 26 | 25 | 24              | 23     | 22       | 21 | 20 | 19      | 18 | 17 | 16 |  |
|-------|----|----|-------|--------|-----|----|----|-----------------|--------|----------|----|----|---------|----|----|----|--|
| Name  |    |    |       |        |     |    | BA | SEAD            | DR[31: | 16]      |    |    |         |    |    |    |  |
| Type  |    | RW |       |        |     |    |    |                 |        |          |    |    |         |    |    |    |  |
| Reset |    |    |       |        |     |    |    |                 |        |          |    |    |         |    |    |    |  |
| Bit   | 15 | 14 | 13    | 12     | 11  | 10 | 9  | 9 8 7 6 5 4 3 2 |        |          |    |    |         |    |    |    |  |
| Name  |    | BA | SEADI | DR[15: | 10] |    |    |                 | ATTE   | R[1:0]   |    | S  | IZE[4:0 | )] |    | ΕN |  |
| Type  |    |    | R     | W      |     |    |    |                 | R      | W        |    |    | RW      |    |    | RW |  |
| Reset |    |    |       |        |     |    |    |                 | 1      | 11 00000 |    |    |         |    |    | 0  |  |

This register sets protection attributes for region 4.

### MPU+0014h Protection setting for region 5

#### MPU\_PROT5

| Bit   | 31 | 30 | 29   | 28     | 27  | 26 | 25 | 24   | 23     | 22     | 21 | 20 | 19      | 18 | 17 | 16 |
|-------|----|----|------|--------|-----|----|----|------|--------|--------|----|----|---------|----|----|----|
| Name  |    |    |      |        |     |    | BA | SEAD | DR[31: | 16]    |    |    |         |    |    |    |
| Type  |    |    |      |        |     |    |    | R    | W      |        |    |    |         |    |    |    |
| Reset |    |    |      |        |     |    |    |      |        |        |    |    |         |    |    |    |
| Bit   | 15 | 14 | 13   | 12     | 11. | 10 | 9  | 8    | 7      | 6      | 5  | 4  | 3       | 2  | 1  | 0  |
| Name  |    | BA | SEAD | DR[15: | 10] |    |    |      | ATT    | R[1:0] |    | S  | IZE[4:0 | )] |    | ΕN |
| Type  |    |    | R    | W      |     |    |    |      | R      | W      |    |    | RW      |    |    | RW |
| Reset | •  |    |      |        |     |    | •  |      | 1      | 1      |    |    | 00000   |    | •  | 0  |

This register sets protection attributes for region 5.

## MPU+0018h Protection setting for region 6

### **MPU\_PROT6**

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



| Name  | BASEADDR[15:10] |  | ATTR[1:0] | SIZE[4:0] | ΕN |
|-------|-----------------|--|-----------|-----------|----|
| Type  | R W             |  | RW        | RW        | RW |
| Reset |                 |  | 11        | 00000     | 0  |

This register sets protection attributes for region 6.

### MPU+001Ch Protection setting for region 7

### MPU\_PROT7

| Bit   | 31 | 30 | 29    | 28     | 27  | 26 | 25 | 24    | 23     | 22     | 21 | 20 | 19      | 18 | 17 | 16 |
|-------|----|----|-------|--------|-----|----|----|-------|--------|--------|----|----|---------|----|----|----|
| Name  |    |    |       |        |     |    | BA | SEADI | DR[31: | 16]    |    |    |         |    |    |    |
| Type  |    |    |       |        |     |    |    | R     | W      |        |    |    |         | 4  |    |    |
| Reset |    |    |       |        |     |    |    |       |        |        |    |    |         |    |    |    |
| Bit   | 15 | 14 | 13    | 12     | 11  | 10 | 9  | 8     | 7      | 6      | 5  | 4  | 3       | 2  | 1  | 0  |
| Name  |    | BA | SEADI | DR[15: | 10] |    |    |       | ATTE   | R[1:0] |    |    | SIZE[4: | 0] |    | EN |
| Type  |    |    | R     | W      |     |    |    |       | R      | W      |    |    | R W     |    |    | RW |
| Reset |    |    | •     |        |     |    |    |       | 1      | 1      |    | •  | 00000   |    | •  | 0  |

This register sets protection attributes for region 7.

### MPU+0040h Cacheable setting for region 0

### **MPU CACHEO**

| Bit   | 31 | 30 | 29    | 28     | 27  | 26 | 25 | 24   | 23     | 22  | 21 | 20 | 19      | 18 | 17 | 16 |
|-------|----|----|-------|--------|-----|----|----|------|--------|-----|----|----|---------|----|----|----|
| Name  |    |    |       |        |     |    | BA | SEAD | DR[31: | 16] |    |    |         |    |    |    |
| Type  |    |    |       |        |     |    |    | R    | W      |     |    |    |         |    |    |    |
| Reset |    |    |       |        |     |    |    |      |        |     |    |    |         |    |    |    |
| Bit   | 15 | 14 | 13    | 12     | 11  | 10 | 9  | 8    | 7      | 6   | 5  | 4  | 3       | 2  | 1  | 0  |
| Name  |    | BA | SEADI | DR[15: | 10] |    |    |      |        | C   | 77 | S  | IZE[4:0 | 0] |    | ΕN |
| Type  |    |    | R     | W      |     |    |    |      |        | RW  |    |    | RW      |    |    | RW |
| Reset |    |    |       | •      | •   |    |    |      |        | 0   |    |    | 00000   | •  | •  | 0  |

This register sets cacheable attributes for region 0.

#### **BASEADDR** Base address of this region

- C Cacheable attribute
  - Uncacheable
  - 1 Cacheable

### **SIZE** Size of this region

**00000** 1 KB

**00001** 2 KB

**00010** 4 KB

00044 0 777

**00011** 8 KB

**00100** 16 KB

**00101** 32 KB

**00110** 64 KB

**00111** 128 KB

**01000** 256 KB

**01001** 512 KB

**01010** 1 MB

**01011** 2 MB

**01100** 4 MB

**EN** Enable this region

- Disable
- 1 Enable



### MPU+0044h Cacheable setting for region 1

## MPU\_CACHE1

| Bit   | 31 | 30 | 29    | 28     | 27  | 26 | 25 | 24   | 23     | 22  | 21 | 20 | 19      | 18 | 17 | 16 |
|-------|----|----|-------|--------|-----|----|----|------|--------|-----|----|----|---------|----|----|----|
| Name  |    |    |       |        |     |    | BA | SEAD | DR[31: | 16] |    |    |         |    |    |    |
| Type  |    |    |       |        |     |    |    | R    | W      |     |    |    |         |    |    |    |
| Reset |    |    |       |        |     |    |    |      |        |     |    |    |         |    | 1  |    |
| Bit   | 15 | 14 | 13    | 12     | 11  | 10 | 9  | 8    | 7      | 6   | 5  | 4  | 3       | 2  | 1  | 0  |
| Name  |    | BA | SEADI | DR[15: | 10] |    |    |      |        | C   |    | S  | IZE[4:0 | 0] |    | EN |
| Туре  |    |    | R     | W      |     |    |    |      |        | RW  |    |    | RW      |    |    | RW |
| Reset |    | •  |       | •      | •   |    |    |      |        | 0   |    |    | 00000   |    |    | 0  |

This register sets cacheable attributes for region 1.

### MPU+0048h Cacheable setting for region 2

### **MPU CACHE2**

| Bit   | 31 | 30 | 29   | 28     | 27  | 26 | 25 | 24   | 23     | 22  | 21 | 20 | 19      | 18 | 17 | 16 |
|-------|----|----|------|--------|-----|----|----|------|--------|-----|----|----|---------|----|----|----|
| Name  |    |    |      |        |     |    | BA | SEAD | DR[31: | 16] |    |    |         |    |    |    |
| Type  |    |    |      |        |     |    |    | R    | W      |     |    |    |         |    |    |    |
| Reset |    |    |      |        |     |    |    |      |        |     |    |    |         |    |    |    |
| Bit   | 15 | 14 | 13   | 12     | 11  | 10 | 9  | 8    | 7      | 6   | 5  | 4  | 3       | 2  | 1  | 0  |
| Name  |    | BA | SEAD | OR[15: | 10] |    |    |      |        | C   |    | S  | IZE[4:0 | 0] |    | EN |
| Type  |    |    | R    | W      |     |    |    |      |        | RW  |    |    | RW      |    |    | RW |
| Reset |    |    |      |        |     |    |    |      |        | 0   |    |    | 00000   |    |    | 0  |

This register sets cacheable attributes for region 2.

### MPU+004Ch Cacheable setting for region 3

### MPU\_CACHE3

| D:4   | 0.1 | 00 | 00   | 00     | 0.7 | 00 | OΓ | 0.4  | T 00   |     | 04 | 00 | 40       | 4.0 | 17 | 10 |
|-------|-----|----|------|--------|-----|----|----|------|--------|-----|----|----|----------|-----|----|----|
| Bit   | 31  | 30 | 29   | 28     | 27  | 26 | 25 | 24   | 23     | 22  | 21 | 20 | 19       | 18  | 17 | 16 |
| Name  |     |    |      |        |     |    | BA | SEAD | DR[31: | 16] |    |    |          |     |    |    |
| Type  |     |    |      |        |     |    |    | R    | W      |     |    |    |          |     |    |    |
| Reset |     |    |      |        |     |    |    |      |        |     |    |    |          |     |    |    |
| Bit   | 15  | 14 | 13   | 12     | 11  | 10 | 9  | 8    | 7      | 6   | 5  | 4  | 3        | 2   | 1  | 0  |
| Name  |     | BA | SEAD | DR[15: | 10] |    |    |      |        | C   |    | 5  | SIZE[4:0 | )]  |    | ΕN |
| Type  |     |    | R    | W      |     |    | 4  |      |        | RW  |    |    | RW       |     |    | RW |
| Reset |     |    |      |        |     |    |    |      |        | 0   |    |    | 00000    |     |    | 0  |

This register sets cacheable attributes for region 3.

### MPU+0050h Cacheable setting for region 4

#### **MPU CACHE4**

| _     |    | _  |      |         |      | V  |    | _    |        |     |    |    |         | _  | _  | _  |
|-------|----|----|------|---------|------|----|----|------|--------|-----|----|----|---------|----|----|----|
| Bit   | 31 | 30 | 29   | 28      | 27   | 26 | 25 | 24   | 23     | 22  | 21 | 20 | 19      | 18 | 17 | 16 |
| Name  |    |    |      |         | . A. |    | BA | SEAD | DR[31: | 16] |    |    |         |    |    |    |
| Type  |    |    |      |         |      |    |    | R    | W      |     |    |    |         |    |    |    |
| Reset |    |    |      |         |      |    |    |      |        |     |    |    |         |    |    |    |
| Bit   | 15 | 14 | 13   | 12      | 11   | 10 | 9  | 8    | 7      | 6   | 5  | 4  | 3       | 2  | 1  | 0  |
| Name  |    | BA | SEAD | DR[15:( | 10]  | ,  |    |      |        | С   |    | S  | IZE[4:0 | 0] |    | ΕN |
| Type  |    |    | R    | W       |      |    |    |      |        | RW  |    |    | RW      |    |    | RW |
| Reset |    | •  |      |         |      |    |    |      |        | 0   | •  | •  | 00000   |    | •  | 0  |

This register sets cacheable attributes for region 4.

# MPU+0054h Cacheable setting for region 5

### MPU\_CACHE5

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



| MEDIA: EX |  |   |       |   |
|-----------|--|---|-------|---|
| Reset     |  | 0 | 00000 | 0 |

This register sets cacheable attributes for region 5.

#### MPU+0058h Cacheable setting for region 6

### MPU CACHE6

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

This register sets cacheable attributes for region 6.

#### MPU+005Ch Cacheable setting for region 7

| MPL  | _ ^ ^ | $\sim$ |     |
|------|-------|--------|-----|
| 1//  |       |        | _ / |
| IVII | , ,,  |        |     |

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

This register sets cacheable attributes for region 7.

### 3.8 Data Cache

## 3.8.1 General Description

The data cache is an 8-kilobyte, 8-way write-back cache that bridges the multi-layer Advanced High-speed Bus (AHB) and the External Memory Interface (EMI). Requests from the AHBs are processed by the data cache before being forwarded to the external bus. The two main objectives of the data cache are to reduce activity on the external bus, and to maximize the throughput of the external bus.

The data cache contains a copy of part of the external memory. If the required data is in data cache, the data is returned from the cache without issuing a request to external memory. This intervention on the cache's part reduces activity on the external bus without losing data throughput. The data cache converts all types of bus read requests into a single type of 16-byte burst read request for the EMI. The EMI converts a 16-byte burst read request to a 16-byte page-mode or 16-byte burst-mode access request on the external bus, depending on the type of memory on the external bus. Page-mode and burst-mode access are more efficient ways to access external memory. The system can retrieve more data in the same amount of time, thereby increasing throughput. The simple request types also simplify the EMI's design, reducing cost and improving timing.

If the data request is a data cache hit (the requested data is found in the cache), the data is returned from the data cache in one cycle for the DMA and GMC busses, and in two cycles for an MCU running at 104MHz. These latencies are much shorter than for an external bus access.

**Figure 23** shows an overview of the bus architecture. The data cache serves all of the bus masters and multi-media engines via the three AHBs.





Figure 23 Overview of the Bus Architecture

The data cache and EMI are connected by four buses. These four interfaces operate independently of each other; requests from the interfaces can be issued at the same time. Three of the four buses are standard AHBs for reading data from external memory, and the other is a request-acknowledgement interface for the write buffer. The EMI can see the next request while current request is still being processed. With the capability of seeing pending requests, the EMI can optimize its access schedule to make memory access more efficient.

The data cache comprises four parts: the AHB interface, the main controller, the line filler, and the write buffer (**Figure 24**).



Figure 24 Data Cache Architecture

The AHB interface's responsibilities are to interface with the AHBs, to prioritize incoming requests from the buses, and to shake hands with the Line Filler for missed data. Requests from the three buses are prioritized before entering the main controller of the cache: requests from the MCU bus take precedence over the requests from the DMA and GMC buses.



The main controller is the core of the data cache: its sophisticated state machine is designed to handle the control of cache TAG memory and DATA memory; hand-shaking with the AHB interface, the write buffer, and line fillers; and debugging functions. The main controller features a "hit under miss" non-blocking cache: a cache miss from an AHB does not block the other buses' access to the cache. When a cache miss occurs, the main controller enters Line Fill Phase: the replaced cache line is flushed (written to target memory as required), and the main controller issues a line fill request to the Line Filler. Once the Line Filler accepts the request, the main control becomes available again for access while the line fill is executed in background. The data cache is still accessible during the line fill.

Two Line Fillers are implemented. They allow two cache lines being replaced concurrently, while leaving the cache still accessible in the meantime. This feature is especially useful for a system with many bus masters. Missed data is returned from Line Filler to the AHB interface directly to reduce the latency.

The data cache contains an eight-stage write buffer. Each stage stores up to 32-bit data. The write buffer favors sequential tags for each buffer stage. Data with sequential tags has the highest priority in the EMI: the EMI can write data sequentially into the same row of the SDRAM memory, reducing the write time by saving on the time required to pre-charge and activate a row.

### 3.8.2 Specification and Main Features

The MT6228 data cache implementation includes the following features:

- 8-kilobyte, 8-way write-back data cache with random cache replacement scheme.
- 64 cache lines for each cache way, and 16 bytes per cache line.
- 2 dirty bits per cache line.

The two dirty bits indicate whether the upper 8-byte and lower 8-byte segment of a cache line have been changed (**Figure 25**). Only half of the cache line is flushed before replacement if that half-line has been changed, shortening the access latency and reducing activity on the external memory bus.



Figure 25 Two Dirty Bits per Cache Line

• Four read/write ports to the EMI.

The EMI sees the next queued memory access request before the current request has been completed, and pre-schedules the access based on requests from the four access ports. This capability is especially useful for SDRAM type memory, where pre-charge and row activation for the next request can be executed in advance to shorten latency.



#### Missed data is returned first.

The data requested during a cache miss is filled by the line filler and returned to the requestor starting at the missed data.

For example: the MCU requests data at address 0x4, but the request results in a cache miss. The data cache dispatches a 16-byte burst request starting from 0x4 to the EMI. The data located at address 0x4 is returned first, followed by that at addresses 0x8, 0xC, then 0x0 (**Figure 26**). The return of the requested data first shortens the access latency.



Figure 26 Missed Data Is Returned First

#### • Background cache line fill.

The data cache has two stand-alone line fillers, each of which can execute a cache line fill upon request from the main controller individually. Other buses can still access the data cache during the line fill, maximizing throughput of the data cache.

For example: two sequential requests come from the MCU and the GMC. The MCU request is accepted before GMC and causes a cache miss. The cache main controller allocates a cache line for the MCU data. If the cache line is dirty, the main controller flushes the line first, then hands over the line fill request to the Line Filler. The main controller is now available to accept the next request from the GMC (**Figure 27**). If the GMC request results in another cache miss, the line fill request is issued to the second Line Filler. The main controller is still available to process the next request from a bus. The main controller is blocked only when a third cache miss occurs before the two previous line fills have been completed.



Figure 27 Background Cache Line Fill



#### Debug support.

The data cache supports a variety of debugging functions and cache tag and data memory read access via the Advanced Peripheral Bus (APB). The following functions can be executed anywhere and anytime without restriction:

- Invalidate all cache lines.
- Invalidate and clean all cache lines.
- Invalidate a single cache line by specifying the set/way or address.
- Invalidate and clean a single cache line by specifying the set/way or address.
- Read a cache tag by specifying the set/way or address.
- Read cache data by specifying the set/way or address.
- Drain the write buffer.

#### • Write buffer flushed before MCU burst read (FBBR mode).

The data cache is specially optimized for MCU code execution, thus the user is recommended to set only code and read-only (RO) data as code cache cacheable (refer to the Code Cache section for the definition of a cacheable region). For regions of cacheable memory, requests are forwarded directly to the EMI through the "MCU burst read" path (**Figure 24**). The requests can be accepted before write buffer is flushed, shortening access latency.

If read-write (RW) data is set as code cache cacheable, data inconsistency may occur. Consider a write request (WB2) followed by a read request (L1C) with the same memory address, both issued by the MCU (**Figure 28 (a)**). The write data (WB2) is queued in the data cache's write buffer, and the read request is forwarded directly to the EMI. Because the write buffer queue contains other data ahead of WB2, WB2 is actually written to target memory after L1C has been executed. Therefore, the MCU receives outdated data, and the consistency problem occurs.



Figure 28 Data Consistency Problem for Cacheable RW

The data cache provides an Flush Buffer Before Read (FBBR) mode that allows RW data to be set as code cache cacheable without compromising data consistency. When in FBBR mode, MCU read requests are not issued to the EMI until the write buffer is empty. This suspension of the read request prevents it from being executed before the write request and solves the data consistency problem. **Figure 28(b)** shows L1C executed after WB2.

Note that in FBBR mode, more cycles are required to complete a read request because of flush cycles before the read operation. Thus MCU access latency may increase, and MCU performance may be reduced.





Figure 29 Increased Latency of FBBR Mode Due to Write Buffer Flush

#### DMA and GMC AHB interfaces allow the clock ratio to switch dynamically between 1:2 and 1:1.

The maximum clock rate of the DMA and GMC buses is 52 MHz; the maximum clock rate of data cache is 104 MHz. A clock ratio bridge is implemented in the AHB interface of the data cache to convert requests and data to different clock rates. The clock ratio of the DMA or GMC bus and data cache can be either 1:2 or 1:1. If the data cache clock rate is lower than 52 MHz, the clock rate of DMA or GMC bus must be the same as that of the data cache and the clock ratio is 1:1. If the data cache clock rate is 104 MHz, the AHB's clock rate can only be 52 MHz, and the clock ratio is 1:2. The clock ratio can be switched between 1:2 and 1:1 dynamically without restriction, reducing the overhead for system clock rate switching software.

### 3.8.3 NOR flash Programming

When data cache is enabled, an external memory access request may not actually result in physical transaction occuring on external memory bus. For instance, when MCU issues a read request to external memory, if the request hits data cache, the data will be returned from data cache directly instead of reading it from external memory. This means no request took place on the external bus.

**Figure 30** illustrates the normal NOR flash programming sequence. These access must be actually executed to the NOR flash memory interface. However, as mentioned before, an internal bus request may not be reflected on the external bus when caches are enabled, and will therefore result in MCU not being able to program the NOR flash.



Figure 30 NOR flash programming sequence

To solve the problem, an IO command mode is designed in data cache. When data cache receive a memory request with "1" at address bit 26, data cache will treat the request as an IO command. For an IO command, data cache will read or write the external memory immediately regardless of the hit/miss condition. In addition, data cache will invalidate the hit cache line for an IO write command. This can prevent data inconsistence between data cache and external memory. Next read data from the same address will return from external memory, not from data cache.

illustrates the NOR flash programming using IO command. To issue an IO command, software has to OR original address bit 26 with "1". In the example, the address to be programmed is 0x0078. To program it with IO command, the address bit 26 is set to "1", and the address becomes 0x4000078.





Figure 31 IO command for NOR flash programming

### 3.8.4 Register Definitions

**Table 16** summarizes the registers used by the data cache.

| Register Address | Register Function           | Acronym    |
|------------------|-----------------------------|------------|
| L2C+0000h        | Data cache control register | L2C_CON    |
| L2C+0004h        | Data cache target register  | L2C_TARGET |
| L2C+0008h        | Data cache status register  | L2C_STA    |
| L2C+000Ch        | Data cache tag register     | L2C_TAG    |
| L2C+0010h        | Data cache data register    | L2C_DATA   |
| L2C+0014h        | Data cache mode register    | L2C_MODE   |
|                  |                             | 957        |

Table 16 Data Cache Registers

### L2C+0000h Data Cache Control Register

L2C\_CON

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

**CMD** Requests an operation on the data cache. Four functions are provided:

0000 Invalidate and clean the data cache.

To invalidate means to clear the valid bit of a cache line. To clean means to write the cache line data to destination memory if dirty.

| VALUE[3:0] | Function                                                                                                                                                            |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0100       | Invalidate a single cache line with the set/way specified in the L2C_TARGET register.                                                                               |
| 0110       | Invalidate and clean a single cache line with the set/way specified in the L2C_TARGET register.                                                                     |
| 1100       | Invalidate a single cache line with the address specified in the L2C_TARGET register. The data cache finds the cache line with the same address and invalidates it. |
| 1110       | Invalidate and clean a single cache line with the address specified in the                                                                                          |
|            | L2C_TARGET register. The data cache finds the cache line with the same address, and cleans and invalidates it.                                                      |
| 0101       | Invalidate all cache lines.                                                                                                                                         |
| 0111       | Invalidate and clean all cache lines.                                                                                                                               |

0001 Read the data cache. Either TAG or DATA can be read.

| 1 | VALUE[1:0] | Function                                                               |
|---|------------|------------------------------------------------------------------------|
| Ţ | 00         | Read a TAG with the set/way specified in the L2C_TARGET register.      |
| ľ | 01         | Read cache data with the set/way specified in the L2C_TARGET register. |
| Ī | 10         | Read a TAG with address specified in the L2C_TARGET register.          |



Read cache data at the address specified in the L2C\_TARGET register.

**O010** Drain the write buffer.

**0011** Configure the MODE bit.

**VALUE** 

| Bit   | 7 | 6 | 5 | 4    | 3            | 2      | 1     | 0      |
|-------|---|---|---|------|--------------|--------|-------|--------|
| Name  |   |   |   | FBBR | DIRTYAL<br>L | GATEDG | MPEG4 | BYPASS |
| Type  |   |   |   | W    | W            | W      | W     | W      |
| Reset |   |   |   | 0    | 0            | 0      | 0     | 1      |

**BYPASS** Bypass the data cache. The write buffer is still activated.

MPEG4 mode.

GATEDG Gate DMA and GMC requests. Any requests from the DMA and GMC are suspended.

DIRTYALL Normally only half a cache line is set as dirty when data is written to only half of the cache line. When this mode is enabled, the entire cache line is set as dirty when data

is written to the line.

FBBR Flush the write buffer before issuing an MCU burst read (L1 cache line fill) to the EMI.

Others Reserved.

**VALUE** Cooperates with CMD to specify a function.

EN Executes the command specified by CMD and VALUE. While EN is set, the values of CMD and VALUE are interpreted as a command: the data cache executes the command CMD with the parameter VALUE.

### L2C+0004h Data Cache Target Register (SET/WAY)

#### L2C\_TARGET

| Bit  | 31 | 30 | 29 | 28 | 27  | 26 | 25  | 24 | 23 | 22  | <u>_21</u> | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|-----|----|-----|----|----|-----|------------|----|----|----|----|----|
| Name |    |    |    |    | SET |    |     |    |    |     | ļ          |    |    |    |    |    |
| Type |    |    |    |    | R/W |    |     |    |    | * = |            |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11  | 10 | 9   | 8  | 7  | 6   | 5          | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |     |    |     |    | I  | XC  |            |    | WO | RD |    |    |
| Type |    |    |    |    |     |    | R/W |    |    |     |            |    | R/ | W  |    |    |

## L2C+0004h Data Cache Target Register (ADDRESS)

#### **L2C TARGET**

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25          | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|-------------|----|----|----|----|----|----|----|----|----|
| Name |    |    |    |    |    |    |             |    | T/ | \G |    |    |    |    |    |    |
| Type |    |    |    |    |    |    | 3C          |    | R/ | W  |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9           | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    | 73 <u> </u> |    | II | X  |    |    | WC | RD |    |    |
| Type |    |    | R/ | W  |    |    |             |    | R  | /W |    |    | R/ | W  |    |    |

Specifies a SET/WAY or address for a single cache invalidation or TAG/DATA read.

### L2C+0008h Data Cache Status Register

### L2C 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  |    |    |    |    |    |    |    |    |    |    |    |    |    | MISS | GATE<br>DG | BUSY |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    | R    | R          | R    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    | 0    | 0          | 0    |

BUSY

Indicates that the current command is still being processed. The register is cleared when the current command is finished.



GATEDG

Indicates that DMA and GMC requests are gated. GATEDG is valid only when the BUSY register is

clear.

**MISS** 

Indicates HIT or MISS of the commands for a single cache invalidation or TAG/DATA read. MISS is valid only when the BUSY register is clear.

#### L2C+000Ch **Data Cache TAG Register**

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

When a read TAG command is executed and finished, the TAG can be read from the L2C\_TAG register.

#### L2C+0010h **Data Cache DATA Register**

L2C DATA

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 |           | 20  | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|-----------|-----|----|----|----|----|
| Name |    |    |    |    |    |    |    | DA | TA |    |    |           |     |    |    |    |    |
| Type |    |    |    |    |    |    |    | F  | 7  |    |    | 4         | V   |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 7         | 4 🛚 | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    | DA | TA |    |    | $\lambda$ |     |    |    |    |    |
| Type | R  |    |    |    |    |    |    |    |    |    |    |           |     |    |    |    |    |

When a read DATA command is executed and finished, DATA can be read from the L2C DATA register.

#### L2C+0014h **Data Cache Mode Register**

L2C\_MODE

| 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  |    |    |    |    |    |    |    |     |    |    |    | FBBR | DIRTY<br>ALL | GATE<br>DG | MPEG<br>4 | BYPA<br>SS |
| Type  |    |    |    |    |    |    |    |     |    |    |    | R    | R            | R          | R         | R          |
| Reset |    |    |    |    |    | ·  |    |     |    |    |    | 0    | 0            | 0          | 0         | 1          |

The L2C\_MODE register shows the data cache's operation mode. The setting can be changed by programming the L2C\_CON register. Refer to the L2C\_CON register description for details.

Bypass the data cache. The write buffer is still activated. **BYPASS** 

MPEG4 MPEG4 mode. This mode is valid only when the data cache is enabled (BYPASS = 0).

**GATEDG** Gate DMA and GMC requests. Any requests from the DMA and GMC are suspended.

**DIRTYALL** Normally only half of a cache line is set as dirty when data is written to only half of the cache line.

When this mode is enabled, the entire cache line is set as dirty when data is written to the line.

**FBBR** Flush the write buffer before issuing an MCU burst read (L1 cache line fill) to the EMI.

#### 3.8.5 Initialize and Enable the Data Cache

Invalidate all cache lines.

Note: DO NOT CLEAN the cache during the first initialization, or the content of the destination memory (external memory) may be overwritten with unpredictable values.



• Set BYPASS to '0' to enable the data cache.

## 3.9 Internal Memory Interface

### 3.9.1 System RAM

MT6228 provides one 128 KByte size of on-chip memory modules acting as System RAM for data access with low latency. Such a module is composed of one high speed synchronous SRAMs with AHB Slave Interface connected to the system backbone AHB Bus, as shown in **Figure 32**. The synchronous SRAM operates on the same clock as the AHB Bus and is organized as 32 bits wide with 4 byte-write signals capable for byte operations. The SRAM macro has limited repair capability. The yield of SRAM is improved if the defects inside it can be repaired during testing.

### 3.9.2 System ROM

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



Figure 32: Block Diagram of the Internal Memory Controller

# 3.10 External Memory Interface

## 3.10.1 General Description

MT6228 incorporates a powerful and flexible memory controller, External Memory Interface, to connect with a variety of memory components. This controller provides one generic access scheme for Flash Memory, SRAM, PSRAM and CellularRAM and another access scheme for MobileRAM. Up to 4 memory banks can be supported simultaneously, BANK0-BANK3, with a maximum size of 64MB each.

Since most of the Flash Memory, SRAM, PSRAM and CellularRAM have similar AC requirements, a generic configuration scheme to interface them is desired. This way, the software program can treat different components by simply specifying certain predefined parameters. All these parameters are based on the cycle time of system clock.

The interface definition based on such a scheme is listed in **Table 17**. Note that, this interface always works with data in Little Endian format for all types of access.



| Signal Name | Type | Description                                             |
|-------------|------|---------------------------------------------------------|
| EA[25:0]    | О    | Address Bus                                             |
| ED[15:0]    | I/O  | Data Bus                                                |
| EWR#        | О    | Write Enable Strobe/MobileRAM Command Input             |
| ERD#        | О    | Read Enable Strobe                                      |
| ELB#        | О    | Lower Byte Strobe/MobileRAM Data Input & Output Mask    |
| EUB#        | О    | Upper Byte Strobe/MobileRAM Data Input & Output Mask    |
| ECS[3:0]#   | О    | BANK0~BANK3 Selection Signal                            |
| EPDN        | О    | PSRAM Power Down Control Signal                         |
| ECLK        | О    | Flash, SRAM, PSRAM and CellularRAM Clock Signal         |
| EADV#       | О    | Flash, SRAM, PSRAM and CellularRAM Address Valid Signal |
| EWAIT       | I    | Flash, SRAM, PSRAM and CellularRAM Wait Signal Input    |
| EDCLK       | О    | MobileRAM Clock Signal                                  |
| ECKE        | О    | MobileRAM Clock Enable Signal                           |
| ERAS#       | О    | MobileRAM Row Address Signal                            |
| ECAS#       | О    | MobileRAM Column Address Signal                         |

Table 17 External Memory Interface Signal of MT6228

| 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 + 0040h      | EMI Control Register 0 for MobileRAM | EMI_CONI  |
| EMI + 0048h      | EMI Control Register 1 for MobileRAM | EMI_CONJ  |
| EMI + 0050h      | EMI Control Register 2 for MobileRAM | EMI_CONK  |
| EMI + 0058h      | EMI Control Register 3 for MobileRAM | EMI_CONL  |
| EMI + 0060h      | EMI Remap Control Register           | EMI_REMAP |
| EMI + 0068h      | EMI General Control Register 0       | EMI_GENA  |
| EMI + 0070h      | EMI General Control Register 1       | EMI_GENB  |
|                  |                                      |           |

Table 18 External Memory Interface Register Map

# 3.10.2 Register Definitions

# EMI+0000h EMI Control Register for BANK 0

**EMI\_CONA** 

| Bit   | 31  | 30   | 29  | 28 | 28 27 26 25 24 23 22 21 20 19 18 |  |  |   |            |     |   | 17  | 16  |     |           |           |
|-------|-----|------|-----|----|----------------------------------|--|--|---|------------|-----|---|-----|-----|-----|-----------|-----------|
| Name  |     | C2WS |     |    | C2WH                             |  |  |   | C2RS       |     |   | PR  | LT  |     | CLKE<br>N | PMO<br>DE |
| Type  |     | R/W  |     |    | R/W                              |  |  |   | R/W        |     |   | R/  |     | R/W | R/W       |           |
| Reset |     | 0    |     |    | 0                                |  |  | 0 |            |     | 0 |     |     |     | 0         | 0         |
| Bit   | 15  | 14   | 13  | 12 | 12 11 10 9                       |  |  | 8 | 7          | 5   | 4 | 3   | 1   | 0   |           |           |
| Name  | DW  | RBLN | BW  |    | WST                              |  |  |   | WAIT PSIZE |     |   |     | RLT |     |           |           |
| Type  | R/W | R/W  | R/W |    | R/W                              |  |  |   | R/W        | R/W |   | R/W |     |     |           |           |
| Reset | 0   | 1    | 0   |    | 0                                |  |  |   | 0          | 0   |   | 7   |     |     |           |           |



### EMI+0008h EMI Control Register for BANK 1

### **EMI\_CONB**

| Bit   | 31  | 30          | 29  | 28 | 27   | 26 | 25 | 24 | 23   | 22           | 21 | 20    | 19  | 18  | 17        | 16        |
|-------|-----|-------------|-----|----|------|----|----|----|------|--------------|----|-------|-----|-----|-----------|-----------|
| Name  |     | C2WS        |     |    | C2WH |    |    |    | C2RS |              |    | PF    | RLT |     | CLKE<br>N | PMO<br>DE |
| Type  |     | R/W         |     |    | R/W  |    |    |    | R/W  |              |    | R     | /W  |     | R/W       | R/W       |
| Reset |     | 0           |     |    | 0    |    |    | 0  |      |              | 0  |       |     |     | 0         | 0         |
| Bit   | 15  | 14          | 13  | 12 | 11   | 10 | 9  | 8  | 7    | 6            | 5  | 5 4 3 |     |     | 1         | 0         |
| Name  | DW  | <b>RBLN</b> | BW  |    | WST  |    |    |    | WAIT | <b>PSIZE</b> |    |       |     | RLT |           |           |
| Type  | R/W | R/W         | R/W |    | R/W  |    |    |    | R/W  | R/W          |    |       |     |     |           |           |
| Reset | 0   | 1           | 0   |    | 0    |    |    |    | 0    | 0            |    |       |     |     |           |           |

### EMI+0010h EMI Control Register for BANK 2

### **EMI CONC**

| Bit   | 31  | 30          | 29  | 28 | 27   | 26  | 25 | 24 | 23   | 22           | 21  | 20 | 19 | 18  | 17        | 16        |
|-------|-----|-------------|-----|----|------|-----|----|----|------|--------------|-----|----|----|-----|-----------|-----------|
| Name  |     | C2WS        |     |    | C2WH |     |    |    | C2RS |              |     | PF | LT |     | CLKE<br>N | PMO<br>DE |
| Type  |     | R/W         |     |    | R/   | W   |    |    | R/W  |              |     | R  | w  |     | R/W       | R/W       |
| Reset |     | 0           |     |    | 0    |     |    | 0  |      |              |     |    |    | 0   | 0         |           |
| Bit   | 15  | 14          | 13  | 12 | 11   | 10  | 9  | 8  | 7    | 6            | 5   | 4  | 3  | 2   | 1         | 0         |
| Name  | DW  | <b>RBLN</b> | BW  |    |      | WST |    |    | WAIT | <b>PSIZE</b> |     | 9. |    | RLT |           |           |
| Type  | R/W | R/W         | R/W |    | R/W  |     |    |    | R/W  | R/W          | R/W |    |    | R/W |           |           |
| Reset | 0   | 1           | 0   |    | 0    |     |    |    | 0    | 0            | 7   |    |    |     |           |           |

### EMI+0018h EMI Control Register for BANK 3

#### EMI\_COND

|       |     |             | _   |    |      |    |    | _  | $\overline{}$ |         |    |    |     | 18 | _         | _         |
|-------|-----|-------------|-----|----|------|----|----|----|---------------|---------|----|----|-----|----|-----------|-----------|
| Bit   | 31  | 30          | 29  | 28 | 27   | 26 | 25 | 24 | 23 _          | _ 22 _  | 21 | 20 | 19  | 17 | 16        |           |
| Name  |     | C2WS        |     |    | C2WH |    |    |    | C2RS          |         |    | PR | LT  |    | CLKE<br>N | PMO<br>DE |
| Type  |     | R/W         |     |    | R/   | W  |    |    | R/W           |         |    | R/ | W   |    | R/W       | R/W       |
| Reset |     | 0           |     |    | 0    |    |    | 0  |               |         |    | (  |     | 0  | 0         |           |
| Bit   | 15  | 14          | 13  | 12 | 11   | 10 | 9  | 8  | 7             | 6       | 5  | 4  | 3   | 2  | 1         | 0         |
| Name  | DW  | <b>RBLN</b> | BW  |    | WST  |    |    |    | WAIT PSIZE    |         |    |    |     |    |           |           |
| Туре  | R/W | R/W         | R/W |    | R/W  |    |    | 不了 | □R/W          | R/W R/W |    |    | R/W |    |           |           |
| Reset | 0   | 1           | 0   |    | 0    |    |    |    | 0             | 0       | 7  |    |     |    |           |           |

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

#### **RLT** Read Latency Time

Specifies the number of wait-states to insert in the bus transfer to the requesting agent. Such a parameter must be chosen carefully to meet the timing specification requirements for common parameter tACC(address access time) for asynchronous-read device and tCWT(chip select low to wait valid time) for synchronous-read device. An example is shown below.





Figure 33 Read Wait State Timing Diagram for Asynchronous-Read Memory (CLKEN=0)

| Access Time     | Read Latency Time in | 104 MHz unit |
|-----------------|----------------------|--------------|
| 65 ns ~ 70 ns   | 7                    |              |
| 85 ns ~ 90 ns   | 9                    |              |
| 110 ns ~ 120 ns | 12                   |              |

Table 19 Reference value of Read Latency Time for Asynchronous-Read memory Devices



Figure 34 Read Wait State Timing Diagram for Synchronous-Read Memory (CLKEN=1)

| ECS# Low to EWAIT Valid | Read Latency Time in 104 MHz unit |
|-------------------------|-----------------------------------|
| 0 ns ~ 10 ns            | 1                                 |
| 10 ns ~ 20 ns           | 2                                 |

Table 20 Reference value of Read Latency Time for Synchronous-Read Devices

**PSIZE** This bit position describes the page size behavior of that the Page Mode enabled device.

- 0 8 byte, EA[22:3] remains the same
- 1 16 byte, EA[22:4] remains the same

**WAIT** Data-valid feedback operation control for Flash memory, PSRAM and CellularRAM.

- O Disable data-valid feedback operation control
- 1 Enable data-valid feedback operation control

WST Write Wait State



Specifies the parameters to extend adequate setup and hold time for target component in write operation. Such parameter must be chosen carefully to meet the timing specification requirements for common parameter tWC(write cycle time) for asynchronous-write device and tCWT(chip select low to wait valid time) for synchronous-write device. An example is shown in **Figure 35** and **Table 21**.



Figure 35 Write Wait State Timing Diagram for Asynchronous-Write Memory (BW=0)

| Write Pulse Width<br>(Write Data Setup Time) | Write Wait State in 104 MHz unit |
|----------------------------------------------|----------------------------------|
| 65 ns ~ 70 ns                                | 7                                |
| 85 ns ~ 90 ns                                | 9                                |
| 110 ns ~ 120 ns                              | 12                               |

Table 21 Reference value of Write Wait State for Asynchronous-Write Devices



Figure 36 Write Wait State Timing Diagram for Synchronous-Write Memory (CLKEN=1 and BW=1)

| ECS# Low to EWAIT Valid | Write Wait State in 104 MHz unit |
|-------------------------|----------------------------------|
| 0 ns ~ 10 ns            | 1                                |
| 10 ns ~ 20 ns           | 2                                |

Table 22 Reference value of Write Wait State for Synchronous-Write Devices

#### **BW** Burst Mode Write Control

O Disable burst write operation



1 Enable burst write operation

**RBLN** Read Byte Lane Enable

**DW** Data Width

0 16 Bit

**1** 8 Bit

**PMODE** Page Mode Control

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

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

**PRLT** Read Latency Time within the Same Page

Since page mode operation only helps to eliminate read latency in subsequent access within the same page, the initial latency does not matter. Thus, the memory controller must still adopt the RLT parameter for the initial read or reads between different pages, even if PMODE is set to 1.

**CLKEN** Clock Enable Control

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

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

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

### EMI+0040h EMI Control Register 0 for MobileRAM

**EMI CONI** 

| Bit   | 31 | 30  | 29  | 28  | 27  | 26  | 25           | 24                  | 23   | 22  | 21        | 20         | 19          | 18        | 17   | 16        |
|-------|----|-----|-----|-----|-----|-----|--------------|---------------------|------|-----|-----------|------------|-------------|-----------|------|-----------|
| Name  |    |     |     |     |     |     | PAUS<br>E_EN | PING<br>PONG<br>_EN | DRAM | MOD | DRAM      | SIZE       | DRAM<br>_EN |           | DRAN | I_CS      |
| Type  |    |     |     |     |     |     | R/W          | R/W                 | R/   | W   | R/        | W          | R/W         |           | R/\  | W         |
| Reset |    |     |     |     |     |     | 0            | 0                   | 2    | d   | C         | )          | 0           |           | 0    | )         |
| Bit   | 15 | 14  | 13  | 12  | 11  | 10  | 9            | 8                   | 7    | 6   | 5         | 4          | 3           | 2         | 1    | 0         |
| Name  |    | BA1 | BA0 | A12 | A11 | A10 | A9           | A8                  | A7.  | A6  | <b>A5</b> | <b>A</b> 4 | A3          | <b>A2</b> | A1   | <b>A0</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       |
| Reset |    | 0   | 0   | 0   | 0   | 0   | 0            | 0                   | 0    | 0   | 0         | 0          | 0           | 0         | 0    | 0         |

**A12-A0** Mode Register Configuration

**BA1-B0** Mode Register Configuration

DRAM\_CS MobileRAM Controller Chip Select Signal Control

OO Chip Select 0 is used for MobileRAM

01 Chip Select 1 is used for MobileRAM

10 Chip Select 2 is used for MobileRAM

11 Chip Select 3 is used for MobileRAM

**DRAM\_EN** MobileRAM Controller Control

MobileRAM controller is disabled

1 MobileRAM controller is enabled

**DRAM\_SIZE** MobileRAM Chip Size

**00** 64Mbit

**01** 128Mbit

10 256Mbit

**11** 512Mbit

**DRAM\_MODE** MobileRAM Scrambling Table Control

**00** Mode 1

**01** Mode 2

10 Mode 3 (PASR is not allowed)



11 Mode 3 (PASR is not allowed)

PINGPONG\_EN Ping-pong Operation Control

PAUSE\_ENSelf-Refresh Mode Control when Baseband is in Pause Mode Operation

### EMI+0048h EMI Control Register 1 for MobileRAM

**EMI CONJ** 

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

PCA Pre-Charge All Command
AREF Auto-Refresh Command
SETM Set Mode Register Command

SRF Self-Refresh Mode Command
PDN Power-Down Mode Command
SRFS Self-Refresh Mode Status

**PDNS** Power Down Mode Status

#### EMI+0050h EMI Control Register 2 for MobileRAN

EMI\_CONK

|       |    |     |      |    |     |    |     |    |      |     | 2  |    |     |    |     |     |  |
|-------|----|-----|------|----|-----|----|-----|----|------|-----|----|----|-----|----|-----|-----|--|
| Bit   | 31 | 30  | 29   | 28 | 27  | 26 | 25  | 24 | 23   | 22  | 21 | 20 | 19  | 18 | 17  | 16  |  |
| Name  | W  | 'R  |      |    |     |    |     |    | RAS_ | MAX |    |    |     |    |     |     |  |
| Type  | R/ | W   |      |    |     |    |     |    | R/   | W   |    |    |     |    |     |     |  |
| Reset |    |     |      |    |     |    |     |    |      |     |    |    |     |    |     |     |  |
| Bit   | 15 | 14  | 13   | 12 | 11  | 10 | 9   | 8  | 7    | 6   | 5  | 4  | 3   | 2  | 1   | 0   |  |
| Name  |    | RAS | _MIN |    | RRD |    |     | 4  | RC . |     | R  | P  | RC  | D  |     | CAS |  |
| Type  |    | R/  | W    |    | R/  | W  | R/W |    |      | R/W |    | R/ | R/W |    | R/W |     |  |
| Reset |    |     |      |    | (   | )  |     |    | 0    | •   | (  | )  |     | )  | 0   |     |  |

**CAS** CAS Latency Control

 $\mathbf{0}$  CAS Latency = 2

1 CAS Latency = 3

**RCD** Active to Read or Write Delay

**RP** Pre-charge Command Period

Active Bank A to Active Bank A Period

**RRD** Active Bank A to Active Bank B Delay

**RAS\_MIN** Minimum Active to Pre-charge Command Delay

RAS\_MAX Maximum Active to Pre-charge Command Delay

**WR** Write Recovery Time

### EMI+0058h EMI Control Register 3 for MobileRAM

**EMI CONL** 

| Bit   | 31        | 30 | 29 | 28 | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20  | 19  | 18 | 17  | 16 |  |
|-------|-----------|----|----|----|-----|----|----|----|----|----|----|-----|-----|----|-----|----|--|
| Name  | ARFE<br>N |    |    |    | HYE |    |    |    |    |    |    |     | DIV |    |     |    |  |
| Type  | R/W       | 4  |    |    | 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  |           | 15 | R  |    |     | M  | RD |    |    | XS | SR | RF  | RFC |    |     |    |  |
| Type  |           | R/ | Ŵ  |    |     | R  | /W |    |    | R/ | W  |     | R/W |    |     |    |  |
| Reset |           | (  | 0  |    |     | (  | 0  |    |    | (  | C  | 0   |     |    |     |    |  |

RFC Auto Refresh Period



**XSR** Exit Self Refresh to Active Command Delay

MRD Load Mode Register Command Period

**ISR** Minimum Period for Self-Refresh Mode

MobileRAM Refresh Period Pre-Divider in units of 32 KHz; this field defines the MobileRAM Refresh Period.

**00** Divide by 1 (32KHz)

**01** Divide by 2 (32KHz/2)

**10** Divide by 3 (32KHz/3)

**11** Divide by 4 (32KHz/4)

**REFCNT** Number of Auto-Refresh-Command to issue per MobileRAM Refresh Period.

**HYE** Reserved

**ARFEN** Auto Refresh Control

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

#### **EMI REMAP**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | _\_3_ <sup>_</sup> _ | 2 | 1   | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|----------------------|---|-----|-----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |                      |   | RM1 | RM0 |
| Туре  |    |    |    |    |    |    |   |   |   |   |   |   | Ď /                  |   | R/W | R/W |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |                      |   | 0   | 0   |

This register accomplishes the Memory Re-mapping Mechanism. The register provides the kernel software program or system designer with 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 23.

| RM[1:0] | Address 0000_0000h - 07ff_ffffh | Address 0800_0000h - 0fff_ffffh |
|---------|---------------------------------|---------------------------------|
| 00      | Boot Code                       | BANK1                           |
| 01      | BANK1                           | BANK0                           |
| 10      | BANK0                           | BANK1                           |
| 11      | BANk1                           | BANK0                           |

Table 23 Memory Map Configuration

### EMI+0068h EMI General Control Register 0

#### **EMI GENA**

| Bit   | 31  | 30    | 29    | 28        | 27        | 26        | 25        | 24         | 23   | 22 | 21 20 19 18 17 16 |   |   |   |   |   |
|-------|-----|-------|-------|-----------|-----------|-----------|-----------|------------|------|----|-------------------|---|---|---|---|---|
| Name  | CKE | EXT_C | SUARD | DCKS<br>R | DCKE<br>2 | DCKE<br>4 | DCKE<br>8 | DCKE<br>16 | DCKE |    | DCKDLY            |   |   |   |   |   |
| Type  | 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                 |   |   |   |   |   |
| Bit   | 15  | 14    | 13    | 12        | 11        | 10        | 9         | 8          | 7    | 6  | 5                 | 4 | 3 | 2 | 1 | 0 |
| Name  | EDA | PDNE  | WPOL  | SCKS<br>R | SCKE<br>2 | SCKE<br>4 | SCKE<br>4 | SCKE<br>16 | SCKE |    | SCKDLY            |   |   |   |   |   |
| Type  | R/W | R/W   | R/W   | R/W       | R/W       | R/W       | R/W       | R/W        | R/W  |    | R/W               |   |   |   |   |   |
| Reset | 1   | 0     | 0     | 0         | 0         | 0         | 0         | 0          | 0    |    | 0                 |   |   |   |   |   |

**SCKDLY** FLASH, SRAM, PSRAM and CellularRAM Clock Delay Control

SCKE FLASH, SRAM, PSRAM and CellularRAM Clock Enable Control

SCKEn FLASH, SRAM, PSRAM and CellularRAM Clock Pad Driving Control (n=2, 4, 8, 16)

SCKSRFLASH, SRAM, PSRAM and CellularRAM Pad Slew-Rate Control

WPOL FLASH, SRAM, PSRAM and CellularRAM Wait Signal Inversion Control

PDNE PSRAM Power Down Control

**EDA** Data Bus Active Drive Control



**DCKDLY** MobileRAM Clock Delay Control

**DCKE** MobileRAM Clock Enable Control

**DCKEn** MobileRAM Clock Pad Driving Control (n=2, 4, 8, 16)

**DCKSR**MobileRAM Clock Pad Slew-Rate Control

**EXT GUARD** Extra IDLE Time for FLASH, SRAM, PSRAM and CellularRAM

**CKE** Dynamic MobileRAM Clock Enable Control



Figure 37 Clock Delay Control

### EMI+0070h EMI General Control Register 1

### **EMI\_GENB**

| Bit   | 31 | 30        | 29        | 28        | 27        | 26         | 25         | 24         | 23         | 22         | 21          | 20        | 19        | 18        | 17        | 16         |
|-------|----|-----------|-----------|-----------|-----------|------------|------------|------------|------------|------------|-------------|-----------|-----------|-----------|-----------|------------|
| Name  |    | EASR      | EAE2      | EAE4      | EAE8      | EAE1<br>6  | EDSR       | EDE2       | EDE4       | EDE8       | EDE1<br>6   | ECSS<br>R | ECSE<br>2 | ECSE<br>4 | ECSE<br>8 | ECSE<br>16 |
| 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        |
| Reset |    | 1         | 1         | 0         | 0         | 0          | 1          | 1          | 0          | 0          | 0           | 1         | 1         | 0         | 0         | 0          |
| Bit   | 15 | 14        | 13        | 12        | 11        | 10         | 9          | 8          | 7_         | 6          | 5           | 4         | 3         | 2         | 1         | 0          |
| Name  |    | ERWS<br>R | ERWE<br>2 | ERWE<br>4 | ERWE<br>8 | ERWE<br>16 | EADV<br>SR | EADV<br>E2 | EADV<br>E4 | EADV<br>E8 | EADV<br>E16 | ERCS<br>R | ERCE<br>2 | ERCE<br>4 | ERCE<br>8 | ERCE<br>16 |
| 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        |
| Reset |    | 1         | 1         | 0         | 0         | 0          | 1          | 1          | 0          | 0          | 0           | 1         | 1         | 0         | 0         | 0          |

**ERCEn** RAS and CAS Pad Driving Control (n=2, 4, 8, 16)

**ERCSR**RAS and CAS Pad Slew-Rate Control

**EADVEn** EADV Pad Driving Control (n=2, 4, 8, 16)

**EADVSR** EADV Pad Slew-Rate Control

**ERWEN**ERD, EWR, EUB and ELB Pad Driving Control (n=2, 4, 8, 16)

**ERWSR** ERD, EWR, EUB and ELB Pad Slew-Rate Control

**ECSEn** ECS[3:0] Pad Driving Control (n=2, 4, 8, 16)

ECSSR ECS[3:0] Pad Slew-Rate Control

**EDEn** ED[15:0] Pad Driving Control (n=2, 4, 8, 16)

**EDSR** ED[15:0] Pad Slew-Rate Control

**EAEn** EA[25:0] Pad Driving Control (n=2, 4, 8, 16)

**EASR** EA[25:0] Pad Slew-Rate Control



# 4 Microcontroller Peripherals

Microcontroller (MCU) Peripherals are devices that are under direct control of the Microcontroller. Most of the devices are attached to the Advanced Peripheral Bus (APB) of the MCU subsystem, and serve as APB slaves. Each MCU peripheral must be accessed as a memory-mapped I/O device; that is, the MCU or the DMA bus master reads from or writes to the 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 38**.



Figure 38 PWM waveform

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

The output PWM frequency is determined by:

 $CLOCK_DIV = 1$ , when CLK[1:0] = 00b

 $CLOCK_DIV = 2$ , when CLK[1:0] = 01b

 $CLOCK_DIV = 4$ , when CLK[1:0] = 10b

 $CLOCK_DIV = 8$ , when CLK[1:0] = 11b

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 is always HIGH.

## 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 |    |    |    |    |    |    |   |   |   |   |   |   |   | CLKS<br>EL | 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 the LOW state.

**CLKSEL** Select PWM1 clock

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_ | COUN  | T [12:0] |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |       | R/W   |          |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |       | 1FFFh |          |   |   |   |   |   |

**PWM1\_COUNT**PWM1 max counter value. This value is the initial value for the internal counter. Regardless of the operation mode, if PWM1\_COUNT is written while the internal counter is counting backwards, the new initial value does not take 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 equal to PWM1\_THRES, the PWM1 output signal is 0; when the internal counter is less than PWM1\_THRES, the PWM1 output signal is 1.

### PWM+000Ch PWM2 Control register

PWM2\_CON

|       |    |    |    |    |      |    |   | 7 |   |   |   |   |   |            |     |       |
|-------|----|----|----|----|------|----|---|---|---|---|---|---|---|------------|-----|-------|
| Bit   | 15 | 14 | 13 | 12 | 11   | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2          | 1   | 0     |
| Name  |    |    |    |    |      |    |   |   |   |   |   |   |   | CLKS<br>EL | CLK | [1:0] |
| Туре  |    |    |    |    | 15.7 |    |   |   |   |   |   |   |   | R/W        | R/  | W     |
| Reset |    |    |    |    |      |    | , |   |   |   |   |   |   | 0          | (   | )     |

**CLK** Select PWM2 clock prescaler scale.

00 CLK Hz

01 CLK/2 Hz

**10** CLK/4 Hz

11 CLK/8 Hz

Note: When PWM2 module is disabled, its output should be kept in the 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\_COUNTPWM2 max counter value. This value is the initial value for the internal counter. Regardless of the operation mode, if PWM2\_COUNT is written while the internal counter is counting backwards, the new initial value does not take effect until the internal counter counts down to zero, i.e. a complete period.

## PWM+0014h PWM2 Threshold Value register

| DΜ | VM2   | ТН | RES |
|----|-------|----|-----|
|    | VIVIE |    |     |

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7     | 6     | 5        | 4 | 3 | 2                       | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|-------|-------|----------|---|---|-------------------------|---|---|
| Name  |    |    |    |    |    |    |   |   | PWM2_ | THRES | S [12:0] |   |   | $\overline{\mathbf{x}}$ |   |   |
| Type  |    |    |    |    |    |    |   |   |       | R/W   |          |   |   |                         |   |   |
| Reset |    |    |    |    |    |    |   |   |       | 0     |          |   |   |                         |   |   |

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

Figure 39 shows the PWM waveform with the indicated register values.



Figure 39 PWM waveform with register values



### 4.2 Alerter

## 4.2.1 General Description

The output of the Alerter has two sources: one is the enhanced PWM output signal, implemented within 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 ALERTER\_CON.

The enhanced PWM has three modes of operation and can 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 for the internal counters counter1 and counter2, respectively.

POWERDOWN signal is applied to power down the Alerter module. When Alerter is deactivated (POWERDOWN=1), the output is in a low state. The waveform of Alerter from the enhanced PWM source in different modes is shown in **Figure 40**.



Figure 40 Alerter Waveform

In Mode 1, the polarity of the Alerter output signal, given the relationship between internal counter1 and the programmed threshold, is inverted each time internal counter2 reaches zero.

In Mode 2, each time the internal counter2 reaches zero, the Alerter output signal toggles between the normal PWM signal (i.e. the signal is low for an internal counter1 value greater than or equals to ALERTER\_THRES; high when the internal counter1 value is less than ALERTER\_THRES) and low state.

In Mode 3, the value of internal counter2 has no effect on output signal. That is, the alerter output signal is low as long as the internal counter 1 value is above the programmed threshold, and is high when the internal counter1 is less than ALERTER\_THRES, regardless of internal counter2's value.

The output signal frequency is given by:



$$\begin{cases} \frac{13000000}{2 \times (ALERTER\_CON[1:0]+1) \times (ALERTER\_CNT1+1) \times (ALERTER\_CNT2+1)} & \text{for mode 1 and mode 2} \\ \frac{130000000}{(ALERTER\_CNT1+1) \times (ALERTER\_CON[1:0])} & \text{for mode 3} \end{cases}$$

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

## 4.2.2 Register Definitions

### ALTER+0000h Alerter counter1 value register

### ALERTER CNT1

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

ALERTER\_CNT1 Alerter max counter's value. Initial value of internal counter1. In any mode, if ALERTER\_CNT1 is written when the internal counter1 is counting, the new start value does not take effect until the next countdown period; i.e. after internal counter1 reaches zero.

## 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  |    |    |    |    |    |    | ALER | TER_T | HRES | [15:0] | $\neg$ $\Box$ |   |   |   |   |   |
| Type  |    |    |    |    |    |    |      | R/    | W    | 75     | ,             |   |   |   |   |   |
| Reset |    | •  | •  |    | •  |    | •    | (     |      |        |               | • | • | • |   | - |

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

## ALTER+0008h Alerter counter2 value register

### **ALERTER\_CNT2**

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

**ALERTER\_CNT2** Initial value for internal counter2. The internal counter2 decreases by one each time the internal counter1 counts down to zero; internal counter1 is a nested counter.

## **ALTER+000Ch Alerter control register**

### **ALERTER CON**

|       |    |    |    |    |                      | 1 |    |   |      |   |   |   |    |    |   |     |       |
|-------|----|----|----|----|----------------------|---|----|---|------|---|---|---|----|----|---|-----|-------|
| Bit   | 15 | 14 | 13 | 12 | 1:                   |   | 10 | 9 | 8    | 7 | 6 | 5 | 4  | 3  | 2 | 1   | 0     |
| Name  |    |    |    |    |                      |   |    |   | TYPE |   |   |   | MO | DE |   | CLK | [1:0] |
| Type  |    |    |    |    | $\mathbb{P}_{\perp}$ |   |    |   | R/W  |   |   |   | R/ | W  |   | R/  | W     |
| Reset |    |    |    |    |                      |   |    |   | 0    |   |   |   | (  | )  |   | (   | )     |

**CLK** Select the PWM Waveform clock.

**00** 13 MHz

**01** 13/2 MHz

**10** 13/4 MHz

11 13/8 MHz

**MODE** Select the 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 the Alerter module is powered down, its output must be kept in low state.

Figure 41 shows the Alerter waveform with the register values.



Figure 41 Alerter Output Signal from Enhanced PWM with Register Value Present

## 4.3 SIM Interface

The MT6228 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 42 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 43 SIM Interface Timing Diagram

## 4.3.1 Register Definitions

| SIWI+ | ·UUUU | n  | SIM | moau | iie co | ntroi | regis | ster |   |   |   |   |   |      | SIM_ | CON  |
|-------|-------|----|-----|------|--------|-------|-------|------|---|---|---|---|---|------|------|------|
| Bit   | 15    | 14 | 13  | 12   | 11     | 10    | 9     | 8    | 7 | 6 | 5 | 4 | 3 | 2    | 1    | 0    |
| Name  |       |    |     |      |        |       |       |      |   |   |   |   |   | WRST | CSTO | SIMO |



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

SIMON SIM card power-up/power-down control

- O 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.

- 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  |    |    |    |    |    | HFEN | T0EN | T1EN | TOUT | SIMS<br>EL | ODD | SDIR | SINV | CPOL | TXAC<br>K | RXAC<br>K |
| 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

- O Disable character receipt handshaking
- 1 Enable character receipt handshaking

TXACK SIM card transmission error handshake control

- O Disable character transmission handshaking
- 1 Enable character transmission handshaking

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

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

**SINV** Data Inverter.

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

**SDIR** Data Transfer Direction

- O LSB is transmitted and received first
- 1 MSB is transmitted and received first

**ODD** Select odd or even parity

- O Even parity
- 1 Odd parity

**SIMSEL** SIM card supply voltage select

- O SIMSEL pin is set to LOW level
- SIMSEL pin is set to HIGH level

**TOUT** SIM work waiting time counter control

- O Disable Time-Out counter
- 1 Enable Time-Out counter

**T1EN** T=1 protocol controller control

- O Disable T=1 protocol controller
- 1 Enable T=1 protocol controller

**T0EN** T=0 protocol controller control

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

**HFEN** Hardware flow control



- O Disable hardware flow control
- 1 Enable hardware flow control

## SIM +0008h SIM Baud Rate Register

SIM BRR

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

**SIMCLK** Set SIMCLK frequency

00 13/2 MHz

**01** 13/4 MHz

**10** 13/8 MHz

**11** 13/12 MHz

**BAUD** Determines the baud rate as a division of SIMCLK (SIMCLK/BAUD[8: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    |    |    |    |    |    | <b>EDCE</b> | T1EN | <b>RXER</b> | T0EN | SIMO | ATRER         | <b>TXER</b> | TOU | <b>OVRU</b> | <b>RXTID</b> | <b>TXTID</b> |
| Ivallie |    |    |    |    |    | RR          | D    | R           | D    | FF   | R             | R           | T   | N           | E            | E            |
| 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    | $\overline{}$ | 0           | 0   | 0           | 0            | 0            |

For all these bits

- 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    |    |    |    |    |    | <b>EDCE</b> | T1EN | RXER | TOEN | SIMO | <b>ATRER</b> | <b>TXER</b> | TOU | <b>OVRU</b> | <b>RXTID</b> | <b>TXTID</b> |
| Ivaille |    |    |    |    |    | RR          | D    | R    | D    | FF   | R            | R           | T   | N           | E            | E            |
| Type    |    |    |    |    |    | RC          | RC   | RC   | RC   | RC   | RC           | RC          | RC  | RC          | RO           | RO           |
| Reset   |    |    |    |    |    | _           |      |      | _    | _    | _            | _           | _   | _           | _            | _            |

TXTIDETransmit FIFO tide mark reached interrupt occurred

**RXTIDE** Receive FIFO tide mark reached interrupt occurred

**OVRUN** Transmit/Receive FIFO overrun interrupt occurred

**TOUT** Between character timeout 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  |    |    |    |    |    | T  | TXRETRY   |   |   |   |   |   |   | R | XRETR | Υ |
| Type  |    |    |    |    |    |    | R/W       |   |   |   |   |   |   |   | R/W   |   |
| Reset |    |    |    |    |    |    | R/W<br>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  |    |    |    |    |    | TXTID | E[3:0] |   |   |   |   |   |   | RXTID | E[3:0] |   |
| Type  |    |    |    |    |    | R/    | W      |   |   |   |   |   |   | R/    | W      |   |
| Reset |    |    |    |    |    | 0     | h      |   |   |   |   |   |   | 0     | h      |   |

**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  |    |    |    |    |    |    |   |   |   |   |   | DATA | <b>\[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 1 | 3  | 2      | 1   | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|-----|----|--------|-----|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   | 767 | CC | DUNT[4 | :0] |   |
| 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  |    |    |    |    |    |    |   | ATIME | [15:0]   |    |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   | R/    | W        |    |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   | AF    | <u> </u> |    |   |   |   |   |   |   |

**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  |    |    |    |    |    |    |   |   |   | DTIME | [11:0] |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   | R/    | W      |   |   |   |   |   |
| Reset |    |    |    |    |    | 7  |   |   |   | 3E    | 7h     |   |   |   |   |   |

**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 |    |    |    |    |    |    |   | 98    | 3h     |   |   |   |   |   |   |   |

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  |    |    |    |    |    |    |   |   |   |   |   |   |   | GT | ME |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | R/ | W  |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 1( | )d |   |



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

### SIM +0050h Transmit error detection register

SIM ETIME

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

**ETIME** The register define the position for transmit error detection in ETU/16 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  |    |    |    |    |    |    |   | INSD |   |   |   | SIMIN | S[7:0] |   |   |   |
| Type  |    |    |    |    |    |    |   | R/W  |   |   |   | R/    | W      |   |   |   |
| Reset |    |    |    |    |    |    |   | 0h   |   |   |   | 0     | h      | • |   |   |

**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\_LE

N

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4      | 3   | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|----|--------|-----|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   | SI | MP3[8: | :0] |   |   |   |
| 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

LEN)

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

**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\_

EDC)

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

**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 44**.





Figure 44 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 |
| Т3   | > 40000 SIMCLK | SIMCLK start to SIMRST High               |
| T4   | _              | SIMVCC High to SIMCLK start               |
| T5   | _              | SIMRST Low to SIMCLK stop                 |
| Т6   | _              | SIMCLK stop to SIMDATA Low                |
| T7   | _              | SIMDATA Low to SIMVCC Low                 |

Table 24 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 TOEN 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, TOEND, TOUT and OVRUN interrupts)
- 4. Write CLA, INS, P1, P2 and P3 into SIM FIFO
- 5. Program the DMA controller: DMAn\_MSBSRC and DMAn\_LSBSRC : address of SIM\_DATA register DMAn\_MSBDST and DMAn\_LSBDST : memory address reserved to store the received characters DMAn\_COUNT : identical to P3 or 256 (if P3 == 0) DMAn\_CON : 0x0078
- 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 DMAn\_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 T0EN bit to 1 in SIM\_CNF register



- 2. Program the SIM\_TIDE register to  $0 \times 0100$  (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: DMAn\_MSBSRC and DMAn\_LSBSRC: memory address reserved to store the transmitted character: DMAn\_MSBDST and DMAn\_LSBDST: address of SIM\_DATA register DMAn\_COUNT: identical to P3 DMAn\_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 DMAn\_START register

Upon completion of the Data Send 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 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 mechanisms. Each time the key is pressed or released, i.e. something different in the 7 x 6 matrix, the key detection block senses the change and recognizes if a key has been pressed or released. Whenever the key status changes and is stable, a KEYPAD IRQ is 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 is not missed, the status register in keypad is not read-cleared by APB 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 45** shows one key pressed condition. **Figure 46**(a) and **Figure 46**(b) illustrate 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, the pressed key cannot be correctly decoded. 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) are detected, and therefore they cannot be distinguished correctly. Hence, the keypad can detect only one or two keys pressed simultaneously at any combination. More than two keys pressed simultaneously in a specific pattern retrieves the wrong information. If these specific patterns are excluded, the keypad-scanning block can detect 11 keys at the same time, shown in **Figure 47**.



Figure 45 One key pressed with de-bounce mechanism denoted





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



Figure 47 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  |    |    |    |    |    |    |     | 1 |   |   |   |   |   |   |   | RO  |
| Reset |    |    |    |    |    |    | 757 |   |   |   |   |   |   |   |   | 0   |

**STA** This register indicates the keypad status. The register is not cleared by the read operation.

- 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  |    |    |    | 7        |    |    |   | <b>KEYS</b> | [15:0] |   |   |   |   |   |   |   |
| Type  |    |    |    |          |    |    |   | R           | 0      |   |   |   |   |   |   |   |
| Reset |    |    |    | $\Box L$ |    |    |   | FFF         | Fh     |   |   |   |   |   |   |   |

#### 

**KP MID KEY** 

| Bit   | 15 | 14 13 | 12 | 11 | 10 | 9 | 8    | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|-------|----|----|----|---|------|---------|---|---|---|---|---|---|---|
| Name  |    |       |    |    |    |   | KEYS | [31:16] |   |   |   |   |   |   |   |
| Type  |    |       |    |    |    |   | R    | 0       |   |   |   |   |   |   |   |
| Reset |    |       |    |    |    |   | FFI  | -Fh     |   |   |   |   |   |   |   |



### KP+000Ch Keypad scanning output, the higher 4 keys

|     |   | _  |     |
|-----|---|----|-----|
| VD. |   | GH | KEV |
| KP  | м |    | KEY |
|     |   |    |     |

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9           | 8 | 7 | 6 | 5  | 4   | 3 | 2 | 1 | 0      |  |
|-------|----|----|----|----|----|----|-------------|---|---|---|----|-----|---|---|---|--------|--|
| Name  |    |    |    |    |    |    | KEYS[41:32] |   |   |   |    |     |   |   |   |        |  |
| Type  |    |    |    |    |    |    |             |   |   |   | R  | 0   |   |   |   | $\Box$ |  |
| Reset |    |    |    |    |    |    |             |   |   |   | 3F | F'h |   |   |   |        |  |

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 is set to 0.

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

### KP +00010h De-bounce period setting

KP\_DEBOUNC

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

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

MT6228 offers 71 general-purpose I/O pins and 3 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 48 GPIO Block Diagram

#### **GPIOs at RESET**

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

These GPIOs are used to latch the inputs upon reset to memorize the desired configuration to ensure that the system restarts or boots up 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 hardwired 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
- NRNB, 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, CMDAT9, CMDAT8, CMDAT7, CMDAT6, CMDAT5, CMDAT4, CMDAT3, CMDAT2, CMDAT1, CMDAT0: sensor interface
- SRCLKENAI: external power on signal of the external VCXO LDO
- NLD8, NLD9, NLD10, NLD11, NLD12, NLD13, NLD14, NLD15, NLD16, NLD17: NAND FLASH and Parallel LCD data signals
- MFIQ, MIRQ: external interrupt
- MCDA4, MCDA5, MCDA6, MCDA7: MMC4.0 data signals

#### **Multiplexed of Signals on GPO**

- SRCLKENA, SRCLKENAN: power on signal of the external VCXO LDO
- EPDN: external memory interface power down controls

## 4.5.1 Register Definitions

## GPIO+0000h GPIO direction control register 1

**GPIO DIR1** 

| Bit     | 15   | 14   | 13   | 12          | 11   | 10   | 9    | 8    | 7           | 6           | 5    | 4           | 3    | 2           | 1           | 0           |
|---------|------|------|------|-------------|------|------|------|------|-------------|-------------|------|-------------|------|-------------|-------------|-------------|
| Name    | GPIO | GPIO | GPIO | <b>GPIO</b> | GPIO | GPIO | GPIO | GPIO | <b>GPIO</b> | <b>GPIO</b> | GPIO | <b>GPIO</b> | GPIO | <b>GPIO</b> | <b>GPIO</b> | <b>GPIO</b> |
| ivaille | 15   | 14   | 13   | 12          | -11  | 10   | 9    | 8    | 7           | 6           | 5    | 4           | 3    | 2           | 1           | 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 +0010h GPIO direction control register 2

**GPIO DIR2** 

| Bit   | 15   | 14   | 13   | 12    | 11          | 10        | 9    | 8         | 7   | 6   | 5         | 4    | 3    | 2    | 1    | 0           |
|-------|------|------|------|-------|-------------|-----------|------|-----------|-----|-----|-----------|------|------|------|------|-------------|
| Name  | GPIO | GPIO | GPIO | GF IO | <b>GPIO</b> | GPIO      | GPIO |           |     |     | GPIO      | raio | GPIO | GPIO | GPIO | <b>GPIO</b> |
| ranic | 31   | 30   | 29   | 28    | <b>27</b>   | <b>26</b> | 25   | <b>24</b> | 23  | 22  | <b>21</b> | 20   | 19   | 18   | 17   | 16          |
| 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+0020h GPIO direction control register 3

**GPIO DIR3** 

| Bit   | 15          | 14          | 13   | 12          | 11          | 10          | 9           | 8           | 7           | 6           | 5           | 4           | 3           | 2           | 1           | 0           |
|-------|-------------|-------------|------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|
| Nama  | <b>GPIO</b> | <b>GPIO</b> | GPIO | <b>GPIO</b> |
| Name  | 47          | 46          | 45   | 44          | 43          | 42          | 41          | 40          | 39          | 38          | 37          | 36          | 35          | 34          | 33          | 32          |
| 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+0030h GPIO direction control register 4

### **GPIO DIR4**

| Bit   | 15   | 14   | 13   | 12   | 11   | 10          | 9           | 8    | 7           | 6    | 5           | 4           | 3    | 2           | 1           | 0    |
|-------|------|------|------|------|------|-------------|-------------|------|-------------|------|-------------|-------------|------|-------------|-------------|------|
| Name  | GPIO | GPIO | GPIO | GPIO | GPIO | <b>GPIO</b> | <b>GPIO</b> | GPIO | <b>GPIO</b> | GPIO | <b>GPIO</b> | <b>GPIO</b> | GPIO | <b>GPIO</b> | <b>GPIO</b> | GPIO |
| ivame | 63   | 62   | 61   | 60   | 59   | 58          | 57          | 56   | 55          | 54   | 53          | 52          | 51   | 50          | 49          | 48   |
| 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+0040h GPIO direction control register 5

### **GPIO\_DIR5**

| Bit     | 15 | 14 | 13 | 12 | 11 | 10          | 9           | 8           | 7    | 6           | 5    | 4           | 3 | 2 | 1 | 0 |
|---------|----|----|----|----|----|-------------|-------------|-------------|------|-------------|------|-------------|---|---|---|---|
| Name    |    |    |    |    |    | <b>GPIO</b> | <b>GPIO</b> | <b>GPIO</b> | GPIO | <b>GPIO</b> | GPIO | <b>GPIO</b> |   |   |   |   |
| Ivaille |    |    |    |    |    | 74          | 73          | 72          | 71   | 70          | 69   | 68          | ^ |   |   |   |
| Type    |    |    |    |    |    | R/W         | R/W         | R/W         | R/W  | R/W         | R/W  | R/W         |   |   |   |   |
| Reset   |    |    |    |    |    | 0           | 0           | 0           | 0    | 0           | 0    | 0           |   |   |   |   |

### **GPIO** GPIO direction control

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

## GPIO +0050h GPIO pull-up/pull-down enable register 1

## **GPIO\_PULLEN**

1

| Bit   | 15         | 14         | 13         | 12         | 11         | 10         | 9          | 8          | 7          | 6         | 5          | 4         | 3         | 2      | 1         | 0         |
|-------|------------|------------|------------|------------|------------|------------|------------|------------|------------|-----------|------------|-----------|-----------|--------|-----------|-----------|
| Name  | GPIO<br>15 | GPIO<br>14 | GPIO<br>13 | GPIO<br>12 | GPIO<br>11 | GPIO<br>10 | GPIO<br>9  | GPIO<br>8  | GPIO<br>7  | GPIO<br>6 | GPIO<br>5  | GPIO<br>4 | GPIO<br>3 | GPIO 2 | GPIO<br>1 | GPIO<br>0 |
| Туре  | 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         |
| Note  | PD         | PD         | PD         | PD         | PD         | PD         | High-<br>Z | High-<br>Z | High-<br>Z | High-     | High-<br>Z | HIzhZ     | PU        | PU     | PD        | PD        |

## GPIO +0060h GPIO pull-up/pull-down enable register 2

### GPIO\_PULLEN

2

| Bit     | 15          | 14          | 13          | 12   | 11          | 10          | 9    | 8           | 7    | 6           | 5    | 4           | 3           | 2           | 1           | 0           |
|---------|-------------|-------------|-------------|------|-------------|-------------|------|-------------|------|-------------|------|-------------|-------------|-------------|-------------|-------------|
| Name    | <b>GPIO</b> | <b>GPIO</b> | <b>GPIO</b> | GPIO | <b>GPIO</b> | <b>GPIO</b> | GPIO | <b>GPIO</b> | GPIO | <b>GPIO</b> | GPIO | <b>PGIO</b> | <b>GPIO</b> | <b>GPIO</b> | <b>GPIO</b> | <b>GPIO</b> |
| ivaille | 31          | 30          | 29          | 28   | 27          | 26          | 25   | 24          | 23   | 22          | 21   | 20          | 19          | 18          | 17          | 16          |
| 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           |
| Note    | PU          | PU          | PU          | PD   | PD          | PU          | PU   | PU          | PU   | PU          | PU   | PU          | PD          | PD          | PD          | PD          |

## GPIO+0070h GPIO pull-up/pull-down enable register 3

### **GPIO\_PULLEN**

3

| Bit   | 15         | 14         | 13         | 12         | 11         | 10         | 9          | 8          | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0          |
|-------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|
| Name  | GPIO<br>47 | GPIO<br>46 | GPIO<br>45 | GPIO<br>44 | GPIO<br>43 | GPIO<br>42 | GPIO<br>41 | GPIO<br>40 | GPIO<br>39 | GPIO<br>38 | GPIO<br>37 | GPIO<br>36 | GPIO<br>35 | GPIO<br>34 | GPIO<br>33 | GPIO<br>32 |
| Type  | R/W        |
| Reset | 1          | 1          | 1          |            | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          |
| Note  | High-Z     | High-Z     | High-<br>Z | High-<br>Z | PU         | PD         | PD         | PD         | PD         |

# GPIO+0080h 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  | GPIO<br>63 | GPIO<br>62 | GPIO<br>61 | GPIO<br>60 | GPIO<br>59 | GPIO<br>58 | GPIO<br>57 | GPIO<br>56 | GPIO<br>55 | GPIO<br>54 | GPIO<br>53 | GPIO<br>52 | GPIO<br>51 | GPIO<br>50 | GPIO<br>49 | GPIO<br>48 |
| Type  | R/W        |
| Reset |            | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          | 1          |
| Note  | PU         | PD         | PU         | PU         | PU         | PD         | PU         | PD         |



### GPIO+0090h GPIO pull-up/pull-down enable register 5

### **GPIO\_PULLEN5**

| Bit     | 15 | 14 | 13 | 12 | 11 | 10   | 9           | 8    | 7    | 6    | 5    | 4           | 3 | 2 | 1 | 0 |
|---------|----|----|----|----|----|------|-------------|------|------|------|------|-------------|---|---|---|---|
| Name    |    |    |    |    |    | GPIO | <b>GPIO</b> | GPIO | GPIO | GPIO | GPIO | <b>GPIO</b> |   |   |   |   |
| ivaille |    |    |    |    |    | 74   | 73          | 72   | 71   | 70   | 69   | 68          |   |   |   |   |
| Type    |    |    |    |    |    | R/W  | R/W         | R/W  | R/W  | R/W  | R/W  | R/W         |   |   |   |   |
| Reset   |    |    |    |    |    | 1    | 1           | 1    | 1    | 1    | 1    | 1           |   |   |   |   |
| Note    |    |    |    |    |    | PD   | PD          | PD   | PD   | PD   | PD   | PD          |   |   |   |   |

**GPIO** GPIO pull-up/pull-down control

### GPIO +00A0h 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  |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0_   | 0    | 0    | 0    |

## GPIO +00B0h 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 | IVN18 | INV17 | INV16 |
| Type  | R/W   |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

## GPIO +00C0h 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+00D0h 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  | INV63 | INV62 | INV61 | INV60 | INV59 | INV58 | INV57 | INV56 | INV55 | INV54 | INV53 | INV52 | INV51 | INV50 | INV49 | INV48 |
| Type  | R/W   |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

## GPIO+00E0h GPIO data inversion control register 5

### **GPIO\_DINV5**

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

#### **INVn** GPIO inversion control

- O GPIOs data inversion disable
- 1 GPIOs data inversion enable

### GPIO +00F0h 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  |     | GPIO |
| Туре  | 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 +0100h 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    | GPIO | <b>GPIO</b> | GPIO | GPIO | GPIO | <b>GPIO</b> | GPIO | GPIO | GPIO | GPIO | <b>GPIO</b> | <b>PGIO</b> | GPIO | GPIO | GPIO | <b>GPIO</b> |
| ivaille | 31   | 30          | 29   | 28   | 27   | 26          | 25   | 24   | 23   | 22   | 21          | 20          | 19   | 18   | 17   | 16          |
| 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 +0110h 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  | GPIO<br>47 | GPIO<br>46 | GPIO<br>45 | GPIO<br>44 | GPIO<br>43 | GPIO<br>42 | GPIO<br>41 | GPIO<br>40 | GPIO<br>39 | GPIO<br>38 | GPIO<br>37 | GPIO<br>36 | GPIO<br>35 | GPIO<br>34 | 33  | GPIO<br>32 |
| Type  | R/W        | R/W | R/W        |
| Reset | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0   | 0          |

### GPIO+0120h 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  | GPIO<br>63 | GPIO<br>62 | GPIO<br>61 | GPIO<br>60 | GPIO<br>59 | GPIO<br>58 | GPIO<br>57 | GPIO<br>56 | GPIO<br>55 | GPIO<br>54 | GPIO<br>53 | GPIO<br>52 | GPIO<br>51 | GPIO<br>50 | GPIO<br>49 | GPIO<br>48 |
| Type  | R/W        |
| Reset | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          |

### GPIO+0130h GPIO data output register 5

### **GPIO\_DOUT5**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10          | 9    | 8           | 7    | 6    | <u> 5</u>   | 4           | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|-------------|------|-------------|------|------|-------------|-------------|---|---|---|---|
| Nama  |    |    |    |    |    | <b>GPIO</b> | GPIO | <b>GPIO</b> | GPIO | GPIO | <b>GPIO</b> | <b>GPIO</b> |   |   |   |   |
| Name  |    |    |    |    |    | 74          | 73   | 72          | 71   | 70   | 69          | 68          |   |   |   |   |
| Type  |    |    |    |    |    | R/W         | R/W  | R/W         | R/W  | R/W  | R/W         | R/W         |   |   |   |   |
| Reset |    |    |    |    |    | 0           | 0    | 0           | 0    | 0    | 0           | 0           |   |   |   |   |

## GPIOn GPIO data output control

- O GPIOs data output 0
- 1 GPIOs data output 1

### GPIO +0140h GPIO data Input register

### GPIO\_DIN1

| Bit     | 15   | 14          | 13          | 12   | 11          | 10                                | 9    | 8           | 7           | 6           | 5           | 4           | 3           | 2    | 1           | 0           |
|---------|------|-------------|-------------|------|-------------|-----------------------------------|------|-------------|-------------|-------------|-------------|-------------|-------------|------|-------------|-------------|
| Name    | GPIO | <b>GPIO</b> | <b>GPIO</b> | GPIO | <b>GPIO</b> | GPIO                              | GPIO | <b>GPIO</b> | <b>GPIO</b> | <b>GPIO</b> | <b>GPIO</b> | <b>GPIO</b> | <b>GPIO</b> | GPIO | <b>GPIO</b> | <b>GPIO</b> |
| Ivallie | 15   | 14          | 13          | 12   | - 11        | 10                                | 9    | 8           | 7           | 6           | 5           | 4           | 3           | 2    | 1           | 0           |
| Type    | RO   | RO          | RO          | RO   | RO          | RO                                | RO   | RO          | RO          | RO          | RO          | RO          | RO          | RO   | RO          | RO          |
| Reset   | Χ    | Χ           | Χ           | Х    | X           | $\lceil \langle X \rangle \rceil$ | X    | Χ           | Χ           | Χ           | Χ           | Χ           | Χ           | Х    | Χ           | Χ           |

## GPIO +0150h GPIO data Input register 2

### **GPIO DIN2**

| Bit   | 15         | 14         | 13         | 12         | 71         | 10         | 9          | 8          | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0          |
|-------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|
| Name  | GPIO<br>31 | GPIO<br>30 | GPIO<br>29 | GPIO<br>28 | GPIO<br>27 | GPIO<br>26 | GPIO<br>25 | GPIO<br>24 | GPIO<br>23 | GPIO<br>22 | GPIO<br>21 | PGIO<br>20 | GPIO<br>19 | GPIO<br>18 | GPIO<br>17 | GPIO<br>16 |
| Туре  | RO         |
| Reset | Χ          | X          | X          | X          | X          | X          | Χ          | Χ          | Χ          | Х          | Х          | Х          | Χ          | Χ          | Χ          | Χ          |

## GPIO +0160h 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  | GPIO<br>47          | GPIO<br>46 | GPIO<br>45 | GPIO<br>44 | GPIO<br>43 | GPIO<br>42 | GPIO<br>41 | GPIO<br>40 | GPIO<br>39 | GPIO<br>38 | GPIO<br>37 | GPIO<br>36 | GPIO<br>35 | GPIO<br>34 | GPIO<br>33 | GPIO<br>32 |
| Type  | RO                  | RO         | RO         | RO         | RO         | RO         | RO         | RO         | RO         | RO         | RO         | RO         | RO         | RO         | RO         | RO         |
| Reset | $\square X \square$ | _X         | X          | Χ          | Χ          | Χ          | Χ          | Χ          | Χ          | X          | Χ          | Χ          | Χ          | Χ          | Χ          | Χ          |



### GPIO+0170h GPIO data input register 4

### **GPIO DIN4**

| Bit   | 15   | 14          | 13          | 12   | 11          | 10          | 9           | 8    | 7    | 6    | 5           | 4           | 3    | 2    | 1           | 0    |
|-------|------|-------------|-------------|------|-------------|-------------|-------------|------|------|------|-------------|-------------|------|------|-------------|------|
| Name  | GPIO | <b>GPIO</b> | <b>GPIO</b> | GPIO | <b>GPIO</b> | <b>GPIO</b> | <b>GPIO</b> | GPIO | GPIO | GPIO | <b>GPIO</b> | <b>GPIO</b> | GPIO | GPIO | <b>GPIO</b> | GPIO |
| ivame | 63   | 62          | 61          | 60   | 59          | 58          | 57          | 56   | 55   | 54   | 53          | 52          | 51   | 50   | 49          | 48   |
| 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    |

### GPIO+0180h GPIO data input register 5

## **GPIO\_DIN5**

| Bit     | 15 | 14 | 13 | 12 | 11 | 10   | 9    | 8    | 7    | 6    | 5           | 4           | 3 | 2 | 1 | 0 |
|---------|----|----|----|----|----|------|------|------|------|------|-------------|-------------|---|---|---|---|
| Name    |    |    |    |    |    | GPIO | GPIO | GPIO | GPIO | GPIO | <b>GPIO</b> | <b>GPIO</b> |   |   |   |   |
| Ivaille |    |    |    |    |    | 74   | 73   | 72   | 71   | 70   | 69          | 68          |   |   |   |   |
| Type    |    |    |    |    |    | RO   | RO   | RO   | RO   | RO   | RO          | RO          |   |   |   |   |
| Reset   |    |    |    |    |    | Χ    | Χ    | Χ    | Χ    | Χ    | Χ           | Χ           |   |   |   |   |

**GPIOn** GPIOs data input

## GPIO +0190h GPO data output register

### **GPO DOUT**

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

**GPOn** GPOs data output

### GPIO +01A0h GPIO mode control register 1

### **GPIO\_MODE1**

| Bit   | 15    | 14  | 13   | 12  | 11   | 10   | 9    | 8   | 7 1  | 6   | 5   | 4    | 3    | 2    | 1    | 0    |
|-------|-------|-----|------|-----|------|------|------|-----|------|-----|-----|------|------|------|------|------|
| Name  | GPI07 | 7_M | GPIC | 6_M | GPIC | )5_M | GPIC | 4_M | GPIO | 3_M | GPI | )2_M | GPIC | )1_M | GPIC | M_00 |
| Type  | R/W   | V   | R/   | W   | R/   | W    | R/   | W   | R/\  | W   | R   | /W   | R/   | W    | R/   | W    |
| Reset | 00    |     | 0    | 0   | 0    | 0    | 0    | 0   | 00   | )   | C   | 00   | 0    | 0    | 0    | 0    |

**GPIO0** M GPIO mode selection

**00** Configured as GPIO function

**01** CMOS Sensor Flash Control Output

10 Reserved

11 DSP Task ID5

**GPIO1 M** GPIO mode selection

00 Configured as GPIO function

01 BSI Auxiliary input

10 Reserved

11 Reserved

**GPIO2\_M** GPIO mode selection

00 Configured as GPIO function

01 SCCB Clock

10 Reserved

11 Reserved

**GPIO3** M GPIO mode selection

**00** Configured as GPIO function

01 SCCB Data

**10** Reserved

11 Reserved

**GPIO4\_M** GPO mode selection

00 Configured as GPIO function



- **01** EDI (I2S) Clock Output
- 10 UART2 RXD Signal
- 11 Software Debug Interface Data Bit 7
- **GPIO5\_M** GPIO mode selection
  - **00** Configured as GPIO function
  - **01** EDI (I2S) Word Synchronization Output
  - 10 UART2 TXD Signal
  - 11 Software Debug Interface Data Bit 6
- **GPIO6** M GPIO mode selection
  - **00** Configured as GPIO function
  - 01 EDI (I2S) Data Signal
  - 10 Reserved
  - 11 Software Debug Interface Data Bit 5
- **GPIO7** M GPIO mode selection
  - **00** Configured as GPIO function
  - 01 Reserved
  - 10 USB-OTG Bus Power On Control
  - 11 Software Debug Interface Data Bit 4

### GPIO +01B0h 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  | GPIO | 15_M | GPIO | 14_M | GPIO | 13_M | GPIO | 12_M | GPIO | 11_M | <b>GPIO</b> | 10_M | GPIC | )9_M | GPIC | M_8C |
| 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    |

- **GPIO8\_M** GPIO mode selection
  - 00 Configured as GPIO function
  - 01 32KHz Clock
  - **10** USB-OTG Bus Charging Enable Control
  - 11 Software Debug Interface Full Signal
- **GPIO9 M** GPIO mode selection
  - 00 Configured as GPIO function
  - 01 26MHz Clock
  - 10 13MHz Clock
  - 11 Software Debug Interface Empty Signal
- **GPIO10\_M** GPIO mode selection
  - **00** Configured as GPIO function
  - 01 Parallel NAND FLASH/LCD Interface Data Bit 16
  - 10 MMC4.0 Data Bit 4
  - 11 DID (DSP ICE Data Signal)
- **GPIO11** M GPIO mode selection
  - 00 Configured as GPIO function
  - 01 Parallel NAND FLASH/LCD Interface Data Bit 17
  - 10 MMC4.0 Data Bit 5
  - 11 DSP Task ID 1
- **GPIO12** M GPIO mode selection
  - **00** Configured as GPIO function
  - 01 Sensor Reset Signal Output
  - 10 Reserved



- 11 Reserved
- **GPIO13** M GPIO mode selection
  - 00 Configured as GPIO function
  - **01** Sensor Power Down Signal Output
  - 10 Reserved
  - 11 Reserved
- **GPIO14** M GPIO mode selection
  - 00 Configured as GPIO function
  - **01** Sensor Data Input 1
  - **10** MMC4.0 Data Bit 6
  - 11 Reserved
- **GPIO15** M GPIO mode selection
  - **00** Configured as GPIO function
  - **01** Sensor Data Input 0
  - **10** MMC4.0 Data Bit 7
  - 11 Reserved

## GPIO +01C0h GPIO mode control register 3

### **GPIO\_MODE3**

| Bit   | 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6    | 5                          | $I = I \cap I$ | 4 | 3    | 2    | 1    | 0    |
|-------|------|------|------|------|------|------|------|------|------|------|----------------------------|----------------|---|------|------|------|------|
| Name  | GPIO | 23_M | GPIO | 22_M | GPIO | 21_M | GPIO | 20_M | GPIO | 19_M | GF                         | 1018           | M | GPIO | 17_M | GPIO | 16_M |
| Type  | R/   | W    |                            | R/W            |   | R/   | W    | R/   | W    |
| Reset | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0 0  | $\Delta \overline{\Delta}$ | 00             |   | 0    | 0    | 0    | 0    |

### **GPIO16\_M** GPIO mode selection

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

#### **GPIO17** M GPIO mode selection

- **00** Configured as GPIO function
- **01** BPI\_BUS7
- 10 13MHz Clock
- 11 26MHz Clock

### **GPIO18\_M** GPIO mode selection

- 00 Configured as GPIO function
- 01 BPI\_BUS8
- 10 6.5MHz Clock
- 11 32KHz Clock

### **GPIO19\_M** GPIO mode selection

- **00** Configured as GPIO function
- 01 BPI BUS9
- **10** BSI\_CS1
- 11 BFE Debug Signal Output

### GPIO20\_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
- **GPIO21** 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

### GPIO22\_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

#### **GPIO23** 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

### GPIO +01D0h 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  | GPIO | 31_M | GPIO | 30_M | GPIO | 29_M | GPIO | 28_M | GPIO | 27_M | GPIC | )26_M | GPIO | 25_M | GPIO | 24_M |
| Type  | R/   | W    | R    | /W    | R    | /W   | R/   | W    |
| Reset | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |      | 00    | C    | 00   | 0    | 0    |

#### **GPIO24** 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

#### **GPIO25** M GPIO mode selection

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

### **GPIO26** M GPIO mode selection

- 00 NAND FLASH Interface Ready/Busy Signal
- **01** Configured as GPIO function
- 10 USB-OTG Session Valid Signal
- 11 Software Debug Interface Data Bit 2

### **GPIO27** M GPIO mode selection

- 00 NAND FLASH Interface Command Latch Signal
- **01** Configured as GPIO function
- 10 USB-OTG VBus Valid Signal
- 11 Software Debug Interface Data Bit 1

#### **GPIO28\_M** GPIO mode selection

- 00 NAND FLASH Interface Address Latch Signal
- **01** Configured as GPIO function
- 10 USB-OTG Session End Signal
- 11 Software Debug Interface Data Bit 0

### GPIO29 M GPIO mode selection

- 00 NAND FLASH Interface Write Strobe Signal
- 01 Configured as GPIO function



- 10 Reserved
- 11 Reserved

### GPIO30\_M GPIO mode selection

- 00 NAND FLASH Interface Read Strobe Signal
- 01 Configured as GPIO function
- 10 USB-OTG Bus Power Discharging Control Signal
- 11 Software Debug Interface Clock Output Signal

#### **GPIO31** M GPIO mode selection

- 00 NAND FLASH Interface Chip Select Signal 0
- **01** Configured as GPIO function
- 10 Reserved
- 11 Reserved

### GPIO +01E0h 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  | GPIO | 39_M | GPIO | 38_M | GPIO | 37_M | GPIO | 36_M | GPIO | 35_M | GPIO | 34_M | GPIC | D33_M | GPIO | 32_M |
| Туре  | R/   | W    | 1) R | I/W   | R/   | W    |
| Reset | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |      | 00    | 0    | 0    |

#### **GPIO32** M GPIO mode selection

- **00** Configured as GPIO function
- **01** PWM1
- 10 TDMA Timer Uplink Frame Sync Signal
- 11 DSP Task ID2

### **GPIO33** M GPIO mode selection

- 00 Configured as GPIO function
- **01** PWM2
- 10 TDMA Timer Downlink Frame Enable Signal
- 11 DSP Task ID3

#### **GPIO34** M GPIO mode selection

- **00** Configured as GPIO function
- 01 Alerter
- 10 TDMA Timer Downlink Frame Sync Signal
- 11 DSP Task ID4

#### **GPIO35** M GPIO mode selection

- **00** Configured as GPIO function
- **01** VCXO Enable Signal Input
- 10 Reserved
- 11 Reserved

### **GPIO36\_M** GPIO mode selection

- **00** Configured as GPIO function
- **01** MIRQ Signal
- 10 6.5 MHz Clock Signal
- 11 32 KHz Clock Signal

### GPIO37\_M GPIO mode selection

- **00** Configured as GPIO function
- 01 UART2 RXD Signal
- 10 UART3 CTS Signal
- 11 Reserved



**GPIO38** M GPIO mode selection

- 00 Configured as GPIO function
- **01** UART2 TXD Signal
- 10 UART3 RTS Signal
- 11 Reserved

**GPIO39** M GPIO mode selection

- **00** Configured as GPIO function
- 01 UART3 RXD Signal
- 10 Reserved
- 11 Reserved

### GPIO +01F0h GPIO mode control register 6

**GPIO MODE**6

| Bit   | 15    | 14  | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-------|-------|-----|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
| Name  | GPIO4 | 7_M | GPIO | 46_M | GPIO | 45_M | GPIO | 44_M | GPIO | 43_M | GPIO | 42_M | GPIO | 41_M | GPIO | 40_M |
| Type  | R/V   | ٧   | R/   | W    |
| Reset | 00    | )   | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

**GPIO40** M GPIO mode selection

- **00** Configured as GPIO function
- **01** UART3 TXD Signal
- 10 Reserved
- 11 DSP Task ID5

GPIO41\_M GPIO mode selection

- **00** Configured as GPIO function
- 01 IrDA RXD Signal
- 10 UART2 CTS Signal
- 11 Software Debug Interface Data 15

**GPIO42** M GPIO mode selection

- **00** Configured as GPIO function
- **01** IrDA TXD Signal
- 10 UART2 RTS Signal
- 11 Software Debug Interface Data 14

**GPIO43** M GPIO mode selection

- **00** Configured as GPIO function
- 01 IrDA Power Down Control Signal
- 10 Reserved
- 11 Software Debug Interface Data 13

**GPIO44\_M** GPIO mode selection

- 00 Keypad Row 5 Scan Signal
- **01** Configured as GPIO function
- 10 ARM Clock Output
- 11 TV\_CK Clock Output

**GPIO45** M GPIO mode selection

- 00 Keypad Row 4 Scan Signal
- **01** Configured as GPIO function
- 10 Internal AHB Bus Clock Output
- 11 DSP Clock Output

GPIO46 M GPIO mode selection

00 Keypad Row 3 Scan Signal



- **01** Configured as GPIO function
- 10 TPLL Clock Output
- 11 SLOW\_CK Clock Output

### **GPIO47\_M** GPIO mode selection

- 00 Keypad Row 2 Scan Signal
- **01** Configured as GPIO function
- 10 MCU/DSP PLL Clock Output
- 11 UPLL Clock Output

### GPIO +0200h GPIO mode control register 7

GPIO\_MODE7

| Bit   | 15  | 14  | 13  | 12         | 11  | 10  | 9   | 8   | 7   | 6          | 5   | 4          | 3  | 2    | 1 1 | 0   |
|-------|-----|-----|-----|------------|-----|-----|-----|-----|-----|------------|-----|------------|----|------|-----|-----|
| Name  | GPI | O55 | GPI | <b>O54</b> | GPI | O53 | GPI | 052 | GPI | <b>051</b> | GPI | <b>O50</b> | GP | 1049 | GPI | O48 |
| Type  | R/  | W   | R/  | W          | R/  | W   | R/  | W   | R/  | W          | R/  | W          | F  | R/W  | R/  | W   |
| Reset | (   | )   | (   | )          | (   | )   | (   | )   | (   | )          | (   | )          |    | 0    | (   | )   |

### **GPIO48\_M** GPIO mode selection

- 00 Configured as GPIO function
- **01** SIM Interface Voltage Select Signal
- 10 Reserved
- 11 Reserved

#### GPIO49 M GPIO mode selection

- **00** Configured as GPIO function
- **01** Digital Audio Interface Clock Output
- 10 Reserved
- 11 Software Debug Interface Data Bit 12

#### **GPIO50\_M** GPIO mode selection

- **00** Configured as GPIO function
- 01 Digital Audio Interface PCM Data Output
- 10 Reserved
- 11 Software Debug Interface Data Bit 11

#### **GPIO51** M GPIO mode selection

- **00** Configured as GPIO function
- **01** Digital Audio Interface PCM Data Input
- 10 Reserved
- 11 Software Debug Interface Data Bit 10

### **GPIO52\_M** GPIO mode selection

- **00** Configured as GPIO function
- 01 Digital Audio Interface Reset Signal Output
- 10 Reserved
- 11 Software Debug Interface Data Bit 9

#### **GPIO53** M GPIO mode selection

- 00 Configured as GPIO function
- **01** Digital Audio Interface Synchronization Signal Input
- 10 Reserved
- 11 Software Debug Interface Data Bit 8

#### **GPIO54** M GPIO mode selection

- 00 NAND FLASH/Parallel LCD Interface Data Bit 8
- 01 Configured as GPIO function
- 10 Reserved



- 11 Software Debug Interface Address Bit 1
- **GPIO55** M GPIO mode selection
  - 00 NAND FLASH/Parallel LCD Interface Data Bit 9
  - **01** Configured as GPIO function
  - 10 Reserved
  - 11 Software Debug Interface Address Bit 0

## GPIO +0210h GPIO mode control register 8

### **GPIO MODE8**

| Bit   | 15  | 14  | 13  | 12  | 11  | 10         | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|-----|-----|-----|-----|-----|------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  | GPI | O63 | GPI | 062 | GPI | <b>061</b> | GPI | O60 | GPI | O59 | GPI | O58 | GPI | 057 | GPI | O56 |
| Туре  | R/  | W   | R/  | W   | R/  | W          | R/  | W   | R/  | W   | R/  | W   | R/  | W   | R/  | W W |
| Reset | (   | )   | (   | )   | (   | )          | (   | )   | (   | )   | (   | )   |     |     | (   | )   |

### GPIO56\_M GPIO mode selection

- 00 NAND FLASH/Parallel LCD Interface Data Bit 10
- **01** Configured as GPIO function
- 10 Reserved
- 11 Software Debug Interface Read Output Enable Control

#### **GPIO57** M GPIO mode selection

- 00 NAND FLASH/Parallel LCD Interface Data Bit 11
- **01** Configured as GPIO function
- 10 Reserved
- 11 Software Debug Interface Read Strobe Control

### **GPIO58\_M** GPIO mode selection

- 00 NAND FLASH/Parallel LCD Interface Data Bit 12
- **01** Configured as GPIO function
- 10 Reserved
- 11 Software Debug Interface Write Strobe Control

### GPIO59\_M GPIO mode selection

- 00 NAND FLASH/Parallel LCD Interface Data Bit 13
- **01** Configured as GPIO function
- 10 Reserved
- 11 Software Debug Interface Packet End Strobe Control

### GPIO60\_M GPIO mode selection

- 00 NAND FLASH/Parallel LCD Interface Data Bit 14
- **01** Configured as GPIO function
- 10 Reserved
- 11 DICK (DSP ICE Clock Input)

#### **GPIO61\_M** GPIO mode selection

- 00 NAND FLASH/Parallel LCD Interface Data Bit 15
- **01** Configured as GPIO function
- 10 Reserved
- 11 DIMS (DSP ICE Mode Select)

#### GPIO62 M GPIO mode selection

- 00 Sensor Input Data Bit 2
- **01** Configured as GPIO function
- 10 Reserved
- 11 Reserved

### GPIO63 M GPIO mode selection



- **00** Configured as GPIO function
- 01 MFIQ Signal
- 10 USB-OTG ID
- 11 Software Debug Interface Data Bit 3

## GPIO +0220h GPIO mode control register 9

**GPIO MODE9** 

| Bit   | 15  | 14         | 13  | 12  | 11  | 10  | 9   | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0_ |
|-------|-----|------------|-----|-----|-----|-----|-----|-----|---|---|---|---|---|---|---|----|
| Name  | GPI | <b>071</b> | GPI | 070 | GPI | O69 | GPI | O68 |   |   |   |   |   |   |   |    |
| Type  | R/  | W          | R/  | W   | R/  | W   | R/  | W   |   |   |   |   |   |   |   |    |
| Reset | 0   | )          | (   | )   | (   | )   | (   | )   |   |   |   |   |   |   |   | •  |

### GPIO68\_M GPIO mode selection

- **00** Sensor Input Data Bit 3
- **01** Configured as GPIO function
- 10 Reserved
- 11 Reserved

#### **GPIO69** M GPIO mode selection

- 00 Sensor Input Data Bit 4
- **01** Configured as GPIO function
- 10 Reserved
- 11 Reserved

#### **GPIO70** M GPIO mode selection

- **00** Sensor Input Data Bit 5
- **01** Configured as GPIO function
- 10 Reserved
- 11 Reserved

#### **GPIO71** M GPIO mode selection

- 00 Sensor Input Data Bit 6
- **01** Configured as GPIO function
- 10 Reserved
- 11 Reserved

## GPIO +0230h GPIO mode control register 10

GPIO\_MODE10

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 |   | 8 | 7 | 6 | 5   | 4          | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|-----|------------|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    |   |   |   |   | GPI | <b>O74</b> | GPI | O73 | GPI | 072 |
| Type  |    |    |    |    |    |    | 7 |   |   |   | R/  | W          | R/  | W   | R/  | W   |
| Reset |    |    |    |    |    |    |   |   |   |   | (   | )          | (   | )   | (   | )   |

### **GPIO72\_M** GPIO mode selection

- OO Sensor Input Data Bit 7
- **01** Configured as GPIO function
- 10 Reserved
- 11 Reserved

### **GPIO73** M GPIO mode selection

- 00 Sensor Input Data Bit 8
- 01 Configured as GPIO function
- 10 Reserved
- 11 Reserved

### **GPIO74** M GPIO mode selection

00 Sensor Input Data Bit 9



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

### GPIO +0240h 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  |    |    |    |    |    |    |   |   |   |   | GPO | 2_M | GPO | 1_M | GP00 | <u>_M</u> _ |
| Type  |    |    |    |    |    |    |   |   |   |   | R/  | W   | R/  | W   | R/W  | V           |
| Reset |    |    |    |    |    |    |   |   |   |   | 0   | 1   | 0   | 1   | 01   |             |

GPO 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

## GPIO+xxx4h GPIO xxx register SET

GPIO\_XXX\_SET

For all registers addresses listed above, writing to the +4h addresse offset will perform a bit-wise **OR** function between the 16bit written value and the 16bit register value already existing in the corresponding GPIO\_xxx registers. Eg.

If GPIO\_DIR1 (GPIO+0000h) = 16'h0F0F,

writing GPIO\_DIR1\_SET (GPIO+0004h) = 16'F0F0 will result in GPIO\_DIR1 = 16'hFFFF.

### GPIO+xxx8h GPIO xxx register CLR

**GPIO XXX CLR** 

For all registers addresses listed above, writing to the +8h addresse offset will perform a bit-wise **AND-NOT** function between the 16bit written value and the 16bit register value already existing in the corresponding GPIO\_xxx registers. Eg.

If GPIO\_DIR1 (GPIO+0000h) = 16'h0F0F,

writing GPIO\_DIR1\_CLR (GPIO+0008h) = 16'0F0F will result in GPIO\_DIR1 = 16'h0000.

# 4.6 General Purpose Timer

## 4.6.1 General Description

Three general-purpose timers are provided. The timers are 16 bits long and run independently of each other, although they share the same clock source. Two timers can operate in one of 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, when the timer reaches zero, it simply resets to countdown initial value and repeats the countdown to zero; this loop repeats until the disable signal is set to 1. Regardless of the timer's mode, if the countdown initial



value (i.e. GPTIMER1\_DAT for GPT1 or GPTIMER\_DAT2 for GPT2) is written when the timer is running, the new initial value does not take effect until the next time the timer is restarted. In auto-repeat mode, the new countdown start value is used on the next countdown iteration. Therefore, before enabling the gptimer, the desired values for GPTIMER\_DAT and the GPTIMER\_PRESCALER registers must first be set.

## 4.6.2 Register Definitions

## GPT +0000h GPT1 Control register

GPTIMER1\_CO

N

| 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 GPT1 to count repeatedly (in a loop) or just one-shot.

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

**EN** This register controls GPT1 to start counting or to stop.

- O GPT1 is disabled.
- 1 GPT1 is enabled.

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

**GPTIMER1 DA** 

1

| 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 |    |    |    |    |    |    |   | FÊ  | FFh    |   |   |   |   |   |   |   |

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

## GPT +0008h GPT2 Control register

**GPTIMER2\_CO** 

N

| 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    |    |    |    |    | 7) — |   |   |   |   |   |   |   |   |   |

**MODE** This register controls GPT2 to count repeatedly (in a loop) or just one-shot.

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

**EN** This register controls GPT2 to start counting or to stop.

- O GPT2 is disabled.
- 1 GPT2 is enabled.

## GPT +000Ch GPT2 Time-Out Interval register

**GPTIMER2 DA** 

1

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



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

### GPT +0010h GPT Status register

**GPTIMER STA** 

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

This register illustrates the gptimer timeout status. Each flag is set when the corresponding timer countdown completes, and can be cleared when the CPU reads the status register.

## GPT +0014h GPT1 Prescaler register

GPTIMER1\_PRES
CALER

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

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

**000** 16 KHz

**001**8 KHz

0104 KHz

**011** 2 KHz

**100**1 KHz

**101** 500 Hz

110 250 Hz

**111** 125 Hz

# GPT +0018h GPT2 Prescaler register GPTIMER2\_PRES

CALER

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

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

**000** 16 KHz

**001**8 KHz

**010**4 KHz

**011** 2 KHz

**100**1 KHz

**101** 500 Hz

**110** 250 Hz

111 125 Hz

## GPT+001Ch GPT3 Control register

**GPTIMER3 CO** 

Ν

| 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 to start counting or to stop.

- O GPT3 is disabled.
- 1 GPT3 is enabled.

### GPT+0020h GPT3 Time-Out Interval register

GPTIMER3\_DA

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

CNT [15:0] If EN=1, GPT3 is a free running timer. Software reads this register for the countdown start value for GPT3.

### GPT+0024h GPT3 Prescaler register

GPTIMER3\_PRES CALER

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

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

**000** 16 KHz

0018 KHz

0104 KHz

011 2 KHz

**100**1 KHz

**101** 500 Hz

110 250 Hz

**112**125 Hz

### **4.7 UART**

## 4.7.1 General Description

MT6228 houses three UARTs. The UARTs provide full duplex serial communication channels between the MT6228 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 certain areas offer 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, 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



synchronization results in minor timing differences between the UART and the industry standard 16550A device, which means that the core is not clock for clock identical to the original device.

After a hardware reset, the UART is in M16C450 mode. Its FIFOs can be enabled and the UART can then 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 feature is very useful when the ISR latency is hard to predict and control in the
  embedded applications. The MCU is relieved of 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], must be set. If EFR[4] is not set, IER[7:5], FCR[5:4], ISR[5:4] and MCR[7:6] cannot be written. The Enhanced Mode bit ensures that the UART is backward compatible with software that has been written for 16C450 and 16550A devices.

Figure 49 shows the block diagram of the MT6228 UART device.



Figure 49 Block Diagram of UART

## 4.7.2 Register Definitions

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

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

UARTn\_RBR

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

RBR RX Buffer Register. Read-only register. The received data can be read by accessing this register. Modified when LCR[7] = 0.

## UARTn+0000h TX Holding Register

**UARTN THR** 

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



THR

TX Holding Register. Write-only register. The data to be transmitted is written to this register, and then sent to the PC via serial communication.

Modified when LCR[7] = 0.

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

**UARTN IER** 

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

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** Unmask 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.

- Unmask 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.

- Unmask 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, TERL DDSR or DCTS (MSR[4:1]) becomes set.

- O 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 B1, FE, PE or OE (LSR[4:1]) becomes set.

- No interrupt is generated if BI, FE, PE or OE (LSR[4:1]) becomes set.
- 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.

- 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.

- O 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  |    |    |    |    |    |    |   |   | FIF | OE | 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 are presented only when EFR[4] = 1.

The following table gives the IIR[5:0] codes associated with the possible interrupts:



| IIR[5:0] | Priority | Interrupt                 | Source                                                      |
|----------|----------|---------------------------|-------------------------------------------------------------|
|          | Level    |                           |                                                             |
| 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** 25 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. The interrupt is 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. The interrupt is 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. FIFO contains at least one character;
- 2. The most recent character was received longer than four character periods ago (including 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 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. FIFO is empty;
- 2. The most recent character was received longer than four character periods ago (including 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. The interrupt is 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. The interrupt is 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. The interrupt is 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. The interrupt is 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 |    |    |    |    |    |    |   |   | RFTL1 | RFTL0 | TFTL1 | TFTL0 | DMA <sub>1</sub> | CLRT | CLRR | <b>FIFOE</b> |
| Type |    |    |    |    |    |    |   |   |       |       |       | W     | 0                |      |      |              |

**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 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

- 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 at least one character is in the RX FIFO or the RX Buffer Register is full. 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 is reached or an RX FIFO Character Timeout occurs. Goes inactive when the RX FIFO is empty.

**CLRT** Clear Transmit FIFO. This bit is self-clearing.

- Leave TX FIFO intact.
- 1 Clear all the bytes in the TX FIFO.

**CLRR** Clear Receive FIFO. This bit is self-clearing.

- Leave RX FIFO intact.
- 1 Clear all the bytes in the RX FIFO.

**FIFOE** FIFO Enabled. This bit must be set to 1 for any of the other bits in the registers to have any effect.



- O 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. Determines 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, depending on the states 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

- 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

- The Parity is neither transmitted nor checked.
- 1 The Parity is transmitted and checked.

**STB** Number of STOP bits

- 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.

• When an XON character is received.



When an XOFF character is received.

IR Enable Enable IrDA modulation/demodulation.

- O Disable IrDA modulation/demodulation.
- 1 Enable IrDA modulation/demodulation.

**LOOP** Loop-back control bit.

- No loop-back is enabled.
- 1 Loop-back mode is enabled.

**OUT2** Controls the state of the output NOUT2, even in loop mode.

- 0 NOUT2=1.
- 1 NOUT2=0.

**OUT1** Controls the state of the output NOUT1, even in loop mode.

- 0 NOUT1=1.
- 1 NOUT1=0.

RTS Controls the state of the output NRTS, even in loop mode.

- 0 NRTS=1.
- 1 NRTS=0.

**DTR** Control the state of the output NDTR, even in loop mode.

- **0** NDTR=1.
- 1 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 | TEMT | THRE | ВІ | 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.

- O 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.

**TEMT** TX Holding Register (or TX FIFO) and the TX Shift Register are empty.

- 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** Indicates if there is room for TX Holding Register or TX FIFO is reduced to its Trigger Level.

- 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.
  - 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.



- 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

- 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 referred byte is the next to be read.

#### **OE** Overrun Error.

- 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 not transferred to the FIFO.

#### DR Data Ready.

- 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 | <b>DDSR</b> | <b>DCTS</b> |
| 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 a 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 value is the complement of the NDCD input signal.

When Loop = "1", this value is equal to the OUT2 bit in the Modem Control Register.

Ring Indicator.

When Loop = "0", this value is the complement of the NRI input signal.

When Loop = "1", this value is equal to the OUT1 bit in the Modem Control Register.

**DSR** Data Set Ready

When Loop = "0", this value is the complement of the NDSR input signal.

When Loop = "1", this value is equal to the DTR bit in the Modem Control Register.

**CTS** Clear To Send.

When Loop = "0", this value is the complement of the NCTS input signal.

When Loop = "1", this value is equal to the RTS bit in the Modem Control Register.

**DDCD** Delta Data Carry Detect.

- O The state of DCD has not changed since the Modem Status Register was last read
- Set if the state of DCD has changed since the Modem Status Register was last read.

**TERI** Trailing Edge Ring Indicator

- 1 The NRI input does not change since this register was last read.
- Set if the NRI input changes from "0" to "1" since this register was last read.



#### **DDSR** Delta Data Set Ready

- O Cleared if the state of DSR has not changed since this register was last read.
- Set if the state of DSR has changed since this register was last read.

#### **DCTS** Delta Clear To Send

- O 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 |    |    |    |    |    |    |   |   |   |   |   | SCR | [7:0] |   |   |   |
| 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  |    |    |    |    |    |    |   |   |   |   | $\overline{}$ | DLL |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |               | R/  | W |   |   |   |
| Reset | •  |    |    |    |    |    |   |   |   |   |               | -   |   |   |   |   |

### **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  |    |    |    |    |    |    |   |   |   |   |   | DLL | [7:0] |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | R/  | W     |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   | (   | )     |   |   |   |

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, 26 MHz and 52 MHz. 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 26 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               |
| Reset | • |  |  |  | 0           | 0           | 0   | 0            | 0                 |

\*NOTE: Only when LCR=BF'h

**Auto CTS** Enables hardware transmission flow control

O Disabled.

1 Enabled.

**Auto RTS** Enables hardware reception flow control

O Disabled.

1 Enabled.

**Enable-E** Enable enhancement features.

O 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 | 3 | 7 | 6 | 5 | 4    | 3      | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|------|--------|---|---|---|
| Name  |    |    |    |    |    |    |   | 7 |   |   |   |   | XON. | 1[7:0] |   |   |   |
| Type  |    |    |    |    |    |    |   | M |   | [ |   |   | R/   | W      |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | (    | )      |   |   |   |

#### UARTn+0014h XON2

UARTn\_XON2

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

### UARTn+0018h XOFF1

UARTn\_XOFF1

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

<sup>\*</sup>Note: XON1, XON2, XOFF1, XOFF2 are valid only when LCR=BFh.



### UARTn+0020h AUTOBAUD\_EN

# UARTn\_AUTOBAU

\_EN

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

**AUTOBAUD EN** Auto-baud enable signal

- Auto-baud function disable
- 1 Auto-baud function enable

#### UARTn+0024h HIGH SPEED UART

#### **UARTH HIGHSPEED**

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

**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 13M Hz 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 27 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 26 MHz 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 28 Divisor needed to generate a given baud rate from 26 MHz 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 29 Divisor needed to generate a given baud rate from 52 MHz based on different HIGHSPEED value

### UARTn+0028h SAMPLE\_COUNT

### **UARTN\_SAMPLE\_COUN**

Т

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

When HIGHSPEED=3, the sample\_count is the threshold value for UART sample counter (sample\_num).



### UARTn+002C

### SAMPLE\_POINT

### **UARTN SAMPLE POIN**

h

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

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 RE**

G

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7              | 6 | 5 | 4 | 3_  | 2     | 1       | 0  |
|-------|----|----|----|----|----|----|---|---|----------------|---|---|---|-----|-------|---------|----|
| Name  |    |    |    |    |    |    |   |   | BAUD_STAT[3:0] |   |   |   | V/E | BAUDR | ATE[3:0 | 0] |
| Type  |    |    |    |    |    |    |   |   |                | R | 0 |   |     | R     | 0       |    |
| Reset |    |    |    |    |    |    |   |   |                | ( | ) |   |     | (     | )       |    |

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

- O 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\_AUTOBAUDSA

**MPLE** 

| Bit  | 15 | 14       | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6   | 5   | 4     | 3     | 2     | 1   | 0   |
|------|----|----------|----|----|----|----|---|---|---|-----|-----|-------|-------|-------|-----|-----|
| Name |    | <b>—</b> |    |    |    |    |   |   |   |     | 1   | AUTOE | BAUDS | AMPLE |     |     |
| Type |    | ·        |    |    |    |    |   |   |   | R/W | R/W | R/W   | R/W   | R/W   | R/W | 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+003C

# 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_ | GI  | JARD   | ĈNT[3: | 01  |
| riamo |    |    |    |    |    |    |   |   |   |   |   | EN     |     | 771112 | , III  | •1  |
| Type  |    |    |    |    |    |    |   |   |   |   |   | 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**

### **UART**n ESCAPE DAT

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5            | V | 4    | 3     | 2           | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|--------------|---|------|-------|-------------|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   | E            |   | APE_ | DAT[7 | <b>:0</b> ] |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   | $\Xi \nabla$ | 6 | R/   | W     |             |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |              |   | FF   | -h    |             |   |   |

**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 transmits data as esc + CEh (~xon).

### **UARTn+0044h Escape enable register**

#### **UARTH ESCAPE EN**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8             | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0     |
|-------|----|----|----|----|----|----|---|---------------|---|---|---|---|---|---|---|-------|
| Name  |    |    |    |    |    |    |   |               |   |   |   |   |   |   |   | ESC_E |
|       |    |    |    |    |    |    |   |               |   |   |   |   |   |   |   | N     |
| Type  |    |    |    |    |    |    |   | $\mathcal{M}$ |   |   |   |   |   |   |   | R/W   |
| Reset |    |    |    |    |    |    |   |               |   |   |   |   |   |   |   | 0     |

**ESC EN** Add escape character in transmitter and remove escape character in receiver by UART.

- O 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<br>P_EN |
| Type  |    |    |    |    |       |    |   |   |   |   |   |   |   |   |   | R/W          |
| Reset |    |    |    |    |       |    | • |   |   |   |   | _ |   |   |   | 0            |

#### **SLEEP\_EN** For sleep mode issue

- O Do not deal with sleep mode indicate signal
- 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 sends xon when awaken and when FIFO does not reach threshold level.

#### UARTn+004C

### Virtual FIFO enable register

UARTn\_VFIFO\_EN

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

MediaTek Inc. Confidential



|       | • |  |  |  |  |  |  |  |              |
|-------|---|--|--|--|--|--|--|--|--------------|
| Name  |   |  |  |  |  |  |  |  | VFIF<br>O_EN |
| Type  |   |  |  |  |  |  |  |  | R/W          |
| Reset |   |  |  |  |  |  |  |  | 0            |

VFIFO EN Virtual FIFO mechanism enable signal.

- Disable VFIFO mode.
- 1 Enable VFIFO mode. When virtual mode is enabled, the flow control is based on the DMA threshold, and generates a timeout interrupt for DMA.

### 4.8 IrDA Framer

### 4.8.1 General Description

IrDA framer is implemented to reduce the CPU loading for IrDA transmissions by performing all the physical level protocol framing in hardware. From a software perspective, the framer need only prepare and process the raw data for transmission and reception. Generic DMA is required to move the data between IrDA framer's internal FIFO and software-designated memory. The IrDA framer supports IrDA SIR, MIR, and FIR modes of operation. SIR mode includes operation from 9600bps  $\sim$  115200bps, MIR includes operation at 567000bps or 1152000bps, and FIR mode includes operation at 4Mbps.

# 4.8.2 Register Definitions

#### IRDA+0000h TX BUF and RX BUF

**BUF** 

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

**BUF** IrDA Framer transmit or receive data.

A write to this register writes into the internal TX FIFO.

A read from this register reads from the internal RX FIFO.

### IRDA+0004h TX BUF and RX BUF clear signal

BUF\_CLEAR

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

**CLEAR SIR mode only.** When CLEAR=1, both the TX and RX FIFO are cleared. This is used primarily for debug purpose. Normal operation does not require this. This control signaled can only be issued under SIR mode.

### 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  |    |    |    |    |    |    |   |   | MAX_T | [13:0] |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   | R/    | W      |   |   |   |   |   |   |
| Reset |    | A  |    |    |    |    |   |   | 3E8   | 30h    |   |   |   |   |   |   |

MAX\_T 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 passing 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. For baud rates less than 115200 kbps, 500 ms is the only valid value. The default value is 500 ms.



### 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  |    |    |    |    |    |    |   | MIN_T | [15:0] |   |   |   |   |   |   |        |
| Type  |    |    |    |    |    |    |   | R/    | W      |   |   |   |   |   |   | $\Box$ |
| Reset |    |    |    |    |    |    |   | FD    | E8h    |   |   |   |   |   |   |        |

MIN\_T Minimum turn around time, the default value is 10 ms. 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. the latency for a transmit to complete and be ready to 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 |   |   | В | OFS [ | 5:0] |   |   |
| Type  |    |    |    |    |    |    |   |   | R/W  |   |   |   | R/W   |      |   |   |
| Reset |    |    |    |    |    |    |   |   | 0    |   |   |   | 10111 | )    |   |   |

**BOFs For SIR mode**: the additional BOFs parameter indicates the number of additional flags needed at the beginning of every frame. The main purpose for the additional BOFs is to provide a delay at the beginning of each frame for devices with a long interrupt latency.

**For MIR mode**: This parameter indicates the number of double STA's to transmit in the beginning. This value should be set to 0 (for default 2 STA's) for MIR mode, unless more are required.

For FIR mode: This parameter has no effect.

**TYPE SIR mode only**. Additional BOFs type.

1 BOF = C0h0 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  |    |    |    |    |    |    |    | D | V[15 | :0] |   |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    | 35 |   | R/W  |     |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |    |   | 55h  |     |   |   |   |   |   |   |   |

DIV Transmit or receive rate divider. Rate = System clock frequency / DIV/ 16. The default value is 55h when in contention mode. This divisor is also used to determine the RX FIFO timeout threshold.

#### IRDA+0018h Transmit frame size

TX\_FRAME\_SIZ

E

| Bit   | 15 | 14 | 13 | 12_ | 11 | 10 | 9 | 8 | 7    | 6    | 5     | 4     | 3 | 2 | 1 | 0 |
|-------|----|----|----|-----|----|----|---|---|------|------|-------|-------|---|---|---|---|
| Name  |    |    |    |     |    |    |   |   | TX_F | RAME | SIZE[ | 11:0] |   |   |   |   |
| Type  |    |    |    |     |    |    |   |   |      | R/   | W     |       |   |   |   |   |
| Reset |    |    |    |     |    | •  |   | • |      | 40   | )h    |       | • |   | • |   |

**TX\_FRAME\_SIZE** Transmit frame size; the default value is 64 when in contention mode.

# IRDA+001Ch Receiving frame1 size

RX\_FRAME1\_SI

ΖĿ

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6     | 5    | 4      | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|------|-------|------|--------|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   | RX_F | RAME1 | SIZE | [11:0] |   |   |   |   |
| Туре  |    |    |    |    |    |    |   |   |      | R     | 0    |        |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |      | (     | )    |        |   |   |   |   |



**RX\_FRAME1\_SIZE** Reports the number of byte received. Includes only the A+C+I fields.

#### IRDA+0020h Transmit abort indication

**ABORT** 

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

**ABORTSIR** mode only. When set 1, the framer transmits an abort sequence and closes the frame without an FCS field or an ending flag.

Note: Tx abort can be achieved in MIR and FIR by simply disabling the tx\_en signal.

### IRDA+0024h IrDA framer transmit enable signal

TX\_EN

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | <u>3</u>   | 2            | 1    | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|------------|--------------|------|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   | 6 | TX_ON<br>E | TXINVE<br>RT | MODE | TX_E<br>N |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | R/W        | R/W          | R/W  | R/W       |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0          | 0            | 0    | 0         |

**TX\_EN** Transmit enable.

MODE SIR mode only. Modulation type selection.

- 0 3/16 modulation
- 1 1.61us

**TXINVERT** Invert the transmit signal.

- **0** Transmit signal is not inverted.
- 1 Transmit signal is inverted.

TX\_ONE: Controls the transmit enable signal is one or not.

tx\_en is not de-asserted until software programs a so.1 tx\_en is 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    |    |    |    |    |    |    |   |   |   |   |   |   |   | RX_ON | RXINVE | RX_E |
| Ivaille |    |    |    |    |    |    |   |   |   |   |   |   |   | E     | RT     | N    |
| Type    |    |    |    |    |    |    |   |   |   |   |   |   |   | R/W   | R/W    | R/W  |
| Reset   |    |    |    |    |    |    |   |   |   |   |   |   |   | 0     | 0      | 0    |

**RX\_EN** Receive enable.

**RXINVERT** Invert the receive signal.

- Receive signal is not inverted.
- 1 Receive signal is inverted.

**RX\_ONE** Disable receive when get one frame.

- **0** rx\_en is not de-asserted until software programs **so**.
- 1 rx\_en is 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  |    |    |    |    |    |    |   |   |   |   |   |   | RX_1 | 'RIG[ | TX_1 | rrig |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | R/   | W     | R/   | W    |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | (    | )     | (    | )    |



**TX\_TRIG** TX FIFO interrupt trigger threshold. When the amount of data in the TX FIFO is less than the specified amount, dma req is asserted. (When TX\_TRIG = 03, dma req is always asserted as long as FIFO is not full.)

**00** 0 byte

**01** 1 byte

**02** 8 byte

**03** 16 byte

**RX\_TRIG** RX FIFO interrupt trigger threshold. When the amount of data in RX FIFO is above the specified amount, dma req is asserted.

**00** 1 byte

**01** 2 byte

**02** 3 byte

### IRDA+0030h IRQ enable signal

### IRQ ENABLE

| Bit   | 15 | 14 | 13 | 12                 | 11            | 10                    | 9                   | 8           | 7           | 6                  | 5                  | 4                  | 3                  | 2         | 1           | 0           |
|-------|----|----|----|--------------------|---------------|-----------------------|---------------------|-------------|-------------|--------------------|--------------------|--------------------|--------------------|-----------|-------------|-------------|
| Name  |    |    |    | 2NDR<br>X_CO<br>MP | RXRE<br>START | THRE<br>SHTIM<br>EOUT | 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 | ERRO<br>R | RXTH<br>RES | TXTH<br>RES |
| 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           |

**TXRES** Transmit data reaches the threshold level. (For debug only. Should be set to 0.)

- No interrupt is generated.
- 1 Interrupt is generated when transmit FIFO size reaches threshold.

**RXRES** Receive data reaches the threshold level. (For debug only. Should be set to 0.)

- **0** No interrupt is generated.
- 1 Interrupt is generated when receive FIFO size reaches threshold.

**ERROR** Error status interrupt enable.

- **0** No interrupt is generated.
- 1 Interrupt is generated when one of the error statuses occurs.

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

- O 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 SIR mode only.** Transmitting aborting frame.

- **0** No interrupt is generated.
- 1 Interrupt is generated when transmitting aborting frame.

FIFOTIMEOUT FIFO timeout.

O No interrupt is generated.



1 Interrupt is generated when FIFO timeout.

THRESHTIMEOUT Threshold time timeout.

- No interrupt is generated.
- 1 Interrupt is generated when threshold timer is timed out.

**RXRESTART** SIR mode only. 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.

- 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  |    |    |    | 2NDR<br>X_CO<br>MP | RXRE<br>START |    | FIFOTI<br>MEOU<br>T | TXABO<br>RT | RXABO<br>RT | MAXTI<br>MEOU<br>T | MINTI<br>MEOU<br>T |    | TXCO<br>MPLET<br>E | ERRO<br>R | RXTR<br>ES | TXTRE<br>S |
| 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. (For debug only. Not recommended for normal usage.)

**RXFIFO** Receive FIFO reaches threshold. (For debug only. Not recommended for normal usage.)

**ERROR** Generated when any of status in Error Status register occurs.

Once the source of an interrupt is determined to be caused by an error (bit 2), the error status register should be read. Once read, both the error status register and the interrupt source are read-cleared. If the error status register indicates either a frame 1 or frame 2 error, the corresponding frame status register should be read.

**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 ERROR STATUS register

**ERR STATUS** 

| Bit   | 15 | 14 | 13 | 12 | Î1 | 10 | 9 | 8 | 7 | 6       | 5      | 4      | 3     | 2     | 1     | 0     |
|-------|----|----|----|----|----|----|---|---|---|---------|--------|--------|-------|-------|-------|-------|
|       |    |    |    |    |    |    |   |   |   | TX FIFO | FRAME  | FRAME  | RESER | DECED | OVER  | RXSIZ |
| Name  |    |    |    |    |    |    |   |   |   | UNDERR  | 2 DATA | 1 DATA | VED2  | VED   | RUN   | E     |
|       |    |    |    |    |    |    |   |   |   | UN      | ERR    | ERR    | VLDZ  | VLD   | 11014 | _     |
| Type  |    |    |    |    |    |    |   |   |   | R/W     | R/W    | R/W    | R/W   | R/W   | R/W   | R/W   |
| Reset |    |    |    |    |    |    |   |   |   | 0       | 0      | 0      | 0     | 0     | 0     | 0     |

**RXSIZE** Receive frame size error.

**OVERRUN** Frame overrun.

**RESERVED** Reserved for future use.

**RESERVED2** Reserved for future use.

FRAME1 DATA ERR Indicates that an error condition occurred in RX frame1. Must check the RX frame1 status.

FRAME2 DATA ERR Indicates that an error condition occurred in RX frame2. Must check the RX frame2 status.



#### TX FIFO UNDERRUN MIR and FIR mode only.

 $TX\ FIFO\ underrun\ has\ occurred.$  Data transmission is aborted. Software must reset the tx\_en signal.

# IRDA+003Ch Transceiver power on/off control. Transceiver mode TRANSCEIVER select.

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2             | 1   | 0      |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---------------|-----|--------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | TXCVR         | TX  | TRANS_ |
| Туре  |    |    |    |    |    |    |   |   |   |   |   |   |   | CONFIG<br>R/W | R/W | R/W    |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0             | 0   | 0      |

**TRANSCEIVER\_PDN** Used for power on/off control for external IrDA transceiver.

**TX\_MANUAL** When txcvr config is set to 1, this bit can be used to select the operation mode of the external IrDA transceiver (some transceivers require selection between high speed and low speed operating modes), by software programming the desired sequence to transmit through the irda\_txd pin.

#### **TXCVR CONFIG**

- O Irda\_txd comes from core logic.
- 1 Irda\_txd depends on tx\_manual value.

### IRDA+0040h Maximum number of receiving frame size

RX\_FRAME\_MA

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

**RX\_FRAME\_MAX** Receive frame I field max size, when actual receiving frame size is larger than rx\_frame\_max, RXSIZE is asserted. The maximum allowed I field size is 2048.

#### IRDA+0044h Threshold Time

THRESH T

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9      | 8    | 7     | 6      | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|--------|------|-------|--------|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    | DISCON | NECT | _TIME | [15:0] |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |        | R/V  | V     |        |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |        | bb8  | h     |        |   |   |   |   |   |   |

**THRESHOLD TIME** Threshold time; used to control the time a station waits without receiving a valid frame before disconnecting the link. Associated with this is the time a station waits without receiving a valid frame before sending a status indication to the service user layer.

### IRDA+0048h Counter enable signal

COUNT\_ENABL

E

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

**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 |    |    |    |    |    |    |   |   |   |   |   |   |   |   | CLOC | K_RA<br>E |



#### MT6228 GSM/GPRS Baseband Processor Data Sheet Revision 1.0

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

### CLOCK\_RATE

**SIR mode only** Indication of the system clock rate.

- 0 26 MHz
- 1 52 MHz
- 2 13 MHz

### 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  |    |    |    |    |    |    |   |   |   |   |   |   |   | CRC<br>REPOR<br>T | SIR<br>FRAMI<br>NG SET | RATE_<br>FIX |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | R/W               | R/W                    | R/W          |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0                 | 0                      | 0            |

**RATE\_FIX** SIR mode only Fix the IrDA framer sample base clock rate as 13 MHz.

- O Clock rate based on clock\_rate selection.
- 1 Clock rate fixed at 13 MHz.

**SIR FRAMING SET SIR mode only.** Framing error check condition.

- **0** Ignore the STOP bit of the last byte of a frame.
- 1 Check the STOP bit of the last byte of a frame.

**CRC REPORT** When set to 1, CRC error is reported via error status register and error interrupt.

### 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       |
|-------|----|----|----|----|----|----|---|-------------|---|-----|------|------|--------|--------|---------|---------|
|       |    |    |    |    |    |    |   |             |   | FIR | FIR  | MIR  | UNKNO  | DE DET | 000 544 | ED 411E |
| Name  |    |    |    |    |    |    |   |             |   | STO | 4PPM | HDLC | W_ERRO | ECT    | CRC_FAI | ERROR   |
|       |    |    |    |    |    |    |   |             |   | ERR | ERR  | ERR  | R      | ECI    | -       | ERROR   |
| Type  |    |    |    |    |    |    |   | <b>T</b> 7. |   | R/W | R/W  | R/W  | R/W    | R/W    | R/W     | R/W     |
| Reset |    |    |    |    |    |    |   |             |   | 0   | 0    | 0    | 0      | 0      | 0       | 0       |

**FRAME\_ERROR** SIR mode only. Framing error, i.e. STOP bit = 0.

- 0 No framing error
- 1 Framing error occurred

CRC FAIL CRC check fail

- 2 CRC check successfully
- 3 CRC check fail

**PF DETECT** P/F bit detect

- O Not a P/F bit frame
- 1 Detected P/F bit in this frame

**UNKNOWN\_ERROR SIR mode only.** 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.

MIR HDLC ERR
MIR mode only. MIR HDLC encoding error

- O No error
- Error

FIR 4PPM ERR FIR mode only. FIR 4ppm encoding error

- 0 No error
- 1 Error



FIR STO ERR

FIR mode only. FIR STO sequence error

- 0 No error
- 1 Error

### IRDA+0058h RX Frame2 Status

FRAME2\_STAT

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6                 | 5                  | 4                  | 3                    | 2      | 1       | 0               |
|-------|----|----|----|----|----|----|---|---|---|-------------------|--------------------|--------------------|----------------------|--------|---------|-----------------|
| Name  |    |    |    |    |    |    |   |   |   | FIR<br>STO<br>ERR | FIR<br>4PPM<br>ERR | MIR<br>HDLC<br>ERR | UNKNO<br>W_ERRO<br>R | PF_DET | CRC_FAI | FRAME_<br>ERROR |
| Туре  |    |    |    |    |    |    |   |   |   | R/W               | R/W                | R/W                | R/W                  | R/W    | R/W     | R/W             |
| Reset |    |    |    |    |    |    |   |   |   | 0                 | 0                  | 0                  | 0                    | 0      | 0       | 0               |

**FRAME\_ERROR** SIR mode only. Framing error, i.e. STOP bit = 0

- **0** No framing error.
- 1 Framing error occurred.

**CRC\_FAIL** CRC check fail.

- CRC check successfully.
- 1 CRC check fail.

**PF DETECT** P/F bit detect.

- Not a P/F bit frame.
- 1 Detected P/F bit in this frame.

**UNKNOWN\_ERROR SIR mode only**. Receiving error data, i.e. escape character is followed by a character that is not an ESC, BOF, or EOF character.

- O Data receiving correctly.
- 1 Unknown error occurred.

MIR HDLC ERR MIR mode only. MIR HDLC encoding error.

- 0 No error
- 1 Error

FIR 4PPM ERR FIR mode only.FIR 4ppm encoding error

- No error
- 1 Error

FIR STO ERR FIR mode only.FIR STO sequence error

- 0 No error
- 1 Error

# IRDA+005Ch Receiving frame2 size

RX\_FRAME2\_SI

ZE

| Bit   | 15 | 14 | 13 | 12 | 11 | 10                      | 9 | 8 | 7    | 6     | 5    | 4      | 3 | 2 | 1 | 0 |  |  |  |
|-------|----|----|----|----|----|-------------------------|---|---|------|-------|------|--------|---|---|---|---|--|--|--|
| Name  |    |    |    |    |    |                         |   |   | RX_F | RAME2 | SIZE | [11:0] |   |   |   |   |  |  |  |
| Type  |    |    |    |    |    | RX_FRAME2_SIZE[11:0] RO |   |   |      |       |      |        |   |   |   |   |  |  |  |
| Reset |    |    |    |    |    |                         |   |   |      | (     | )    |        |   |   |   |   |  |  |  |

**RX\_FRAME2\_SIZE** Reports the number of byte received. Includes only the A+C+I fields.

### IRDA+0060h Irda Mode Select

IRDA\_MODE

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



**IRDA MODE** Selects the IrDA operating mode. NOTE: this mode selection cannot be issued while transmitting or receiving.

- 00 IR mode
- 01 MIR mode
- 10 FIR mode

MIR SPEED Select the MIR speed.

- **0** 0.576 Mbps
- 1 1.152 Mbps

#### IRDA+0064h Fifo Status

FIFO\_STAT

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4                  | 3                  | 2                      | 1_1_               | 0                      |
|-------|----|----|----|----|----|----|---|---|---|---|---|--------------------|--------------------|------------------------|--------------------|------------------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   | RX<br>FIFO<br>HOLD | TX FIFO<br>WR FULL | TX FIFO<br>RD<br>EMPTY | RX FIFO<br>WR FULL | RX FIFO<br>RD<br>EMPTY |
| Туре  |    |    |    |    |    |    |   |   |   |   |   | RO                 | RO                 | RO                     | RO                 | RO                     |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 0                  | 0                  | 1                      | 0                  | 1                      |

This register indicates the real time FIFO status, for monitoring purposes.

### 4.9 Real Time Clock

### 4.9.1 General Description

The Real Time Clock (RTC) module provides time and data information. The clock is based on a 32.768KHz oscillator with an independent power supply. When the mobile handset is powered off, a dedicated regulator supplies the RTC block. If the main battery is not present, a backup supply such as a small mercury cell battery or a large capacitor is used. In addition to providing timing data, an alarm interrupt is generated and can be used to power up the baseband core via the BBWAKEUP pin. Regulator interrupts corresponding to seconds, minutes, hours and days can be generated whenever the time counter value reaches a maximum value (e.g., 59 for seconds and minutes, 23 for hours, etc.). The year span is supported up to 2127. The maximum day-of-month values, which depend on the leap year condition, are stored in the RTC block.

# 4.9.2 Register Definitions

### RTC+0000h Baseband power up

RTC BBPU

| Bit  | 15 | 14 | 13 | 12   | <u> 1</u> 1                                  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3    | 2    | 1            | 0         |
|------|----|----|----|------|----------------------------------------------|----|---|---|---|---|---|---|------|------|--------------|-----------|
| Name |    |    |    | KEY_ | BBPU                                         |    |   |   |   |   |   |   | AUTO | BBPU | WRITE_E<br>N | PWRE<br>N |
| Type |    |    |    | V    | <u>v                                    </u> |    |   |   |   |   |   |   | R/W  | R/W  | R/W          | R/W       |

**KEY\_BBPU** A bus write is acceptable only when KEY\_BBPU=0x43.

**AUTO** Controls if BBWAKEUP is automatically in the low state when SYSRST# transitions from high to low.

- BBWAKEUP is not automatically in the low state when SYSRST# transitions from high to low.
- BBWAKEUP is automatically in the low state when SYSRST# transitions from high to low.

**BBPU** Controls the power of PMIC. If powerkey1=A357h and powerkey2=67D2h, PMIC takes on the value programmed by software; otherwise PMIC is low.

- O Power down
- Power on

**WRITE\_EN** When WRITE\_EN is set to 0 by the software program, the RTC write interface is disabled until another system power on.



### **PWREN**

- **0** RTC alarm has no action on power switch.
- 1 When an RTC alarm occurs, BBPU is set to 1, and the system powers 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 |    |    |    |    |    |    |   |   |   |   |   |   |   |   | TCST<br>A | ALST<br>A |
| Type |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/C       | R/C       |

ALSTA This register indicates the IRQ status and whether or not the alarm condition has been met.

- No IRQ occurred; the alarm condition has not been met.
- 1 IRQ occurred; the alarm condition has been met.

TCSTA This register indicates the IRQ status and whether or not the tick condition has been met.

- No IRQ occurred; the tick condition has not been met.
- 1 IRQ occurred; the 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 | 9   | 4 | 3 | 2           | 1         | 0         |
|------|------|----|----|----|----|----|---|---|---|---|---|-----|---|---|-------------|-----------|-----------|
| Name | WING |    |    |    |    |    |   |   |   |   |   |     |   |   | ONESH<br>OT | TC_E<br>N | AL_E<br>N |
| Type | R/O  |    |    |    |    |    |   |   |   |   |   | 7/- |   |   | R/W         | R/W       | R/W       |

**ONESHOT** Controls automatic reset of AL\_EN and TC\_EN.

AL EN This register enables the control bit for IRQ generation if the alarm condition has been met.

- O Disable IRQ generation.
- 1 Enable the alarm time match interrupt. Clear the interrupt 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 the interrupt when ONESHOT is high upon generation of the corresponding IRQ.

WING This bit indicates that RTC is still writing to this register.

### 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 | WING |    |    |    |      |    | 1/8SEC<br>CII | 1/4SEC<br>CII | 1/2SEC<br>CII | YEAC | MTHC | DOW | DOM<br>CII | HOUC | MINCI | SECC |
| Туре | R/O  |    |    |    | - 77 |    | 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.

**HOUCII**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 of a second update.

1/4SECCIL Set the bit to 1 to activate the IRQ at each one-fourth of a second update.

1/8SECCII Set the bit to 1 to activate the IRQ at each one-eighth of a second update.



WING This bit indicates RTC is still writing to this register.

#### 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 | WING |    |    |    |    |    |   |   |   | YEA_M<br>SK | MTH_M<br>SK | DOW_M<br>SK | DOM_M<br>SK | HOU_M<br>SK | MIN_M<br>SK | SEC_M<br>SK |
| Туре | R/O  |    |    |    |    |    |   |   |   | R/W         |

The alarm condition for alarm IRQ generation depends on whether or not the corresponding bit in this register is masked.

#### **SEC MSK**

- O 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 does not affect the alarm IRQ generation.

#### **MIN MSK**

- O 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 does not affect the alarm IRQ generation.

#### **HOU MSK**

- O 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 does not affect the alarm IRQ generation.

#### DOM\_MSK

- O 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 does not affect the alarm IRQ generation.

#### **DOW MSK**

- O 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 does not affect the alarm IRQ generation.

#### MTH MSK

- O 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 does not affect the alarm IRQ generation.

#### YEA MSK

- O 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 does not affect the alarm IRQ generation.

**WING** This bit indicates RTC is still writing to this register.

### 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 | WING |    |    |    |    |    |   |   |   |   | TC_SECOND        |   |   |   |   |   |
| Type | R/O  | 4  |    |    |    |    |   |   |   |   | TC_SECOND<br>R/W |   |   |   |   |   |

**TC SECOND** The second initial value for the time counter. The range of its value is: 0-59.

**WING** This bit indicates RTC is still writing to this register.

| RTC+0018h | RTC minutes time counter register | RTC_TC_MIN |
|-----------|-----------------------------------|------------|
|-----------|-----------------------------------|------------|

| _ |    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|---|----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Р | it | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|   |    |    |    |    |    |    |    | • |   |   |   | • |   |   |   |   | • |
|   | _  |    | _  |    |    |    |    |   |   |   |   |   |   |   |   |   |   |





| Name | WING |  |  |  |  | TC_MINUTE |
|------|------|--|--|--|--|-----------|
| Type | R/O  |  |  |  |  | R/W       |

**TC\_MINUTE** The minute initial value for the time counter. The range of its value is: 0-59.

**WING** This bit indicates RTC is still writing to this register.

### 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 | WING |    |    |    |    |    |   |   |   |   |   |   | T | C_HOU | Ŗ |   |
| Type | R/O  |    |    |    |    |    |   |   |   |   |   |   |   | R/W   |   |   |

**TC\_HOUR** The hour initial value for the time counter. The range of its value is: 0-23.

WING This bit indicates RTC is still writing to this register.

### 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 | WING |    |    |    |    |    |   |   |   |   |   |   | V i | C_DOI | <b>/</b> I |   |
| Type | R/O  |    |    |    |    |    |   |   |   |   |   |   |     | R/W   |            |   |

**TC\_DOM** The day-of-month initial value for the time counter. The day-of-month maximum value depends on the leap year condition, i.e. 2 LSB of year time counter are zeros.

**WING** This bit indicates RTC is still writing to this register.

### RTC+0x0024 RTC day-of-week time counter register

RTC\_TC\_DOW

| Bit  | 15   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | <u> </u> | 5 | 4 | 3 | 2 | 1     | 0 |
|------|------|----|----|----|----|----|---|---|---|----------|---|---|---|---|-------|---|
| Name | WING |    |    |    |    |    |   |   |   |          |   |   |   | Т | C_DOV | V |
| Туре | R/O  |    |    |    |    |    |   |   |   | ₩.       |   |   |   |   | R/W   |   |

**TC\_DOW** The day-of-week initial value for the time counter. The range of its value is: 1-7.

**WING** This bit indicates RTC is still writing to this register.

#### 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 | WING |    |    |    |    |    |   |   |   |   |   |   |   | TC_M | ONTH |   |
| Type | R/O  |    |    |    |    |    |   |   |   |   |   |   |   | R/   | W    |   |

**TC MONTH** The month initial value for the time counter. The range of its value is: 1-12.

**WING** This bit indicates RTC is still writing to this register.

### 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 | WING |    |    |    |    |    |   |   |   |   |   | AL <sub>.</sub> | SECO | ND |   |   |
| Type | R/O  |    |    |    |    |    |   |   |   |   |   |                 | R/W  |    |   |   |

TC YEAR The year initial value for the time counter. The range of its value is: 0-127. (2000-2127)

**WING** This bit indicates RTC is still writing to this register.

### 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 |
|------|------|----------|----|----|----|----|---|---|---|---|---|---|-------|------|---|---|
| טונ  | 13   | <u> </u> | 10 | 12 | 11 | 10 | J | U |   | U | J | т | U     |      |   | U |
| Name | WING |          |    |    |    |    |   |   |   |   |   |   | AL_SE | COND |   |   |
| Type | R/O  |          |    |    |    |    |   |   |   |   |   |   | R/    | W    |   |   |

**AL\_SECOND** The second value of the alarm counter setting. The range of its value is: 0-59.

**WING** This bit indicates RTC is still writing to this register.



### 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 | WING |    |    |    |    |    |   |   |   |   |   |   | AL_M | NUTE |   |   |
| Type | R/O  |    |    |    |    |    |   |   |   |   |   |   | R/   | W    |   |   |

**AL\_MINUTE** The minute value of the alarm counter setting. The range of its value is: 0-59.

**WING** This bit indicates RTC is still writing to this register.

### 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 | WING |    |    |    |    |    |   |   |   |   |   |   | Α | L_HOU | R |   |
| Type | R/O  |    |    |    |    |    |   |   |   |   |   |   |   | R/W   |   |   |

**AL\_HOUR** The hour value of the alarm counter setting. The range of its value is: 0-23.

**WING** This bit indicates RTC is still writing to this register.

### 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 | WING |    |    |    |    |    |   |   |   |   |   |   | - | L_DOI | VI |   |
| Type | R/O  |    |    |    |    |    |   |   |   |   |   |   |   | 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.

WING This bit indicates RTC is still writing to this register.

### 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 | WING |    |    |    |    |    |   |   |   |   |   |   |   | A | L_DOV | V |
| Type | R/O  |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W   |   |

**AL\_DOW** The day-of-week value of the alarm counter setting. The range of its value is: 1-7.

**WING** This bit indicates RTC is still writing to this register.

#### 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 | WING |    |    |    |    |    |   |   |   |   |   |   |   | AL_M | ONTH |   |
| Type | R/O  |    |    |    |    |    |   |   |   |   |   |   |   | R/   | W    |   |

**AL\_MONTH** The month value of the alarm counter setting. The range of its value is: 1-12.

**WING** This bit indicates RTC is still writing to this register.

### 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 | WING |    |    | 77 |    |    |   |   |   |   |   | Α | L_YEA | R |   |   |
| Type | R/O  |    |    |    |    |    |   |   |   |   |   |   | R/W   |   |   |   |

**AL\_YEAR** The year value of the alarm counter setting. The range of its value is: 0-127. (2000-2127)

**WING** This bit indicates RTC is still writing to this register.

## RTC+0x004C XOSC bias current control register

RTC XOSCCAL

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

Name WING

Type R/O

WO

MediaTek Inc. Confidential



**XOSCCALI** This register controls the XOSC32 bias current. Before the first program by software, the XOSCCALI value is 11111b.

**WING** This bit indicates RTC is still writing to this register.

### RTC+0050h RTC\_POWERKEY1 register

RTC\_POWERK

EY1

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

### RTC+0054h RTC\_POWERKEY2 register

RTC\_POWERK EY2

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----|----|----|----|----|----|---|----|---|---|---|---|---|---|---|---|
| Name |    |    |    |    |    |    |   |    |   |   |   |   |   |   |   |   |
| 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 is first powered 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 the contents of these register sets are wrong, the interrupt is not generated. Therefore, the real time clock does not generate the interrupts before the software programs the registers; unwanted interrupt due to wrong time value do 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 | WING | DBIN<br>G |    |    |    |    |   |   |   |   | F | TC_PE | )N1[7:0 | )] |   |   |
| Type | R/O  | R/O       |    |    |    |    |   |   |   |   |   | R/    | W       |    |   |   |

RTC\_PDN1[3:1] is for reset de-bounce mechanism.

- 0 4ms
- **1** 16ms
- **2** 64ms
- **3** 256ms
- 4 512ms
- 5 1024ms
- 6 2048ms
- **7** 4096ms

RTC\_PDN1[7:4] & RTC\_PDN1[0] is the spare register for software to keep power on and power off state information.

**DBING** This bit indicates RTC is still de-bouncing.

**WING** This bit indicates RTC is still writing to this register.

| RTC+005Ch | PDN: | 2  |    |    |   |   |   |   |   |   |   | R | TC_F | DN2 |   |
|-----------|------|----|----|----|---|---|---|---|---|---|---|---|------|-----|---|
| Bit 15 14 | 13   | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0   | l |



| Name | WING |  |  |  | RTC_PDN2[7:0] |
|------|------|--|--|--|---------------|
| Type | R/O  |  |  |  | R/W           |

RTC\_PDN2 The spare register for software to keep power on and power off state information.

**WING** This bit indicates RTC is still writing to this register.

#### RTC+0060h RTC writing completed flag

RTC WOK

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

**WING1** This bit indicates RTC is still writing POWERKEY1.

WING2 This bit indicates RTC is still writing POWERKEY2.

**WING3** This bit indicates RTC is still writing BBPU.

# 4.10 Auxiliary ADC Unit

The auxiliary ADC unit is used to monitor the status of the battery and charger, to identify the plugged peripheral, and to perform temperature measurement. Seven input channels allow diverse applications in this unit.

Each channel can operate in one of two modes: 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 is set in timer-triggered mode. Otherwise, the channel operates in immediate mode.

In immediate mode, the A/D converter samples the value once only when the flag in the AUXADC\_CON1 register has been set. For example, if the flag IMM0 in AUXADC\_CON1 is set, the A/D converter samples the data for channel 0. The IMM flags must be cleared and set again to initialize another sampling.

The value sampled for channel 0 is stored in register AUXADC\_DAT0, the value for channel 1 is stored in register AUXADC\_DAT1, etc.

If the AUTOSET flag in the register AUXADC\_CON3 is set, the auto-sample function is enabled. The A/D converter samples 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 samples the next value for channel 1 immediately.

If multiple channels are selected at the same time, the task is performed sequentially on every selected channel. For example, if AUXADC\_CON1 is set to 0x7f, that is, all 7 channels are selected, the state machine in the unit starts sampling from channel 6 to channel 0, and saves the values of each input channel in the respective registers. The same process also applies in timer-triggered mode.

In timer-triggered mode, the A/D converter samples 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 AUXADC\_CON0 is set to 0x7f, all 7 channels are selected to be in timer-triggered mode. The state machine samples 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 AUTOCLR*n* 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 SYN*n* flags in the register AUXADC\_CON0 are 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 is cleared.

The usage of the immediate mode and timer-triggered mode are mutually exclusive in terms of individual channels.

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 is automatically powered down after the conversion is completed.

### 4.10.1 Register Definitions

#### AUXADC+000

# Oh Auxiliary ADC control register 0

**AUXADC CON0** 

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6    | 5    | 4    | <sub>0</sub> 3 | 2    | 1    | 0    |
|-------|----|----|----|----|----|----|---|---|---|------|------|------|----------------|------|------|------|
| Name  |    |    |    |    |    |    |   |   |   | SYN6 | SYN5 | SYN4 | SYN3           | SYN2 | SYN1 | SYN0 |
| Type  |    |    |    |    |    |    |   |   |   | R/W  | R/W  | R/W  | R/W            | R/W  | R/W  | R/W  |
| Reset |    |    |    |    |    |    |   |   |   | 0    | 0    | 0    | 0              | 0    | 0    | 0    |

**SYNn** These 7 bits define whether the corresponding channel is 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.

- The channel is not selected.
- 1 The channel is selected.

### AUXADC+000

4h

### **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  |    |    |    |    |    |    |   |   |   | IMM6 | IMM5 | IMM4 | IMM3 | IMM2 | IMM1 | <b>IMM0</b> |
| Type  |    |    |    |    |    |    |   |   |   | R/W         |
| Reset |    |    |    |    |    |    |   |   |   | 0    | 0    | 0    | 0    | 0    | 0    | 0           |

**IMM***n* These 7 bits are set individually to sample the data for the corresponding channel. It supports multiple flags.

- The channel is not selected.
- 1 The channel is selected.

#### AUXADC+000

# 8h 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  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | SYN7 |
| 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+000

# **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  | AUTO<br>SET |    |    |    | PUW<br>AIT_E<br>N |    |     | AUTO<br>CLR0 |   |   |   |   |   |   |   | STA |
| 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.

**PUWAIT 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.

- The mode is not enabled.
- 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 samples of the specified channels once the SYNn bit in the register AUXADC\_CON0 has been set. The SYNn bits are automatically cleared and the channel is not enabled again by the timer event except when the SYNn flags are set again.

- The automatic clear mode is not enabled.
- The automatic clear mode is enabled.

The field defines the auto-clear mode of the module for event 0. In auto-clear mode, the **AUTOCLR0** timer-triggered channel 0 gets the sample once the SYN7 bit in the register AUXADC\_CON2 has been set. The SYN7 bit is automatically cleared and the channel is not 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.

- This module is idle.
- 1 This module is busy.

### AUXADC+001

### **Auxiliary ADC channel 0 register** 0h

#### AUXADC\_DAT0

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

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 30.

| 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 30 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 a START condition. A LOW to HIGH transition on the SIO\_DAT line while SIO\_CK is high indicates a 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. A phase contains 9 bits: an 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 a 3-phase write transmission cycle is displayed in Figure 50. 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 a 2-phase write transmission cycle is to identify the sub-address of the specific slave the master intends to access; 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 51 and Figure 52, respectively.



Figure 50 SCCB 3-phase write transmission cycle



Figure 51 SCCB 2-phase write transmission cycle



Figure 52 SCCB 2-phase read transmission cycle

# 4.11.2 Register Definitions

| SCCB+0000h | SCCI | B Coi | ntrol | Regis | ster |   |   |   |   |   |   |   |   | TRL |
|------------|------|-------|-------|-------|------|---|---|---|---|---|---|---|---|-----|
| 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. The bit must be accessed when SCCB wants to communicate with the slave, i.e. generates write or read transmission cycles.

### SCCB+0008h SCCB Data Length Register

DAT LEN

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 1     | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---------|---|
| 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

**TBUF** 

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

TBUF For SCCB, the master initiates transmission with a START condition, and ends the transmission by sending a STOP condition. TBUF indicates the bus free time between a STOP and START condition, i.e. the interval of the STOP and START conditions. Based on a 13 MHz clock frequency, the SCCB buffer time = (TBUF / 13000000), and the default setting is ~4.7us.

#### SCCB+0010h SCCB Start Hold Time

**THDSTA** 

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

THDSTA START condition occurs when there is a HIGH to LOW transition on the SIO\_DAT line while SIO\_CK is HIGH. The START hold time indicates that SIO\_CK should be HIGH at least THDSTA length of time after SIO\_DAT becomes LOW. Based on a 13 MHz frequency, the SCCB start hold time = (THDSTA/13000000), and the default setting is ~4us.

### SCCB+0014h SCCB Data Hold Time

**THDDAT** 

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

THDDAT Since SCCB data can be changed only when SIO\_CK is LOW, a data hold time is defined to indicate the time interval that data cannot be changed after SIO\_CK becomes LOW. Based on 13 MHz frequency, SCCB data hold time = (THDDAT / 13000000), and the default setting is ~3us.

### SCCB+0018h SCCB TLOW

**TLOW** 

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3           | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-------------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | <b>TLOW</b> |   |   |   |
| Туре  |    |    |    |    |    |    |   |   |   |   |   |   | R/W         |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 46h         |   |   |   |



TLOW This field indicates the low period of serial clock. Combined with THIGH, the SIO\_CK duty is adjustable. Based on a 13MHz frequency, the SIO\_CK low period = (TLOW / 13000000), and the default setting is ~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  |    |    |    |    |    |    |   |   |   |   |   |   | THIGH |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | R/W   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 3Ch   |   |   |   |

**THIGH** This field indicates the high period of serial clock. Combined with TLOW, the SIO\_CK duty is adjustable. Based on a 13 MHz frequency, the SIO\_CK high period = (THIGH / 13000000), and the default setting is ~4.6us.

### SCCB+0020h SCCB Data Register

**DATA** 

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

**DATA** SCCB write data. DATA[8] indicates whether or not the following 8bits is an ID address. If the word is an ID address, the write or read information is hidden in DATA[0].

**DATA[8] 0** The following 8-bits is a sub address or pure data.

The following 8-bits is an ID address field.

### DATA[0]

**0** When DATA [8] = 1, the data is an ID address.

DATA [0] = 0, a write cycle

DATA [0] = 1, a read cycle

1 When DATA [8] = 0, the data is 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  |    |    |    |    |    |    |   |   |   |   |   |   | TSU | STO |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | R/  | W   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 34  | 1h  |   |   |

TSUSTO A LOW to HIGH transition on the SIO\_DAT line while SIO\_CK is high indicates a STOP condition. For a 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. Based on a 13 MHz frequency, SCCB STOP setup time = (TSUSTOP / 13000000), and the default setting is ~4us.

#### SCCB+0038h SCCB MODE

MODE

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

**MODE** This bit indicates the SCCB operating mode

- O To operate as Slave
- 1 To operate as Master

| CCC   | · nnach | SCCB | <b>Buf Clear</b> |
|-------|---------|------|------------------|
| SCCD. | TUUSUII | 3000 | Dui Cicai        |

**BUF CLEAR** 

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



| Name  |  |  |  |  |  |  |  | BUF_<br>CLEA<br>R |
|-------|--|--|--|--|--|--|--|-------------------|
| Type  |  |  |  |  |  |  |  | R/W               |
| Reset |  |  |  |  |  |  |  | 0                 |

**BUF CLEAR** Buffer clear bit. Set this bit to clear the SCCB FIFO.

- **0** Buffer is not cleared.
- 1 Clear the 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<br>E | READ |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W       | R/W  |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0         | 0    |

**READ** Indicates the read is complete.

- Read command is not finished.
- 1 Read command is finished.

**WRITE** Indicates the write is complete.

- Write command is not finished.
- 1 Write command is finished.

### SCCB+0044h SCCB Read Data Register

**READ DATA** 

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | $\overline{7}$ | 6 1 | 5 | 4    | 3     | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|----------------|-----|---|------|-------|---|---|---|
| Name  |    |    |    |    |    |    |   |   |                |     |   | READ | _DATA |   |   |   |
| Type  |    |    |    |    |    |    |   |   |                |     |   | R    | 0     |   |   |   |
| Reset |    |    |    |    |    |    |   |   |                |     |   | (    | )     |   |   |   |

**READ DATA** The returned read data from slave.

# 4.12 Cipher Hash Engine

# 4.12.1 General Description

The Cipher and Hash Engine (CHE) and Secure Booting module is responsible for security functions in the MT6228 that are essential for applications such as M-Payment, WAP, WIM, banking communication, and Digital Rights Management. The hardware support allows for lower complexity and higher efficiency. The architecture is based on Direct Memory Access (DMA) without a word-alignment constraint, increasing its flexibility for users.

For the cipher and decipher functions, CHE supports Advanced Encryption Standard (AES), Data Encryption Standard (DES), and Triple-DES (**Figure 53**). These standards are used for both Electronic Codebook mode (**Figure 54**) and Cipher Block Chaining mode (**Figure 55**). The cipher and decipher functions are symmetric functions: the same key is used for both encryption and decryption. They are block-based algorithms: AES operates on a block size of 16 bytes and 3DES/DES on a block size of 8 bytes. The lengths of the cipher text and the plain text are typically the same if the original length is a multiple of the block size. CHE supports all AES key lengths: 128, 192, 256 bits. Under certain conditions, the decoding speed can be comparable to encoding speed. Write-only key registers are given higher security level for use. The user can keep the cipher-text of raw keys and discard original keys to prevent peepers.



Encryption: 
$$M_i \rightarrow \begin{array}{c} DEA_1 \\ E_{K1} \end{array} \rightarrow \begin{array}{c} DEA_2 \\ D_{K2} \end{array} \rightarrow \begin{array}{c} DEA_3 \\ E_{K3} \end{array} \rightarrow C_i$$

Decryption: 
$$C_i \xrightarrow{DEA_1} \xrightarrow{DEA_2} \xrightarrow{DEA_3} \xrightarrow{DK_3} M$$

Figure 53 3DES Function



Figure 54 ECB Mode



Figure 55 CBC Mode

For the hash function, CHE supports both Message Digest 5 (MD5 in RFC 1321) and US Secure Hash Algorithm 1 (SHA-1 in RFC 3174). The hash function is a one-way function: a message is converted into a fixed-length string of digits. MD5 is a 128-bit message digest, and SHA-1 is 160-bit. They are very similar functions such that resources sharing can be applied in CHE.

A new Save and Resume feature is implemented in CHE. Because only one task can be applied on CHE at any given time, unfinished jobs can be saved to the assigned memory addresses until the source data is ready again.

Register Definitions

| Register Address | Register Function                                         | Acronym    |
|------------------|-----------------------------------------------------------|------------|
| CHE + 0000h      | CHE start register                                        | CHE_START  |
| CHE + 0004h      | CHE control register                                      | CHE_CON    |
| CHE + 0008h      | CHE key0/key4/initial vector 0/source memory address      | CHE_IN0    |
| CHE + 000ch      | CHE key1/key5/initial vector 1/destination memory address | CHE_IN1    |
| CHE + 0010h      | CHE key2/key6/initial vector 2/data length                | CHE_IN2    |
| CHE + 0014h      | CHE key3/key7/initial vector 3/state memory address       | CHE_IN3    |
| CHE + 0018h      | CHE slow down rate                                        | CHE_SDRAT  |
| CHE + 001ch      | CHE pad count                                             | CHE_PCNT   |
| CHE + 0020h      | CHE status                                                | CHE_STAT   |
| CHE + 0024h      | CHE current destination address                           | CHE_CDES   |
| CHE + 0028h      | CHE interrupt status                                      | CHE_INTSTA |
| CHE + 002ch      | CHE interrupt enable                                      | CHE_INTEN  |
| CHE + 00c0h      | CHE Secure Booting control                                | CHE_BCON   |
| CHE + 00c4h      | CHE Secure Booting source data                            | CHE_BSRC   |
| CHE + 00c8h      | CHE Secure Booting seed data                              | CHE_BSEED  |
| CHE + 00cch      | CHE Secure Booting encrypted data                         | CHE_BENC   |
| CHE + 00d0h      | CHE Secure Booting decrypted data                         | CHE_BDEC   |



### Table 31 CHE Registers

### CHE+0000h CHE start register

**CHE START** 

| Bit   | 15 | 14 | 13    | 12    | 11    | 10    | 9     | 8          | 7    | 6    | 5         | 4         | 3     | 2     | 1    | $\Box$ |
|-------|----|----|-------|-------|-------|-------|-------|------------|------|------|-----------|-----------|-------|-------|------|--------|
| Name  |    |    | UPK67 | UPK45 | UPK23 | UPK01 | UPIV2 | UPIV0<br>1 | RKEY | WKEY | UPDE<br>S | CLEA<br>R | RSTAT | WSTAT | LAST | ST/UD  |
| 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    |
| Reset |    |    | 0     | 0     | 0     | 0     | 0     | 0          | 0    | 0    | 0         | 0         | 0     | 0     | 0    | 0      |

Start register for CHE.

**ST/UD** This bit means **Start** (1) / **!Update** (0).

When the ST/UD bit is asserted, CHE enters **NORMAL mode** and performs the job pre-defined according to the bit settings of LAST, WSTAT, RSTAT, UPDES, WKEY, RKEY and register CHE\_CON. This bit must be de-asserted after the current operation finished. **Note:** CHE only starts when the CHE\_CON control register ATYPE is 111 (Reserved); otherwise, CHE ends immediately and returns an error.

When ST/UD is de-asserted, CHE enters **UPDATE mode**. It depends on the UPIV01, UPIV23, UPK01, UPK23, UPK45 and UPK67 to update the corresponding Initial Vectors (IV0~3) and cipher or decipher keys 0~7 in symmetric ciphering or deciphering mode. It's suggested that writing 0x0000 into START immediately before other operations.

**LAST** This bit indicates the last section for this process. If this bit is asserted, CHE finishes the current process and resets to the initial state.

In ciphering mode, CHE outputs the last result (including padding process operation).

In deciphering mode, CHE outputs the last result and updates CHE PCNT.

In hashing mode, CHE pads and outputs the digest.

**WSTAT** Write CHE states after this operation completed. CHE needs 120 bytes of space for each state to write to address CHE\_SADDR (CHE\_IN3). The state can be read back by asserting RSTAT.

**RSTAT** Read states before the start of the operation. CHE reads 120 bytes back from address CHE\_SADDR (CHE\_IN3). The states can be written beforehand by asserting WSTAT.

CLEAR Reset all states and return to the initial state. To perform a clear operation, write 0x0010 to CHE\_START, then write 0x0000 to CHE\_START immediately (in the next instruction cycle) to return to the idle mode. The clear operation has the highest priority of all. If this operation starts with RSTAT disabled, the user is recommended to clear CHE. The user is highly recommended to clear CHE if this operation starts without RSTAT enabled.

**UPDES** Force an update for CHE\_DES (CHE\_IN1). CHE automatically updates CHE\_DES under two conditions only: the first operation after a reset or a last operation. The user can force CHE to update the destination address by asserting UPDES. When this bit is enabled, CHE does not update the destination address when RSTAT is enabled.

WKEY Write key values into encrypted form. To encrypt the key after writing CHE\_KEY0~ 7 (CHE\_IN0~3), write 0x0041 to CHE\_START. Wait for the OK state before writing 0x0000 to CHE\_START to return to idle mode. The keys are stored in encrypted form; the user cannot recover the plain text key, only restore the encrypted key to CHE by asserting RKEY.

This operation needs 36 bytes of buffer space and uses SADDR as a target address. The WKEY process does not affect the contents of the KEY registers in CHE. WKEY and RKEY override the NORMAL mode operation for CHE; WKEY has higher priority than RKEY.

RKEY Restore the key values back to CHE. To retrieve a previously stored key (36 bytes), write 0x0081 to CHE\_START. Wait for the OK state before writing 0x0000 to CHE\_START to return to the idle mode. The keys can be stored by asserting WKEY.

**UPIV01** Update CHE\_IV0 from CHE\_IN0 and CHE\_IV1 from CHE\_IN1 in UPDATE mode.

**UPIV23** Update CHE IV2 from CHE IN2 and CHE IV3 from CHE IN3 in UPDATE mode.



**UPK01** Update CHE\_KEY0&1 from CHE\_IN0 and CHE\_IV1 in UPDATE mode.

**UPK23** Update CHE\_KEY2&3 from CHE\_IN2 and CHE\_IV3 in UPDATE mode.

**UPK45** Update CHE\_KEY4&5 from CHE\_IN0 and CHE\_IV1 in UPDATE mode.

**UPK67** Update CHE\_KEY6&7 from CHE\_IN2 and CHE\_IV3 in UPDATE mode.

### CHE+0004h CHE control register

CHE CON

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4         | 3          | 2 | 1     | 0_ |
|-------|----|----|----|----|----|----|---|---|---|---|---|-----------|------------|---|-------|----|
| Name  |    |    |    |    |    |    |   |   |   |   |   | SMOD<br>E | CIPH<br>ER |   | ATYPE |    |
| Type  |    |    |    |    |    |    |   |   |   |   |   | R/W       | R/W        |   | R/W   |    |
| Reset |    |    |    |    | •  | ,  |   |   |   |   | , | 0         | 0          |   | 000   |    |

Control register for CHE.

**ATYPE** Cipher Hash algorithm type: 000=MD5, 001=SHA-1, 010=DES, 011=3-DES, 100=AES-128, 101=AES-192, 110=AES-256. 111=Reserved.

**CIPHER** 0=Decipher mode, 1=Cipher mode.

**SMODE** 0=ECB mode, 1=CBC mode. For CBC mode, load the initialization vectors (IV) beforehand.

### CHE+0008h CHE key0/key4/initial vector 0/source address

CHE INO

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23    | 22 | 2    |          | 20 <u></u> | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|-------|-------|----|------|----------|------------|----|----|----|----|
| Name  |    |    |    |    |    |    |    | IN0[3 | 1:16] |    |      | 0 ]      |            |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R     | W     | 4  |      | Y        |            |    |    |    |    |
| Reset |    |    |    |    |    |    |    | (     | 0     |    |      |          |            |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7     | 6  | o 7. | $\equiv$ | 4          | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    | IN0[  | 15:0] |    |      |          |            |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R     | W     | 05 |      |          |            |    |    |    |    |
| Reset |    |    | •  |    | •  | •  |    |       | 0     |    |      |          |            |    |    |    |    |

INO Temporary buffer to load the CHE internal registers: KEY0, KEY4, IV0 and SRC. Which registers are loaded depends on CHE\_START: in UPDATE mode, KEY0, KEY4, IV0 are loaded; in NORMAL mode, SRC is loaded

**KEY0** When CHE is in UPDATE mode and the UPK01 bit is enabled, the content of IN0 is copied into the internal KEY0 registers. CHE stores 8 KEYs, KEY0~KEY7. Different algorithms use different KEYs. AES-128: [0,1,2,3]; AES-192: [0,1,2,3,4,5]; AES-256: [0,1,2,3,4,5,6,7]; DES: [0,1]; 3-DES encryption:  $[0,1] \rightarrow [2,3] \rightarrow [4,5]$ ; and 3-DES decryption:  $[4,5] \rightarrow [2,3] \rightarrow [0,1]$ .

**KEY4** When CHE is in UPDATE mode and UPK45 is enabled, the content of IN0 is copied into the internal KEY4 registers.

When CHE is in UPDATE mode and UPIV01 is enabled, the content of IN0 is copied into the internal IV0 registers. DES/3DES uses a 64-bit initial vector [IV0,IV1] in CBC mode. AES uses a 128-bit initial vector [IV0,IV1,IV2,IV3] in CBC mode.

**SRC** When CHE is in NORMAL mode, the content of IN0 is copied into internal SRC registers. SRC is the source address for CHE operation.

### CHE+000ch CHE key1/key5/initial vector 1/destination address

CHE IN1

| Bit   | 31 | 30         | 29 | 28 | 27 | 26 | 25 | 24   | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|------------|----|----|----|----|----|------|-------|----|----|----|----|----|----|----|
| Name  |    | IN1[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  |    | -          |    |    |    |    |    | IN1[ | 15:0] |    |    |    |    |    |    |    |
| Type  |    | R/W        |    |    |    |    |    |      |       |    |    |    |    |    |    |    |
| Reset |    |            |    |    |    |    |    |      |       |    |    |    |    |    |    |    |



- Temporary buffer to load the CHE internal registers: KEY1, KEY5, IV1 and DES. Which registers are loaded depends on CHE\_START: in UPDATE mode, KEY1, KEY5, IV1 are loaded; in NORMAL mode, DES is loaded.
- **KEY1** When CHE is in UPDATE mode and UPK01 is enabled, the content of IN1 is copied into the internal KEY1 registers.
- **KEY5** When CHE is in UPDATE mode and UPK45 is enabled, the content of IN1 is copied into the internal KEY5 registers.
- When CHE is in UPDATE mode and UPIV01 is enabled, the content of IN1 is copied into the internal IV1 registers.
- **DES** When CHE is in NORMAL mode, the content of IN1 is copied into internal DES if UPDES is asserted or if this operation immediately follows a reset or a last operation. DES is the destination address for a CHE operation.

Info: About the destination buffer length:

In ciphering mode, the destination buffer length must be larger than the source data length.

In deciphering mode, the destination data length is the same as the source data length, a multiple of BLOCK SIZE.

In hash mode, the destination buffer length is 16 bytes in MD5 mode and 20 bytes in SHA-1 mode. BLOCK\_SIZE is 8 bytes in DES (3-DES) mode and 16 bytes in AES mode.

### CHE+0010h CHE key2/key6/initial vector 2/operation length

CHE IN2

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24               | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|------------------|------|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    | IN2[31           | :16] |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R/V              | ٧    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | 0                |      |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 🗸              | 7    | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    | IN2[1            | 5:0] |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | $\overline{R}/V$ | V    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | 0                |      |    |    |    |    |    |    |    |

- IN2 Temporary buffer to load the CHE internal registers: KEY2, KEY6, IV2 and LEN. Which registers are loaded in depends on CHE\_START: in UPDATE mode, KEY2, KEY6, IV2 are loaded; in NORMAL move, LEN is loaded
- **KEY2** When CHE is in UPDATE mode and UPK23 is enabled, the content of IN2 is copied into the internal KEY2 registers.
- **KEY6** When CHE is in UPDATE mode and UPK67 is enabled, the content of IN2 is copied into the internal KEY6 registers.
- **IV2** When CHE is in UPDATE mode and UPIV23 is enabled, the content of IN2 is copied into the internal IV2 registers.
- When CHE is in NORMAL mode, the content of IN2 is copied into the internal LEN registers. LEN is the length for the CHE operation. A zero length is allowed only in a last operation (LAST asserted); avoid using a zero length if possible. If a zero-length setting is unavoidable, clear the CHE after this operation. If a zero length is used in ciphering mode, the corresponding padded cipher text would be output. In deciphering mode, CHE resets. Both of them are regardless of previous ciphering or deciphering operations. In hash mode, if there are previous hash operations, CHE resets. Otherwise, the digest of zero length is output. I.e., MD5 outputs "d41d8cd98f00b204e9800998ecf8427e" and SHA1 outputs "da39a3ee5e6b4b0d3255bfef95601890afd80709".



# CHE+0014h CHE key3/key7/initial vector 3/state address

CHE IN3

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

IN3 Temporary buffer to load the CHE internal registers: KEY3, KEY7, IV3 and SADDR. Which registers are loaded depends on CHE\_START: in UPDATE mode, KEY3, KEY7, IV3 are loaded; in NORMAL mode, SADDR is loaded.

**KEY3** When CHE is in UPDATE mode and UPK23 is enabled, the content of IN3 is copied into internal KEY3 registers.

**KEY7** When CHE is in UPDATE mode and UPK67 is enabled, the content of IN3 is copied into internal KEY7 registers.

**IV3** When CHE is in UPDATE mode and UPIV23 is enabled, the content of IN3 is copied into internal IV3 registers.

SADDR When CHE is in NORMAL mode, the content of IN3 is copied into the internal SADDR registers.

SADDR is the state/KEY address for the CHE operation. If RSTAT or WSTAT is asserted, CHE treats SADDR as a state address, and reads or writes 120 bytes from or to this address. If RKEY or WKEY is asserted, CHE reads or stores 36-byte KEYs from or to SADDR. Note: SADDR must 4-byte aligned.

## CHE+0018h CHE slow down rate

**CHE SDRAT** 

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

SDRAT Slow down CHE to prevent too many requests for AHB resources. Each unit increment translates into a 4-cycle delay for each bus access (read or write). The range of SDRAT is from 0 (no delay) to 255 (255\*4=1020 cycles' delay).

# CHE+001ch CHE pad count

CHE\_PCNT

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

**PCNT** When performing symmetric deciphering, this register indicates the padding length.

### CHE+0020h CHE return status

**CHE STAT** 

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

STAT STAT represents the current state of CHE. 000b: OK. 001b: control field setting error. 010b: zero length for a non-last operation, or a last operation that is not hash nor ciphering (a last operation that is deciphering). 011b: resume state, wait for the next last or non-last operation. 100b: BUSY. 101b: RKEY and WKEY at the same time.

## CHE+0024h CHE current destination address

CHE CDES

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



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

**CDES** CDES is the current destination address in CHE.

## CHE+0028h CHE interrupt status

## CHE INTSTA

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

**INTSTA** Interrupt status. Bit 0 indicates CHE finished in the OK or RESUME state. Bit 1 indicates CHE returned a failure. Further information can be obtained from CHE\_STAT.

# CHE+002ch CHE interrupt enable

## **CHE INTEN**

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

**INTEN** Interrupt enable control register. When bit 0 is enabled, an interrupt occurs when CHE finishes in the OK or RESUME state. If bit 1 is enabled, CHE interrupts if an error occurs.

#### 

## CHE\_BCON

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

DIS Disable Secure Booting function. When DIS is asserted, the data read from CHE\_BENC and CHE\_BDEC is the same as CHE\_BSRC.

**PAR1** Use inner information parameter 1 (SK) to strengthen security.

PAR2 Use inner information parameter 2 (RS) to strengthen security.

**PAR3** Use inner information parameter 3 (MR) to strengthen security.

## CHE+00c4h CHE Secure Booting source data

### **CHE BSRC**

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

**BSRC** Source data for Secure Booting to be encrypted (obtained from CHE\_BENC) or decrypted (obtained from CHE\_BDEC).

## CHE+00c8h CHE Secure Booting seed value

## CHE\_BSEED

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



**BSEED** Seed data needed to increase security of the Boot Secure function. Set the seed value before performing Boot Secure the first time.

#### 

CHE BENC

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

**BENC** Encrypted data from CHE\_BSRC.

#### 

CHE\_BDEC

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23      | 22 | 21 | 20                | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|------|---------|----|----|-------------------|----|----|----|----|
| Name  |    |    |    |    |    |    |    | BDEC | [31:16] |    |    |                   |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R    | 0       |    |    |                   |    |    |    |    |
| Reset |    |    |    |    |    |    |    | (    | )       |    |    |                   |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7       | 6  | 5  | 4.3               | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    | BDEC | [15:0]  |    |    | 707               |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R    | 0       |    |    |                   |    |    |    |    |
| Reset |    | •  |    | •  | •  | •  |    | (    | )       |    |    | <i>5</i> <u> </u> |    | •  |    |    |

**BDEC** Decrypted data from CHE\_BSRC.

## 4.12.2 CHE KEY Phase Transient

In CHE, all cipher and decipher functions need a KEY, i.e., AES, DES, 3DES. However, due to the cost and performance concern, all the keys are put together in a KEY buffer with four phases (**Figure 56**).

- 1. Phase 1: AES128 decipher phase.
- 2. Phase 2: AES192 decipher phase
- 3. Phase 3: AES256 decipher phase.
- 4. Phase 4: Common phase, other functions which exclude the AES decipher. I.e., DES (cipher and decipher), 3DES (cipher and decipher), AES128, AES192, AES256 cipher.



**Figure 56** Key Phase Transient GraphPhases 1 through 3 are internal phases, unknown to the user. When the user first enters the key data, the key phase is reset to the Common Phase. Transition among phases is limited to the arrows shown in **Figure 56**. For example, if currently performing a 3DES cipher function, any cipher or decipher function may follow. If currently using a AES192 decipher function, only the AES192 decipher function or the Common Phase algorithms may be used next; otherwise an error occurs.

For security reasons and convenience, the key phase can be saved with key contents by WKEY or WSTAT. The user is highly recommended to convert raw key data into CKEY data format (using WKEY), discard the original key data, and to use CKEY by RKEY.



# 4.12.3 Secure Booting Procedure

Secure Booting is a feature of CHE that protects the program contents on flash memory from modification, skip or hard copy. With a secure process and a unique chip ID (UID), CHE can encrypt or decrypt a segment of instruction data in order.

#### Encryption procedure:

- 1. Activate the eFuse module.
- 2. Write the seed value into BSEED. The seed value can be any 32-bit value. The same seed value is necessary in the decryption procedure.
- 3. Write the control value into BCON.
- 4. Write source data (instruction) into BSRC and read the cipher text from BENC.
- 5. Repeat step 4 until all instructions are encrypted.

#### Decryption procedure:

- 1. Activate the eFuse module.
- 2. Write the seed value into BSEED. The seed value must be the same one used in the encryption procedure.
- 3. Write the control value into BCON. The control value must be the same one used in the encryption procedure.
- 4. Write the source data (instruction) into BSRC and read the plain text from BDEC.
- 5. Repeat step 4 until all instructions are decrypted.

#### Notes:

- 1. A bit length equal or less than 32 bits is acceptable for Secure Boot. E.g.: a 16-bit data 0x1234 is treated as 0x12340000 32-bit data and decrypted in the same manner.
- 2. For security reasons, access times to be encrypted or decrypted should not be the multiples of 4.
- 3. The internal states of Secure Booting function change under the following conditions, such that redundant register access is forbidden.
  - Write data into BSRC
  - Write data into BSEED
  - Read data from BENC or BDEC

As an example of the encryption and decryption of 16-bit data, consider the value 0xabcd:

#### Encryption:

- 1. The data is padded with zeros to obtain a 32-bit value: 0xabcd0000.
- 2. The encryption operation produces a value 0x12345678.

#### Decryption:

- 1. Only the most significant 16 bits 0x1234000 are considered and decrypted as 0xabcd7893.
- 2. The first 16 bits 0xabcd are retained, and 0x00007893 is ignored.



# 5 Microcontroller Coprocessors

Microcontroller Coprocessors are designed to run computing-intensive processes in place of the Microcontroller (MCU). These coprocessors especially target 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.

# 5.1 Divider

To ease the processing load of the MCU, a divider is employed. The divider can perform 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, depending on the magnitude of the dividend. Detailed processing times are listed below in **Table 32**. **Table 32** shows two processing times (except for when the dividend is zero) for each range of dividends, depending on whether or not restoration is required during the last step of the division operation.

| Signed Division                                         |              | Unsigned Divisio        | n            |
|---------------------------------------------------------|--------------|-------------------------|--------------|
| Dividend                                                | Clock Cycles | Dividend                | Clock Cycles |
| 0000_0000h                                              | 1            | 0000_0000h              | 1            |
| 0000_00ffh -<br>(-0000_0100h), excluding<br>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 0000b - ffff ffffb | 32 or 33     |

Table 32 Processing Time for Different Dividend Values

Table 33 Processing Time for Different Dividend Values

When the divider is started by setting the Divider Control Register START bit to 1, DIV\_RDY becomes 0; this bit is asserted when the division process is complete. MCU detects this status bit by polling it to know the correct access timing. To simplify polling, only the value of register DIV\_RDY is visible while Divider Control Register is being read. Hence, MCU does not need to mask other bits to extract the value of DIV\_RDY.

In a GSM/GPRS system, many divisions are executed with constant divisors. Therefore, oft-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, a division can be performed without providing a divisor. This omission of a step saves on the time for writing a divisor in and on the instruction fetch time, thus making the process more efficient.

# 5.1.1 Register Definitions

# DIVIDER+000 Oh Divider Control Register

**DIV\_CON** 

| Bit   | 31 | 30 | 29_ | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21          | 20   | 19 | 18 | 17          | 16        |
|-------|----|----|-----|----|----|----|----|----|----|----|-------------|------|----|----|-------------|-----------|
| Name  |    | 7  |     |    |    |    |    |    |    |    |             |      |    | С  | NST_ID      | X         |
| Type  |    |    |     |    |    |    |    |    | -  |    |             |      |    |    | WO          |           |
| Reset |    |    |     |    |    |    |    |    | *  | •  |             |      |    |    | 0           |           |
| Bit   | 15 | 14 | 13  | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5           | 4    | 3  | 2  | 1           | 0         |
| Name  |    |    |     |    |    |    |    |    |    |    | IN_CNS<br>T | SIGN |    |    | DIV_RD<br>Y | STAR<br>T |



| Ty  | ре  |  |  |  |  |  | WO | WO |  | RO | WO |
|-----|-----|--|--|--|--|--|----|----|--|----|----|
| Res | set |  |  |  |  |  | 0  | 1  |  | 1  | 0  |

**START** 

Starts a division operation. Returns to 0 after the division has started.

**DIV RDY** 

Current status of the divider. Note that when DIV\_CON register is read, only the value of DIV\_RDY appears; the program does not need to mask other parts of the register to extract the information in DIV\_RDY.

- Division is in progress.
- 1 Division is finished

**SIGN** 

Indicates a signed or unsigned division operation.

- Unsigned division
- 1 Signed division

IS\_CNST

Specifies that an internal constant value should be used as a divisor. If IS\_CNST is enabled, the divisor value need not be written, and divider automatically uses the internal constant value instead. The internal constant value used depends on the value of CNST\_IDX.

- Normal division. Divisor is written in via APB.
- Using internal constant divisor instead.

**CNST IDX** 

- Index of constant divisor.
- divisor = 13
- divisor = 261
- 2 divisor = 51
- 3 divisor = 52
- divisor = 1024
- 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  |    |    |    |    |    |    | D  | IVIDE | ND[31:1 | 6] |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | V     | VO      |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |       | 0       |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    | IVIDE | ND[15:0 | )] |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | ٧     | VO      |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |       | 0       |    |    |    |    |    |    |    |
|       |    |    |    |    |    | _  |    |       |         |    |    |    |    |    |    |    |

Dividend.

# **DIVIDER**

#### **Divider Divisor register** +0008h

**DIV\_DIVISOR** 

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

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  |    |    |    |    |    |    | Ql | JOTIEN       | NT[31:1 | [6] |    |    |    |    | 1  |    |
| Type  |    |    |    |    |    |    |    | R            | 0       |     |    |    |    |    |    |    |
| Reset |    | 0  |    |    |    |    |    |              |         |     |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8            | 7       | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    | Q  | <b>UOTIE</b> | NT[15:  | 0]  |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R            | 0       |     |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | (            | )       |     |    |    |    |    |    |    |

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  |    |    |    |    |    |    | RE | MAIND | ER[31: | 16] |    |     |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R     | 0      |     |    |     |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | (     | )      |     |    | I ø |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6   | 5  | 4   | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    | RE | MAIN  | DER[15 | :0] |    | 74  |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R     | 0      |     |    | 7   |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | (     | )      |     |    |     |    |    |    |    |    |

Remainder.

# 5.2 CSD Accelerator

# 5.2.1 General Description

This unit performs the data format conversion of RAO, RAI, 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 requires several instructions to complete a conversion, thus making it inefficient for the MCU to perform itself. A coprocessor, CSD accelerator, is designed to reduce the computing power needed to perform this function.

The CSD accelerator helps in converting data format only; 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, too many case scenarios for the downlink path conversion greatly increase the hardware area cost, thus only uplink RA0 data format conversion is provided. Uplink RA0 conversion consists of inserting a start bit before and a stop bit after each a byte, for a duration of 16 bytes. illustrates the detailed conversion table.







Figure 57 Data Format Conversion of RA0

The RA0 converter processes data state by state. Therefore, before filling in new data, software must ensure that converted data of in a state is withdrawn, otherwise the converted data is replaced by new data. For example, if 32 bits of data are written, the state pointer increments from state 0 to state 1, and word ready of state 0 is asserted. Before writing the next 32-bit data, the word of state 0 must be withdrawn first, or the data is lost when the next conversion is performed.

RA0 records the number of written bytes, the state pointer, and a ready state word. This information helps the software to perform flow control. See Register Definition for more detail.

For RA1 conversion, both downlink and uplink directions are supported. The data formats vary for different data rate. Detailed conversion tables are shown in and . The yellow part is the payload data, and the blue part is the status bit.



Figure 58 Data Format Conversion for 6k/12k RA1





Figure 59 Data Format Conversion for 3.6k RA1

For FAX, two types of bit-reversal functions are provided. Type 1 reversal is a bit-wise reversal (), and Type 2 is a byte-wise reversal ().



Figure 60 Type 1 Bit Reversal



Figure 61 Type 2 Bit Reversal

| 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 34 CSD Accelerator Registers

# 5.2.2 Register Definitions

# CSD+0000h CSD RA0 Control Register

**CSD RAO CON** 

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                       | 23 | 22 | 21  | 20   | 19 | 18 | 17   | 16 |
|-------|----|----|----|----|----|----|----|--------------------------|----|----|-----|------|----|----|------|----|
| Name  |    |    |    |    |    |    |    | $\overline{\mathcal{A}}$ |    |    |     |      |    |    |      |    |
| Type  |    |    |    |    |    |    |    | 2/2                      |    |    |     |      |    |    |      |    |
| Reset |    |    |    |    |    |    |    |                          |    |    |     |      |    |    |      |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                        | 7  | 6  | 5   | 4    | 3  | 2  | 1    | 0  |
| Name  |    |    |    |    |    |    |    |                          |    |    | RST | BTS0 |    | VI | D_BY | ΓE |
| Type  |    |    |    |    |    |    |    | 1                        |    |    | WO  | WO   |    | ΨO |      |    |
| Reset |    |    |    |    |    |    |    |                          |    |    | 0   | 0    |    |    | 100  |    |

**VLD\_BYTE** Specifies the number of valid bytes in the current input data. This value must be specified before filling data.

BTS0 Back to state 0. Forces RA0 converter return back to state 0. Incomplete words are padded with stop bits. For example, consider a back-to-state0 command that is issued after 8 bytes of data are filled in. All bits after the 8<sup>th</sup> byte are padded with stop bits, and the second ready word byte RDYWD2 is asserted (Figure 62). 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.



#### MT6228 GSM/GPRS Baseband Processor Data Sheet Revision 1.0



Figure 62 Example of Back to State 0

RST Resets the RA0 converter. If an erroneous operation disorders the data, this bit restores all states to their original state.

# CSD+0004h CSD RA0 Status Register

# CSD\_RA0\_STA

| Bit   | 31 | 30 | 29 | 28 | 27 | 26  | 25   | 24 | 23 | 22   | 21 | $\begin{bmatrix} \overline{20} \end{bmatrix}$ | 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  |    |    |    |    |    | BYT | ECNT |    |    | RTST | 4  |                                               | F  | RDYWE | )  |    |
| Type  |    |    |    |    |    | R   | 0    |    |    | RO   | ,  |                                               |    | RC    |    |    |
| Reset |    |    |    |    |    | (   | )    |    |    | 0    |    |                                               |    | 0     |    |    |

RDYWD0~4 Ready words. Indicates which state words are ready for withdrawal. If any bits asserted, data must be withdrawn before new data is filled into CSD\_RA0\_DI, to avoid data loss.

0 Not ready

1 Ready

CRTSTA Current state. State0 ~ State4. Indicates which state word software is currently filling.

**BYTECNT** Total number of bytes being filled.

# CSD+0008h CSD RA0 Input Data Register

## CSD\_RA0\_DI

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

**DIN** The RA0 conversion input data. The ready word indicator is checked before filling in data; if any words are ready, they are withdrawn first, otherwise the ready data in RA0 converter is replaced.

# CSD+000Ch CSD RA0 Output Data Register

## CSD\_RA0\_DO

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



Reset

**DOUT** RA0 converted data. The return data corresponds to the ready word indicator defined in CSD\_RA0\_STA register. The five bits of RDYWD map to state0 ~ state 4 respectively. When CSD\_RA0\_DO is read, the asserted state word is returned. If two state words asserted at the same time, the lower one is 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  |    |    |    |    |    |    |    | DI | N  |    |    |    |             |
| Type  |    |    |    |    |    |    |    | W  | O  |    |    |    |             |
| Reset |    |    |    |    |    |    |    | (  | )  |    |    |    |             |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3 2 1 0     |
| Name  |    |    |    |    |    |    |    | D  | N  |    |    |    |             |
| Type  |    |    |    |    |    |    |    | W  | O  |    |    |    |             |
| Reset |    |    |    |    |    |    |    | (  | )  |    |    |    |             |

DIN D1 to D32 of the 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    | $\overline{6}$ | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    | D  | IN S |                |    |    |    |    |    |    |
| Type  |    |    |    | •  | •  | •  |    | W  | 0    |                |    | •  | •  |    |    |    |
| Reset |    | 0  |    |    |    |    |    |    |      |                |    |    |    |    |    |    |

DIN D33 to D48 of the 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  |    |    |    |    |    |    |          | 1  |    |    |           |           |    |    |    |    |
| Reset |    |    |    |    |    |    | <b>7</b> |    |    |    |           |           |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9        | 8  | 7  | 6  | 5         | 4         | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    | ۵. |    | <u> </u> |    |    | E7 | <b>E6</b> | <b>E5</b> | E4 | X  | SB | SA |
| Type  |    |    |    |    | FX |    |          |    |    | WO | WO        | WO        | WO | WO | WO | WO |
|       |    |    |    |    |    |    |          |    |    |    |           |           |    |    |    |    |

- SA Represents S1, S3, S6, and S8 of the status bits.
- **SB** Represents S4 and S9 of the status bits.
- X Represents X of the status bits.
- **E4** Represents E4 of the status bits.
- **E5** Represents E5 of the status bits.
- **E6** Represents E6 of the status bits.
- **E7** Represents E7 of the 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 |    |    |    |    |    |    |    | DO | UT |    |    |    |    |    |    |    |



| Type  |    |    |    |    |    |    |   | R  | 0  |   |   |   |   |   |   |      |
|-------|----|----|----|----|----|----|---|----|----|---|---|---|---|---|---|------|
| Reset |    |    |    |    |    |    |   | (  | )  |   |   |   |   |   |   |      |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7  | 6 | 5 | 4 | 3 | 2 | 1 | 0    |
| Name  |    |    |    |    |    |    |   | DO | OU |   |   |   |   |   |   |      |
| Type  |    |    |    |    |    |    |   | R  | 0  |   |   |   |   |   |   | ( () |
| Reset |    |    |    |    |    |    |   | (  | )  |   |   |   |   |   |   |      |

**DOUT** Bit 0 to bit 31 of the 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  |    |    |    |    |    |    |    |    |    | DO | UT |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    | R  | 0  |    | _  |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    | (  | )  |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    | DO | UT |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R  | 0  |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | (  | )  |    |    |    |    |    |    |    |

**DOUT** Bit 32 to bit 59 of the RA1 6K/12K uplink frame.

# CSD+0200h CSD RA1 6K/12K Downlink Input Data Register 0

CSD\_RA1\_6\_12 K DLDI0

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

**DIN** Bit 0 to bit 31 of the RA1 6K/12K downlink frame.

# CSD+0204h CSD RA1 6K/12K Downlink Input Data Register 1

CSD\_RA1\_6\_12 K DLDI1

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

DIN Bit 32 to bit 59 of the 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   |    |        |    |    |    |    |    | DO | UT |    |    |    |    |    |    |    |
| Type   |    |        |    |    |    |    |    | R  | 0  |    |    |    |    |    |    |    |
| Reset  |    |        |    |    |    |    |    | (  | )  |    |    |    |    |    |    |    |
| Bit    | 15 | 14     | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name   | 45 |        |    |    |    |    |    | DO | UT |    |    |    |    |    |    |    |
| Type   |    |        |    |    |    |    |    | R  | 0  |    |    |    |    |    |    |    |
| Reset. |    | $\sum$ |    |    |    |    |    | (  | )  |    |    |    |    |    |    |    |



**DOUT** D1 to D32 of the 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  |    |    |    |    |    |    |    | DO | UT |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R  | 0  |    |    |    |    |    |    |    |
| Reset |    | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**DOUT** D33 to D48 of the 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        | l 2 <u>1</u> 9 | 18       | 17       | 16 |
|-------------|----|----|----|----|----|----|----|----|----|----------------|----------|-----------|----------------|----------|----------|----|
| Name        |    |    |    |    |    |    |    |    |    |                |          |           |                |          |          |    |
| Type        |    |    |    |    |    |    |    |    |    |                |          |           |                |          |          |    |
| Reset       |    |    |    |    |    |    |    |    |    |                |          | <u> </u>  |                |          |          |    |
|             |    |    |    |    |    |    |    |    |    |                |          |           |                |          |          |    |
| Bit         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6              | 5        | 4         | 3              | 2        | 1        | 0  |
| Bit<br>Name |    | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6<br><b>E7</b> | <u>5</u> | <u>E5</u> |                | 2<br>X   | SB       | SA |
|             |    | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | _              | _        |           | 3              | <u> </u> | SB<br>RO |    |

- **SA** The majority vote of the S1, S3, S6 and S8 status bits. If the vote is split, SA=0.
- SB The majority vote of the S4 and S9 status bits. If the vote is split, SB=0.
- X The majority vote of the two X bits in downlink frame. If the vote is split, X=0.
- **E4** Represents E4 of the status bits.
- **E5** Represents E5 of the status bits.
- **E6** Represents E6 of the status bits.
- **E7** Represents E7 of the status bits.

# CSD+0300h CSD RA1 3.6K Uplink Input Data Register 0

CSD\_RA1\_3P6 K ULDI0

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

DIN D1 to D24 of the RA1 3.6K uplink data.

# CSD+0304h ← CSD RA1 3.6K Uplink Status Data Register

CSD\_RA1\_3P6 K\_ULSTUS

| Bit   | 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21         | 20         | 19 | 18 | 17 | 16 |
|-------|------|----|----|----|----|----|----|----|----|----|------------|------------|----|----|----|----|
| Name  |      |    |    |    |    |    |    |    |    |    |            |            |    |    |    |    |
| Туре  |      |    |    |    |    |    |    |    |    |    |            |            |    |    |    |    |
| Reset |      |    |    |    |    |    |    |    |    |    |            |            |    |    |    |    |
| Bit   | □15\ | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5          | 4          | 3  | 2  | 1  | 0  |
| Name  |      |    |    |    |    |    |    |    |    | E7 | <b>E</b> 6 | <b>E</b> 5 | E4 | X  | SB | SA |



| Ty | уре  |  |  |  |  | WO |
|----|------|--|--|--|--|----|----|----|----|----|----|----|
| Re | eset |  |  |  |  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

- **SA** Represents S1, S3, S6, and S8 of the status bits.
- **SB** Represents S4 and S9 of the status bits.
- X Represents X of the status bits.
- **E4** Represents E4 of the status bits.
- **E5** Represents E5 of the status bits.
- **E6** Represents E6 of the status bits.
- **E7** Represents E7 of the status bits.

# CSD+0308h CSD RA1 3.6K Uplink Output Data Register 0

CSD\_RA1\_3P6 K ULDO0

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

**DOUT** Bit 0 to bit 31 of the RA1 3.6K uplink frame.

# CSD+030Ch CSD RA1 3.6K Uplink Output Data Register 1

CSD\_RA1\_3P6 K\_ULDO1

| 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  |    |    |    |    |    |    |    |     |    |    |    |    |    | DO | UT |    |
| Type  |    |    |    |    |    |    |    |     |    |    |    |    |    | R  | 0  |    |
| Reset |    |    |    |    |    |    |    |     |    |    |    |    |    | (  | )  |    |

**DOUT** Bit 32 to bit 35 of the RA1 3.6K uplink frame.

# CSD+0400h CSD RA1 3.6K Downlink Input Data Register 0

CSD\_RA1\_3P6 K DLDI0

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    | D  | IN |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | W  | 0  |    |    |    |    |    |    |    |
| Reset |    |    |    | 4  |    |    |    | (  | )  |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    | D  | IN |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | W  | 0  |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | (  | )  |    |    |    |    |    |    |    |
| Туре  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | _  |

Bit 0 to bit 31 of the RA1 3.6K downlink frame.

# CSD+0404h CSD RA1 3.6K Downlink Input Data Register 1

CSD\_RA1\_3P6 K DLDI1

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Туре  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |



| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2  | 1  | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|----|----|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | DI | IN |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | W  | 0  |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | (  | )  |   |

**DIN** Bit 32 to bit 35 of the RA1 3.6K downlink frame.

# CSD+0408h CSD RA1 3.6K Downlink Output Data Register 0

CSD\_RA1\_3P6
K DLDO0

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23                          | 22 | 21                                | 20                                  | 19                                  | 18                                                   | 17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 16                                           |  |  |
|----|----|----|----|----|----|----|----|-----------------------------|----|-----------------------------------|-------------------------------------|-------------------------------------|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|--|--|
|    |    |    |    |    |    |    |    |                             |    |                                   | DC                                  | UT                                  |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                              |  |  |
|    |    |    |    |    |    |    |    | RO                          |    |                                   |                                     |                                     |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                              |  |  |
|    |    |    |    |    |    |    |    |                             |    |                                   | -                                   | 0                                   |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                              |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                           | 6  | 5                                 | 4                                   | 3                                   | 2                                                    | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0                                            |  |  |
|    |    |    |    |    |    |    | DO | UT                          |    |                                   |                                     |                                     |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                              |  |  |
|    |    |    |    |    |    |    | R  | Р                           |    |                                   |                                     |                                     |                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                              |  |  |
| •  |    |    | •  | •  | •  |    | (  | )                           |    |                                   | •                                   |                                     | •                                                    | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | -                                            |  |  |
|    |    |    |    |    |    |    |    | 15 14 13 12 11 10 9 8<br>DO |    | 15 14 13 12 11 10 9 8 7 6<br>DOUT | 15 14 13 12 11 10 9 8 7 6 5<br>DOUT | 15 14 13 12 11 10 9 8 7 6 5 4  DOUT | DOUT RO 0 15 14 13 12 11 10 9 8 7 6 5 4 3  DOUT RP 0 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2  DOUT  DOUT  RO  0  15 The state of | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 |  |  |

**DIN** D1 to D24 of the RA1 3.6K downlink data.

# CSD+040Ch CSD RA1 3.6K Downlink Status Data Register

CSD\_RA1\_3P6 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  |    |    |    |    |    |    |    |    |    | <b>E7</b> | <b>E6</b> | <b>E</b> 5 | E4 | X  | SB | SA |
| Type  |    |    |    |    |    |    |    |    |    | RO        | RO        | RO         | RO | RO | RO | RO |
| Reset |    |    |    |    |    |    |    |    |    | Λ         | 0         | Λ          | 0  | 0  | 0  | 0  |

- **SA** The majority vote of the S1, S3, S6 and S8 status bits. If the vote is split, SA=0.
- SB The majority vote of the S4 and S9 status bits. If the vote is split, SB=0.
- X The majority vote of the two X bits in downlink frame. If the vote is split, X=0.
- **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\_FAX\_BR1

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

**DIN** 32-bit input data for a Type 1 bit reversal of the FAX data. A Type 1 bit reversal reverses the data bit by bit.

# 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.  |    |    |    |    |    |    | 1161 | UT |    |    |    |    |    |    |    |



|       | -  |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |
|-------|----|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| Type  |    |    |    |    |    |    |   | F | 30  |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   | 0   |   |   |   |   |   |   |   |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  |    |    |    |    |    |    |   | D | TUC |   |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   | F | 30  |   |   |   |   |   |   | 1 |
| Reset |    |    |    |    |    |    |   |   | 0   |   |   |   |   |   |   |   |

**DOUT** 32-bit result data for a Type 1 bit reversal of the FAX data.

#### 

CSD\_FAX\_BR2

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

**DIN** 32-bit input data for a Type 2 bit reversal of the FAX data. A Type 2 bit reversal reverses the data byte 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  |    |    |    |    |    |    |    | DO | UT         | 7/5 | ,  |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R  | 0          |     |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | (  | )          |     |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7          | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    | DO | UT         |     |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R  | 0          |     |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    | ) <u> </u> |     |    |    |    |    |    |    |

**DOUT** 32-bit result data for a Type 2 bit reversal of the FAX data.

# 5.3 FCS Codec

# 5.3.1 General Description

The Frame Check Sequence (FCS) serves to detect errors in the following information bits:

- RLP-frame of CSD services in GSM: The frame length is fixed at 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 bits.

Generation of the FCS is very similar to CRC coding in baseband signal processing. ETSI GSM specifications 04.22 and 04.64 both define the coding rules as:

- 1. The CRC is the one's complement of the modulo-2 sum of the following additives:
  - the remainder of  $x^k \cdot (x^{23} + x^{22} + x^{21} + ... + 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); and,



- 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 is appended to the data bits in the MSB-first manner. Decoding is identical to encoding except that data fed into the syndrome circuit is 24 bits longer than the information bits at encoding. The dividend is also multiplied by x<sup>24</sup>. If no error occurs, the remainder satisfies:

$$R(x) = x^{22} + x^{21} + x^{19} + x^{18} + x^{16} + x^{15} + x^{11} + x^{8} + x^{5} + x^{4}$$
(0x6d8930)

The parity output word is 0x9276cf.

In contrast to conventional CRC, this special coding scheme makes the encoder 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 |

The data bits input. First write of this register is the starting point of the encode or decode process.

**D0~15** The input format is D15· $x^n$ + D14· $x^{n-1}$ + D13· $x^{n-2}$ + ... + Dk· $x^k$ + ..., thus D15 is the first bit pushed into the shift register. If the last data word is less than 16 bits, the remaining 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** Data length. The length must be a multiple of 8 bits.

## FCS+0x0008h FCS parity output register 1, MSB part

FCS PAR1

| Bit   | 15  | 14  | 13  | 12  | 11  | 10  | 7_9        | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|-------|-----|-----|-----|-----|-----|-----|------------|----|----|----|----|----|----|----|----|----|
| Name  | P15 | P14 | P13 | P12 | P11 | P10 | <b>P</b> 9 | P8 | P7 | P6 | P5 | P4 | P3 | P2 | P1 | P0 |
| Type  | RC         | RC | RC | RC | RC | RC | RC | RC | RC | RC |
| Reset | 0   | 0   | 0   | 0   | 00  | 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 bit 15 are filled with zeros when reading.

P0~23 The output format is P23·D<sup>23</sup>+ P22·D<sup>22</sup>+ P21·D<sup>21</sup>+ ... + Pk·D<sup>k</sup>+ ...+P1·D<sup>1</sup>+P0, thus P23 is the first bit being popped out from the shift register and the 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 the parity bits appended to the data.

## FCS+0010h FCS codec status register

FCS STAT

|     |       | _   |     |    |    |     |    |   |   |   |     |   |   |     |    |     |     |
|-----|-------|-----|-----|----|----|-----|----|---|---|---|-----|---|---|-----|----|-----|-----|
|     |       | 4 5 | 7.4 | 10 | 10 | 4.4 | 10 | _ | _ |   | _   |   | 4 | _   | _  | -   | )   |
| 1 b | 3it 🥒 | 15  | 14  | 13 | 12 | 11  | 10 | 9 | 8 | / | 1 6 | 5 | 4 | - 3 | 12 | 1 1 | . 0 |
|     |       |     |     |    |    |     |    |   |   |   |     |   |   |     |    |     |     |
|     |       |     |     |    |    |     |    |   |   |   |     |   |   |     |    |     |     |



| Name  |  |  |  |  |  |  | BUSY | FER | RDY |
|-------|--|--|--|--|--|--|------|-----|-----|
| Type  |  |  |  |  |  |  | RC   | RC  | RC  |
| Reset |  |  |  |  |  |  | 0    | 1   | 0   |

- BUSY Indicates whether or not the current data work is available for writing. The codec works in a serial manner and the data word is input in a parallel manner. BUSY=1 indicates that the current data word is being processed and a write to FCS\_DATA is invalid: the operation is permitted but the data may not be consistent. BUSY=0 allows a write of FCS\_DATA during an encoding or decoding process.
- FER Frame error indication, for decode mode only. FER=0 means no error has occurred; FER=1 indicates the parity check has failed. Writing to FCS\_RST.RST or the first write to FCS\_DATA resets this bit to 0.
- When RDY=1, verify that the encode or decode process has been finished. For an encode, the parity data in FCS\_PAR1 and FCS\_PAR2 are available and consistent. For a decode, FCS\_STAT.FER indication is valid. A write of FCS\_RST.RST or the first write of FCS\_DATA resets 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  | PAR | BIT | RST |
| Type |    |    |    |    |    |    |   |   |   |   |   | WC  | WO  | WO  | WO  |

- RST = 0 resets the CRC coprocessor. Before setup of the FCS codec, the MCU needs to set RST=0 to flush the shift register content before encode or decode.
- BIT=0 signifies not to invert the bit order in a data word byte when the codec is running. BIT=1 signifies to reverse the bit order in a byte written in FCS\_DATA.
- PAR PAR=0 means not to invert the bit order in a byte of parity words when the codec is running, including reading FCS\_PAR1 and FCS\_PAR2. PAR=1 means the bit order of the parity words should be reversed, in encoding or decoding.
- **EN\_DE** EN DE=0 indicates an encode operation; EN DE=1 indicates a decode operation.

# 5.4 PPP Framer Coprocessor

# 5.4.1 General Description

The PPP Framer Coprocessor (PFC) is an accelerator for PPP frame parsing; it helps pack and unpack the PPP frame while performing:

- 1. Flag sequence (0x7e) recognition,
- 2. Byte stuffing handling, and
- 3. 16- or 32-bit frame check sequence (FCS) handling.

The PFC architecture is based on Direct Memory Access (DMA). All PPP framer parameters are configurable, such as Address and Control Field Compression (ACFC), Protocol Field Compression (PFC), 16- or 32-bit FCS, and Asynchronous Control Character Map (ACCM).

# 5.4.2 Register Definitions

| Register Address | Register Function     | Acronym   |
|------------------|-----------------------|-----------|
| PFC + 0000h      | PFC start register    | PFC_START |
| PFC + 0004h      | PFC control register  | PFC_CON   |
| PFC + 0008h      | PFC encoding protocol | PFC_EPTC  |



| PFC initial byte stuffing configuration for encoding | PFC_EACCM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PFC destination/source address                       | PFC_D/SRC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| PFC destination buffer/source operation length       | PFC_D/SLEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| PFC slow down rate                                   | PFC_SDRAT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| PFC status                                           | PFC_STAT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| PFC current source address in decoding mode          | PFC_DCSRC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| PFC current source address in encoding mode          | PFC_ECSRC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| PFC current destination address in decoding mode     | PFC_DCDES                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| PFC current destination address in encoding mode     | PFC_ECDES                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| PFC unread source data length in decoding mode       | PFC_DUSLEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| PFC unread source data length in encoding mode       | PFC_EUSLEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| PFC unused write buffer length in decoding mode      | PFC_DUDLEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| PFC unused write buffer length in encoding mode      | PFC_EUDLEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| PFC decoding protocol                                | PFC_DPTC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| PFC interrupt status                                 | PFC_INTSTA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| PFC interrupt enable                                 | PFC_INTEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                      | PFC destination/source address  PFC destination buffer/source operation length  PFC slow down rate  PFC status  PFC current source address in decoding mode  PFC current source address in encoding mode  PFC current destination address in decoding mode  PFC current destination address in encoding mode  PFC unread source data length in decoding mode  PFC unread source data length in encoding mode  PFC unused write buffer length in decoding mode  PFC unused write buffer length in encoding mode  PFC unused write buffer length in encoding mode  PFC interrupt status |

**Table 35** PFC Registers

## PFC+0000h PFC start register

PFC\_START

| Bit   | 15 | 14 | 13 | 12 | 11         | 10         | 9          | 8    | 7          | 6          | 5    | 4    | 3          | 2          | 1         | 0          |
|-------|----|----|----|----|------------|------------|------------|------|------------|------------|------|------|------------|------------|-----------|------------|
| Name  |    |    |    |    | ELAS<br>TD | ELAS<br>TS | DSET<br>7E | DF7E | EUPD<br>EL | DUPD<br>EL | ECLR | DCLR | EUPS<br>RL | DUPS<br>RL | NADD<br>R | DEL/<br>ST |
| 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          |

Start register for PPP framer coprocessor.

**DEL/ST**When this bit is enabled, the PFC is started up; otherwise, the DES and DLEN statuses are updated.

**NADDR** When NADDR is asserted, PFC updates only DSLEN and bypasses DSRC when updating source or destination information.

**DUPSRL** Force an update of the decoding register set for SRC and SLEN. This bit only takes effect when DEL/ST is enabled. If this bit is disabled, the operation uses the old settings, i.e., CSRC and USLEN.

**EUPSRL** Force an update of the encoding register set for SRC and SLEN. This bit only takes effect when DEL/ST is enabled. If this bit is disabled, the operation uses the old settings, i.e., CSRC and USLEN.

**DCLR** Reset all decoding states and return to the initial state.

**ECLR** Reset all encoding states and return to the initial state.

DUPDEL Force an update of the decoding register set for DES and DLEN. This bit only takes effect when DEL/ST is disabled. After asserting this bit, a de-assert should follow immediately (in the next instruction cycle). Note: The result depends on the ENC bit. Only one of the encoder and decoder parts changes.

EUPDEL Force an update of the encoding register set for DES and DLEN. This bit only takes effect when DEL/ST is disabled. After asserting this bit, a de-assert should follow immediately (in the next instruction cycle). Note: The result depends on the ENC bit. Only one of the encoder and decoder parts changes.

**DF7E** In decoding mode, if PFC starts with DF7E enabled, PFC does nothing until a 0x7e byte is found.

**DSET7E** In decoding mode, set 0x7e-found mode.

**ELASTS** End the process (append the FCS and flag sequence on last) after source data has run out.



**ELASTD** End the process (append the FCS and flag sequence on last) after the destination buffer is full. The buffer may have a 0- to 4-byte space, depending on byte-stuffing conditions of FCS and the last encoded character.

# PFC+0004h PFC control register

PFC CON

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6    | 5    | 4         | 3    | 2    | 1         | 0   |
|-------|----|----|----|----|----|----|---|---|------|------|------|-----------|------|------|-----------|-----|
| Name  |    |    |    |    |    |    |   |   | EDEL | DF32 | DPFC | DACF<br>C | EF32 | EPFC | EACF<br>C | ENC |
| Type  |    |    |    |    |    |    |   |   | R/W  | R/W  | R/W  | R/W       | R/W  | R/W  | R/W       | R/W |
| Reset |    |    |    |    |    |    |   |   | 1    | 0    | 0    | 0         | 0    | 0    | 0         | 0   |

Control register for PPP framer coprocessor.

**ENC** Encode bit. If enabled, this operation is encoding; otherwise the operation is decoding.

EACFC Address and Control Field Compression in encoding mode. This Configuration Option provides a method to negotiate the compression of the Data Link Layer Address and Control fields. By default, all implementations MUST transmit frames with Address and Control fields appropriate to the link framing. When the Address and Control fields are compressed, the Data Link Layer FCS field is calculated based on the compressed frame, not the original uncompressed frame.

PPP Protocol Field Compression in encoding mode. PPP Protocol field numbers are chosen such that some values may be compressed into a single octet form that is clearly distinguishable from the two-octet form. This Configuration Option is sent to inform the peer that the implementation can receive such single octet Protocol fields. When a Protocol field is compressed, the Data Link Layer FCS field is calculated on the compressed frame, not the original uncompressed frame.

**EF32** Use FCS32 in encoding mode.

**DACFC**Use Address and Control Field Compression in decoding mode.

**DPFC** Use Protocol Field Compression in decoding mode.

**DF32** Use FCS32 in decoding mode.

**EDEL** Escape DEL(0x7f) in encoding mode.

# PFC+0008h PFC encoding protocol

**PFC EPTC** 

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

**EPTC** Encoding protocol. This register contains the protocol field value for encoding a frame. Writing 8 or 16 bits depends on the EPFC bit. An 8-bit protocol uses LSB.

# PFC+000ch PFC byte stuffing configuration for encoding

PFC EACCM

| Bit   | 31 | 30 | 29 | 28 | 27           | 26 | 25 | 24           | 23                    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|--------------|----|----|--------------|-----------------------|----|----|----|----|----|----|----|
| Name  |    | -  | -  |    |              |    | -  | EACC         | / <mark>[31:16</mark> | ]  | -  |    |    | -  |    | -  |
| Type  |    |    |    |    |              |    |    | R            | /W                    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |              |    |    | 0x           | rffff                 |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | D <u>/11</u> | 10 | 9  | 8            | 7                     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |              |    |    | <b>EACCI</b> | M[15:0]               |    |    |    |    |    |    |    |
| Type  |    |    |    |    |              |    |    | R            | /W                    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |              |    |    | 0x           | dfff                  |    |    |    |    |    |    |    |

**EACCM** This byte stuffing control register is for encoding. Each bit of the 32-bit byte stuffing configuration indicates whether or not to enable the byte stuffing option if that byte value is encountered during encoding or decoding.

For example, if bit 7 is set to 1 (enabled), then each byte 0x7 encountered is encoded as  $\{0x7d, 0x27\}$ , i.e. a 0x7d byte followed by the byte (here, 0x7) XOR'ed with 0x20. Similarly, if bit 0 is enabled,  $\{0x7d, 0x20\}$  is decoded into 0x00 by ignoring 0x7d and obtaining 0x20 XOR 0x20 = 0x0.



## PFC+0010h PFC destination/source address

## PFC D/SRC

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

**D/SRC** When DEL/ST is disabled, D/SRC is the destination address to load when UPDEL is enabled. When DEL/ST is enabled, D/SRC is the source address for PFC operation.

### PFC+0014h PFC destination/source operation length

## PFC D/SLEN

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

D/SLEN When DEL/ST is disabled, D/SLEN is the destination buffer length. When DEL/ST is enabled, D/SLEN is the source length for the PFC operation. Note: Zero length is not allowed in decoding mode. A zero length when encoding results in padding FCS and 0x7e directly regardless of whether or not the ELAST bit is asserted.

### PFC+0018h PFC slow down rate

# PFC\_SDRAT

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

SDRAT Slow down the PFC to prevent too many requests for AHB resources. Each unit increment translates into a 4-cycle delay for each bus access (read or write). The range of SDRAT is from 0 (no delay) to 255 (255\*4=1020 cycles' delay).

### PFC+001ch PFC return status

## **PFC STAT**

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3               | 2    | 1     | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-----------------|------|-------|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |                 | STAT | [3:0] |   |
| Туре  |    |    |    |    |    |    |   |   |   |   |   |   | STAT[3:0]<br>RO |      |       |   |
| Reset |    |    |    |    |    |    | V |   |   |   |   |   | 0               |      |       |   |

STAT Current status of PFC. 0000b: OK. 0001b: BUSY. 0010b: write buffer full. 0011b: zero source length in decoding. 0100b: FCS error in decoding mode. 0101b: not starting with 0x7e byte in decoding mode. 0110b: address or control field error in decoding mode. 0111b:Invalid frame due to 0x7d, 0x7e sequence occurred. 1000b: RESUME stat, wait for next last or non-last operation.

## PFC+0020h PFC current source address in decoding

## PFC\_DCSRC

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

**DCSRC** CSRC is the current source address in the PFC in decoding mode.

# PFC+0024h PFC current source address in encoding

|                        | <u> </u> | -   | $\sim$ |
|------------------------|----------|-----|--------|
| $\mathbf{P}\mathbf{F}$ |          | - ( | SHU    |
|                        | •        |     | ,,,,   |

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



| Name  |    |    |    |    |    |    |   | ECSR | C[31:16 | ] |   |   |   |   |   |   | ٦ |
|-------|----|----|----|----|----|----|---|------|---------|---|---|---|---|---|---|---|---|
| Type  |    |    |    |    |    |    |   | I    | 30      |   |   |   |   |   |   |   | 1 |
| Reset |    |    |    |    |    |    |   |      | 0       |   |   |   |   |   |   |   | _ |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7 |
| Name  |    |    |    |    |    |    |   | ECSF | C[15:0] |   |   |   |   |   |   |   | 1 |
| Type  |    |    |    |    |    |    |   | ſ    | 30      |   |   |   |   |   |   |   |   |
| Reset |    | •  | •  |    |    |    |   | •    | 0       |   |   |   |   |   |   |   | 1 |

**ECSRC** CSRC is the current source address in the PFC in encoding mode.

## PFC+0028h PFC current destination address in decoding

|  | DC | DEC |
|--|----|-----|
|  | טע | レヒシ |

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23      | 22 | 21 | 20 | 19           | 18  | 17 | 16 |
|-------|----|----|----|----|----|----|----|-------|---------|----|----|----|--------------|-----|----|----|
| Name  |    |    |    | -  | -  | _  |    | DCDES | [31:16] |    | -  | -  | -            |     |    | -  |
| Type  |    |    |    |    |    |    |    | R     | 0       |    |    |    |              | N O |    |    |
| Reset |    |    |    |    |    |    |    | (     | )       |    |    |    |              |     |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7       | 6  | 5  | 4  | 3            | 2   | 1  | 0  |
| Name  |    |    |    |    |    |    |    | DCDES | S[15:0] |    |    |    |              |     |    |    |
| Type  |    |    |    |    |    |    |    | R     | 0       |    |    |    | 8            |     |    |    |
| Reset |    |    |    |    |    |    |    | (     | )       |    |    |    | $\mathbf{W}$ |     |    |    |

DCDES CDES is the current destination address in the PFC in decoding mode.

# PFC+002ch PFC current destination address in encoding

PFC\_ECDES

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

**ECDES** CDES is the current destination address in the PFC in encoding mode.

## PFC+0030h PFC unread source data length in decoding

**PFC DUSLEN** 

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 8   | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|-------|--------|---|---|---|---|---|---|---|
| Name  |    | _  | -  | -  | _  |    | DUSLE | N[15:0 | ] | - | _ | - | _ | _ | _ |
| Type  |    |    |    |    |    |    | F     | Ю      |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |       | 0      |   |   |   |   |   |   |   |

**DUSLEN** DUSLEN is the unread source data length in decoding mode.

# PFC+0034h PFC unread source data length in encoding

**PFC EUSLEN** 

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

**EUSLEN** Unread source data length in encoding mode.

# PFC+0038h PFC unused destination buffer length in decoding

PFC DUDLEN

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|------|---------|---|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   | UDLE | N[15:0] |   |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |   | R    | 0       |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   | C    | )       |   |   |   |   |   |   |   |

**DUDLEN** Unused write buffer space length in decoding mode.

# PFC+003ch PFC unused destination buffer length in encoding

PFC\_EUDLEN

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|------|---------|---|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    |   | UDLE | N[15:0] |   |   |   |   |   |   |   |
| Туре  |    |    |    |    |    |    |   | R    | 0       |   |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |   | C    | )       |   |   |   |   |   |   |   |



**EUDLEN** Unused write buffer space length in encoding mode.

# PFC+0040h PFC decoding protocol

PFC DPTC

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

**DPTC** Decoding protocol. This register contains the protocol field value decoded from a frame. Writing 8 or 16 bits depends on the DPFC bit. An 8-bit protocol uses LSB.

# PFC+0044h PFC interrupt status

**PFC INTSTA** 

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

INTSTA Interrupt status. Bit 0 indicates that PFC finished with OK or RESUME state. Bit 1 indicates that PFC failed. Further error information can be obtained from PFC STAT.

## PFC+0048h PFC interrupt enable

PFC\_INTEN

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | Ī        | 4 🗵 | 3 | 2 | 1   | 0  |
|-------|----|----|----|----|----|----|---|---|---|---|---|----------|-----|---|---|-----|----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |          |     |   |   | INT | EN |
| Type  |    |    |    |    |    |    |   |   |   |   |   | $\Gamma$ |     |   |   | R/  | W  |
| Reset |    |    |    |    |    |    |   |   |   |   |   |          |     | • |   | (   | )  |

**INTEN** Interrupt enable control register. When bit 0 is enabled, an interrupt occurs when PFC finishes in the OK or RESUME state. If bit 1 is enabled, PFC interrupts if an error occurs.

## 5.4.3 MRU

When a PPP task wants to transmit a set of raw data through the network, the data must be encoded first (**Figure 63**). In process A, the raw data is prefixed with an Address (0xff) and Control (0x03) field\* (AC), followed by Protocol field\*\* (PTC). An FCS is appended\*\*\*.

In process B, the data stream resulting from process A is byte-stuffed. A 0x7e byte is then added both at the front and at the end of the byte-stuffed stream.



Figure 63 Basic PFC Flow

\* The Control field depends on the DACFC, EACFC, and EACCM bits.



\*\* The Protocol field depends on the DPTC and EPTC bits.

\*\*\* The FCS field depends on the DF32 and EF32 bits.

Figure 64 shows the resulting PPP frame.

| Flag     | Address  | Control  | Protocol  | Information | Padding | FCS        | Flag     |
|----------|----------|----------|-----------|-------------|---------|------------|----------|
| 01111110 | 11111111 | 00000011 | 8/16 bits | *           | *       | 16/32 bits | 01111110 |

Figure 64 PPP Frame Structure



# 6 Multi-Media Subsystem

MT6228 is a highly integrated Baseband/Multimedia single chip. It integrates several hardware-based multimedia accelerators to enable rich multimedia application. Hardware accelerators include Image signal processor, Image resizer, JPEG Codec, MPEG-4 Codec, GIF Decoder, PNG Decoder, 2D graphics engine, TV encoder, and advanced hardware LCD display controller. A lot of attractive multimedia functions can be realized through above hardware accelerators in MT6228. The functions include camera function, JPEG/GIF/PNG image playback, MPEG-4 video recording, MPEG-4 video playback, TV out, 2D graphics acceleration, and so on. Image data paths of multi-media sub-system are shown in **Figure 1-1**. Hardware data paths and Image DMA are designed to make data transfer more efficient. MT6228 also incorporates NAND Flash, USB 1.1 OTG Controller and SD/SDIO/MMC/MS/MS Pro Controllers for mass data transfers and storage.



Figure 6-1 Image Data Path of Multi-media Sub-system

# 6.1 LCD Interface

# 6.1.1 General Description

MT6228 contains a versatile LCD controller, which is optimized for multimedia applications. This controller supports many types of LCD modules and contains a rich feature set to enhance the functionality. These features are:

- Up to 320 x 240 resolution
- The internal frame buffer supports 8bpp indexed color, RGB 565, RGB 888 and ARGB 8888 format.
- Supports 8-bpp (RGB332), 12-bpp (RGB444), 16-bpp (RGB565), 18-bit (RGB666) and 24-bit (RGB888) LCD modules.
- 6 Layers Overlay with individual color depth, window size, vertical and horizontal offset, source key, alpha value and display rotation control(90°,180°, 270°, mirror and mirror then 90°, 180° and 270°)
- One color look-up table of 24bpp



For parallel LCD modules, the LCD controller can reuse external memory interface or use dedicated 8/9/16/18-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 format serial interface is supported. The 8-bit format serial interface uses four pins – LSCE#, LSDA, LSCK and LSA0 – to enter commands and data. Meanwhile, the 9-bit format 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.

Data and command send to LCM are always through the parallel Nandflash/Lcd interface or through serial SPI/LCD interface. Sending LCM signals through EMI is forbidden, but the pixel data produced by LCD controller can be dumped to memory through AHB bus.



Figure 2 LCD Interface Block Diagram

**Figure 3** 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 remain LOW for the duration of the transmission.





Figure 3 Serial LCD Interface Transfer Timing Diagram

## $LCD = 0x9000\_0000$

| Address     | Register Function                                  | Width | Acronym         |
|-------------|----------------------------------------------------|-------|-----------------|
| LCD + 0000h | LCD Interface Status Register                      | 16    | LCD_STA         |
| LCD + 0004h | LCD Interface Interrupt Enable Register            | 16    | LCD_INTEN       |
| LCD + 0008h | LCD Interface Interrupt Status Register            | 16    | LCD_INTSTA      |
| LCD + 000ch | LCD Interface Frame Transfer Register              | 16    | LCD_START       |
| LCD + 0010h | LCD Parallel/Serial LCM Reset Register             | 16    | LCD_RSTB        |
| LCD + 0014h | LCD Serial Interface Configuration Register        | 16    | LCD_SCNF        |
| LCD + 0018h | LCD Parallel Interface 0 Configuration Register    | 32    | LCD_PCNF0       |
| LCD + 001ch | LCD Parallel Interface 1 Configuration Register    | 32    | LCD_PCNF1       |
| LCD + 0020h | LCD Parallel Interface 2 Configuration Register    | 32    | LCD_PCNF2       |
| LCD + 0040h | LCD Main Window Size Register                      | 32    | LCD_MWINSIZE    |
| LCD + 0044h | LCD ROI Window Write to Memory Offset Register     | 32    | LCD_WROI_W2MOFS |
| LCD + 0048h | LCD ROI Window Write to Memory Control<br>Register | 16    | LCD_WROI_W2MCON |
| LCD + 004ch | LCD ROI Window Write to Memory Address<br>Register | 32    | LCD_WROI_W2MADD |
| LCD + 0050h | LCD ROI Window Control Register                    | 32    | LCD_WROICON     |
| LCD + 0054h | LCD ROI Window Offset Register                     | 32    | LCD_WROIOFS     |
| LCD + 0058h | LCD ROI Window Command Start Address Register      | 16    | LCD_WROICADD    |
| LCD + 005ch | LCD ROI Window Data Start Address Register         | 16    | LCD_WROIDADD    |
| LCD + 0060h | LCD ROI Window Size Register                       | 32    | LCD_WROISIZE    |
| LCD + 0064h | LCD ROI Window Hardware Refresh Register           | 32    | LCD_WROI_HWREF  |
| LCD + 0068h | LCD ROI Window Background Color Register           | 32    | LCD_WROI_BGCLR  |
| LCD + 0070h | LCD Layer 0 Window Control Register                | 32    | LCD_L0WINCON    |
| LCD + 0074h | LCD Layer 0 Source Color Key Register              | 32    | LCD_L0WINSKEY   |
| LCD + 0078h | LCD Layer 0 Window Display Offset Register         | 32    | LCD_L0WINOFS    |
| LCD + 007ch | LCD Layer 0 Window Display Start Address Register  | 32    | LCD_L0WINADD    |
| LCD + 0080h | LCD Layer 0 Window Size                            | 32    | LCD_L0WINSIZE   |



| MEDIATEK               |                                                   |    |               |
|------------------------|---------------------------------------------------|----|---------------|
| LCD + 0090h            | LCD Layer 1 Window Control Register               | 32 | LCD_L1WINCON  |
| LCD + 0094h            | LCD Layer 1 Source Color Key Register             | 32 | LCD_L1WINSKEY |
| LCD + 0098h            | LCD Layer 1 Window Display Offset Register        | 32 | LCD_L1WINOFS  |
| LCD + 009ch            | LCD Layer 1 Window Display Start Address Register | 32 | LCD_L1WINADD  |
| LCD + 00a0h            | LCD Layer 1 Window Size                           | 32 | LCD_L1WINSIZE |
| LCD + 00b0h            | LCD Layer 2 Window Control Register               | 32 | LCD_L2WINCON  |
| LCD + 00b4h            | LCD Layer 2 Source Color Key Register             | 32 | LCD_L2WINSKEY |
| LCD + 00b8h            | LCD Layer 2 Window Display Offset Register        | 32 | LCD_L2WINOFS  |
| LCD + 00bch            | LCD Layer 2 Window Display Start Address Register | 32 | LCD_L2WINADD  |
| LCD + 00c0h            | LCD Layer 2 Window Size                           | 32 | LCD_L2WINSIZE |
| LCD + 00d0h            | LCD Layer 3 Window Control Register               | 32 | LCD_L3WINCON  |
| LCD + 00d4h            | LCD Layer 3 Source Color Key Register             | 32 | LCD_L3WINSKEY |
| LCD + 00d8h            | LCD Layer 3 Window Display Offset Register        | 32 | LCD_L3WINOFS  |
| LCD + 00dch            | LCD Layer 3 Window Display Start Address Register | 32 | LCD_L3WINADD  |
| LCD + 00e0h            | LCD Layer 3 Window Size                           | 32 | LCD_L3WINSIZE |
| LCD + 00f0h            | LCD Layer 4 Window Control Register               | 32 | LCD_L4WINCON  |
| LCD + 00f4h            | LCD Layer 4 Source Color Key Register             | 32 | LCD_L4WINSKEY |
| LCD + 00f8h            | LCD Layer 4 Window Display Offset Register        | 32 | LCD_L4WINOFS  |
| LCD + 00fch            | LCD Layer 4 Window Display Start Address Register | 32 | LCD_L4WINADD  |
| LCD + 0100h            | LCD Layer 4 Window Size                           | 32 | LCD_L4WINSIZE |
| LCD + 0110h            | LCD Layer 5 Window Control Register               | 32 | LCD_L5WINCON  |
| LCD + 0114h            | LCD Layer 5 Source Color Key Register             | 32 | LCD_L5WINSKEY |
| LCD + 0118h            | LCD Layer 5 Window Display Offset Register        | 32 | LCD_L5WINOFS  |
| LCD + 011ch            | LCD Layer 5 Window Display Start Address Register | 32 | LCD_L5WINADD  |
| LCD + 0120h            | LCD Layer 5 Window Size                           | 32 | LCD_L5WINSIZE |
| LCD + 4000h            | LCD Parallel Interface 0 Data                     | 32 | LCD_PDAT0     |
| LCD + 4100h            | LCD Parallel Interface 0 Command                  | 32 | LCD_PCMD0     |
| LCD + 5000h            | LCD Parallel Interface 1 Data                     | 32 | LCD_PDAT1     |
| LCD + 5100h            | LCD Parallel Interface 1 Command                  | 32 | LCD_PCMD1     |
| LCD + 6000h            | LCD Parallel Interface 2 Data                     | 32 | LCD_PDAT2     |
| LCD + 6100h            | LCD Parallel Interface 2 Command                  | 32 | LCD_PCMD2     |
| LCD + 8000h            | LCD Serial Interface 1 Data                       | 16 | LCD_SDAT1     |
| LCD + 8100h            | LCD Serial Interface 1 Command                    | 16 | LCD_SCMD1     |
| LCD + 9000h            | LCD Serial Interface 0 Data                       | 16 | LCD_SDAT0     |
| LCD + 9100h            | LCD Serial Interface 0 Command                    | 16 | LCD_SCMD0     |
| LCD + c800h<br>~ cbfch | LCD Color Palette LUT Register                    | 32 | LCD_PAL       |
| LCD + cc00h<br>~ ccfch | LCD Interface Command/Parameter Register          | 32 | LCD_COMD      |



# 6.1.2 Table 36 Memory map of LCD InterfaceRegister 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                 | $\sqrt{0}$ |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|-------------------|-------------------|------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   | CMD_<br>CPEN<br>D | DATA<br>_PEN<br>D | RUN        |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | R                 | R                 | R          |
| 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  |    |    |    |    |    |    |   |   |   |   |   |     |   | CMD_<br>CPL | DATA<br>_CPL | CPL |
| Type  |    |    |    |    |    |    |   |   |   |   |   |     |   | R/W         | R/W          | R/W |
| Reset | ,  |    |    |    |    |    |   |   |   |   |   | 947 |   | 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  |    |    |    |    |    |    |   |   |   |    |   |   |   | CMD_<br>CPL | DATA<br>_CPL | CPL |
| Type  |    |    |    |    |    |    |   |   |   |    |   |   |   | R           | R            | R   |
| 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  | STAR<br>T |    |    |    | X  |      |   |   |   |   |   |   |   |   |   |
| Туре  | 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 26M | 13M |    |    |    |    | CSP1 | CSP0 |   |   |   | 8/9 | D | IV | SPH | SPO |





| Ту | ре | R/W | R/W |  |  | R/W | R/W |  | R/W | R/W | R/W | R/W |
|----|----|-----|-----|--|--|-----|-----|--|-----|-----|-----|-----|
| Ty | ре | 0   | 0   |  |  | 0   | 0   |  | 0   | 0   | 0   | 0   |

SPO Clock Polarity ControlSPH Clock Phase Control

Serial Clock Divide Select Bits8/98-bit or 9-bit Interface Selection

CSP0 Serial Interface Chip Select 0 Polarity ControlCSP1 Serial Interface Chip Select 1 Polarity Control

# LCD +0018h LCD Parallel Interface Configuration Register 0

LCD\_PCNF0

| Bit   | 31  | 30  | 29  | 28 | 27 | 26  | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17 | 16 |
|-------|-----|-----|-----|----|----|-----|----|----|----|----|----|----|----|-----|----|----|
| Name  | C2' | WS  | C2\ | WΗ |    | C2  | RS |    |    |    |    |    |    |     | D' | W  |
| 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  | 26M | 13M |     |    |    | WST |    |    |    |    |    |    |    | RLT |    |    |
| Type  | R/W | R/W |     |    |    | R/W |    |    |    |    |    |    |    | R/W |    |    |
| Reset | 0   | 0   |     |    | •  | 0   |    | •  | _  |    |    |    |    | 0   | •  |    |

**RLT** Read Latency Time

WST Write Wait State Time

Enable 13MHz clock gating.Enable 26MHz clock gating.

**DW** Data width of the parallel interface.

**00** 8-bit.**01** 9-bit**10** 16-bit

10 16-bit 11 18-bit

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 +001Ch LCD Parallel Interface Configuration Register 1

LCD PCNF1

| Bit   | 31  | 30  | 29  | 28 | 27 | 26  | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17 | 16 |
|-------|-----|-----|-----|----|----|-----|----|----|----|----|----|----|----|-----|----|----|
| Name  | C2' | WS  | C2\ | WH |    | C2F | RS |    |    |    |    |    |    |     | D' | W  |
| Type  | R/  | W   | R/  | W  |    | R/V | N  |    |    |    |    |    |    |     | R/ | W  |
|       | (   | )   | (   | )  |    | 0   |    |    |    |    |    |    |    |     | (  | )  |
| Bit   | 15  | 14  | 13  | 12 | 11 | 10  | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2   | 1  | 0  |
| Name  | 26M | 13M |     |    |    | WST |    |    |    |    |    |    |    | RLT |    |    |
| Type  | R/W | R/W |     |    |    | R/W |    |    |    |    |    |    |    | R/W |    |    |
| Reset | 0   | 0   |     | _  |    | 0   |    |    |    |    |    |    |    | 0   |    |    |

211/616

**RLT** Read Latency Time

**WST** Write Wait State Time

13M Enable 13MHz clock gating.26M Enable 26MHz clock gating.

**DW** Data width of the parallel interface.

00 8-bit.

**01** 9-bit

**10** 16-bit

**11** 18-bit

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 +0020h LCD Parallel Interface Configuration Register 2

LCD PCNF2

| Bit   | 31  | 30  | 29  | 28 | 27  | 26  | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17      | 16 |
|-------|-----|-----|-----|----|-----|-----|----|----|----|----|----|----|----|-----|---------|----|
| Name  | C2' | WS  | C21 | WH |     | C2  | RS |    |    |    |    |    |    |     | D<br>R/ | W  |
| Type  | R/  | W   | R/  | W  |     | R   | /W |    |    |    |    |    |    |     | R/      | W  |
|       | (   | )   | (   | )  |     | (   | 0  |    |    |    |    |    |    |     |         |    |
| Bit   | 15  | 14  | 13  | 12 | 11  | 10  | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2   | _ 1     | 0  |
| Name  | 26M | 13M |     |    |     | WST |    |    |    |    |    |    |    | RLT |         |    |
| Type  | R/W | R/W |     |    |     | R/W |    |    |    |    |    |    |    | R/W |         |    |
| Reset | 0   | 0   |     |    | 0 H |     |    |    |    |    |    |    |    |     |         |    |

**RLT** Read Latency Time

**WST** Write Wait State Time

**13M** Enable 13MHz clock gating.

**26M** Enable 26MHz clock gating.

**DW** Data width of the parallel interface.

**00** 8-bit.

**01** 9-bit

**10** 16-bit

**11** 18-bit

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 +4000h LCD Parallel 0 Interface Data

LCD PDAT0

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

**DATA** Writing to LCD+4000 will drive LPA0 low when sending this data out in parallel BANK0, while writing to LCD+4100 will drive LPA0 high.

# LCD +5000h LCD Parallel 1 Interface Data

**LCD PDAT1** 

| 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 4 | <u> 11</u> | 10 | 9  | 8    | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |      |            |    |    | DATA | [15:0]  |    |    |    |    |    |    |    |
| Type |    |    |    |      |            |    |    | R    | /W      |    |    |    |    |    |    |    |

**DATA** Writing to LCD+5000 will drive LPA1 low when sending this data out in parallel BANK1, while writing to LCD+5100 will drive LPA1 high

## 

LCD PDAT2

| 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       |    |    |    |    |    |    | ·  |



**DATA** Writing to LCD+6000 will drive LPA2 low when sending this data out in parallel BANK2, while writing to LCD+6100 will drive LPA2 high

LCD

# +8000/8100h LCD Serial Interface 1 Data

LCD SDAT1

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3 | 2 | 1 | 0_ |
|------|----|----|----|----|----|----|---|---|---|---|---|----|---|---|---|----|
| Name |    |    |    |    |    |    |   |   |   |   |   | DA |   |   |   |    |
| Type |    |    |    |    |    |    |   |   |   |   |   | V  | V |   |   |    |

DATA Writing to LCD+8000 will drive LSA0 low while sending this data out in serial BANK1, while writing to LCD+8100 will drive LSA0 high

**LCD** 

# +9000/9100h LCD Serial Interface 0 Data

LCD\_SDAT0

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 |     | 2 | 1 | 0 |
|------|----|----|----|----|----|----|---|---|---|---|---|---|-----|---|---|---|
| Name |    |    |    |    |    |    |   |   |   |   |   | D | ATA |   |   |   |
| Type |    |    |    |    |    |    |   |   |   |   |   |   | w T |   |   |   |

**DATA** Writing to LCD+9000 will drive LSA0 low while sending this data out in serial BANK0, while writing to LCD+9100 will drive LSA0 high

# LCD +0040h Main Window Size Register

LCD\_MWINSIZE

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

**COLUMN** 10-bit Virtual Image Window Column Size

**ROW** 10-bit Virtual Image Window Row Size

# LCD +0044h Region of Interest Window Write to Memory Offset LCD\_WROI\_W2 Register MOFS

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

This control register is used to specify the offset of the ROI window from the LCD\_WROI\_W2MADDR when writing the ROI window's content to memory.

**X-OFFSET** the x offset of ROI window in the destination memory.

**Y-OFFSET** the y offset of ROI window in the destination memory.

# LCD +0048h Region of Interest Window Write to Memory Control LCD\_WROI\_W2 Register MOON

| Bit           | 15 14 | <u> 13</u> | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2          | 1                  | 0         |
|---------------|-------|------------|----|----|----|---|---|---|---|---|---|---|------------|--------------------|-----------|
| Name          |       |            |    |    |    |   |   |   |   |   |   |   | DISC<br>ON | W2M_<br>FORM<br>AT | W2L<br>CM |
| Type          |       |            |    |    |    |   |   |   |   |   |   |   | R/W        | R/W                | R/W       |
| Type<br>Reset |       |            |    |    |    |   |   |   |   |   |   | _ | 0          | 0                  | 0         |



This control register is effective only when the W2M bit is set in LCD\_WROICON register.

**W2LCM** Write to LCM simultaneously.

**W2M\_FORMAT** Write to memory format.

**0** RGB565

1 RGB888

DISCON Block Write Enable Control. By setting both DISCON and W2M to 1, the LCD controller will write out the ROI pixel data as a part of MAIN window, using the width of MAIN window to calculate the write-out address. If this bit is not set, the ROI window will be written to memory in continuous addresses.

# LCD +004Ch Region of Interest Window Write to Memory Address Register

LCD\_WROI\_W2 MADD

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

**W2M\_ADDR** Write to memory address.

# LCD +0050h Region of Interest Window Control Register

LCD\_WROICO

| Bit  | 31  | 30  | 29  | 28  | 27  | 26   | 25 | 24 | 23 | $\perp \overline{22}$ | 21  | 20  | 19  | 18 | 17 | 16 |
|------|-----|-----|-----|-----|-----|------|----|----|----|-----------------------|-----|-----|-----|----|----|----|
| Name | EN0 | EN1 | EN2 | EN3 | EN4 | EN5  |    |    |    |                       | PER | IOD |     |    |    |    |
| Type | 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 | ENC | W2M |     |     | COM | MAND |    |    |    |                       |     | FOR | MAT |    |    |    |
| Туре | R/W | R/W |     |     | R/  | W    |    |    |    |                       |     | R/  | W   |    |    |    |

FORMAT LCD Module Data Format

Bit 0: in BGR sequence, otherwise in RGB sequence.

Bit 1: LSB first, otherwise MSB first.

Bit 2: padding bits on MSBs, otherwise on LSBs.

Bit 5-3:000 for RGB332, 001 for RGB444, 010 for RGB565, 011 for RGB666, 100 for RGB888.

Bit 7-6:00 for 8-bit interface, 01 for 16-bit interface, 10 for 9-bit interface, 11 for 18-bit interface.

Note: When the interface is configured as 9 bit or 18 bit, the field of bit5-2 is ignored.

| 00000000 | 8bit | 1cycle/1pixel | RGB3.3.2 | RRRGGGBB |
|----------|------|---------------|----------|----------|
| 00000001 |      | 1cycle/1pixel | RGB3.3.2 | BBGGGRRR |
| 00001000 |      | 3cycle/2pixel | RGB4.4.4 | RRRRGGGG |
|          |      |               |          | BBBBRRRR |
|          |      |               |          | GGGGBBBB |
| 00001011 |      | 3cycle/2pixel | RGB4.4.4 | GGGGRRRR |
|          |      |               |          | RRRRBBBB |
| A        |      |               |          | BBBBGGGG |
| 00010000 |      | 2cycle/1pixel | RGB5.6.5 | RRRRGGG  |
|          |      |               |          | GGGBBBBB |
| 00010011 |      | 2cycle/1pixel | RGB5.6.5 | GGGRRRRR |
|          |      |               |          | BBBBBGGG |
| 00011000 |      | 3cycle/1pixel | RGB6.6.6 | RRRRRXX  |



|       | 1                           |                                                                                                                                                                                | CCCCCCVV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                             |                                                                                                                                                                                | GGGGGXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       |                             |                                                                                                                                                                                | BBBBBBXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       | 3cycle/1pixel               | RGB6.6.6                                                                                                                                                                       | XXRRRRR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       |                             |                                                                                                                                                                                | XXGGGGG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       |                             |                                                                                                                                                                                | XXBBBBBB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       | 3cycle/1pixel               | RGB8.8.8                                                                                                                                                                       | RRRRRRR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       |                             |                                                                                                                                                                                | GGGGGGG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|       |                             |                                                                                                                                                                                | ВВВВВВВВ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 9bit  | 2cycle/1pixel               | RGB6.6.6                                                                                                                                                                       | RRRRRGGG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       |                             |                                                                                                                                                                                | GGGBBBBBB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|       | 2cycle/1pixel               | RGB6.6.6                                                                                                                                                                       | GGGRRRRR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       |                             |                                                                                                                                                                                | BBBBBBGGG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 16bit | 1cycle/2pixel               | RGB3.3.2                                                                                                                                                                       | RRRGGGBBRRRGGGBB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       | 1cycle/2pixel               | RGB3.3.2                                                                                                                                                                       | RRRGGGBBRRRGGGBB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       | 1cycle/2pixel               | RGB3.3.2                                                                                                                                                                       | BBGGGRRBBGGGRRR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       | 1cycle/2pixel               | RGB3.3.2                                                                                                                                                                       | BBGGGRRRBBGGGRRR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       | 1cycle/1pixel               | RGB4.4.4                                                                                                                                                                       | XXXXRRRRGGGGBBBB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       | 1cycle/1pixel               | RGB4.4.4                                                                                                                                                                       | XXXXBBBBGGGGRRRR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       | 1cycle/1pixel               | RGB4.4.4                                                                                                                                                                       | RRRRGGGGBBBBXXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       | 1cycle/1pixel               | RGB4.4.4                                                                                                                                                                       | BBBBGGGRRRRXXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       | 1cycle/1pixel               | RGB5.6.5                                                                                                                                                                       | RRRRGGGGGBBBBB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       | 1cycle/1pixel               | RGB5.6.5                                                                                                                                                                       | BBBBBGGGGGRRRRR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       | 3cycle/2pixel               | RGB6.6.6                                                                                                                                                                       | XXXXRRRRRRGGGGGG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       |                             |                                                                                                                                                                                | XXXXBBBBBBRRRRRR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       |                             |                                                                                                                                                                                | XXXXGGGGGGBBBBBB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       | 3cycle/2pixel               | RGB6.6.6                                                                                                                                                                       | XXXXGGGGGGRRRRRR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       |                             |                                                                                                                                                                                | XXXXRRRRRRBBBBB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       |                             |                                                                                                                                                                                | XXXXBBBBBBGGGGG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       | 3cycle/2pixel               | RGB6.6.6                                                                                                                                                                       | RRRRRGGGGGXXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       |                             |                                                                                                                                                                                | BBBBBBRRRRRXXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       |                             |                                                                                                                                                                                | GGGGGBBBBBBXXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       | 3cycle/2pixel               | RGB6.6.6                                                                                                                                                                       | GGGGGRRRRRXXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       | . 0                         |                                                                                                                                                                                | RRRRRBBBBBBXXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       |                             |                                                                                                                                                                                | BBBBBBGGGGGXXXX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       | 3cycle/2pixel               | RGB8.8.8                                                                                                                                                                       | RRRRRRRGGGGGGG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       |                             |                                                                                                                                                                                | BBBBBBBBRRRRRRR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       |                             |                                                                                                                                                                                | GGGGGGGBBBBBBBB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|       |                             |                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| -6    | 3cycle/2pixel               | RGB8.8.8                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6     | 3cycle/2pixel               | RGB8.8.8                                                                                                                                                                       | GGGGGGGRRRRRRR<br>RRRRRRRBBBBBBB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Co    | 3cycle/2pixel               | RGB8.8.8                                                                                                                                                                       | GGGGGGGRRRRRRR<br>RRRRRRRBBBBBBB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 18bit | 3cycle/2pixel 1cycle/1pixel | RGB8.8.8<br>RGB6.6.6                                                                                                                                                           | GGGGGGGRRRRRRR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       |                             | 2cycle/1pixel  16bit 1cycle/2pixel 1cycle/2pixel 1cycle/2pixel 1cycle/2pixel 1cycle/1pixel 1cycle/1pixel 1cycle/1pixel 1cycle/1pixel 1cycle/1pixel 1cycle/1pixel 3cycle/2pixel | 9bit 2cycle/1pixel RGB8.8.8    Public Properties of the properties |

**COMMAND** Number of Commands to be sent to LCD module. Maximum is 63.

**W2M** Enable Data Address Increasing After Each Data Transfer

**ENC** Command Transfer Enable Control

**PERIOD** Waiting period between two consecutive transfers, effective for both data and command.

**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 LCD\_WROICAD Register D

| Bit  | 15   | 14  | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3             | 2 | 1 | 0 |
|------|------|-----|----|----|----|----|---|---|---|---|---|---|---------------|---|---|---|
| Name | ADDR |     |    |    |    |    |   |   |   |   |   |   |               |   |   |   |
| Type |      | R/W |    |    |    |    |   |   |   |   |   |   | $\mathbf{U}'$ |   |   | - |

**ADDR** ROI Window Command Address. Only writing to LCD modules is allowed.

# LCD +005Ch Region of Interest Window Data Start Address Register

LCD\_WROIDAD

D

| 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 Only writing to LCD modules is allowed.

## 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 |    |    |    |    |    |    |        |    |    |    | RC | W  |    |    |    |    |  |  |
| 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 (width)

**ROW** ROI Window Row Size (height)

# LCD +0064h Region of Interest Window Hardware Refresh Register

LCD\_WROI\_HW

REF

| Bit   | 31  | 30  | 29                  | 28  | 27  | 26  | 25 | 24 | 23          | 22          | 21          | 20          | 19          | 18          | 17 | 16        |
|-------|-----|-----|---------------------|-----|-----|-----|----|----|-------------|-------------|-------------|-------------|-------------|-------------|----|-----------|
| Name  | EN0 | EN1 | EN2                 | EN3 | EN4 | EN5 |    |    | IMGD<br>MA0 | IMGD<br>MA1 | IMGD<br>MA2 | IMGD<br>MA3 | IMGD<br>MA4 | IMGD<br>MA5 |    |           |
| 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           |    |           |
| Bit   | 15  | 14  | 13                  | 12  | 11  | 10  | 9  | 8  | 7           | 6           | 5           | 4           | 3           | 2           | 1  | 0         |
|       |     |     | IMGD<br>MA_S<br>EL2 |     |     |     |    |    | HWE<br>N    |             |             |             |             |             |    | HWR<br>EF |
| 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         |

**ENn** Enable layer n source address from Image\_DMA.

**IMGDMA***n* Enable layer n source data from Image\_DMA.

**IMGDMA SELn**Select layer n read from Image\_DMA0 or Image\_DMA1.



• Image\_DMA0.

1 Image\_DMA1

**HWEN** Enable hardware triggered LCD fresh.

**HWREF** Starting the hardware triggered LCD frame transfer.

### LCD +0068h Region of Interest Background Color Register

LCD\_WROI\_BG

CLR

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

**RED** Red component of ROI window's background color

**GREEN**Green component of ROI window's background color

**BLUE** Blue component of ROI window's background color

### LCD +0070h Layer 0 Window Control Register

LCD\_LOWINCO

N

| Bit  | 31  | 30        | 29 | 28     | 27 | 26 | 25  | 24        | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  |
|------|-----|-----------|----|--------|----|----|-----|-----------|----|----|----|----|----|----|----|-----|
| Name |     |           |    |        |    |    |     |           |    |    |    |    |    |    |    | SWP |
| Type |     |           |    |        |    |    |     |           |    |    |    |    |    |    |    | R/W |
| Bit  | 15  | 14        | 13 | 12     | 11 | 10 | 9   | 8         | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0   |
| Name | SRC | KEYE<br>N | F  | ROTATE |    |    | DPT | OPAE<br>N |    |    |    | OF | PA |    |    |     |
| Type | R/W | R/W       |    | R/W    |    | R/ | W   | R/W       |    |    |    | R/ | W  |    |    |     |

**OPA** Opacity value, used as constant alpha value.

**OPAEN** Opacity enabled

**CLRDPT** Color format

00 8bpp indexed color.

**01** RGB 565

**10** ARGB 8888

11 RGB 888

**ROTATE** Rotation Configuration

**000** 0 degree rotation

001 90 degree rotation anti-counterclockwise

**010** 180 degree rotation anti-counterclockwise

**011** 270 degree rotation anti-counterclockwise

100 Horizontal flip

**101** Horizontal flip then 90 degree rotation anti-counterclockwise

110 Horizontal flip then 180 degree rotation anti-counterclockwise

111 Horizontal flip then 270 degree rotation anti-counterclockwise

**KEYEN** Source Key Enable Control

**SRC** Disable auto-increment of the source pixel address

**SWP** Swap high byte and low byte of pixel data



### LCD +0074h Layer 0 Source Color Key Register

### **LCD LOWINSK**

ΕΥ

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

**SRCKEY** Transparent color key of the source image.

### LCD +0078h Layer 0 Window Display Offset Register

LCD\_LOWINOF

S

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

Y-OFFSET Layer 0 Window Row Offset

X-OFFSET Layer 0 Window Column Offset

### LCD+007Ch Layer 0 Window Display Start Address Register

LCD\_LOWINAD

D

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

**ADDR** Layer 0 Window Data Address

## LCD +0080h Layer 0 Window Size

LCD\_LOWINSIZ

Ε

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

**ROW** Layer 0 Window Row Size

**COLUMN** Layer 0 Window Column Size

### LCD +0090h Layer 1 Window Control Register

LCD\_L1WINCO

Ν

| Bit  | 31  | 30        | 29 | 28    | 27 | 26  | 25  | 24        | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  |
|------|-----|-----------|----|-------|----|-----|-----|-----------|----|----|----|----|----|----|----|-----|
| Name |     |           |    |       |    |     |     |           |    |    |    |    |    |    |    | SWP |
| Type |     |           |    |       |    |     |     |           |    |    |    |    |    |    |    | R/W |
| Bit  | 15  | 14        | 13 | 12    | 11 | 10  | 9   | 8         | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0   |
| Name | SRC | KEYE<br>N | F  | ROTAT | E  | CLR | DPT | OPAE<br>N |    |    |    | O  | PA |    |    |     |
| Type | R/W | R/W       |    | R/W   |    | R/  | W   | R/W       |    |    |    | R/ | W  |    |    |     |



**OPA** Opacity value, used as constant alpha value.

**OPAEN** Opacity enabled

**CLRDPT** Color format

**00** 8bpp indexed color.

01 RGB 565

**10** ARGB 8888

**11** RGB 888

**ROTATE** Rotation Configuration

**000**0 degree rotation

001 90 degree rotation anti-counterclockwise

010 180 degree rotation anti-counterclockwise

**011** 270 degree rotation anti-counterclockwise

100 Horizontal flip

**101** Horizontal flip then 90 degree rotation anti-counterclockwise

**110** Horizontal flip then 180 degree rotation anti-counterclockwise

111 Horizontal flip then 270 degree rotation anti-counterclockwise

**Layer 1 Source Color Key Register** 

**KEYEN** Source Key Enable Control

LCD +0094h

**SRC** Disable auto-increment of the source pixel address

**SWP** Swap high byte and low byte of pixel data

### LCD\_L1WINSK

EY

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

**SRCKEY** Transparent color key of the source image.

## LCD +0098h Layer 1 Window Display Offset Register

LCD\_L1WINOF

5

| Bit  | 31 | 30 | 29 | 28 | 27       | 26 | 25       | 24 | 23 | 22 | 21   | 20   | 19 | 18 | 17 | 16               |
|------|----|----|----|----|----------|----|----------|----|----|----|------|------|----|----|----|------------------|
| Name |    |    |    |    | <b>.</b> |    | <u> </u> |    |    |    | Y-OF | FSET |    |    |    |                  |
| Type |    |    |    |    |          |    |          |    |    |    | R/   | W    |    |    |    |                  |
| Bit  | 15 | 14 | 13 | 12 | 11       | 10 | 9        | 8  | 7  | 6  | 5    | 4    | 3  | 2  | 1  | 0                |
| Name |    |    |    |    |          |    |          |    |    |    | X-OF | FSET |    |    |    |                  |
| Type |    |    |    | 4  |          | >  |          | •  |    |    | R/   | W    | •  | •  |    | , and the second |

Y-OFFSET Layer 1 Window Row Offset

X-OFFSET Layer 1 Window Column Offset

### LCD+009Ch Layer 1 Window Display Start Address Register

LCD\_L1WINAD

D

| Bit  | 31 | 30  | 29            | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|-----|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |    | 7.2 | $\overline{}$ |    |    |    |    | AD | DR |    |    |    |    |    |    |    |
| Type |    |     |               |    |    |    |    | R/ | W  |    |    |    |    |    |    |    |
| Bit  | 15 | 14  | 13            | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | 46 |     |               |    |    |    |    | AD | DR |    |    |    |    |    |    |    |
| Type |    |     |               |    |    |    |    | R/ | W  |    |    |    |    |    |    |    |



**ADDR** Layer 1 Window Data Address

### LCD +00A0h Layer 1 Window Size

## LCD\_L1WINSIZ

F

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

**ROW** Layer 1 Window Row Size

**COLUMN** Layer 1 Window Column Size

### LCD +00B0h 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 |     |           |    |        |    |    |     |           |    |    |    |     |    |    |    | SWP |
| Type |     |           |    |        |    |    |     |           |    |    |    |     |    |    |    | R/W |
| Bit  | 15  | 14        | 13 | 12     | 11 | 10 | 9   | 8         | 7  | 6  | 5  | 4   | 3  | 2  | 1  | 0   |
| Name | SRC | KEYE<br>N | F  | ROTATE |    |    | DPT | OPAE<br>N |    |    | 0  | OF  | A  |    |    |     |
| Type | R/W | R/W       |    | R/W    |    |    | W   | R/W       |    |    |    | R/\ | W  |    |    |     |

**OPA** Opacity value, used as constant alpha value.

**OPAEN** Opacity enabled

**CLRDPT** Color format

00 8bpp indexed color.

01 RGB 565

10 ARGB 8888

11 RGB 888

**ROTATE** Rotation Configuration

**000**0 degree rotation

001 90 degree rotation anti-counterclockwise

**010** 180 degree rotation anti-counterclockwise

**011** 270 degree rotation anti-counterclockwise

100 Horizontal flip

**101** Horizontal flip then 90 degree rotation anti-counterclockwise

110 Horizontal flip then 180 degree rotation anti-counterclockwise

111 Horizontal flip then 270 degree rotation anti-counterclockwise

KEYEN Source Key Enable Control

**SRC** Disable auto-increment of the source pixel address

**SWP** Swap high byte and low byte of pixel data

## LCD +00B4h Layer 2 Source Color Key Register

LCD L2WINSK

ΕY

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



**SRCKEY** Transparent color key of the source image.

### LCD +00B8h Layer 2 Window Display Offset Register

LCD\_L2WINOF

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

Y-OFFSET Layer 2 Window Row Offset

X-OFFSET Layer 2 Window Column Offset

### LCD+00BCh Layer 2 Window Display Start Address Register

LCD\_L2WINAD

D

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

**ADDR** Layer 1 Window Data Address

### LCD +00C0h Layer 2 Window Size

**LCD L2WINSIZ** 

Ε

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                       | 23 | 22 | 21  | 20  | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|--------------------------|----|----|-----|-----|----|----|----|----|
| Name |    |    |    |    |    |    |    | 4                        |    |    | RC  | W   |    |    |    |    |
| Type |    |    |    |    |    |    |    |                          |    |    | R/  | W   |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                        | 7  | 6  | 5   | 4   | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    | $\overline{\mathcal{M}}$ |    |    | COL | UMN |    |    |    |    |
| Type |    |    |    |    |    |    |    |                          | ,  |    | R/  | W   |    |    |    |    |

**ROW** Layer 2 Window Row Size

**COLUMN** Layer 2 Window Column Size

## LCD +00D0h Layer 3 Window Control Register

LCD\_L3WINCO

N

| Bit  | 31  | 30        | 29 | 28     | 27  | 26  | 25  | 24        | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  |
|------|-----|-----------|----|--------|-----|-----|-----|-----------|----|----|----|----|----|----|----|-----|
| Name |     |           |    |        |     |     |     |           |    |    |    |    |    |    |    | SWP |
| Type |     |           |    |        |     |     |     |           |    |    |    |    |    |    |    | R/W |
| Bit  | 15  | 14        | 13 | 12     | [ स | 10  | 9   | 8         | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0   |
| Name | SRC | KEYE<br>N | F  | ROTATE |     | CLR | DPT | OPAE<br>N |    |    |    | OF | PA |    |    |     |
| Type | R/W | R/W       |    | R/W    |     | R/  | W   | R/W       |    |    |    | R/ | W  |    |    |     |

**OPA** Opacity value, used as constant alpha value.

**OPAEN** Opacity enabled

**CLRDPT** Color format

**00** 8bpp indexed color.

**01** RGB 565

**10** ARGB 8888

11 RGB 888

**ROTATE** Rotation Configuration



**000**0 degree rotation

001 90 degree rotation anti-counterclockwise

010 180 degree rotation anti-counterclockwise

**011** 270 degree rotation anti-counterclockwise

100 Horizontal flip

**101** Horizontal flip then 90 degree rotation anti-counterclockwise

110 Horizontal flip then 180 degree rotation anti-counterclockwise

111 Horizontal flip then 270 degree rotation anti-counterclockwise

**KEYEN** Source Key Enable Control

**SRC** Disable auto-increment of the source pixel address

**SWP** Swap high byte and low byte of pixel data

### LCD +00D4h Layer 3 Source Color Key Register

LCD\_L3WINSK

EY

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

**SRCKEY** Transparent color key of the source image.

### LCD +00D8h Layer 3 Window Display Offset Register

LCD\_L3WINOF

S

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24      | 23 | 22 | 21   | 20   | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|---------|----|----|------|------|----|----|----|----|
| Name |    |    |    |    |    |    |    |         |    |    | Y-OF | FSET |    |    |    |    |
| Type |    |    |    |    |    |    |    |         |    |    | R/   | W    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8 _     | 7. | 6  | 5    | 4    | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    | $\pi$ 7 |    |    | X-OF | FSET |    |    |    |    |
| Type |    |    |    |    |    |    |    |         |    |    | R/   | W    |    |    |    |    |

Y-OFFSET Layer 3 Window Row Offset

X-OFFSET Layer 3 Window Column Offset

## LCD+00DCh Layer 3 Window Display Start Address Register

LCD\_L3WINAD

....D

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

**ADDR** Layer 3 Window Data Address

### LCD +00E0h Layer 3 Window Size

LCD\_L3WINSIZ

Ε

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



**ROW** Layer 3 Window Row Size

**COLUMN** Layer 3 Window Column Size

### LCD +00F0h Layer 4 Window Control Register

LCD\_L4WINCO

N

| Bit  | 31  | 30        | 29 | 28    | 27 | 26  | 25  | 24        | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16_ |
|------|-----|-----------|----|-------|----|-----|-----|-----------|----|----|----|----|----|----|----|-----|
| Name |     |           |    |       |    |     |     |           |    |    |    |    |    |    |    | SWP |
| Type |     |           |    |       |    |     |     |           |    |    |    |    |    |    |    | R/W |
| Bit  | 15  | 14        | 13 | 12    | 11 | 10  | 9   | 8         | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0   |
| Name | SRC | KEYE<br>N | F  | OTATI | E  | CLR | DPT | OPAE<br>N |    |    |    | OF | PA |    |    |     |
| Type | R/W | R/W       |    | R/W   |    | R/  | W   | R/W       |    |    |    | R/ | W  |    |    |     |

**OPA** Opacity value, used as constant alpha value.

**OPAEN** Opacity enabled

**CLRDPT** Color format

**00** 8bpp indexed color.

01 RGB 565

**10** ARGB 8888

**11** RGB 888

**ROTATE** Rotation Configuration

**000** 0 degree rotation

001 90 degree rotation anti-counterclockwise

**010** 180 degree rotation anti-counterclockwise

**011** 270 degree rotation anti-counterclockwise

100 Horizontal flip

**101** Horizontal flip then 90 degree rotation anti-counterclockwise

**110** Horizontal flip then 180 degree rotation anti-counterclockwise

111 Horizontal flip then 270 degree rotation anti-counterclockwise

**KEYEN** Source Key Enable Control

**SRC** Disable auto-increment of the source pixel address

**SWP** Swap high byte and low byte of pixel data

### LCD +00F4h Layer 4 Source Color Key Register

LCD\_L4WINSK

| Bit  | 31 | 30 | 29 | 28            | 27 | 26 | 25 | 24    | 23      | 22       | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|---------------|----|----|----|-------|---------|----------|----|----|----|----|----|----|
| Name |    |    |    |               |    |    | S  | RCKE' | Y[31:16 | <u>[</u> |    |    |    |    |    |    |
| Type |    |    |    |               |    |    |    | R/    | W       |          |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12            | 11 | 10 | 9  | 8     | 7       | 6        | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |               |    |    | ,  | SRCKE | Y[15:0  |          |    |    |    |    |    |    |
| Type |    |    |    | $\Box$ $\Box$ |    |    |    | R/    | W       |          |    |    |    |    |    |    |

**SRCKEY** Transparent color key of the source image.

## **LCD** +00F8h Layer 4 Window Display Offset Register

LCD\_L4WINOF

S

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



Y-OFFSET Layer 4 Window Row Offset

X-OFFSET Layer 4 Window Column Offset

### LCD+00FCh Layer 4 Window Display Start Address Register

LCD\_L4WINAD

D

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

**ADDR** Layer 4 Window Data Address

### LCD +0100h Layer 4 Window Size

LCD L4WINSIZ

Ē

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

**ROW** Layer 4 Window Row Size

**COLUMN** Layer 4 Window Column Size

## LCD +0110h Layer 5 Window Control Register

LCD\_L5WINCO

N

| Bit  | 31  | 30        | 29 | 28     | 27       | 26  | 25  | 24        | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  |
|------|-----|-----------|----|--------|----------|-----|-----|-----------|----|----|----|----|----|----|----|-----|
| Name |     |           |    |        |          |     |     |           |    |    |    |    |    |    |    | SWP |
| Type |     |           |    |        |          |     |     |           |    |    |    |    |    |    |    | R/W |
| Bit  | 15  | 14        | 13 | 12     | 11       | 10  | 9   | 8         | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0   |
| Name | SRC | KEYE<br>N | F  | ROTATI | <b>E</b> | CLR | DPT | OPAE<br>N |    |    |    | O  | PA |    |    |     |
| Type | R/W | R/W       |    | R/W    |          | R/  | W   | R/W       |    |    |    | R/ | W  |    |    |     |

**OPA** Opacity value, used as constant alpha value.

**OPAEN** Opacity enabled

**CLRDPT** Color format

**00** 8bpp indexed color.

01 RGB 565

**10** ARGB 8888

**11** RGB 888

**ROTATE** Rotation Configuration

**000**0 degree rotation

001 90 degree rotation anti-counterclockwise

**010** 180 degree rotation anti-counterclockwise

011 270 degree rotation anti-counterclockwise

100 Horizontal flip

**101** Horizontal flip then 90 degree rotation anti-counterclockwise

110 Horizontal flip then 180 degree rotation anti-counterclockwise

111 Horizontal flip then 270 degree rotation anti-counterclockwise



**KEYEN** Source Key Enable Control

**SRC** Disable auto-increment of the source pixel address

**SWP** Swap high byte and low byte of pixel data

### LCD +0114h Layer 5 Source Color Key Register

LCD\_L5WINSK

EY

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

**SRCKEY** Transparent color key of the source image.

### LCD +0118h Layer 5 Window Display Offset Register

LCD\_L5WINOF

S

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

Y-OFFSET Layer 5 Window Row Offset

X-OFFSET Layer 5 Window Column Offset

### LCD+011Ch Layer 5 Window Display Start Address Register

LCD\_L5WINAD

D

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

**ADDR** Layer 5 Window Data Address

## LCD +0120h Layer 5 Window Size

LCD\_L5WINSIZ

Е

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

**ROW** Layer 5 Window Row Size

**COLUMN**Layer 5 Window Column Size

LCD

+C800h~CBFCh LCD Interface Color Palette LUT Registers

LCD PAL

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |    |    |    |    |    |    |    | LU | JT |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R/ | W  |    |    |    |    |    |    |    |



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

**LUT** These Bits Set LUT Data in RGB565 Format

| LCD | <u>'</u> |      |
|-----|----------|------|
| +CC | 00h~     | CCFC |

### **LCD Interface Command/Parameter Registers**

LCD\_COMD

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

**COMM** Command Data and Parameter Data for LCD Module

Write to ROI Command Address if C0 = 1, otherwise write to ROI Data Address

### 6.2 NAND FLASH interface

## 6.2.1 General description

MT6228 provides NAND flash interface.

The NAND FLASH interface support features as follows:

- ECC (Hamming code) acceleration capable of one-bit error correction or two bits error detection.
- Programmable ECC block size. Support 1, 2 or 4 ECC block within a page.
- Word/byte access through APB bus.
- Direct Memory Access 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.
- Support page size: 512(528) bytes and 2048(2112) bytes.
- Support 2 chip select for NAND flash parts.
- Support 8/16 bits I/O interface.

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 operating 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 or detecting two bits error within one ECC block.



## 6.2.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  |   |
|-------|----|----|----|----|----|----|-----|---|----|----|----|---|----|----|----|---|
| Name  |    |    |    |    |    |    | C2R |   | W: | 2R | W  |   | W  |    | RI | T |
| Type  |    |    |    |    |    |    | R/W |   | R/ | W  | R/ | W | R/ | /W | R/ | W |
| Reset |    |    |    |    |    |    | 0   |   | (  | )  | (  | ) |    | )  |    |   |

This is the timing access control register for the NAND FLASH interface. In order to accommodate operations for different system clock frequency ranges 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  |    |    |    |    |       |    |   | B16E<br>N |   | EC | CBLKS | IZE |   | ADRM<br>ODE | PSI | ZE |
| Type  |    |    |    |    |       |    |   | R/W       |   |    | R/W   |     |   | R/W         | R/  | W  |
| Reset |    |    |    |    |       |    |   | 0         |   |    | 0     |     |   | 0           | C   | )  |

This register manages the page format of the device. It includes the bus width selection, the page size, the associated address format, and the ECC block size.

**B16EN** 16 bits I/O bus interface enable.

**ECCBLKSIZE** ECC block size.

This field represents the size of one ECC block. The hardware-fuelled ECC generation provides 2 or 4 blocks within a single page.

**O** ECC block size: 128 bytes. Used for devices with page size equal to 512 bytes.

1 ECC block size: 256 bytes. Used for devices with page size equal to 512 bytes.



- ECC block size: 512 bytes. Used for devices with page size equal to 512 (1 ECC block) or 2048 bytes (4 ECC blocks).
- **3** ECC block size: 1048 bytes. Used for devices with page size equal to 2048 bytes.
- 4~ Reserved.

#### **ADRMODE** Address mode. This field specifies the input address format.

- O 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 37, 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 38**, A11 to A0 identifies the byte address within a page. The mode is used for the device with 2048 bytes page size and 8bits I/O interface.
- 2 Large size input address mode. As in **Table 38**, A10 to A0 identifies the column address within a page. The mode is used for the device with 2048 byte page size and 16bits I/O interface.

|              | NLD7 | NLD6 | NLD5 | NLD4 | NLD3 | NLD2 | NLD1 | NLD0 |
|--------------|------|------|------|------|------|------|------|------|
| First cycle  | A7   | A6   | A5   | A4   | A3   | A2 - | A1   | A0   |
| Second cycle | A16  | A15  | A14  | A13  | A12  | A11  | A10  | A9   |

**Table 37** Page address assignment of the first type (ADRMODE = 0)

|              | NLD7 | NLD6 | NLD5 | NLD4 | NLD3        | NLD2 | NLD1 | NLD0 |
|--------------|------|------|------|------|-------------|------|------|------|
| First cycle  | A7   | A6   | A5   | A4   | $\sqrt{A3}$ | A2   | A1   | A0   |
| Second cycle | 0    | 0    | 0    | 0    | A11         | A10  | A9   | A8   |

**Table 38** Page address assignment of the second type (ADRMODE = 1 or 2)

#### **PSIZE** Page Size.

The field specifies the size of one page for the device. Two most widely used page size are supported.

- **0** The page size is 512 bytes or 528 bytes (including 512 bytes data area and 16 bytes spare area).
- 1 The page size is 2048 bytes or 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  |    |    | NC | )B | ۵.  |    | <u> </u> | SRD |   |   | EWR | ERD |   |   | BWR | BRD |
| Туре  |    |    | W  | /R | FX. |    |          | WO  |   |   | WO  | WO  |   |   | R/W | R/W |
| Reset |    |    | (  | )  |     |    |          | 0   |   |   | 0   | 0   |   |   | 0   | 0   |

This register controls the burst mode and the single 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 less than 4 bytes of data to be accessed.

BRD Burst read mode. Setting this field to be logic-1 enables the data read operation. The NFI core will issue read cycles to retrieve data from the device 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 to 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 inactive 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.



**BWR** Burst write mode. Setting to be logic-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. But if DMA is to be utilized, the bit should be enabled. If DMA is not to be utilized, the bit didn't have to be enabled.

**ERD** *ECC read mode.* Setting to be logic-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 logic-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 Setting to be logic-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.

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

- 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  |    |    |    |    |    |    |   |   |   |   |   | - 2 | CI | /ID |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | 7.0 | R/ | W   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   | 1 |     | 4  | 5   |   |   |   |

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 | <u> 8</u> | $\mathbb{Z}^{2}$ | 7 | 6 | 5 | 4 | 3 | 2  | 1    | 0  |
|-------|----|----|----|----|----|----|---|-----------|------------------|---|---|---|---|---|----|------|----|
| Name  |    |    |    |    |    |    |   |           |                  |   |   |   |   |   | AD | DR_N | OB |
| 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 to be used and what commands to be applied. The NFI core is made transparent to those different situations except that the user has to define the number of bytes.

The user should write the target address to the address register **NFI ADDRL** before programming this register.

**ADDR NOB** Number of bytes for the address

#### NFI +0014h Least significant address register

**NFI ADDRL** 

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

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.

**ADDRO** 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  |    |    |    |    |    |    |   |   |   |   |   | ADI | DR4 |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | R/  | W   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   | (   | )   |   |   |   |

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 1 | 9   1 | 8 | 17 | 16 |
|-------|----|----|----|----|-----------|----|----|----|----|----|----|------|-------|---|----|----|
| Name  |    |    |    | D۱ | N3        |    |    |    |    |    |    | DW2  |       |   |    |    |
| Type  |    |    |    | R/ | W         |    |    |    |    |    |    | R/W  |       |   |    |    |
| Reset |    |    |    | (  | )         |    |    |    |    |    |    | 0    |       |   |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11        | 10 | 9  | 8  | 7  | 6  | 5_ | 4 3  | 2     |   | 1  | 0  |
| Name  |    |    |    | D۱ | <b>V1</b> |    |    |    |    |    |    | DW0  |       |   |    |    |
| Type  |    |    |    | R/ | W         |    |    |    |    |    | 4  | 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. Be reminded 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 | <u> </u> | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|-------|----|----|----|----|----------|----|---|---|---|---|---|----|----|---|---|---|
| Name  |    |    |    |    |          |    |   |   |   |   |   | DV | V0 |   |   |   |
| Type  |    |    |    |    |          |    |   |   |   |   |   | R/ | W  |   |   |   |
| Reset |    |    |    |    |          |    |   |   |   |   |   | (  | )  |   |   |   |

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  |    |    |    | DI | R3 |    |    |    |    |    |    | DF | R2 |    |    |    |
| Type  |    |    |    | R  | 0  |    |    |    |    |    |    | R  | 0  |    |    |    |
| Reset |    |    |    | (  | )  |    |    |    |    |    |    | C  | )  |    |    |    |



MEDIATEK

| Bit   | 15 | 14 | 13 | 12 | 11             | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3              | 2 | 1 | 0 |
|-------|----|----|----|----|----------------|----|---|---|---|---|---|----|----------------|---|---|---|
| Name  |    |    |    | DF | <del>?</del> 1 |    |   |   |   |   |   | DF | <del>7</del> 0 |   |   |   |
| Type  |    |    |    | R  | 0              |    |   |   |   |   |   | R  | 0              |   |   |   |
| Reset |    |    |    | (  | )              |    |   |   |   |   |   | (  | )              |   |   |   |

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 +0028h Read data buffer for byte access

NFI\_DATARB

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

This is the read port of the data FIFO for byte access.

#### NFI +002Ch NFI status

**NFI PSTA** 

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7 | 6 | 5 | 7/ | 4 | 3         | 2         | 1    | 0   |
|-------|----|----|----|----|----|----|---|------|---|---|---|----|---|-----------|-----------|------|-----|
| Name  |    |    |    |    |    |    |   | BUSY |   | 0 | 7 |    |   | DATA<br>W | DATA<br>R | ADDR | CMD |
| Type  |    |    |    |    |    |    |   | RO   |   |   |   |    |   | R/W       | R/W       | R/W  | R/W |
| Reset |    |    |    |    |    |    |   | 0*   |   |   |   |    |   | 0         | 0         | 0    | 0   |

This register represents 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.

\*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** Synchronized busy signal from the NAND flash. It's read-only.

**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  |    |    |    |    |    |    |   |   |   |   | RESE<br>T | FLUS<br>H | WR_F<br>ULL | WR_E<br>MPTY | _  | RD_E<br>MPTY |
| 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 state 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  | BYTE<br>_RW |    |    |    | MULT<br>IPAG<br>E_CO<br>N | READ<br>_CON | PROG<br>RAM_<br>CON | ERAS<br>E_CO<br>N |   |   | SW_P<br>ROGS<br>PARE<br>_EN | I_PA | ECC_ | 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               | 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 logic-1 represents enabled, while 0 represents disabled.

**BYTE RW** Enable APB byte access.

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

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

**SW\_PROGSPARE\_EN** If enabled, the NFI core allows the user to program or read the spare area directly. 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, the mode can't be enabled since the core can't 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 |    | ERAS<br>E_CO<br>MPLE<br>TE |    |    | RD O E |
| 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      |

The register indicates the status of all the interrupt sources. Read this register will clear all interrupts.

**BUSY RETURN** Indicates that the device state returns from busy by inspecting the R/B# pin.

**ERR COR3** Indicates that the single bit error in ECC block 3 needs to be corrected.

**ERR\_COR2** Indicates that the single bit error in ECC block 2 needs to be corrected.



**ERR\_COR1** Indicates that the single bit error in ECC block 1 needs to be corrected.

**ERR\_COR0** Indicates that the single bit error in ECC block 0 needs to be corrected.

**ERR\_DET3** Indicates an uncorrectable error in ECC block 3.

**ERR DET2** Indicates an uncorrectable error in ECC block 2.

**ERR DET1** Indicates an uncorrectable error in ECC block 1.

**ERR DETO** Indicates an uncorrectable error in ECC block 0.

**ERASE\_COMPLETE**RESET\_COMPLETE

WR\_COMPLETE

Indicates that the erase operation is completed.

Indicates that the reset operation is completed.

Indicates that the write operation is completed.

**RD\_COMPLETE** 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 | ERR_<br>COR3<br>_EN | ERR_<br>COR2<br>_EN | ERR_<br>COR1<br>_EN |    | ERR_<br>DET3<br>_EN | ERR_<br>DET2<br>_EN | ERR_<br>DET1<br>_EN |   |   | BUSY<br>_RET<br>URN_<br>EN | ERR_<br>COR_<br>EN | ERR_<br>DET_<br>EN | ERAS<br>E_CO<br>MPLE<br>TE_E<br>N | RESE<br>T_CO<br>MPLE<br>TE_E<br>N | WR_C<br>OMPL<br>ETE_<br>EN | RD_<br>COM<br>PLET<br>E_EN |
| Туре | 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                        |
| Rese | 0                   | 0                   | 0                   |    | 0                   | 0                   | 0                   |   |   | 0                          | 0                  | 7 O <u>/</u>       | 0                                 | 0                                 | 0                          | 0                          |

This register controls the activity for the interrupt sources.

**ERR\_COR1\_EN** The error correction interrupt enable for the 2<sup>nd</sup> ECC block.

**ERR\_COR2\_EN** The error correction interrupt enable for the 3<sup>rd</sup> ECC block.

**ERR\_COR3\_EN** The error correction interrupt enable for the 4<sup>th</sup> ECC block.

**ERR\_DET1\_EN** The error detection interrupt enable for the 2<sup>nd</sup> ECC block.

**ERR\_DET2\_EN** The error detection interrupt enable for the 3<sup>rd</sup> ECC block.

**ERR DET3 EN** The error detection interrupt enable for the 4<sup>th</sup> ECC block.

**BUSY RETURN EN** The busy return interrupt enable.

**ERR\_COR\_EN** The error correction interrupt enable for the 1<sup>st</sup> ECC block.

**ERR\_DET\_EN** The error detection interrupt enable for the 1<sup>st</sup> ECC block.

**ERASE\_COMPLETE\_EN** The erase completion interrupt enable.

**RESET\_COMPLETE\_EN** The reset completion interrupt enable.

**WR\_COMPLETE\_EN** The single page write completion interrupt enable.

**RD COMPLETE EN**The single page read completion interrupt enable.

#### NFI+0040h NAND flash page counter

NFI\_PAGECNT

R

| Bit   | 15 | 14 | 13 | 12 | 11              | 10       | 9 | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|-------|----|----|----|----|-----------------|----------|---|---|---|---|---|----|----|---|---|---|
| Name  |    |    |    |    |                 | <b>)</b> |   |   |   |   |   | CN | TR |   |   |   |
| Type  |    |    |    |    | $1\overline{1}$ |          |   |   |   |   |   | R/ | W  |   |   |   |
| Reset |    |    |    |    |                 |          |   |   |   |   |   | (  | )  | • |   | • |

The register represents the number of pages that the NFI has read since the issuing of the read command. For some devices, the data can be read consecutively through different pages without the need to issue another read command. The user can monitor this register to know current page count, particularly when read DMA is enabled.

CNTR T

The page counter.



### NFI+0044h NAND flash page address counter

# NFI\_ADDRCNT

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

The register represents the current read/write address with respect to initial address input. It counts in unit of byte. In page read and page program operation, the address should be the same as that in the state machine in the target device.

NFI supports the address counter up to 4096 bytes.

**CNTR** The address count.

#### 

NFI\_ SYM0 ADDR

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4_       | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|----|----------|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   | S۱ | /M       |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   | R  | 0        |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |    | <u> </u> | • |   | • | • |

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\_ADD

R

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7 | 6 | 5  | 4  | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|----|---|---|----|----|---|---|---|---|
| Name  |    |    |    |    |    |    |   |    |   |   | SY | /M |   |   |   |   |
| Type  |    |    |    |    |    |    |   |    |   |   | R  | 0  |   |   |   |   |
| Reset |    |    |    |    |    |    |   | 70 |   |   | (  | )  |   |   | · |   |

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\_ADD

R

| Bit   | 15 | 14 | 13 | 12 | 11 |    | 10 | <u> </u>  | 9 | 8 | 7 | 6 | 5 |    | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|----|-----------|---|---|---|---|---|----|---|---|---|---|---|
| Name  |    |    |    |    |    |    |    | $\sqrt{}$ |   |   |   |   | S | ΥN | / |   |   |   |   |
| Type  |    |    |    |    |    | J. |    |           |   |   |   |   |   | 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\_ADD

R

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5  | 4  | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|----|----|---|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   | S١ | /M |   |   |   |   |
| Type  |    |    | T  |    |    |    |   |   |   |   | R  | 0  |   |   |   |   |
| Reset | 7. |    |    |    |    |    |   |   |   |   | (  | )  |   |   |   |   |

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\_SYMO\_DAT

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

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 | 2   | 4 | 20    | 19 | 18 | 17 | 16 |
|-------|------------|----|----|----|----|----|----|----|--------------|----|-----|---|-------|----|----|----|----|
| DIL   | <b>अ</b> । | 30 | 29 | 20 | 21 | 26 | 25 | 24 | 23           | 22 | 2   | I | _20 / | 19 | 10 | 17 | 10 |
| Name  |            |    |    | E  | 03 |    |    |    |              |    |     |   | E     | )2 |    |    |    |
| Type  |            |    |    |    |    |    |    |    | B            | 0  |     |   |       |    |    |    |    |
| Reset |            |    |    |    |    |    |    |    | $\mathbf{G}$ | )  |     |   |       |    |    |    |    |
| Bit   | 15         | 14 | 13 | 12 | 8  | 7  | 6  | 5  | 74           | 4  | 3   | 2 | 1     | 0  |    |    |    |
| Name  |            |    |    | E  | 01 |    |    |    |              |    |     | 5 | E     | 00 |    |    |    |
| Type  |            | RO |    |    |    |    |    |    |              |    |     |   | P     | 0  |    |    |    |
| Reset |            | 0  |    |    |    |    |    |    |              |    | Z 1 |   |       | )  |    |    |    |

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  |    |                            |    | E  | 03         |    | - 16 |    |    |    |    | E  | D2 |    |    |    |
| Type  |    | RO                         |    |    |            |    |      |    |    |    |    | F  | 0  |    |    |    |
| Reset |    | 0                          |    |    |            |    |      |    |    |    |    |    | 0  |    |    |    |
| Bit   | 15 | 14   13   12   11   10   9 |    |    |            |    |      |    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |                            |    | E  | <b>)</b> 1 |    | 7/1  |    |    |    |    | Е  | D0 |    |    |    |
| Type  |    | RO                         |    |    |            |    |      |    |    |    |    | F  | 0  |    |    |    |
| 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 SYM3 DAT** 

| Bit   | 31 | 30  | 29 | 28 | 27        | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|-----|----|----|-----------|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |     |    | E  | 03        |    |    |    |    |    |    | EC | )2 |    |    |    |
| Type  |    |     |    | R  | 0         |    |    |    |    |    |    | R  | 0  |    |    |    |
| Reset |    | 4   |    | (  | )         |    |    |    |    |    |    | C  | )  |    |    |    |
| Bit   | 15 | 14  | 13 | 12 | 11        | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    | 721 |    | E  | <b>D1</b> |    |    |    |    |    |    | E  | 00 |    |    |    |
| Type  |    | RO  |    |    |           |    |    |    |    |    |    | R  | 0  |    |    |    |
| Reset | 7  |     |    | (  | )         |    | •  | •  |    |    |    | C  | )  | •  | •  |    |



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  |    |    |    |    |    |    |   |   |   |   |   |   | EBLK<br>3 | EBLK<br>2 | EBLK<br>1 | EBLK<br>0 |
| Туре  |    |    |    |    |    |    |   |   |   |   |   |   | RO        | RO        | RO        | RO        |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 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  |    |    |    |    |    |    |   |   |   | PAR |   |   |     |   |   |   |
| 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 39 NFI parity bits register table

### NFI+0100h NFI device select register

**NFI CSEL** 

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

The register is used to select the target device. It decides which CEB pin to be functional. This is useful while using the high-density device.

**CSEL** Chip select. The value defaults to 0.

- O Device 1 is selected.
- 1 Device 2 is selected.

## 6.2.3 Device programming sequence

This section lists the program sequences to successfully use any compliant devices.

For block erase



- 1. Enable erase complete interrupt (NFI\_INTR\_EN = 8h).
- 2. Write command (NFI\_CMD = 60h).
- 3. Write block address (NFI\_ADDR).
- 4. Set the number of address bytes (NFI\_ADDRNOB).
- 5. Check program status (NFI\_PSTA) to see whether the operation has been completed. Omitted if ERASE\_CON has been set.
- 6. Write command (NFI\_CMD = D0h). Omitted if ERASE\_CON has been set.
- 7. Check the erase complete interrupt.

#### For status read

- 1. Write command (NFI\_CMD = 70h).
- 2. Set single word read for 1 byte (NFI\_OPCON = 1100h).
- 3. Check program status (NFI\_PSTA) to see whether the operation has been completed.
- 4. Read single byte (NFI\_DATAR).

#### For page program

- 1. Enable write complete interrupt (NFI\_INTR\_EN = 2h).
- 2. Set DMA mode, and hardware ECC mode (NFI\_CON = Ah).
- 3. Write command (NFI\_CMD = 80h).
- 4. Write page address (NFI\_ADDR).
- 5. Set the number of address bytes (NFI\_ADDRNOB).
- 6. Set burst write (NFI\_OPCON = 2h).
- 7. In DMA mode, the signal DMA\_REQ controls the access. The user can also check the status of the FIFO (NFI\_FIFOCON) and write a pre-specified number of data whenever the FIFO is not full and until the end of page is reached.
- 8. Check program status (NFI PSTA) to see whether all operation has been completed.
- 9. Set ECC parities write. Omitted if hardware ECC mode has been set.
- 10. Check program status (NFI\_PSTA) to see whether the above operation has been completed.
- 11. Write command (NFI\_CMD = 10h). Omitted if PROGRAM\_CON has been set.
- 12. Check the program complete interrupt.

#### For page read

- 1. Enable busy ready, read complete, ECC correct indicator, and ECC error indicator interrupt. (NFI\_INTR\_EN = 41h).
- 2. Set DMA mode, and hardware ECC mode. (NFI\_CON = 5h).
- 3. Write command (NFI\_CMD = 00h).
- 4. Write page address (NFI\_ADDR).
- 5. Set the number of address bytes (NFI\_ADDRNOB).



- 6. Check busy ready interrupt.
- 7. Set burst read  $(NFI\_OPCON = 1h)$ .
- In DMA mode, the signal DMA\_REQ controls the access. The user can also check the status of the FIFO
  (NFI\_FIFOCON) and read a pre-specified number of data whenever the FIFO is not empty and until the end of
  page is reached.
- 9. Set ECC parities check. Omitted if hardware ECC mode has been set.
- 10. Check program status (NFI\_PSTA) or check ECC correct and error interrupt.
- 11. Read the ECC correction or error information.

## 6.2.4 Device timing control

This section illustrates the timing diagram.

The ideal timing for write access is listed as listed in **Table 40**.

| Parame<br>ter    | 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 <sub>WC1</sub> | Write cycle time                | 3T + WST + WH        | 230.8ns                              | 105.4ns                              | 76.9ns                               |
| T <sub>WC2</sub> | Write cycle time                | 2T + WST + WH        | 153.9ns                              | 76.9ns                               | 57.7ns                               |
| T <sub>DS</sub>  | Write data setup time           | 1T + WST             | 76.9ns                               | 38.5ns                               | 38.5ns                               |
| T <sub>DH</sub>  | Write data hold time            | 1T + WH              | 76.9ns                               | 38.5ns                               | 19.2ns                               |
| T <sub>WP</sub>  | Write enable time               | 1T + WST             | 76.9ns                               | 38.5ns                               | 38.5ns                               |
| T <sub>WH</sub>  | Write high time                 | 1T + WH              | 76.9ns                               | 38.5ns                               | 19.2ns                               |
| T <sub>CLS</sub> | Command latch enable setup time | 1T                   | 76.9ns                               | 38.5ns                               | 19.2ns                               |
| T <sub>CLH</sub> | Command latch enable hold time  | 1T + WH              | 76.9ns                               | 38.5ns                               | 19.2ns                               |
| T <sub>ALS</sub> | Address latch enable setup time | 1T                   | 76.9ns                               | 38.5ns                               | 19.2ns                               |
| T <sub>ALH</sub> | Address latch enable hold time  | 1T + WH              | 76.9ns                               | 38.5ns                               | 19.23ns                              |
| Fwc              | Write data rate                 | 1 / T <sub>WC2</sub> | 6.5Mbytes/s                          | 13Mbytes/s                           | 17.3Mbytes/s                         |

Table 40 Write access timing





Figure 4 Command input cycle (1 wait state).



Figure 5 Address input cycle (1 wait state)





Figure 6 Consecutive data write cycles (1 wait state, 0 hold time extension)



Figure 7 Consecutive data write cycles (1 wait state, 1 hold time extension)

The ideal timing for read access is as listed in **Table 6**.

| Parame<br>ter    | Description                     | Timing specification | Timing at 13MHz<br>(RLT, WH) = (0,0) | Timing at 26MHz<br>(RLT, WH) = (1,0) | Timing at 52MHz<br>(RLT, WH) = (2,0) |
|------------------|---------------------------------|----------------------|--------------------------------------|--------------------------------------|--------------------------------------|
| T <sub>RC1</sub> | Read cycle time                 | 3T + RLT + WH        | 230.8ns                              | 153.8ns                              | 96.2ns                               |
| T <sub>RC2</sub> | Read cycle time                 | 2T + RLT + WH        | 153.9ns                              | 115.4ns                              | 76.9ns                               |
| T <sub>DS</sub>  | Read data setup time            | 1T + RLT             | 76.9ns                               | 76.9ns                               | 57.7ns                               |
| T <sub>DH</sub>  | Read data hold time             | 1T + WH              | 76.9ns                               | 38.5ns                               | 19.2ns                               |
| T <sub>RP</sub>  | Read enable time                | 1T + RLT             | 76.9ns                               | 76.9ns                               | 57.7ns                               |
| T <sub>RH</sub>  | Read high time                  | 1T + WH              | 76.9ns                               | 38.5ns                               | 19.2ns                               |
| T <sub>CLS</sub> | Command latch enable setup time | 1T                   | 76.9ns                               | 38.5ns                               | 19.2ns                               |



| F <sub>RC</sub>  | Write data rate                 | 1 / T <sub>RC2</sub> | 6.5Mbytes/s | 8.7Mbytes/s | 13Mbytes/s |
|------------------|---------------------------------|----------------------|-------------|-------------|------------|
| T <sub>ALH</sub> | Address latch enable hold time  | 1T + WH              | 76.9ns      | 38.5ns      | 19.2ns     |
| T <sub>ALS</sub> | Address latch enable setup time | 1T                   | 76.9ns      | 38.5ns      | 19.2ns     |
| T <sub>CLH</sub> | Command latch enable hold time  | 1T + WH              | 76.9ns      | 38.5ns      | 19.2ns     |

Table 41 Read access timing



Figure 8 Serial read cycle (1 wait state, 1 hold time extension)



Figure 9 Status read cycle (1 wait state)





Figure 10 ID and manufacturer read (0 wait state)

## 6.3 USB OTG Controller

## 6.3.1 General Description

The USB OTG controller complies with Universal Serial Bus (USB) Specification Rev 1.1 and USB On-The-Go (OTG) Supplement Rev. 1.0a. The USB OTG controller supports USB device mode, USB simple host mode, as well as OTG handshaking capabilities, at full-speed (12 Mbps) operation. The cellular phone uses this widely available USB interface to exchange data with USB hosts such as a PC or laptop; or to function as a host, allowing it to connect to other devices. When operating in host mode, only a single peer-to-peer (no intermediate hub) connection is supported.

The USB device controller provides 5 endpoints in addition to the mandatory control endpoint, three of which are for TX transactions and two for RX transactions. Word, half-word, and byte access methods are allowed for loading and unloading the FIFO buffer. Four independent DMA channels are equipped with the separate controllers to accelerate data transfer. The features of each endpoint are as follows:

- 1. Endpoint 0 RX: A double buffer is implemented; each buffer is an 8-byte FIFO. DMA transfer is not supported.
- 2. Endpoint 0 TX: A double buffer is implemented; each buffer is an 8-byte FIFO. DMA transfer is not supported.
- 3. Endpoint 1 RX: A 64-byte FIFO that accommodates maximum packet size of 64 bytes. DMA transfer is supported.
- 4. Endpoint 1 TX: A 64-byte FIFO that accommodates maximum packet size of 64 bytes. DMA transfer is supported.
- 5. Endpoint 2 RX: A 64-byte FIFO that accommodates maximum packet size of 64 bytes. DMA transfer is supported.
- 6. Endpoint 2 TX: A 64-byte FIFO that accommodates maximum packet size of 64 bytes. DMA transfer is supported.
- 7. Endpoint 3 TX: An 8-byte FIFO that accommodates maximum packet size of 8 bytes. DMA transfer is not supported.



This controller is highly software configurable. All endpoints except the control endpoint can be configured to be a bulk, interrupt or isochronous endpoints.

Note: The Internal Bus clock must be running at 26Mhz or higher for the USB OTG controller to operate correctly.

## 6.3.2 USB MEMBUF Mapping and BDT Format

The controller uses a buffer descriptor table (BDT) mechanism for control information as well as address pointer into the data buffer that contains the data for each endpoint. A single dedicated software-addressable local memory (USB\_MEMBUF) is allocated inside the USB controller to contain both the BDT and the data. Detailed descriptions of the BDT and the USB\_MEMBUF mapping follow.

#### 6.3.2.1 USB MEMBUF Memory Map



Figure 11 USB Memory Buffer (96x32)



#### **6.3.2.2** Buffer Descriptor Byte Format

Each Buffer Descriptor contains 8 bytes of data. The first word contains control information, and the second word contains the address of the associated data buffer.

| Bit  | 31:26 | 25:16                    | 15:8 | 7   | 6           | 5                   | 4                   | 3                  | 2                        | 1 | 0 |  |  |  |  |
|------|-------|--------------------------|------|-----|-------------|---------------------|---------------------|--------------------|--------------------------|---|---|--|--|--|--|
| Name | RSVD  | ВС                       | RSVD | OWN | DATA0<br>/1 | KEEP/TOK_PI<br>D[3] | NINC/TOK_PID<br>[2] | DTS/TOK_PID[<br>1] | BDT_STALL/TOK_P<br>ID[0] | 0 | 0 |  |  |  |  |
| Name |       | Buffer Address (32 bits) |      |     |             |                     |                     |                    |                          |   |   |  |  |  |  |

(Note: VUSB refers to the USB controller hardware)

**BUFFER ADDRESS** The Address bits represent the 32 -bit buffer address in USB MEMBUF. These bits are unchanged by the VUSB hardware.

**BC[9:0]** The Byte Count bits represent a 10-bit Byte Count. The VUSB Serial Interface Engine (SIE) changes this field upon completion of a RX transfer with the byte count of the data received.

The OWN bit determines who currently owns the buffer. If OWN=1, VUSB has exclusive access to the BD. If OWN=0 the microprocessor has exclusive access to the BD. The SIE generally writes a 0 to this bit when it has completed a token, except when KEEP=1. When OWN=0, the VUSB ignores all other fields in the BD, and the microprocessor has access to the entire BD. This byte of the BD must be the last byte updated by the microprocessor when initializing a BD. Once the BD has been assigned to the VUSB, the microprocessor must not change it in any way.

**DATA0/1** The DATA0/1 bit indicates if a DATA0 field (DATA0/1=0) or a DATA1 (DATA0/1=1) field was transmitted or received. This bit is unchanged by the VUSB.

KEEP/TOK\_PID[3] If KEEP=1, once the OWN bit is set, the BD is owned by the VUSB. Typically this bit is set to 1 for ISO endpoints that are feeding a FIFO. The microprocessor is not informed that a token has been processed, the data is simply transferred to or from the FIFO. The NINC bit is normally also set when KEEP=1 to prevent address increment. KEEP must equal 0 to allow the VUSB to release the BD when a token has been processed.

If KEEP=1, this bit is unchanged by the VUSB; otherwise bit 3 of the current token PID is written back into the BD by the VUSB.

NINC/TOK\_PID[2] The No INCrement bit disables the DMA engine address increment, forcing the DMA engine to read from or to write to the same address. This feature is useful when data needs to be read from or written to a single location such as a FIFO. Typically this bit is set with the KEEP bit for ISO endpoints that interface with a FIFO.

If KEEP=1, this bit is unchanged by the VUSB; otherwise bit 2 of the current token PID is written back into the BD by the VUSB.

**DTS/TOK\_PID[1]** Setting this bit enables Data Toggle Synchronization by the VUSB. When this bit is 0, no Data Toggle Synchronization is performed.

If KEEP=1, this bit is unchanged by the VUSB; otherwise bit 1 of the current token PID is written back into the BD by the VUSB.

BDT\_STALL/TOK\_PID[0] Setting this bit causes the VUSB to issue a STALL handshake if a token is received by the SIE that would use the BDT in this location. The BDT is not changed by the SIE (the own bit and the rest of the BDT remain unchanged) when the BDT-STALL bit is set.

If KEEP=1, this bit is unchanged by the VUSB; otherwise bit 0 of the current token PID is written back into the BD by the VUSB.

**TOK\_PID** The current token PID is written back into the BD by the VUSB when a transfer is complete. The token PID takes on values from the USB specification: 0x1 for an OUT token, 0x9 for an IN token or 0xd for a SETUP token. In host mode, this field is used to report the last returned PID or to indicate the transfer



status. The possible values returned are: 0x3 DATA0, 0xb DATA1, 0x2 ACK, 0xe STALL, 0xa NAK, 0x0 Bus Timeout, 0xf Data Error.

## 6.3.3 Operating Modes

The USB\_OTG controller supports 3 modes of operation.

#### 6.3.3.1 Standard Mode

In this mode, MEMBUF data is accessed via a single software read/write operation. Both 8-bit and 32-bit access methods are supported. Standard mode is the most flexible operating mode with the maximum software control flexibility. All BDT values are required to be managed by software. However, the throughput for standard mode is slowest of the three modes due to heavy software intervention.

#### 6.3.3.2 Direct Memory Access (DMA) Mode

In DMA mode, MEMBUF data for endpoints 1 and 2 (TX and RX) is accessed via DMA. This access method allows for faster data movement. To issue a DMA transfer, software must enable and disable the individual USB DMA control via its corresponding register set. Aside from the faster data movement, everything is the same as in standard mode.

#### 6.3.3.3 Fast Mode

To increase the operating throughput, the USB OTG controller provides a "fast mode" operation. This mode is most suitable for transmission of large, regular chunks of data. While operating in this mode, DMA is enabled automatically for endpoints 1 and 2 (TX and RX), and each packet transfer is 64 bytes. In order to minimize software involvement and latency, all interrupts to the MCU (except for fast mode error status) are masked during the transmission until the last packet is transferred. Fast mode supports only one endpoint and one direction.

Note: When using fast mode, the own bit of the BDT must be 0 to avoid a software configuration race problem. Hardware manages the own bit value and also BDT values automatically.

## 6.3.4 Special Conditions

Due to the complex nature of the USB OTG controller design and software operation, some special cases must be noted:

- 1. When using DMA mode, if B2W of the generic DMA is enabled with 4-beat burst and byte access, then the transfer count of the generic DMA controller must be set to a 4-byte multiple. Otherwise, once the controller arranges the data into words, the few remaining bytes are incorrectly read or written one byte at a time, and each byte is padded to a 4-byte word. The internal USB DMA controller treats each read/write as one word and increments the address after each read/write, thereby incrementing the access pointer incorrectly.
  - From a software perspective, all transfer byte counts that are not 4-byte aligned must be padded to a 4-byte multiple; That amount of space must be allocated for receiving: the extra bytes of memory need to be reserved so the received data does not overwrite any useful data.
  - For example: If generic DMA is to move 13 bytes of data from USB MEM to SRAM, software must allocate 16 bytes in SRAM for such an operation. The last 3 bytes are unknown data and are to be discarded by software.
- 2. During a host mode operation, the CRC16 bit of the USB\_ERR\_STAT register cannot be checked. Instead, use the TOK PID bits of the BDT to check for a data CRC error.



- 3. When operating in fast mode, software must ignore the token\_dne status bit of the USB\_INT\_STAT register.
- 4. Interrupts can come from the following sources:
  - a. sources listed in the USB\_INT\_STAT register,
  - b. sources listed in the USB\_OTG\_INT\_STAT register,
  - c. sources listed in the USB\_FM\_ERR\_STAT register, or,
  - d. PHY resume interrupt.

### 6.3.5 Register Definitions

(Note: VUSB and SIE refer to the USB controller hardware internal modules)

#### 70000000h USB Peripheral ID register

**USB PER ID** 

| Bit   | 7 | 6 | 5 | 4        | 3  | 2  |    | 1 | 0 |  |  |
|-------|---|---|---|----------|----|----|----|---|---|--|--|
| Name  |   |   |   | ID [5:0] |    |    |    |   |   |  |  |
| Type  |   |   |   |          | R  | 0  | CA |   |   |  |  |
| Reset | 0 | 0 |   |          | 0x | 04 |    |   |   |  |  |

#### **DEBUG PURPOSES ONLY**

Configuration number. This number is set to 0x04 for hardware core version control.

### 70000004h USB Peripheral ID complement register

USB\_ID\_COMP

| Bit   | 7 | 6 | 5 | 4 | 3   | 2       | 1 | 0 |
|-------|---|---|---|---|-----|---------|---|---|
| Name  |   |   |   |   | NII | D [5:0] |   |   |
| Type  |   |   |   |   |     | RO      |   |   |
| Reset | 1 | 1 |   |   |     |         |   |   |

#### DEBUG PURPOSES ONLY

NID One's complement of ID. This register reads back 0xFB.

### 70000008h USB revision register

**USB REV** 

| Bit   | 7 | 6 | 5 | 4   | 3     | 2 | 1 | 0 |
|-------|---|---|---|-----|-------|---|---|---|
| Name  |   |   |   | REV | [7:0] |   |   |   |
| Type  |   |   |   | R   | 0     |   |   |   |
| Reset |   |   |   |     |       |   |   |   |

#### **DEBUG PURPOSES ONLY**

**REV** Revision ID of the hardware controller core. This register reads back 0x32.

### 7000000Ch USB Peripheral additional info register

USB\_ADD\_INF

0

| Bit   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|---|---|---|---|---|---|---|---|
| Name  |   |   |   |   |   |   |   |   |
| Type  |   |   |   |   |   |   |   |   |
| Reset |   |   |   |   |   |   |   |   |

#### **DEBUG PURPOSES ONLY**

This register is used for debug purposes only. The register reads back 0x01.

### 70000010h USB OTG Interrupt status register

**USB ISTAT** 

| Bit    | 7      | 6      | 5                  | 4 | 3                | 2              | 1 | 0              |
|--------|--------|--------|--------------------|---|------------------|----------------|---|----------------|
| Name   | ID_CHG | 1_MSEC | LINE_STATE_C<br>HG |   | SESS_VLD_<br>CHG | B_SESS_CH<br>G |   | A_VBUS_CH<br>G |
| Type . | R/W    | R/W    | R/W                |   |                  | R/W            |   | R/W            |





| Reset | 0 | 0 | 0 |  | 0 | 0 |
|-------|---|---|---|--|---|---|

The OTG Interrupt Status Register records changes of the ID and VBUS signals. Software reads this register to determine which event is causing an interrupt. Only bits that have changed since the last software read are set. Writing a one to a bit clears the respective interrupt. The change conditions are de-bounced in hardware.

**ID\_CHG** 

This bit is set when a change in the ID Signal from the USB connector is sensed.

1\_MSEC

This bit is set when the 1 millisecond timer expires. This bit stays asserted until cleared by software. The interrupt must be serviced every millisecond to avoid losing 1 ms counts.

LINE\_STATE\_CHG This interrupt is set when the USB line state (CTL\_RG SE0 and JSTATE bits) has been stable (unchanged) for 1 millisecond, and if the line state value is different from the last time that the line state was stable. The interrupt is set on transitions between SE0 and J, SE0 and K, and J and K. Changes in JSTATE while SE0 is true do not cause an interrupt. This interrupt can be used in detecting Reset, Resume, Connect and Data Line Pulse signaling.

**SESS\_VLD\_CHG** This bit is set when a change in VBUS is detected, indicating a session has become valid or a session is no longer valid.

B\_SESS\_END\_CHG This bit is set when a change in VBUS is detected on a "B" device.

A VBUS CHG

This bit is set when a change in VBUS is detected on an "A" device.

### 70000014h USB OTG Interrupt Control register

USB\_OTG\_ICT

| Bit   | 7     | 6         | 5                | 4 | 3               | 2         | 1 | 0         |
|-------|-------|-----------|------------------|---|-----------------|-----------|---|-----------|
| Name  | ID_EN | 1_MSEC_EN | LINE<br>STATE_EN |   | SESS_VLD_<br>EN | B_SESS_EN |   | A_VBUS_EN |
| Type  | R/W   | R/W       | R/W              |   |                 | R/W       |   | R/W       |
| Reset | 0     | 0         | 0                |   |                 | 0         |   | 0         |

**ID EN** Enables the ID interrupt.

**1 MSEC EN** Enables the 1 millisecond timer interrupt.

**LINESTATE EN** Enables the interrupt on a line state change.

**SESS\_VLD\_EN**Enables the session valid interrupt.

**B SESS EN** Enables the "B" Session End Interrupt.

**A\_VBUS\_EN** Enables the "A" VBUS Valid Interrupt.

### 70000018h USB OTG status register

**JSB OTG STAT** 

| Bit   | 7   | 6      | 5                     | 4 | 3        | 2              | 1 | 0              |
|-------|-----|--------|-----------------------|---|----------|----------------|---|----------------|
| Name  | ID  | 1_MSEC | LINE_STATE_STA<br>BLE |   | SESS_VLD | B_SESS_EN<br>D |   | A_VBUS_VL<br>D |
| Type  | R/W | R/W    | R/W                   |   |          | R/W            |   | R/W            |
| Reset | 0   | 0      | 0                     |   |          | 0              |   | 0              |

ID

Indicates the current state of the ID pin on the USB connector:

0: A Type A cable has been plugged into the USB connector;

1: no cable is attached or a Type B cable has been plugged into the USB connector.

1 MSEC

DEBUG only. This bit is reserved for the 1Msec count. The bit is not useful to software.

LINE\_STATE\_STABLE This bit is set when the line state (JSTATE and SE0 in the CTL\_RG) has been stable for the previous 1 millisecond. This bit is used to provide a hardware debounce of the line state for detection of connect, disconnect and resume signaling. First read the state of JSTATE and SE0 in the CTL\_RG, then read this bit. If this bit is 1, then the value of the JSTATE and SE0 bits of the CTL\_RG have been static for the previous 1ms and can be considered debounced.

SESS\_VLD

This bit is set when the VBUS voltage is above the "B" session Valid threshold.

**B SESS END** 

This bit is set when the VBUS voltage is below the "B" session End threshold.



A\_VBUS\_VLD

This bit is set when the VBUS voltage is above the "A" VBUS Valid threshold.

#### 7000001Ch USB OTG Control register

JSB\_OTG\_CTRL

| Bit   | 7       | 6       | 5      | 4      | 3       | 2      | 1        | 0              |
|-------|---------|---------|--------|--------|---------|--------|----------|----------------|
| Name  | DP_HIGH | DM_HIGH | DP_LOW | DM_LOW | VBUS_ON | OTG_EN | VBUS_CHG | VBUS_DSC<br>HG |
| 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              |

The OTG Control Register controls the operation of VBUS and data line termination resistors.

**DP\_HIGH** When set, a pull-up resistor on the D+ Data line is enabled.

**DM\_HIGH** When set, a pull-up resistor on the D- Data line is enabled.

**DP LOW** When set, a pull-down resistor on the D+ Data line is enabled.

**DM LOW** When set, a pull-down resistor on the D- Data line is enabled.

**VBUS\_ON** When set, the VBUS power signal is turned on.

OTG\_EN When set, the pull-up and pull-down controls in this register are used. When OTG\_EN is cleared:

- If the CTL register HOST\_MODE bit is set, the D+ and D- pull-down resistors are engaged; or,
- If the CTL register HOST\_MODE bit is clear and the USB\_EN bit is set, the D+ pull-up is engaged.

**VBUS\_CHG** When set, the VBUS signal is charged through a resistor.

**VBUS\_DSCHG** When set, the VBUS signal is discharged through a resistor.

### 70000020h USB FM packet count number (low byte)

USB\_FM\_PKT\_NU

 $M_L$ 

| Bit   | 7 | 6   | 5 | 4       | 3 |  | 2 | 1 | 0 |  |
|-------|---|-----|---|---------|---|--|---|---|---|--|
| Name  |   |     |   | JM[7:0] |   |  |   |   |   |  |
| Type  |   | R/W |   |         |   |  |   |   |   |  |
| Reset |   |     |   |         |   |  |   |   |   |  |

## 70000024h USB FM packet count number (low byte)

USB\_FM\_PKT\_NU

 $M_H$ 

| Bit   | 7   | 6 | 5 | 4      | 3        | 2 | 1 | 0 |  |  |
|-------|-----|---|---|--------|----------|---|---|---|--|--|
| Name  |     |   |   | PKT_NU | JM[15:8] |   |   |   |  |  |
| Type  | R/W |   |   |        |          |   |   |   |  |  |
| Reset |     |   |   |        | )        |   |   |   |  |  |

#### **FAST MODE ONLY**

**PKT\_NUM** These 2 registers combined specify the number of 64-byte packets to be transferred.

#### 70000028h USB FM error status register

USB\_FM\_ERR\_ STAT

| Bit   | 7         | 6               | 5      | 4      | 3 | 2       | 1       | 0        |
|-------|-----------|-----------------|--------|--------|---|---------|---------|----------|
| Name  | STA_OVR_F | FM_TOK_D<br>ONE | DMA TX | DMA RX |   | SUC_ERR | NAK_ERR | SHRT_ERR |
| Type  | R/W       | R/W             | R/W    | R/W    |   | R/W     | R/W     | R/W      |
| Reset |           | 0               | 0      | 0      |   | 0       | 0       | 0        |

**FAST MODE ONLY** All status bits that are set are cleared by rewriting a 1.

**STA\_OVR\_FLW** Indicates that during fast mode, the non-fast mode status FIFO (+0x50) has overflowed.

**FM\_TOK\_DONE** This is the non-fast mode endpoint token done interrupt. During fast mode operation, any non-fast mode endpoint token done signal is moved to this register bit for indication.



**DMA\_TX\_EN DEBUG only.** Asserted if fm dma\_rx\_en is asserted and USB\_FM\_INT\_MASK (+0x6C) mask is

enabled.

**DMA\_RX\_EN DEBUG only.** Asserted if fm dma\_rx\_en is asserted and USB\_FM\_INT\_MASK (+0x6C) mask is

enabled.

**SUC\_ERR** HOST mode only. 3 successive errors. This bit is set when the error count is 3 and

USB\_FM\_CTRL (+0x2C) is 1, or when the error count is 1 and USB\_FM\_CTRL (+0x2C) is 0.

**NAK\_ERR** HOST mode only. This bit is set when the NAK count exceeds the IN-NAK Timeout Setting

register.

SHRT\_ERR HOST mode only. Short packet error. This bit is set when the data transferred in a single

transaction is less than 64 bytes.

#### 70000028h USB FM control register

#### **USB FM CTRL**

| Bit     | 7 | 6       | E   | 4 | 2         | 2         | 4         | 0        |
|---------|---|---------|-----|---|-----------|-----------|-----------|----------|
| DIL     | / | U       | ິ່ງ | 4 | J         |           |           | U        |
| Name    |   | TOG BIT |     |   | SUC_ERR_E | EPT0_TX_O | EPT0_RX_O | FASTMODE |
| Ivaille |   | TOG_BIT |     |   | N         | DD        | DD        | _EN      |
| Type    |   | R/W     |     |   | R/W       | R         | R         | R/w      |
| Reset   |   | 0       |     |   | 1         | 0         | 0         | 0        |

#### **FAST MODE ONLY**

**TOG\_BIT** Data toggle bit. This bit indicates whether the type of data transmitted or received by hardware was DATA0 or DATA1.

0: DATA0 1: DATA1

**EPO\_TX\_ODD** Endpoint 0 TX ODD. This bit is set when using the TX ODD BDT. Endpoint 0 RX ODD. This bit is set when using the RX ODD BDT.

**FASTMODE EN** Enable Fast Mode operation. This bit is reset by hardware after the transfer is complete.

## 70000030h USB FM transfer counter register (low byte)

USB\_FM\_PKT\_CN

| Bit   | 7 | 6 | 5 | 4      | 3      | 2 | 1 | 0 |
|-------|---|---|---|--------|--------|---|---|---|
| Name  |   |   |   | PKT_CN | T[7:0] |   |   |   |
| Type  |   |   |   | RC     | 1      |   |   |   |
| Reset |   |   |   | 0      |        |   |   |   |

## 70000034h USB FM transfer counter register (high byte)

USB\_FM\_PKT\_CN

| Name         PKT_CNT[15:8]           Type         RO | Bit   | 7 | 6             |  |  | 4 | 3 | 2 | 1 | 0 |  |
|------------------------------------------------------|-------|---|---------------|--|--|---|---|---|---|---|--|
| Type                                                 | Name  |   | PKI_CNI[13.0] |  |  |   |   |   |   |   |  |
|                                                      | Type  |   |               |  |  |   |   |   |   |   |  |
| Reset 0                                              | Reset |   |               |  |  |   |   |   |   |   |  |

#### **FAST MODE ONLY**

**PKT\_CNT** These 2 registers combined specify the number of 64-byte packets transferred.

### 70000038h USB FM timeout setting register (high byte)

| US | ВЕ | =M | TIN | 1EOU |
|----|----|----|-----|------|
|    | _  | _  | _   |      |

| Bit   | 7 | 6 | 6 5 4 3 2 1 0    |  |  |  |  |  |  |  |  |
|-------|---|---|------------------|--|--|--|--|--|--|--|--|
| Name  |   |   | NAK_TIMEOUT[7:0] |  |  |  |  |  |  |  |  |
| Type  |   |   | R/W              |  |  |  |  |  |  |  |  |
| Reset |   |   | 1                |  |  |  |  |  |  |  |  |

#### **FAST MODE ONLY**

NAK TIMEOUT

**HOST mode only.** Transfer timeout setting = 64ms \* NAK\_TIMEOUT



### 7000003Ch USB FM status register

USB\_FM\_STAT

| Bit   | 7 | 6 | 5 | 4 | 3               | 2               | 1               | 0         |   |
|-------|---|---|---|---|-----------------|-----------------|-----------------|-----------|---|
| Name  |   |   |   |   | EPT2_TX_O<br>DD | EPT2_RX_O<br>DD | EPT1_TX_O<br>DD | EPT1_RX_C | 1 |
| Type  |   |   |   |   | R               | R               | R               | R         | 7 |
| Reset |   |   |   |   | 0               | 0               | 0               | 0         |   |

#### **FAST MODE ONLY**

**EP2\_TX\_ODD** Endpoint 2 TX ODD.

**EP2\_RX\_ODD** Endpoint 2 RX ODD.

**EP1\_TX\_ODD** Endpoint 1 TX ODD.

**EP1\_RX\_ODD** Endpoint 1 RX ODD.

#### 70000050h USB FM additional status register

USB\_ FM\_ADD\_STAT

| Bit   | 7 | 6    | 5  | 4   | 3 | 2  | 1 | 0 |
|-------|---|------|----|-----|---|----|---|---|
| Name  |   | ENDP | TX | ODD |   |    |   |   |
| Type  |   | RO   |    |     |   | RO |   |   |
| Reset |   | (    | )  |     | 0 | 0  |   |   |

#### **FAST MODE ONLY**

The additional status register stores the status of non-fast mode packet during fast mode operation, to allow the intermixing of fast mode and non-fast mode packets.

When entering fast mode, any existing status in USB\_STAT register that has not yet been cleared is automatically transferred to this register. The format of this status register is the same as the USB\_STAT register, and a 4-byte FIFO is also used in this case. When the FM\_TOK\_DONE bit in USB\_FM\_ERR\_STAT is cleared, the FM\_ADD\_STAT register is updated with the contents of the next value in the FIFO. FM\_TOK\_DONE is asserted until the FIFO is empty.

**ENDPT[3:0]** These four bits represents the endpoint address that received or transmitted the previous token, so that the microprocessor can determine which BDT entry was updated by the last USB transaction.

This bit indicates whether the last BDT updated was for a transmit data transfer (TX=1) or for a receive data transfer (TX=0).

ODD This bit indicates that the last buffer descriptor updated was in the odd bank of the BDT. See the earlier section for more information on BDT address generation.

#### 70000068h USB FM endpoint register

USB\_FM\_ENDP

T

| Bit   | 7      | 6        | 5   | 4   | 3 2 1 0    |  |  |  |  |  |
|-------|--------|----------|-----|-----|------------|--|--|--|--|--|
| Name  | TX_RES | DMA_DONE | OWN | TX  | ENDPT[3:0] |  |  |  |  |  |
| Type  | R/W    | R/W      | R/W | R/W | R/W        |  |  |  |  |  |
| Reset | 0      | 1        | 0   | 0   | 0          |  |  |  |  |  |

#### **FAST MODE ONLY**

TX\_RES DEVICE mode only. Tx residue. This setting is used when the transmit byte count is not a multiple of 64 bytes. By default, fast mode operates on 64B packet boundaries, and the fast mode-done indication is asserted once the last 64-byte packet is sent: no further USB DMA sequence takes place. If this bit is set, the fast mode controller issues an additional dma\_tx\_en request to the USB DMA controller after the last 64B-aligned packet is sent, even with fast mode-done indication still asserted, allowing the USB DMA engine to fetch the next non-64B-aligned data. Software needs to take this situation into consideration.



**DMA\_DONE DEBUG only.** Test only.

**OWN DEBUG only.** Own bit of fast mode. This bit is used when a token is received during fast mode but the BDT is not yet valid, or the BDT is valid but fast mode has not yet been enabled. The bit clears itself once fast mode completes.

**TX DEVICE mode only.** The endpoint direction of fast mode. TX=1 indicates a transmit (IN) direction; TX=0 indicates a receive (OUT) direction.

### 7000006Ch USB FM interrupt mask register

USB\_FM\_INT\_MAS

| Bit   | 7 | 6 | 5 | 4 | 3                  | 2                  | 1   | 0 |
|-------|---|---|---|---|--------------------|--------------------|-----|---|
| Name  |   |   |   |   | DMA_TX_EN_M<br>ASK | DMA_RX_EN_M<br>ASK | 9.0 |   |
| Type  |   |   |   |   | R/W                | R/W                |     |   |
| Reset |   |   |   |   | 0                  | 0                  |     |   |

**FAST MODE ONLY** 

DMA\_TX\_MASK

DEBUG only. When set, the dma\_tx\_en interrupt is enabled.

DMA\_RX\_MASK

DEBUG only. When set, the dma\_rx\_en interrupt is enabled.

#### 70000070h USB extra register

**USB EXTRA** 

| Bit   | 7                  | 6 | 5 | 4 | 3 | 叿 | $\sqrt{2}$          | 1              | 0               |
|-------|--------------------|---|---|---|---|---|---------------------|----------------|-----------------|
| Name  | PHY_RESUME_<br>INT |   |   |   |   |   | HY_RESU<br>E_INT_EN | PHY_SUSPN<br>D | TOGGLE_TE<br>ST |
| Type  | RO                 |   |   |   |   | 8 | R/W                 | R/W            | R/W             |
| Reset | 0                  |   |   |   |   |   | 0                   | 0              | 0               |

**PHY\_RESUME\_INT** Interrupt indicating PHY Resume. This bit can only be asserted when PHY\_SUSPND = 1. This bit clears itself when PHY\_SUSPND=0.

PHY RESUME INT\_EN When set, the PHY Resume interrupt is enabled.

**PHY\_SUSPND** When set, the PHY is suspended.

**TOGGLE\_TEST DEBUG only.** Toggles USB DP/DM output automatically.

#### 70000080h USB Interrupt status register

**USB INT STAT** 

| Bit   | 7     | 6      | 5      | 4     | 3       | 2       | 1     | 0       |
|-------|-------|--------|--------|-------|---------|---------|-------|---------|
| Name  | STALL | ATTACH | RESUME | SLEEP | TOK_DNE | SOF_TOK | ERROR | USB_RST |
| 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       |

All status bits that are set are cleared by rewriting a 1.

STALL The stall interrupt is used in target and host modes. In target mode the stall bit is asserted when a STALL handshake is sent by the SIE.

In host mode this bit is set if the VUSB has detected a STALL acknowledgement during the handshake phase of a USB transaction. This interrupt is useful for determining if the last USB transaction was completed successfully or stalled.

This bit is set if the VUSB has detected the attachment of a USB peripheral. This signal is only valid if HOST\_MODE\_EN is true. This interrupt signifies that a peripheral is now present and must be configured. The ATTACH interrupt is asserted if there have been no transitions on the USB for 2.5us and the current bus state is not SE0.

**RESUME** This bit is set when a K-state is observed on the DP/DM signals for 2.5usec. The bit can indicate a remote wake up signal on the USB bus. When not in suspend mode, disable this interrupt.

(Note: this bit is only useful if the PHY has not been powered down into suspend mode. Otherwise, use USB\_EXTRA register status bits to resume monitoring.)



This bit is set if the VUSB has detected a constant idle on the USB bus signals for 3 ms. The sleep timer is reset by activity on the USB bus.

**TOK\_DNE** This bit is set when the current token being processing is complete. The microprocessor must immediately read the STAT register to determine the End Point and BD used for this token. Clearing this bit (by writing a one) causes the STAT register to be cleared or the STAT holding register to be loaded into the STAT register. (Note: When Fast Mode is enabled, DO NOT look at this bit.)

**SOF\_TOK** This bit is set if the VUSB has received a Start Of Frame (SOF) token. In host mode, this bit is set when the SOF threshold is reached, so that software can prepare for the next SOF.

**ERROR** 

This bit is set when any of the error conditions in the ERR\_STAT register has occurred. The microprocessor must then read the ERR\_STAT register to determine the source of the error.

USB RST This bit is set when the VUSB has decoded a valid USB reset. An asserted USB\_RST bit informs the microprocessor to write 0x00 into the address register and enable endpoint 0. USB\_RST is set once a USB reset has been detected for 2.5 microseconds, and is not asserted again until the USB reset condition has been removed, and then reasserted.

#### 70000084h **USB Interrupt Enable register**

### **USB INT ENB**

| Bit   | 7     | 6      | 5      | 4     | 3       | 2       | 1     | 0       |
|-------|-------|--------|--------|-------|---------|---------|-------|---------|
| Name  | STALL | ATTACH | RESUME | SLEEP | TOK_DNE | SOF_TOK | ERROR | USB_RST |
| 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       |

STALL

Setting this bit enables the STALL interrupt.

ATTACH

Setting this bit enables the ATTACH interrupt.

RESUME

Setting this bit enables the RESUME interrupt.

**SLEEP** 

Setting this bit enables the SLEEP interrupt.

**TOK DNE** Setting this bit enables the TOK\_DNE interrupt.

**SOF TOK** Setting this bit enables the SOF\_TOK interrupt.

**ERROR** 

Setting this bit enables the ERROR interrupt.

**USB RST** Setting this bit enables the USB\_RST interrupt.

#### 70000088h **USB Error Interrupt Status register**

#### **USB ERR STAT**

| Bit   | 7       | 6 | 5       | 4       | 3    | 2     | 1        | 0       |
|-------|---------|---|---------|---------|------|-------|----------|---------|
| Name  | BTS_ERR |   | DMA_ERR | BTO_ERR | DFN8 | CRC16 | CRC5/EOF | PID_ERR |
| Type  | R/W     |   | R/W     | R/W     | R/W  | R/W   | R/W      | R/W     |
| Reset | 0       |   | 0       | 0       | 0    | 0     | 0        | 0       |

The Error Interrupt Status Register contains bits for each of the error sources within the VUSB. Each of these bits are qualified with their respective error enable bits (See Error Enable Register page). The error bits are OR'ed together and the result is sent to the ERROR bit of the INT STAT register. Once an interrupt bit has been set, it can only be cleared by writing a one to the respective interrupt bit. Each bit is set as soon as the error condition is detected. Thus, the interrupt does not typically correspond with the end of a token being processed.

(Note: All status bits that are set are cleared by writing a 1.)

BTS\_ERR A bit stuff error has been detected. If set, the corresponding packet is rejected due to a bit stuff error. **DMA ERR** This bit is set if the VUSB has requested a DMA access to read a new BDT but the bus is not available before VUSB needs to receive or transmit data. If processing a TX transfer, a transmit data underflow condition occurs. If processing an RX transfer, a receive data overflow condition occurs. This interrupt is useful when developing device arbitration hardware for the microprocessor and VUSB to minimize bus request and bus grant latency. This bit is also set if a data packet to or from the host is



larger than the allocated buffer size in the BDT. In this case the data packet is truncated as it is placed into the buffer memory.

BTO\_ERR This bit is set if a bus turnaround timeout error has occurred. This VUSB uses a bus turnaround timer to keep track of the amount of time elapsed between the token and data phases of a SETUP or OUT TOKEN, or between the data and handshake phases of a IN TOKEN. If more than 16 bit times are counted from the previous EOP before a transition from IDLE, a bus turnaround timeout error occurs.

**DFN8** The data field received is not a multiple of 8 bits. The USB Specification 1.0 specifies that the data field must be an integral number of bytes. If the data field is not an integral number of bytes, this bit is set.

CRC16 The CRC16 failed. If set, the data packet was rejected due to a CRC16 error.

(Note: When in HOST MODE, ignore this bit. Look at the BDT TOK\_PID entries instead to determine error conditions.)

CRC5/EOF This error interrupt has two functions. When the VUSB is operating in peripheral mode (HOST\_MODE\_EN=0) this interrupt detects a CRC5 error in token packets generated by the host. If set, the token packet was rejected due to a CRC5 error. When the VUSB is operating in host mode (HOST\_MODE\_EN=1), this interrupt detects End of Frame (EOF) error conditions. This condition occurs when the VUSB is transmitting or receiving data and the SOF counter has reached zero. This interrupt is useful when developing USB packet scheduling software to ensure that no USB transactions cross into the start of the next frame.

PID ERR The PID check field failed.

#### 7000008Ch USB Error Interrupt Enable register

USB\_ERR\_ENB

| Bit   | 7       | 6 | 5       | 4       | 3    | 2     | 1        | 0       |
|-------|---------|---|---------|---------|------|-------|----------|---------|
| Name  | BTS_ERR |   | DMA_ERR | BTO_ERR | DFN8 | CRC16 | CRC5/EOF | PID_ERR |
| Type  | R/W     |   | R/W     | R/W     | R/W  | R/W   | R/W      | R/W     |
| Reset | 0       |   | 0       | 0       | 0    | 0     | 0        | 0       |

BTS\_ERR Setting this bit enables the BTS\_ERR interrupt.

DMA\_ERR Setting this bit enables the DMA\_ERR interrupt.

BTO\_ERR Setting this bit enables the BTO\_ERR interrupt.

DFN8 Setting this bit enables the DFN8\_ERR interrupt.

CRC16 Setting this bit enables the CRC16 interrupt.

**CRC5/EOF** Setting this bit enables the CRC5/EOF\_ERR interrupt.

PID\_ERR Setting this bit enables the PID\_ERR interrupt.

#### 70000090h USB Status register

**USB STAT** 

| Bit   | 7 | 6  | 5        | 4 | 3  | 2   | 1 | 0 |
|-------|---|----|----------|---|----|-----|---|---|
| Name  |   | EN | DPT[3:0] |   | TX | ODD |   |   |
| Type  |   |    | RO       |   | RO | RO  |   |   |
| Reset |   |    | 0        |   | 0  | 0   |   |   |

The Status Register reports the transaction status within the VUSB. When the microprocessor has received a TOK\_DNE interrupt, the Status Register should be read to determine the status of the previous endpoint communication. The data in the status register is valid when the TOK\_DNE interrupt bit is asserted. The STAT register acts as a read window into a status FIFO maintained by the VUSB. When the VUSB uses a BD, the status register is updated. If another USB transaction is performed before the TOK\_DNE interrupt is serviced the VUSB stores the status of the next transaction in the STAT FIFO. Thus, the STAT register is actually a 4-byte FIFO that allows the microprocessor to process one transaction while the SIE is processing the next. Clearing the TOK\_DNE bit in the INT\_STAT register causes the SIE to update the STAT register with the contents of the next STAT value. If the data in the STAT holding register is valid, the SIE immediately reasserts the TOK\_DNE interrupt.



**ENDPT[3:0]** These four bits encode the endpoint address that received or transmitted the previous token, allowing the microprocessor to determine which BDT entry was updated by the last USB transaction.

This bit indicates whether the last BDT updated was a transmit transfer (TX=1), or a receive data transfer (TX=0).

ODD This bit indicates that the last buffer descriptor updated was in the odd bank of the BDT. See earlier section for more information on BDT address generation.

#### 70000094h USB Control register

**USB CTL** 

| Bit   | 7      | 6   | 5                             | 4     | 3                | 2      | 1       | 0                  |
|-------|--------|-----|-------------------------------|-------|------------------|--------|---------|--------------------|
| Name  | JSTATE | SE0 | TXDSUSPEN<br>D /<br>TOKENBUSY | RESET | HOST_MOD<br>E EN | RESUME | ODD_RST | USB_EN /<br>SOF_EN |
| 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                  |

**JSTATE** Live USB differential receiver JSTATE signal. The polarity of this signal is affected by the current state of LS\_EN (See the Address Register description below).

**SE0** Live USB Single Ended Zero signal.

#### TXDSUSPEND / TOKENBUSY

This dual use control signal is used to access TXD\_SUSPEND when the VUSB is a target, and Token Busy when the VUSB is in host mode.

The TXD Suspend bit informs the processor that the SIE has disabled packet transmission and reception. Clearing this bit allows the SIE to continue token processing. This bit is set by the SIE when a Setup Token is received allowing software to dequeue any pending packet transactions in the BDT before resuming token processing.

The Token Busy bit informs the host processor that the VUSB is busy executing a USB token and that no more token commands should be written to the Token Register. Software must check this bit before writing any tokens to the Token Register to ensure that token command are not lost.

RESET Setting this bit enables the VUSB to generate USB reset signaling, allowing the VUSB to reset USB peripherals. This control signal is only valid in host mode, (i.e. HOST\_MDOE\_EN=1). Software must set RESET=1 for the required amount of time and then clear it to 0 to end reset signaling. For more information on RESET signaling see Section 7.1.4.3 of the USB specification version 1.0.

**HOST\_MODE\_EN** Setting this bit enables the VUSB to operate in host mode. In host mode the VUSB performs USB transactions under the programmed control of the host processor.

RESUME Setting this bit allows the VUSB to execute resume signaling, allowing the VUSB to perform remote wake-up. Software must set RESUME=1 for the required amount of time and then clear it to 0. If the HOST\_MODE\_EN bit is set, the VUSB appends a Low Speed End of Packet to the Resume signal when the RESUME bit is cleared. For more information on RESUME signaling see Section 7.1.4.5 of the USB specification version 1.0.

ODD\_RST Setting this bit resets all the BDT ODD ping/pong bits to 0 which then specify the EVEN BDT bank.
USB\_EN / SOF\_EN Setting this bit enables the VUSB; clearing the bit disables the VUSB. Setting this bit causes the SIE to reset all of its ODD bits to the BDTs. Thus, setting this bit resets much of the logic in the SIE.
When host mode is enabled clearing this bit causes the SIE to stop sending SOF tokens.

#### 70000098h USB Address register

**USB ADDR** 

| Bit   | 7     | 6 | 5 | 4 | 3         | 2 | 1 | 0 |
|-------|-------|---|---|---|-----------|---|---|---|
| Name  | LS_EN |   |   |   | ADDR[6:0] |   |   |   |
| Туре  | R/W   |   |   |   | R/W       |   |   |   |
| Reset | 0     |   |   |   | 0         |   |   |   |



LS EN The Low Speed enable bit informs the VUSB that the next token command written to the token register must be performed at low speed. This indication enables the VUSB to perform necessary preparations for low speed data transmissions.

ADDR[6:0] This 7-bit value defines the USB address that the VUSB decodes in peripheral mode, or transmits when in host mode.

#### 7000009Ch **USB BDT page 1 register**

**USB BDT PAG** E\_01

| Bit   | 7 | 6 | 5 | 4            | 3 | 2 | 1 | 0 |
|-------|---|---|---|--------------|---|---|---|---|
| Name  |   |   |   | BDT_BA [15:8 | ] |   |   |   |
| Type  |   |   |   | R/W          |   |   |   |   |
| Reset |   |   |   | 0            |   |   |   |   |

#### 700000B0h **USB BDT page 2 register**

USB\_BDT\_PAG

E 02

| Bit   | 7 | 6              | 5 | 4 | 3 | 2 |  | 1 | 0 |
|-------|---|----------------|---|---|---|---|--|---|---|
| Name  |   | BDT_BA [23:16] |   |   |   |   |  |   |   |
| Type  |   | R/W            |   |   |   |   |  |   |   |
| Reset |   |                |   | 0 |   |   |  |   |   |

#### **USB BDT page 3 register** 700000B4h

USB\_BDT\_PAG

E 03

| Bit   | 7 | 6 | 5 | 4             | 3  |          | 2 | 1 | 0 |
|-------|---|---|---|---------------|----|----------|---|---|---|
| Name  |   |   | В | BDT_BA [31:24 | 4] | <u> </u> |   |   |   |
| Type  |   |   |   | R/W           |    |          |   |   |   |
| Reset |   |   |   | 0             |    | ,        |   | • |   |

BDT\_BA[31:8] These 3 registers combined forms the BDT\_PAGE pointer. Set these bytes as follows:

 $USB\_BDT\_PAGE\_01 = 0x0$ 

 $USB\_BDT\_PAGE\_02 = 0x0$ 

 $USB_BDT_PAGE_03 = 0xBD$ 

#### 700000A0h **USB Frame number low byte register**

**USB FRM NU** 

ML

| Bit   | 7 | 6 | 5    |             | 4   | 3     | 2 | 1 | 0 |
|-------|---|---|------|-------------|-----|-------|---|---|---|
| Name  |   |   |      |             | FRM | [7:0] |   |   |   |
| Type  |   |   | _ 7/ |             | R   | 0     |   |   |   |
| Reset |   |   |      | <b>&gt;</b> | (   | )     |   |   |   |

#### USB Frame number high byte register 700000A4h

USB\_FRM\_NU MH

| Bit   | 7 | 6 | 5 | 4 | 3 | 2 | 1         | 0 |
|-------|---|---|---|---|---|---|-----------|---|
| Name  |   |   |   |   |   |   | FRM[10:8] |   |
| Type  | 4 |   |   |   |   |   | RO        |   |
| Reset |   |   |   |   |   |   | 0         |   |

FRM[10:0] These 2 registers combined represent the 11-bit frame number. The registers are updated with the current frame number whenever a SOF TOKEN is received.

| 700000A8h | USB | Token | register |
|-----------|-----|-------|----------|
|-----------|-----|-------|----------|

**USB TOKEN** 

| Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|---|---|---|---|---|---|---|



| Name  | TOKEN_PID | TOKEN_ENDPT |
|-------|-----------|-------------|
| Type  | R/W       | R/W         |
| Reset | 0         | 0           |

The Token Register is used when performing USB transactions when in host mode (HOST\_MODE\_EN=1). When the host processor wishes to execute a USB transaction to a peripheral, it writes the TOKEN type and endpoint to this register. Once this register has been updated the VUSB begins the specified USB transaction to the address contained in the Address Register. The host processor must check that the TOKEN\_BUSY bit in the control register is not set before performing a write to the Token Register: checking ensures that token commands are not overwritten before they can be executed. The address register and endpoint control register 0 are also used when performing a token command and therefore must also be updated before the Token Register. The address register is used to select the correct USB peripheral address to transmit by the token command. The endpoint control register determines the handshake and retry policies used during the transfer.

**TOKEN\_PID** This 4-bit value is the token type that is executed by the VUSB. Valid tokens are:

| TOKEN_PID | TOKEN type | Description                            |
|-----------|------------|----------------------------------------|
| 0001      | OUT        | VUSB performs an OUT (TX) Transaction  |
| 1001      | IN         | VUSB performs an IN (RX) Transaction   |
| 1101      | SETUP      | VUSB performs a SETUP (TX) Transaction |

**TOKEN\_ENDPT** This 4-bit value determines the Endpoint address for the token command. The 4-bit value that is written must be a valid endpoint.

## 700000ACh USB SOF threshold register

USB\_SOF\_THL

| Bit   | 7 | 1        | 0 |    |   |  |  |  |  |  |  |
|-------|---|----------|---|----|---|--|--|--|--|--|--|
| Name  |   | CNT[7:0] |   |    |   |  |  |  |  |  |  |
| Type  |   |          |   | R/ | W |  |  |  |  |  |  |
| Reset |   |          |   |    | ) |  |  |  |  |  |  |

The Start Of Frame (SOF) Threshold Registers are used only in HOST\_MODE. When HOST\_MODE is enabled, the 14-bit SOF counter counts the interval between SOF frames. The SOF must be transmitted every millisecond so the SOF counter is loaded with a value of 12000 since it is based on a 12MHz internal counter. When the SOF counter reaches zero, a SOF token is transmitted. The SOF threshold register is used to program the number of USB byte times *before* the SOF to stop initiating token packet transactions. This register must be set to a value that ensures that other packets are not actively being transmitted when the SOF timer count reaches zero. When the SOF counter reaches the threshold value, no more tokens are transmitted until after the SOF has been transmitted. The value programmed into the threshold register must reserve enough time to ensure that the worst case transaction completes. In general the worst case transaction is an IN token followed by a data packet from the target, followed by the response from the host. The actual time required is a function of the maximum packet size on the bus. Typical values for the SOF threshold are:

| Package size (bytes) | Time (byte times) |
|----------------------|-------------------|
| 64                   | 74                |
| 32                   | 42                |
| 16                   | 26                |
| 8                    | 18                |

**CNT[7:0]** These bits represents the SOF count threshold in BYTE times.



#### 700000C0h~

700000FFh

## **USB Endpoint Control register**

USB\_EP\_CTLN

| Bit   | 7               | 6         | 5 | 4          | 3        | 2        | 1        | 0         |
|-------|-----------------|-----------|---|------------|----------|----------|----------|-----------|
| Name  | HOST_WO_<br>HUB | RETRY_DIS |   | EP_CTL_DIS | EP_RX_EN | EP_TX_EN | EP_STALL | EP_HSHK I |
| Type  | R/W             | R/W       |   | R/W        | R/W      | R/W      | R/W      | R/W       |
| Reset | 0               | 0         |   | 0          | 0        | 0        | 0        | 0         |

The Endpoint Control Registers contains the endpoint control bits for each of the 16 endpoints available on USB for a decoded address. These four bits define all of the control necessary for any one endpoint. The formats for these registers are shown in the table on the following page. Endpoint 0 (ENDP0) is associated with control pipe 0 which is required by USB for all functions. Therefore, after a USB\_RST interrupt has been received the microprocessor must set ENDPT0 to contain 0x0D. In host mode ENDPT0 is used to determine the handshake, retry and low-speed characteristics of the host transfer. For host mode control, bulk and interrupt transfers, the EP\_HSHK bit must be set to 1; for Isochronous transfers the EP\_HSHK must be set to 0. Common values for ENDPT0 in host mode are 0x4D for Control, Bulk and Interrupt transfers, and 0x4C for Isochronous transfers.

HOST\_WO\_HUB HOST mode only. This bit is only present in the control register for endpoint 0 (endpt0\_rg). When this bit is set, the host can communicate with a directly connected low-speed device. When cleared, the host produces a PRE\_PID then switches to low-speed signaling when sending a token to a low-speed device, as required for communication with a low-speed device via a hub.

RETRY\_DIS HOS

HOST mode only. This bit is only present in the control register for endpoint 0 (endpt0\_rg). When this bit is set, the host does not reattempt NAK'ed transactions. When a transaction is NAK'ed, the BDT PID field is updated with the NAK pid, and the token done interrupt is set. When this bit is cleared, NAK'ed transactions are retried in hardware. This bit must be set when the host is attempting to poll an interrupt endpoint.

#### EP\_CTL\_DIS, EP\_RX\_EN, EP\_TX\_EN

These 3 bits define if an endpoint is enabled and the direction of the endpoint. The endpoint enable/direction control is defined as follows:

| ep ctl dis | ep rx en | ep tx en | endpoint en / direction control                     |
|------------|----------|----------|-----------------------------------------------------|
| X          | 0        | 0        | Disable Endpoint                                    |
| X          | 0        | 1        | Enable Endpoint for TX transfers only               |
| X          | 1        | 0        | Enable Endpoint for RX transfers only               |
| 1          | 1        | 1        | Enable Endpoint for both RX and TX transfers        |
| 0          | 1        | 1        | Enable Endpoint for RX and TX and control transfers |

**EP STALL** 

When set to 1, this bit indicates that the endpoint is stalled. This bit has priority over all other control bits in the End Point Enable register, but is only valid if EP\_TX\_EN=1 or EP\_RX\_EN=1. Any access to this endpoint causes the VUSB to return a STALL handshake. Once an endpoint is stalled, intervention from the Host Controller is required.

**EP HSHK** 

Setting this bit determines if an endpoint performs handshaking during a transaction to this endpoint. This bit is generally set to 1 unless the endpoint is an Isochronous endpoint.

## 700000410h USB DMA enable

**USB DMA EN** 

| Bit   | 7 |   | 6 | 5 | 4 | 3          | 2          | 1          | 0          |
|-------|---|---|---|---|---|------------|------------|------------|------------|
| Name  |   |   |   |   |   | TX2_DMA_EN | RX2_DMA_EN | TX1_DMA_EN | RX1_DMA_EN |
| Type  |   | 5 | , |   |   | W          | W          | W          | W          |
| Reset |   |   |   |   |   | 0          | 0          | 0          | 0          |

These are 1 shot signal.

**TX2 DMA EN** Setting this bit enablesTX2 DMA.



**RX2\_DMA\_EN** Setting this bit enables RX2 DMA.

**TX1\_DMA\_EN** Setting this bit enables TX1 DMA.

**RX1\_DMA\_EN** Setting this bit enables RX1 DMA.

#### 700000414h USB DMA disable

**USB DMA DIS** 

| Bit   | 7 | 6 | 5 | 4 | 3           | 2           | 1           | 0           |
|-------|---|---|---|---|-------------|-------------|-------------|-------------|
| Name  |   |   |   |   | TX2_DMA_DIS | RX2_DMA_DIS | TX1_DMA_DIS | RX1_DMA_DIS |
| Type  |   |   |   |   | W           | W           | W           | W           |
| Reset |   |   |   |   | 0           | 0           | 0           | 0           |

These are 1 shot signal.

**TX2 DMA DIS** Setting this bit disables TX2 DMA.

**RX2\_DMA\_DIS** Setting this bit disables RX2 DMA.

**TX1\_DMA\_DIS** Setting this bit disables TX1 DMA.

**RX1\_DMA\_DIS** Setting this bit disables RX1 DMA.

## 700000414h USB DMA address counter clear

USB\_DMA\_ADDR\_CNTE

R\_CLR

| Bit   | 7 | 6 | 5 | 4 | 3           | 2           |             | 0           |
|-------|---|---|---|---|-------------|-------------|-------------|-------------|
| Name  |   |   |   |   | TX2_DMA_CLR | RX2_DMA_CLR | TX1_DMA_CLR | RX1_DMA_CLR |
| Type  |   |   |   |   | W           | W           | W           | W           |
| Reset |   |   |   |   | 0           | 0           | 0           | 0           |

These are 1 shot signals.

**TX2\_DMA\_CLR** Setting this bit clears the TX2 DMA address pointer.

**RX2\_DMA\_CLR** Setting this bit clears the RX2 DMA address pointer.

**TX1\_DMA\_CLR** Setting this bit clears the TX1 DMA address pointer.

**RX1\_DMA\_CLR** Setting this bit clears the RX1 DMA address pointer.

#### 7000041Ch USB DMA FM select register

USB\_DMA\_FM\_SELEC

T

| Bit   | 7 | 6 | 5 | 4 | I | 3 | 2 | 1     | 0     |
|-------|---|---|---|---|---|---|---|-------|-------|
| Name  |   |   |   |   | Τ |   |   | DMA_F | M_SEL |
| Type  |   |   |   |   |   |   |   | R/    | W     |
| Reset |   |   |   |   |   |   |   | (     | )     |

#### **FAST MODE ONLY**

**DMA\_FM\_SEL** Selects which USB DMA controller the FM controller should use.

00: Use RX1 DMA
 01: Use TX1 DMA
 10: Use RX2 DMA
 11: Use TX1 DMA

## 70000420h USB Soft Reset

USB\_SOFT\_RE SET

| Bit   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0              |
|-------|---|---|---|---|---|---|---|----------------|
| Name  |   |   |   |   |   |   |   | SOFT_RESE<br>T |
| Type  |   |   |   |   |   |   |   | W              |
| Reset |   |   |   |   |   |   |   | 0              |

**SOFT\_RESET** Setting this bit to 1 invokes a synchronous soft reset. The asserted bit holds high for 4 clock counts, therefore, software must not issue any read/write within 4T of this reset.



#### 70000450h USB PHY Control

# USB\_PHY\_CTR

| Bit   | 7 | 6 | 5 | 4 | 3 | 2 | 1               | 0      |
|-------|---|---|---|---|---|---|-----------------|--------|
| Name  |   |   |   |   |   |   | PUSW2EB_<br>REG | MANUAL |
| Type  |   |   |   |   |   |   | R               | R      |
| Reset |   |   |   |   |   |   | 0               | 0      |

#### **DEBUG ONLY**

The 2 register bits are used to manually control IPUSW2EB signal to PHY. When Manual =1, IPUSW2EB contains the value of IPUSW2EB\_REG.

# 6.4 Memory Stick and SD Memory Card Controller

#### 6.4.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. Furthermore, the controller also support SDIO card specification version 1.0 partially. 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.4.2 Overview

## 6.4.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 42 shows how they are shared. In Table 42, 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 42 Sharing of pins for Memory Stick and SD/MMC Memory Card Controller

## 6.4.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 12**. 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 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 13**. 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<sub>CD</sub> 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<sub>CD</sub> 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 12**.



Figure 12 Card detection for Memory Stick



Figure 13 Card detection for SD/MMC Memory Card



# 6.4.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 + 0054h     | SDIO Configuration Register                         | SDIO_CFG     |
| MSDC + 0058h     | SDIO Status Register                                | SDIO_STA     |
| 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 43 MS/SD Controller Register Map

# 6.4.3.1 Global Register Definitions

# MSDC+0000h MS/SD Memory Card Controller Configuration Register MSDC\_CFG

| Bit   | 31 3  | 0 29       | 28         | 27   | 26  | 25  | 24  | 23         | 22   | 21        | 20         | 19         | 18        | 17        | 16        |
|-------|-------|------------|------------|------|-----|-----|-----|------------|------|-----------|------------|------------|-----------|-----------|-----------|
| Name  | F     | IFOTHD     | <b>(5)</b> | PRO  | FG2 | PRO | FG1 | PRC        | FG0  | VDDP<br>D | RCDE<br>N  | DIRQ<br>EN | PINE<br>N | DMAE<br>N | INTE<br>N |
| Type  |       | R/W        | W          | R/   | W   | R/W | R/W | R/W        | R/W  | R/W       | R/W        |            |           |           |           |
| Reset |       | 0001 01 01 |            |      |     |     |     |            | 0    | 0         | 0          | 0          | 0         | 0         | 0         |
| Bit   | 15 14 | 4 13       | 12         | 8    | 7   | 6   | 5   | 4          | 3    | 2         | 1          | 0          |           |           |           |
| Name  |       |            | SC         | LKF  |     |     |     | SCLK<br>ON | CRED | STDB<br>Y | CLKS<br>RC | RST        | NOCR<br>C | RED       | MSD<br>C  |
| Type  |       |            | R          | /W   |     |     |     | R/W        | R/W  | R/W       | R/W        | W          | R/W       | R/W       | R/W       |
| Reset |       |            | 0000       | 0000 |     |     |     | 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.
  - O 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'.
  - O 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.
  - O 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.
  - 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=26MHz. If USB clock is used, the fastest clock rate for memory card is 48/2=24MHz.
  - 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.
  - O 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.
  - O 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_{slave}$  and clock frequency of the MS/SD controller as  $f_{host}$  which is 104 or 52 MHz. Then the value of the register field is as follows. Note that the allowable maximum frequency of  $f_{slave}$  is 26MHz.

```
 \begin{array}{ll} \textbf{00000000b} & f_{slave} = (1/2) * f_{host} \\ \textbf{00000001b} & f_{slave} = (1/(4*1)) * f_{host} \\ \textbf{00000010b} & f_{slave} = (1/(4*2)) * f_{host} \\ \end{array}
```

**00000011b** 
$$f_{slave} = (1/(4*3))* f_{host}$$

**00010000b**  $f_{\text{slave}} = (1/(4*16))* f_{\text{host}}$ 



**11111111b**  $f_{\text{slave}} = (1/(4*255)) * 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.
  - 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.
  - O 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.
  - 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.
  - 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.
  - 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** Pull Up/Down Register Configuration for the pin WP. The default value is 10.
  - **00** Pull up resistor and pull down resistor in the I/O pad of the pin WP are all disabled.
  - **01** Pull down resistor in the I/O pad of the pin WP is enabled.
  - 10 Pull up resistor in the I/O pad of the pin WP 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.
  - 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. The default value is 0b01.



- OP Pull up resistor and pull down resistor in the I/O pads of the pins DATO, DAT1, DAT2, DAT3. 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. 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 |    |    |    |    |   |   |   | FIFOC | NT |   | INT | DRQ | BE | BF |
| Туре  | 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.
  - 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.
  - FIFO in MS/SD controller is not empty.
  - FIFO in MS/SD controller is empty.
- 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.
  - No DMA request exists.
  - 1 DMA request exists.
- 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.
  - No interrupt request exists.
  - 1 Interrupt request exists.
- 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.

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'.

- 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  |    |    |    |    |    |    |   |   | SDIOI<br>RQ | SDR1<br>BIRQ | MSIFI<br>RQ | SDMC<br>IRQ |    | SDCM<br>DIRQ | PINIR<br>Q | DIRQ |
| 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.
  - O 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.
  - 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.
  - 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.
  - No SD DAT line interrupt.
  - 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.

- 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.

- O No MS Bus Interface interrupt.
- 1 MS Bus Interface interrupt exists.

sdriber 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. Single block write commands with R1b response will cause the interrupt when the command completes no matter successfully or with CRC error. However, multi-block write commands with R1b response do not cause the interrupt because multi-block write commands are always stopped by STOP\_TRANS commands.

STOP\_TRANS commands (with R1b response) behind multi-block write commands will cause the interrupt. Single block read command with R1b response will cause the interrupt when the command completes but multi-block read commands do not. Note that STOP\_TRANS commands (with R1b response) behind multi-block read commands will cause the interrupt.

- 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 |     |    |    |    |    |    |      |        |    |    |    |    |    |    |    |
| Name |    |     |    |    |    |    |    | DATA | [15:0] |    |    |    |    |    |    |    |
| Type |    | •   |    | •  | •  |    |    |      | 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   | 31 | 30         | 29   | 28 | 27 | 26 | 25 | 24  | 23              | 22 | 21 | 20         | 19   | 18        | 17    | 16   |
|-------|----|------------|------|----|----|----|----|-----|-----------------|----|----|------------|------|-----------|-------|------|
| Name  |    |            |      |    |    |    |    | CMD |                 |    |    | D          | AT . |           |       |      |
| Type  |    |            |      |    |    |    | )  | RO  |                 |    |    | R          | 0    |           |       |      |
| Reset |    |            |      |    |    |    |    | -   |                 |    |    |            |      |           |       |      |
| Bit   | 15 | 14         | 13   | 12 | 11 | 10 | 9  | 8   | 5 1 6 5 4 5 2 1 |    |    |            |      |           | 0     |      |
| Name  | (  | CDDEB      | OUNC | E  |    |    |    |     |                 |    |    | PINC<br>HG | PIN0 | POEN<br>0 | PIEN0 | CDEN |
| Type  |    | R'         | W    |    |    |    |    |     |                 |    |    | RC         | RO   | R/W       | R/W   | R/W  |
| Reset |    | RW<br>0000 |      |    |    |    |    |     |                 |    |    | 0          | 1    | 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.



- Card detection is disabled.
- 1 Card detection is enabled.

**PIENO** The register bit is used to control input pin for card detection.

- Input pin for card detection is disabled.
- 1 Input pin for card detection is enabled.

**POEN0** The register bit is used to control output of input pin for card detection.

- 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.

- Otherwise.
- 1 Card is inserted or removed.

**CDDEBOUNCE** The register field specifies the time interval for card detection de-bounce. Its default value is 0. It means that de-bounce interval is 32 cycle time of 32KHz. The interval will extend one cycle time of 32KHz by increasing the counter by 1.

**DAT** Memory Card Data Lines.

**CMD** Memory Card Command Lines.

## 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  |    |    |    |    |    |    | PRC | FG3 | SRCF<br>G1 | SRCF<br>G0 | 0 | DCCF | 31 | 0 | DCCFG | 0 |
| Type  |    |    |    |    |    |    | R/  | W   | R/W        | R/W        |   | R/W  |    |   | R/W   |   |
| Reset |    |    |    |    |    |    | 1   | 0 0 | _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

**000** 2mA

**001** 4mA

**010** 6mA

**011** 8mA

**ODCCFG1** Output driving capability the pins DAT0, DAT1, DAT2 and DAT3

**000** 2mA

**001** 4mA

**010** 6mA

**011** 8mA

**SRCFG0** Output driving capability the pins CMD/BS and SCLK

O Fast Slew Rate

Slow Slew Rate

**SRCFG1** Output driving capability the pins DAT0, DAT1, DAT2 and DAT3

Fast Slew Rate

Slow Slew Rate

PRCFG3 Pull Up/Down Register Configuration for the pin INS. The default value is 10.



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

## 6.4.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  |    |     |     | DT   | ОС   |    |    |    |    | WD     | OD     |    | SDIO | MDL<br>W8 | MDLE<br>N | SIEN |
| Type  |    |     |     | R/   | W    |    |    |    |    | R      | W      |    | R/W  | R/W       | R/W       | R/W  |
| Reset |    |     |     | 0000 | 0000 |    |    |    |    | 00     | 00     |    | 0    | 0         | 0         | 0    |
| Bit   | 15 | 14  | 13  | 12   | 11   | 10 | 9  | 8  | 7  | 6      | 5      | 4  | 3    | 2         | 1         | 0    |
| Name  |    | BSY | DLY |      |      |    |    |    |    | BLK    | LEN    |    |      |           |           |      |
| Type  |    | R/  | W   |      |      |    |    |    |    | R/     | W      |    |      |           |           |      |
| Reset |    | 10  | 00  |      |      |    |    |    |    | 000000 | 000000 |    |      |           |           |      |

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.

**00000000000** Reserved.

**00000000001** Block length is 1 byte. **000000000010** Block length is 2 bytes.

. . .

**01111111111** 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.

- O Serial interface for SD/MMC is disabled.
- 1 Serial interface for SD/MMC is enabled.

MDLW8 Eight Data Line Enable. The register works when MDLEN is enabled. The register can be enabled only when MultiMediaCard 4.0 is applied and detected by software application.

- 4-bit Data line is enabled.
- 1 8-bit Data line is enabled.

SDIO SDIO Enable.

SDIO mode is disabled



1 SDIO mode is enabled

MDLENMultiple 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.

- 4-bit Data line is disabled.
- 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   | 31   | 30   | 29  | 28  | 27  | 26          | 25 | 24    | 23 | 22        | 21 | 20 | 19  | 18  | 17 | 16          |
|-------|------|------|-----|-----|-----|-------------|----|-------|----|-----------|----|----|-----|-----|----|-------------|
| Name  |      |      |     |     |     |             |    |       |    |           |    |    |     |     |    | CMDF<br>AIL |
| Type  |      |      |     |     |     |             |    |       |    |           |    |    |     |     |    | R/W         |
| Reset |      |      |     |     |     |             |    |       |    |           |    |    |     |     |    | 0           |
| Bit   | 15   | 14   | 13  | 12  | 11  | 10          | 9  | 8     | 7  | 6         | 5  | 4  | 3   | 2   | 1  | 0           |
| Name  | INTC | STOP | RW  | DTY | /PE | IDRT        |    | RSPTY | P  | BREA<br>K |    |    | CN  | /ID |    |             |
| Type  | R/W  | R/W  | R/W | R/  | W 🌲 | R/W         |    | R/W   |    | R/W       |    |    | R/  | W   |    |             |
| Reset | 0    | 0    | 0   | 0   | 0   | <u>_</u> 0_ |    | 000   |    | 0         |    |    | 000 | 000 |    |             |

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.

- Other fields are valid.
- 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'.

- 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.
- O11 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.

Note that the response type R4 and R5 mentioned above is for MMC only.

For SDIO, RSPTYP definition is different and shall be set to:

- (i) CMD5 of SDIO is to be issued. (Where the response is defined as R4 in SDIO spec)
  (ii) CMD52 or CMD53 for READ is to be issued. (Where the response is defined as R5 in SDIO spec)
- 111 CMD52 for I/O abort or CMD53 for WRITE is to be issued (Where the response is defined as R5 in SDIO spec)
- IDRT Identification Response Time. The register bit indicates if the command has a response with N<sub>ID</sub> (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).
  - 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.
  - O The command is a read command.
  - 1 The command is a write command.
- The register bit indicates if the command is a stop transmission command. It should be set to 1 when CMD12 (SD/MMC) or CMD52 with I/O abort (SDIO) is to be issued.
  - **0** The command is not a stop transmission command.
  - 1 The command is a stop transmission command.
- **INTC** 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.



- The command is not GO\_IRQ\_STATE.
- 1 The command is GO\_IRQ\_STATE.

**CMDFAIL** The register bit is used for controlling SDIO interrupt period when CRC error or Command/Data timeout condition occurs. It is useful only when SDIO 4-bit mode is activated.

- SDIO Interrupt period will re-start after a stop command (CMD12) or I/O abort command (CMD52) is issued.
- 1 SDIO Interrupt period will re-start whenever DAT line is not busy.

#### 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 |    |    |    |    |    |    |    | ARG [ | 31:16] |    |    |    |    | $oldsymbol{ abla}$ |    |    |
| Type |    |    |    |    |    |    |    | R/    | W      |    |    |    |    |                    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6  | 5  | 4  | 3  | 2                  | 1  | 0  |
| Name |    |    |    |    |    |    |    | ARG   | [15:0] |    |    |    |    |                    |    |    |
| 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  | WP |    |    |    |    |    |   |   |   |   | V | R1BS<br>Y | RSV | DATB<br>USY | CMDB<br>USY | SDCB<br>USY |
| Type  | R  |    |    |    |    |    |   |   |   |   |   | RO        | RO  | RO          | RO          | RO          |
| Reset | ī  |    |    |    |    |    |   |   |   |   |   | 0         | 0   | 0           | 0           | 0           |

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.

- 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.

- O No transmission is going on DAT line on SD bus.
- 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.

- O 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.
- 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,  |    |    |    |    |    |    | RESP | 31:16] |    |    |    |    |    |    |    |

MediaTek Inc. Confidential



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

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

| SIM | DECIM  |
|-----|--------|
|     |        |
|     | nlor i |

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23      | 22 | 21 | 20 | 19 18 | 17 16 | ; |
|------|----|----|----|----|----|----|----|------|---------|----|----|----|-------|-------|---|
| Name |    |    |    |    |    |    |    | RESP | [63:48] |    |    |    |       |       |   |
| Type |    |    |    |    |    |    |    | R    | 0       |    |    |    |       |       |   |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7       | 6  | 5  | 4  | 3 2   | 1 0   |   |
| Name |    |    |    |    |    |    |    | RESP | [47:32] |    |    |    |       | ,     | П |
| Type |    |    |    |    |    |    |    | R    | 0       |    |    |    |       |       |   |

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] | 4  |          |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R    | 0       |    |          |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7       | 6  | 5        | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    | RESP | [79:64] |    | <i>-</i> |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R    | 0       |    |          |    |    |    |    |    |

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 |    |    |    |    |    |    | 1  | 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       | <u> </u> |    |    |    |    | ·  |    |

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

#### SDC\_CMDSTA

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3          | 2                 | 1         | 0          |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|------------|-------------------|-----------|------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   | MMCI<br>RQ | RSPC<br>RCER<br>R | CMDT<br>O | CMD<br>RDY |
| Type  |    |    | I. |    |    |    |   |   |   |   |   |   | RC         | RC                | RC        | RC         |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   | 0          | 0                 | 0         | 0          |



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

- 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.

- 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.

- Otherwise.
- 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.

- 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  |    |    |    |    |    |    |   | 1          |   |   |   |   |   | DATC<br>RCER<br>R | DATT<br>O | BLKD<br>ONE |
| Type  |    |    |    |    |    |    |   | <b>T</b> 5 |   |   |   |   |   | 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.

- 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.

- 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.

- 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</b> | [31:16] |    |    |    |    |    |    |    |
| Type  |    |               |    |    |    |    |     | R           | C       |    |    |    |    |    |    |    |
| Reset |    | 0000000000000 |    |    |    |    |     |             |         |    |    |    |    |    |    |    |
| Bit   | 15 |               |    |    |    |    |     |             |         |    |    |    |    |    |    | 0  |
| Name  |    |               |    |    |    |    |     | CSTA        | [15:0]  |    |    |    |    |    |    |    |
| Type  |    |               |    |    |    |    |     | R           | C       |    |    |    |    |    |    |    |
| Reset |    |               |    |    |    |    | 000 | 000000      | 000000  | 00 |    |    |    |    |    |    |

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\_IRQMASK

0

| Bit   | 31 | 30                  | 29 | 28 | 27 | 26 | 25  | 24          | 23      | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|---------------------|----|----|----|----|-----|-------------|---------|-----|----|----|----|----|----|----|
| Name  |    |                     |    |    |    |    | IR  | <b>QMAS</b> | K [31:1 | 6]  |    |    |    |    |    |    |
| Type  |    |                     |    |    |    |    |     | R/          | W       |     |    |    |    |    |    |    |
| Reset |    | 0000000000000000000 |    |    |    |    |     |             |         |     |    |    |    |    |    |    |
| Bit   | 15 | 14                  | 13 | 12 | 11 | 10 | 9   | 8           | 7       | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |                     |    |    |    |    | IF  | RQMAS       | K [15:0 | 0]  |    |    |    |    |    |    |
| Type  |    |                     |    |    |    |    |     | R/          | W       |     |    |    |    |    |    |    |
| Reset |    |                     |    |    | •  |    | 000 | 000000      | 000000  | 000 | •  |    |    |    |    |    |



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

SDC\_IRQMASK

1

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

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.

## MSDC+0054h SDIO Configuration Register

SDIO\_CFG

| Bit   | 31 | 30 | 29 | 28 | 27 | 26  | 25 | 24         | 23 | 22 | 21 | 20 | 19 | 18         | 17         | 16        |
|-------|----|----|----|----|----|-----|----|------------|----|----|----|----|----|------------|------------|-----------|
| Name  |    |    |    |    |    |     |    | <b>4</b> 7 |    |    |    |    |    |            |            |           |
| Type  |    |    |    |    |    |     |    |            |    |    |    |    |    |            |            |           |
| Reset |    |    |    |    |    |     |    |            |    |    |    |    |    |            |            |           |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10  | 9  | 8          | 7  | 6  | 5  | 4  | 3  | 2          | 1          | 0         |
| Name  |    |    |    |    |    |     |    |            |    |    |    |    |    | DSBS<br>EL | INTSE<br>L | INTE<br>N |
| Туре  |    |    |    |    |    | . ( |    |            |    |    |    |    |    | R/W        | R/W        | R/W       |
| Reset |    |    |    |    |    |     |    |            |    |    |    |    |    | 0          | 0          | 0         |

The register is used to configure functionality for SDIO.

**INTEN** Interrupt enable for SDIO.

- O Disable
- 1 Enable

**INTSEL**Interrupt Signal Selection

- Use data line 1 as interrupt signal
- 1 Use data line 5 as interrupt signal

**DSBSEL** Data Block Start Bit Selection.

- Use data line 0 as start bit of data block and other data lines are ignored.
- 1 Start bit of a data block is received only when data line 0-3 all become low.

## MSDC+0058h SDIO Status Register

SDIO\_STA

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| וכו   |    | 00 |    |    |    |    |    |    |    |    |    |    | 10 | 10 |    | 10 |
| Nama  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| LIVDE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |



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

### 6.4.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  | PMOD<br>E | PRED |    |    |    |    |   |   |   |   |   |   | В | USYCNI |   | SIEN |
| Туре  | 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 x 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 5x4+2=22 serial clock cycles causes a RDY timeout error.

000 Not detect RDY timeout

**001** BUSY signal exceeding 1x4+2=6 serial clock cycles causes a RDY timeout error.

**010** BUSY signal exceeding 2x4+2=10 serial clock cycles causes a RDY timeout error.

...

111 BUSY signal exceeding 7x4+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.

- 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.

- 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  |    | P  | D  |    |    |    | DATASIZE  R/W |   |   |   |   |   |   |   |   |   |  |
| Type  |    | R/ | W  |    |    |    | R/W           |   |   |   |   |   |   |   |   |   |  |
| Reset |    | 00 | 00 |    |    |    | 000000000     |   |   |   |   |   |   |   |   |   |  |

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 '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.

**000000000** Data size is 0 byte.

**000000001** Data size is one byte.

**000000010** Data size is two bytes.

...

**0111111111** Data size is 511 bytes.

**100000000** 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 | T | 2           | 1   | 0 |
|-------|----|----|-----|----|----|-----------|---|---|---|---|---|---|---|---|-------------|-----|---|
| Name  |    | AF | PID |    |    |           |   |   |   |   |   |   |   |   | <b>ACEN</b> |     |   |
| Type  |    | R/ | W   |    |    | R/W       |   |   |   |   |   |   |   |   |             | R/W |   |
| Reset |    | 01 | 11  |    |    | 000000001 |   |   |   |   |   |   |   |   | 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.

- Auto Command is disabled.
- 1 Auto Command is enabled.

**ADATASIZE** Data size in unit of byte for Auto Command. Initial value is 0x01.

**000000000** Data size is 0 byte.

**000000001** Data size is one byte.

**000000010** Data size is two bytes.

...

**0111111111** Data size is 511 bytes.

**100000000** 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  | CMDN<br>K | BREQ | ERR | CED |    |    |   |   |   |   |   | HSRD<br>Y | CRCE<br>R | 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.



- 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.
  - Otherwise.
  - 1 A transaction on MS bus is ended.
- 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



- 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.
  - O 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.
  - Otherwise.
  - 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.
  - Otherwise.
  - 1 A Memory Stick card responds to a TPC by RDY.
- 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.
  - O 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.
  - 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.
  - 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.
  - Otherwise
  - Indicate non-recognized command.

## 6.4.4 Application Notes

#### 6.4.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.4.4.2 Card Detection Procedures

The pseudo code is as follows:

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.4.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.4.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.4.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.4.4.6 Notes on Response Timeout

If a read command doest 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
- Issue STOP\_TRANS command => Get Response
- 3. Read register SDC\_DATSTA to clear it

#### 6.4.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. DMAn\_CON.SIZE=0
- 2. DMAn\_CON.BTW=1
- 3. DMAn\_CON.BURST=2 (or 4)
- 4. DMAn\_COUNT=byte number instead of word number
- 5. fifo threshold setting must be 1 (or 2), depending on DMAn\_CON.BURST

Note  $n=4 \sim 11$ 

#### 6.4.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.5 Graphic Memory Controller

# 6.5.1 General Description

Graphic memory controller provides channels to allow graphic engines to access SYSRAM and External Memory. Simple Request-Acknowledgement handshaking scheme is employed here to ease the complexity of memory access control circuitry in each graphic engine.



To maximize data bandwidth, five individual access ports are implemented, which can access different memory banks simultaneously. **Figure 14** shows the connection between GMC, AHB, and memories. One access port is connected to the SYSRAM, and the other access port for external memory access is connected to data cache directly.



Figure 14 Graphic memory controller

# 6.5.2 Register Definitions

| Register Address | Register Function              | Acronym          |
|------------------|--------------------------------|------------------|
| GMC + 0000h      | GMC Control Register           | GMC_CON          |
| GMC + 0004h      | GMC Match Address Register     | GMC_MATCHADDR    |
| GMC + 0008h      | GMC Mask Address Register      | GMC_MASKADDR     |
| GMC + 000Ch      | GMC INRANGE Master Register    | GMC_INRANGE_MAST |
| GMC + 0010h      | GMC Bandwidth Limiter Register | GMC_LIMITER      |
|                  |                                |                  |

**Table 44** GMC Registers

## GMC+0000h GMC Control Register

|    |    | _ |   | N I |
|----|----|---|---|-----|
| G۱ | ทษ | L | U | N   |

| 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  | TRAP |    |    |    |    |    |    |    |    |    |    |    |    | BURS |     |     |
|       | CLR  |    |    |    |    |    |    |    |    |    |    |    |    | T    | INV | EN  |
| Type  | W    |    |    |    |    |    |    |    |    |    |    |    |    | R/W  | R/W | R/W |
| Reset | 0    |    |    |    |    |    |    |    |    |    |    |    |    | 1    | 0   | 0   |

This register is used to control the functionality for GMC.

**TRAP EN** To enable address-trapping function. When this function is turned on, GMC compares the address between the address configured in GMC Match Address Register and the address issued to memory.



When the address is matched, the engine number that issued the request is recorded. The record can be read from GMC INRANGE Master Register

**Table 6** shows the engine number of each engine.

| Engine<br>Number | Engine Name | Engine<br>Number | Engine Name            |
|------------------|-------------|------------------|------------------------|
| 0                | MP4/JPEG    | 10               | CAM (high priority)    |
| 1                | MP4/JPEG    | 11               | TVE (high priority)    |
| 2                | MP4/JPEG    | 12               | MP4_MV (high priority) |
| 3                | MP4/JPEG    | 13               | 2D WRITE               |
| 4                | MP4/JPEG    | 14               | 2D COMMAND QUEUE       |
| 5                | RESIZER     | 15               | 2D READ                |
| 6                | RESIZER     | 16               | GIF                    |
| 7                | RESIZER     | 17               | PNG                    |
| 8                | IMAGE DMA   | 18               | IPP                    |
| 9                | IMAGE DMA   |                  |                        |

**Table 45** Engine number

**TRAP INV** Enable trapping range inversion. If this register bit is set, the engine, which issues the address out of the address range specified with GMC\_MATCHADDR, and GMC\_MASKADDR, is trapped. The register bit in GMC\_INRANGE\_MAST is set accordingly.

Enable burst mode. If burst mode is enabled, arbiter does not change the grant until finishing the burst.

On the other hand, GMC treats every request as a SINGLE transfer.

**TRAP CLR** This register field is used to clear the record in GMC INRANGE Master Register. This register field is a write only register field.

### GMC+0004h GMC Match Address Register

GMC\_MATCHA DDR

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

This register is used to specify the trapping address for the address-trapping function.

**ADDR** The trapping address.

## GMC+0008h GMC Mask Address Register

GMC\_MASKAD

DR

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

This register is used to specify the address mask the address-trapping function. The address comparator ignores the address bits that is set as "1" in the GMC Mask Address Register.

MASK address mask.



## GMC+000Ch GMC INRANGE Master Register

# GMC\_INRANGE MAST

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

This register is used to show the trapped engine..

**ENGn** The trapped address is issued by corresponding engine.

## GMC+0010h GMC Bandwidth Limiter Register

#### **GMC\_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    | $\sqrt{4}$ | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    | LIMI | TER        |    |    |    |    |
| Type  |    |    |    |    |    |    | RW |    |    |    |      |            |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |      | 0          |    |    |    |    |

This register is used for slow-down function of GMC EMI interface.

LIMITER

This register field is used to specify the period that GMC EMI interface can issue a bus request to AHB. LIMITER represents an AHB request can only be issued in LIMITER X 4 clock cycles. The value of LIMITER is from 0 to 1023.

## 6.6 2D acceleration

# 6.6.1 2D Engine

#### 6.6.1.1 General Description

To enhance MMI display and gaming experiences, a 2D acceleration engine is implemented. It supports ARGB8888, RGB888, ARGB4444, RGB565 and 8-bpp color modes. Main features are listed as follows:

- Rectangle fill with color gradient.
- Bitblt: multi-Bitblt without transform, 7 rotate, mirror (transparent) Bitblt
- Alpha blending
- Binary ROP
- Line drawing: normal line, dotted line, anti-alias line
- Font caching: normal font, italic font
- Circle drawing
- Quadratic Bezier curve drawing
- Triangle drawing



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 parser is implemented for further offloading of MCU. The command queue can be randomly assigned in the system memory, with a maximum depth of 2047 commands. If the command queue is enabled, MCU has to check if the command queue has free space before writing to the command queue. Command queue parser will consume command queue entries upon 2D engine requests. **Figure 15** shows the command queue and 2D engine block diagram. Please refer to the graphic command queue functional specification for more details.



Figure 15 The command queue and 2D engine block diagram.

#### 6.6.1.2 Features Introduction

#### 6.6.1.2.1 2D Coordinate

The coordinates in the 2D engine are represented as 12-bit signed integers. The negative part is clipped during rendering. The maximum resolution can achieve 2047x2047 pixels. The programmed base address is mapped to the origin of the picture, which is illustrated in **Figure 16**.



Figure 16 The coordinate of the 2D engine.



#### 6.6.1.2.2 Color format

The 2D engine support the color format of 8bpp, RGB565, RGB888, ARGB4444, and ARGB 8888. The color formats of source and destination can be specified separately. Note that when using the 8bpp format, the source and destination color formats have to be the same, since table-lookup of color palette is not provided in 2D engine. Graphic modes of Bitblt, Bitblt with alpha blending, and Bitblt with binary ROP require color format setting for both source and destination. For other graphic modes, only destination color format needs to be specified. The possible settings are listed as **Table 46Table 47**.

| Bitblt (Copy, ROP)  |                          |  |  |  |  |  |
|---------------------|--------------------------|--|--|--|--|--|
| Source color format | Destination color format |  |  |  |  |  |
| 8bpp                | 8bpp                     |  |  |  |  |  |
| DCD565              | RGB565                   |  |  |  |  |  |
| RGB565              | RGB888                   |  |  |  |  |  |
| DCD000              | RGB565                   |  |  |  |  |  |
| RGB888              | RGB888                   |  |  |  |  |  |
| ARGB4444            | ARGB4444                 |  |  |  |  |  |
| AKUB4444            | ARGB8888                 |  |  |  |  |  |
| ADCD0000            | ARGB4444                 |  |  |  |  |  |
| ARGB8888            | ARGB8888                 |  |  |  |  |  |

Table 46 source and destination color format setting for Bitblt.

| Bitblt with Alpha Blending |                                 |  |  |  |  |  |
|----------------------------|---------------------------------|--|--|--|--|--|
| Source color format        | <b>Destination color format</b> |  |  |  |  |  |
| 8bpp                       | 8bpp                            |  |  |  |  |  |
| RGB565                     | RGB565                          |  |  |  |  |  |
| KUD303                     | RGB888                          |  |  |  |  |  |
| RGB888                     | RGB565                          |  |  |  |  |  |
| KUD000                     | RGB888                          |  |  |  |  |  |
| ARGB4444                   | RGB565                          |  |  |  |  |  |
| AKUD4444                   | RGB888                          |  |  |  |  |  |
| ARGB8888                   | RGB565                          |  |  |  |  |  |
| ARUD0000                   | RGB888                          |  |  |  |  |  |

Table 47 source and destination color format setting for alpha blending.

When source image is used, the source key function could be enabled or disabled. When enabled, the source color key is in the same format of source color. Be aware that the source key is still effective for alpha blending mode.

### 6.6.1.2.3 Clipping Window

The setting for clipping window is effective for all the 2D graphics. A pair of minimum and maximum boundary is applied on destination side. The portion outside the clipping window will not be drawn to the destination, but the pixels on the boundary will be kept. The clipping operation is illustrated in **Figure 17**.





Figure 17 The clipping operation of the 2D engine.

#### 6.6.1.2.4 Bitblt operation

The Bitblt function copies the pixels from source picture to destination. To be more flexible, 4 copy directions and 7 kinds of rotations are provided when doing Bitblt operation. **Figure 18** illustrates the Bitblt operation and required settings.



Figure 18 The clipping operation of the 2D engine.

Note that the size of source and destination blocks can be different. If the source block is larger than destination block, the size of destination block is used instead of the source size. When source block size is smaller than destination block size, the pattern of source block is repeated horizontally and vertically in the destination block, which is illustrated as **Figure 19** below.





Figure 19 The Bitblt operation when destination size > source size.

#### 6.6.1.2.4.1 Copy direction

When the source block and destination blocks are on the same picture, they may be overlapped by each other. To prevent error from occurring, 4 directions for Bitblt can be programmed. However, the copy direction shall not be enabled when doing rotation, or it will produce unwanted results. The 4 kinds of copy direction are shown in **Figure 20**.



Figure 20 The 4 directions of Bitblt operation.

6.6.1.2.4.2 Rotation

To facilitate Bitblt operation, 7 kinds of rotation can be set at the same time. The rotation operation is illustrated as **Figure 21**. Here the rotation is done on the destination side, while the read sequence of pixels in source block is fixed.





Figure 21 The rotations of Bitblt operation.

#### 6.6.1.2.5 Bitblt with Alpha Blending

Similar to simple Bitblt operation, alpha blending function is provided as well. The pixels in source block are blended onto destination block. Blending is performed according the formula listed below:

$$C = (alpha * Cs + (255 - alpha) * Cd)/255,$$

where Cs is the source color, Cd is the destination color, and alpha is an unsigned integer range from 0 to 255.

The alpha value programmed into the 2D control registers is called constant alpha. When no alpha channel exists, the constant alpha is used to calculate blended color. If the alpha channel exists (in ARGB color mode), the per-pixel alpha is used for blending operation instead of constant alpha.

In addition, the setting of copy directions and rotations are also effective for alpha blending mode. Also, the size and color format of source block can be different from destination.

#### 6.6.1.2.6 Bitblt with Binary ROP

The ROP (Raster Operation) is another block-wise functional mode. Here the 2D engine provides a set of binary ROPs. The ROP code has 16 different combinations, which is listed in the definition of 2D control registers --- G2D\_SMODE\_CON. Please see sec.1.1.1.3 for detail descriptions.

Similar with other block-wise functions, the copy directions and rotations are also applicable in ROP mode. The size and color format of source and destination do not need to be the same.

#### 6.6.1.2.7 Rectangle Fill with Color Gradient

Rectangle fill mode provides the configurations for color gradient for both x-direction and y-direction. Each of the color gradient of component A, R, G, B is represented by 9.16 signed fixed point number. In order to prevent color crossing the boundary of 0 and 255, it is clipped to 0 and 255 when performing gradient fill. When the color gradient is disabled, the rectangle is filled by one color. An example of gradient fill is shown in **Figure 22**.





Figure 22 Rectangle gradient fill.

#### 6.6.1.2.8 Line Draw

The line drawing function is implemented with the mid-point algorithm. Given the two endpoints of a line, the points on the line are calculated recursively. The line anti-aliasing is also supported but it requires extra register configurations. In addition, dotted line is also provided for use. Simultaneously turning on anti-aliasing and dotted-line is not recommended since the line may result in a strange look.

#### 6.6.1.2.9 Circle Draw

The circle drawing is quite similar with line drawing, using the mid-point algorithm as well. A center point and a radius have to be programmed into 2D control registers. There are 4 enable bits for each quadrant of a circle, each determines whether the arcs shall be rendered or not. The setting of circle drawing is illustrated in **Figure 23**.



Figure 23 Circle drawing.

#### 6.6.1.2.10 Bezier curve

The quadratic Bezier curve is implemented, too. The quadratic Bezier curve is defined by three control points, as illustrated in **Figure 24**. The Bezier curve drawing is implemented with subdivision method. The amount of subdivisions is programmed by software. The curve gets more detailed with the increase of subdivision factor, but it requires more memory and computing time. To be more precise, doing n times of subdivision needs a buffer of  $2^{(n+1)}*4$  bytes.





Figure 24 Bezier curve.

#### 6.6.1.2.11 Triangle Flat Fill

The 2D engine supports the function of triangle flat fill with the help of software. First, the software divides the triangle into upper plane and lower plane and passes them to hardware individually. Given the starting vertex's coordinate and the slopes of left and right edges, the 2D hardware fills the horizontal segments between the two edges until the horizontal end is reached. The slope of each edge is in 12.16 bit signed fix-point representation. The programming of triangle drawing is illustrated in **Figure 25**.



Figure 25 Triangle drawing.

#### 6.6.1.2.12 Font Drawing

The 2D engine helps to render fonts stored in one-bit-per-pixel format. It expends the zero bits to background color and expands one bits to foreground color. The background color can be set as transparent. The font drawing can be programmed as tilt, when given each line's tilt value.



The start bit of font drawing can be non-byte aligned to save memory usage for font caching. In addition, the rotations can be performed at the same time when drawing fonts.

## 6.6.1.3 Register Definitions

Table 48 The 2D engine register mapping. summarizes the 2D engine register mapping on APB and through command queue. The base address of 2D engine is 80670000h.

| APB Address | CMQ<br>mapped<br>Address | Register Function                              | Acronym     |
|-------------|--------------------------|------------------------------------------------|-------------|
| G2D+0100h   | 100h                     | 2D engine fire mode control register           | FMODE_CON   |
|             | 102h                     | Reserved                                       |             |
| G2D+0104h   | 104h                     | 2D Engine sub-mode control lower register      | SMODE_CON_L |
|             | 106h                     | 2D Engine sub-mode control higher register     | SMODE_CON_H |
| G2D+0108h   | 108h                     | 2D engine common control register              | COM_CON     |
|             | 10Ah                     | Reserved                                       |             |
| G2D+0110h   | 110h                     | 2D engine status register                      | STA         |
|             | 112h                     | Reserved                                       |             |
| G2D+0200h   | 200h                     | Source base address lower hword register       | SRC_BASE_L  |
|             | 202h                     | Source base address higher hword register      | SRC_BASE_H  |
| G2D+0204h   | 204h                     | Source pitch register                          | SRC_PITCH   |
|             | 206h                     | Reserved                                       |             |
| G2D+0208h   | 208h                     | Source y coordinate register                   | SRC_Y       |
|             | 20Ah                     | Source x coordinate register                   | SRC_X       |
| G2D+020Ch   | 20Ch                     | Source height register                         | SRC_H       |
|             | 20Eh                     | Source width register                          | SRC_W       |
| G2D+0210h   | 210h                     | Source color key lower hword register          | SRC_KEY_L   |
|             | 212h                     | Source color key lower hword register          | SRC_KEY_H   |
| G2D+0300h   | 300h                     | Destination base address lower hword register  | DST_BASE_L  |
|             | 302h                     | Destination base address higher hword register | DST_BASE_H  |
| G2D+0304h   | 304h                     | Destination Pitch Register                     | DST_PITCH   |
|             | 306h                     | Reserved                                       |             |
| G2D+0308h   | 308h                     | Destination y coordinate register 0            | DST_Y0      |
|             | 30Ah                     | Destination x coordinate register 0            | DST_X0      |
| G2D+030Ch   | 30Ch                     | Destination y coordinate register 1            | DST_Y1      |
|             | 30Eh                     | Destination x coordinate register 1            | DST_X1      |
| G2D+0310h   | 310h                     | Destination y coordinate register 2            | DST_Y2      |
|             | 312h                     | Destination x coordinate register 2            | DST_X2      |
| G2D+0318h   | 318h                     | Destination height register                    | DST_H       |
|             | 31Ah                     | Destination width register                     | DST_W       |
| G2D+400h    | 400h                     | Foreground color lower hword register          | FGCLR_L     |
|             | 402h                     | Foreground color lower hword register          | FGCLR_H     |
| G2D+404h    | 404h                     | Background color lower hword register          | BGCLR_L     |
|             | 406h                     | Background color lower hword register          | BGCLR_H     |



| G2D+408h                 | 408h        | Clipping minimum y coordinate register           | CLP_MIN_Y               |
|--------------------------|-------------|--------------------------------------------------|-------------------------|
|                          | 40Ah        | Clipping minimum x coordinate register           | CLP_MIN_X               |
| G2D+40Ch                 | 40Ch        | Clipping maximum y coordinate register           | CLP_MAX_Y               |
|                          | 40Eh        | Clipping maximum x coordinate register           | CLP_MAX_X               |
| G2D+410h                 | 410h        | Rectangle color gradient x lower hword register  | REC_CLRGD_X_L           |
|                          | 412h        | Rectangle color gradient x higher hword register | REC_CLRGD_X_H           |
| G2D+414h                 | 414h        | Rectangle color gradient y lower hword register  | REC_CLRGD_Y_L           |
|                          | 416h        | Rectangle color gradient y higher hword register | REC_CLRGD Y_H           |
| G2D+0700h ~<br>G2D+071Fh | 700h ~ 71Fh |                                                  | TILT_0300~<br>TILT_IF1C |

Table 48 The 2D engine register mapping.

There are several function modes in 2D graphics engine. Some registers are shared between different them. **Table 49** summarizes the settings under different function modes.

| APB<br>Address              | CMQ<br>Addres<br>s | Rectangle fill           | Bitblt<br>Operations     | Line/Circle<br>drawing | Bezier curve<br>drawing | Triangle drawing | Font caching             |
|-----------------------------|--------------------|--------------------------|--------------------------|------------------------|-------------------------|------------------|--------------------------|
| G2D+0200h                   | 200h               |                          | SRC_BASE                 |                        | . (7)                   | SLOPE_L          | SRC_BASE                 |
| G2D+0204h                   | 204h               |                          | SRC_PITCH                |                        |                         |                  |                          |
| G2D+0208h                   | 208h               |                          | SRC_XY                   |                        |                         |                  |                          |
| G2D+020Ch                   | 20Ch               |                          | SRC_SIZE                 |                        |                         |                  |                          |
| G2D+0210h                   | 210h               |                          | SRC_KEY                  |                        |                         |                  | SRC_KEY                  |
| G2D+0300h                   | 300h               | DST_BASE                 | DST_BASE                 | DST_BASE               | DST_BASE                | DST_BASE         | DST_BASE                 |
| G2D+0304h                   | 304h               | DST_PITCH                | DST_PITCH                | DST_PITCH              | DST_PITCH               | DST_PITCH        | DST_PITCH                |
| G2D+0308h                   | 308h               | DST_XY                   | DST_XY                   | DST_XY0                | DST_XY0                 | DST_XY_START     | DST_XY                   |
| G2D+030Ch                   | 30Ch               |                          | 4                        | DST_XY1/<br>RADIUS     | DST_XY1                 | DST_Y_END        |                          |
| G2D+0310h                   | 310h               |                          |                          |                        | DST_XY2                 |                  |                          |
| G2D+0318h                   | 318h               | DST_SIZE                 | DST_SIZE                 |                        |                         |                  | DST_SIZE                 |
| G2D+0400h                   | 400h               | START_CLR                |                          | FGCLR                  | FGCLR                   | FGCLR            | FGCLR                    |
| G2D+0404h                   | 404h               |                          | DST_KEY                  | XY_SQRT                |                         |                  | BGCLR                    |
| G2D+0408h                   | 408h               | CLP_MIN                  | CLP_MIN                  | CLP_MIN                | CLP_MIN                 | CLP_MIN          | CLP_MIN                  |
| G2D+040Ch                   | 40Ch               | CLP_MAX                  | CLP_MAX                  | CLP_MAX                | CLP_MAX                 | CLP_MAX          | CLP_MAX                  |
| G2D+0410h                   | 410h               | ALPGD_X                  |                          |                        | BUF_STA_ADD             | SLOPE_R          |                          |
| G2D+0414h                   | 414h               | RED_GD_X                 |                          |                        | SUBDIV_TIME             |                  |                          |
| G2D+0418h                   | 418h               | GREEN_GD_X               |                          |                        |                         |                  |                          |
| G2D+041Ch                   | 41Ch               | BLUE_GD_X                |                          |                        |                         |                  |                          |
| G2D+0420h                   | 420h               | ALPGD_Y                  |                          |                        |                         |                  |                          |
| G2D+0424h                   | 424h               | RED_GD_Y                 |                          |                        |                         |                  |                          |
| G2D+0428h                   | 428h               | GREEN_GD_Y               |                          |                        |                         |                  |                          |
| G2D+042Ch                   | 42Ch               | BLUE_GD_Y                |                          |                        |                         |                  |                          |
| G2D+0700h<br>~<br>G2D+071Fh | 700h ~<br>71Fh     | TILT_0300 ~<br>TILT_1F1C | TILT_0300 ~<br>TILT_1F1C |                        |                         |                  | TILT_0300 ~<br>TILT_1F1C |



| APB<br>Address              | CMQ<br>Addres<br>s | Horizontal Line<br>Gradient | Horizontal<br>Line Copy<br>with Mask |        |     |  |
|-----------------------------|--------------------|-----------------------------|--------------------------------------|--------|-----|--|
| G2D+0200h                   | 200h               |                             | SRC_BASE                             |        |     |  |
| G2D+0204h                   | 204h               |                             |                                      |        |     |  |
| G2D+0208h                   | 208h               |                             |                                      |        |     |  |
| G2D+020Ch                   | 20Ch               |                             | SRC_SIZE                             |        | 4   |  |
| G2D+0210h                   | 210h               |                             |                                      |        |     |  |
| G2D+0300h                   | 300h               | DST_BASE                    | DST_BASE                             |        | 60  |  |
| G2D+0304h                   | 304h               |                             |                                      |        |     |  |
| G2D+0308h                   | 308h               |                             |                                      |        |     |  |
| G2D+030Ch                   | 30Ch               |                             |                                      |        | (7) |  |
| G2D+0310h                   | 310h               |                             |                                      |        |     |  |
| G2D+0318h                   | 318h               | DST_SIZE                    | DST_SIZE                             |        |     |  |
| G2D+0400h                   | 400h               | START_CLR                   |                                      | 70     | 7   |  |
| G2D+0404h                   | 404h               |                             |                                      | . (7/) |     |  |
| G2D+0408h                   | 408h               |                             |                                      |        |     |  |
| G2D+040Ch                   | 40Ch               |                             |                                      |        |     |  |
| G2D+0410h                   | 410h               | ALPGD_X                     | MASK_BASE                            |        |     |  |
| G2D+0414h                   | 414h               | RED_GD_X                    |                                      |        |     |  |
| G2D+0418h                   | 418h               | GREEN_GD_X                  |                                      |        |     |  |
| G2D+041Ch                   | 41Ch               | BLUE_GD_X                   |                                      |        |     |  |
| G2D+0420h                   | 420h               |                             |                                      |        |     |  |
| G2D+0424h                   | 424h               |                             |                                      |        |     |  |
| G2D+0428h                   | 428h               |                             |                                      |        |     |  |
| G2D+042Ch                   | 42Ch               |                             |                                      |        |     |  |
| G2D+0700h<br>~<br>G2D+071Fh | 700h ~<br>71Fh     |                             |                                      |        |     |  |

Table 49 2D engine common registers

Below shows common control registers.

# G2D+0100h Graphic 2D Engine Fire Mode Control Register

G2D\_FMODE\_C ON

| Bit   | 15 | 14 | 13 | 12 | 11   | 10    | 9    | 8 | 7    | 6     | 5    | 4 | 3  | 2    | 1     | 0  |
|-------|----|----|----|----|------|-------|------|---|------|-------|------|---|----|------|-------|----|
| Name  |    |    |    |    | SRC_ | CLR_I | MODE |   | DST_ | CLR_N | IODE |   | G2 | D_EN | G_MOD | DE |
| Type  |    |    |    |    |      | R/W   |      |   |      | R/W   |      |   |    | R/   | W     |    |
| Reset |    | 4  |    |    |      | 000   |      |   |      | 000   |      |   |    | 00   | 00    |    |

Write this register will fire the 2D engine according to the CLR\_MODE and ENG\_MODE field.

**SRC\_CLR\_MODE** source color mode

0008-bpp, LUT disabled

**001** 16-bpp, RGB 565 format

**010** 32-bpp, ARGB 8888 format



**011** 24-bpp, RGB 888 format

101 16-bpp, ARGB 4444 format

others reserved

**DST CLR MODE** destination color mode

000 8-bpp, LUT disabled

**001** 16-bpp, RGB 565 format

**010** 32-bpp, ARGB 8888 format

**011** 24-bpp, RGB 888 format

**101** 16-bpp, ARGB 4444 format

others reserved

**G2D\_ENG\_MODE** 2D engine function mode

**0000** Line draw.

0001 Circle draw.

**0010** Bezier curve draw.

**0011** Triangle fill.

**1000** Rectangle fill.

**1001** Bitblt.

**1010** Bitblt with alpha blending.

**1011** Bitblt with ROP.

**1100** Font drawing.

Horizontal line fill with color gradient. In this mode, the source key and the clipping functions are disabled automatically.

Horizontal line copy with mask. In this mode, the source key and the clipping functions are disabled automatically.

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  | FITA | FNBG | FMSB<br>_FIRS<br>T |    |      |    |    |            |                              | ALP | РНА |     |      | ROP_ | CODE |    |  |
| Type  | R/W  | R/W  | R/W                |    |      |    |    |            |                              | R/  | W   |     |      | R/W  |      |    |  |
| Reset | 0    | 0    | 0                  |    |      |    |    |            | 0000                         |     |     |     |      | 0000 |      |    |  |
| Bit   | 15   | 14   | 13                 | 12 | 11   | 10 | 9  | 8          | 7                            | 6   | 5   | 4   | 3    | 2    | 1    | 0  |  |
| Name  |      |      |                    |    | LDOT |    |    | LAA_<br>EN | DST_<br>KEY_<br>EN D_EN BDIR |     |     | DIR | BITA |      | BROT |    |  |
| Туре  |      |      |                    |    | R/W  |    |    | R/W        | R/W                          | R/W | R/  | W   | R/W  |      | R/W  |    |  |
| Reset |      |      |                    |    | 0    |    |    | 0          | 0                            | 0   | 1   | 1   | 0    |      | 111  |    |  |

Write this register to set the 2D engine configuration.

**FITA** font italic enabled.

**FNBG** font drawing with no background color

**FMSB FIRST** font drawing from most significant bit

ALPHA Bit 7-4 of constant alpha value. ROP\_CODE is Bit3-0 of constant alpha value.

**ROP\_CODE** Binary ROP code. Bits 2-0 are also used to specify the start bit position for Font drawing and enabled arcs for circle drawing.

| Bitblt ROP Code Boolean Function Start Bit Position for Font Drawing Enabled Arcs | ] | Bitblt ROP Code | Boolean Function |  | Enabled Arcs |
|-----------------------------------------------------------------------------------|---|-----------------|------------------|--|--------------|
|-----------------------------------------------------------------------------------|---|-----------------|------------------|--|--------------|



| 0000 | 0 (Black) | Bit 0 | None           |
|------|-----------|-------|----------------|
| 0001 | ~(S + D)  | Bit 1 | Ι              |
| 0010 | ~S . D    | Bit 2 | II             |
| 0011 | ~S        | Bit 3 | Ι, Π           |
| 0100 | S . ~D    | Bit 4 |                |
| 0101 | ~D        | Bit 5 | I, III         |
| 0110 | S ^ D     | Bit 6 | П, Ш           |
| 0111 | ~(S . D)  | Bit 7 | І,П, Ш         |
| 1000 | S.D       | Bit 0 | IV             |
| 1001 | ~(S ^ D)  | Bit 1 | I , IV         |
| 1010 | D         | Bit 2 | П, Ш           |
| 1011 | ~S + D    | Bit 3 | I, II, IV      |
| 1100 | S         | Bit 4 | III, IV        |
| 1101 | S + ~D    | Bit 5 | I, III, IV     |
| 1110 | S + D     | Bit 6 | П, Ш, IV       |
| 1111 | 1 (White) | Bit 7 | I, II, III, IV |

S = Source, D = Destination.

I = first quadrant, II = second quadrant, III = third quadrant, IV = fourth quadrant.

**LDOT** line dotted

LAA EN line anti-aliasing enabled

**DST\_KEY\_EN** Destination key enabled for Bitblt functions

**CLRGR\_EN** Color gradient enabled for rectangle fill

**BDIR** Bitblt direction:

00 from lower right corner

**01** from lower left corner

10 from upper right corner

11 from upper left corner

This field only takes effect when the Bitblt rotation is set as none (111). When doing rotation the Bitblt direction of source image is always from upper left corner.

BITA Bitblt italic enabled, using the tilt value defined in G2D\_TILT\_00 ~ G2D\_TILT\_1F registers. The tilt function should not be enabled in Alpha Blending and ROP mode.

**BROT** Bitblt rotation:

**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 CO** 

N

| 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  |    |    |    |    |    |    |   |   |   |   |   |   |   | CLP_<br>EN | SRCK<br>EY_E<br>N | RST |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   | R/W        | R/W               | R/W |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   | 0          | 0                 | 0   |

Write this register to set the 2D engine configuration.

**RST** 2D engine reset, only the state machine is reset, the content of control registers will not be reset.

**SRCKEY\_EN** Source key enabled.

**CLP\_EN** Clipping enabled.

#### G2D+010Ch Graphic 2D Engine Interrupt Control Register

G2D\_IRQ\_CON

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | <u>√19</u> ] | 18 | 17 | 16  |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|--------------|----|----|-----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |              |    |    |     |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    | 1/           |    |    |     |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |              |    |    |     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 74 | 3            | 2  | 1  | 0   |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |              |    |    | EN  |
| 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  |    |    |    |    |    |    |    | $\mathbf{M}^{T}$ |    |    |    |    |    |    |    |      |
| Reset |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |    |      |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0    |
| Name  |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |    | BUSY |
| Type  |    |    |    |    |    |    | RE |                  |    |    |    |    |    |    |    | 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

#### G2D+0200h Graphic 2D Source Base Address Register

**G2D SRC BAS** 

Е

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

**SRC\_BASE** The base address of source image. Also, this field is used for the slope of the left triangle edges represented in 12.16 format.



#### G2D+0204h Graphic 2D Engine Source Pitch Register

# G2D\_SRC\_PITC

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

**SRC\_PITCH** The width of source image in the unit of pixels.

#### G2D+0208h Graphic 2D Engine Source X and Y Register

#### **G2D SRC XY**

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

**SRC\_Y** The starting y co-ordinate of source image. It must be positive although represented as 12-bit signed integer.

**SRC\_X** The starting x co-ordinate of source image. It must be positive although represented as 12-bit signed integer.

#### G2D+020Ch Graphic 2D Engine Source Size Register

#### G2D\_SRC\_SIZE

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

**SRC\_H** The source height for Bitblt, alpha blending and ROP. It must be positive although represented as 12-bit signed integer.

**SRC\_W** The source width for Bitblt, alpha blending and ROP. It must be positive although represented as 12-bit signed integer.

#### G2D+0210h Graphic 2D Engine Source Color Key Register

#### G2D\_SRC\_KEY

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

**SRC\_KEY**The source color key. The color will be transparent if color keying is enabled.

# G2D+0300h Graphic 2D Destination Base Address Register

G2D\_DST\_BAS

E

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|-------|---------|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    | DS | T_BAS | SE[31:1 | 6] |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R/    | W       |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | (     | )       |    |    |    |    |    |    |    |



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

**DST BASE**The base address of destination image.

#### G2D+0304h Graphic 2D Engine Destination Pitch Register

G2D\_DST\_PITC

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

**DST\_PITCH** The width of destination image in the unit of pixels.

#### G2D+0308h Graphic 2D Engine Destination X and Y Register 0 G2D\_DST\_XY

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

(DST\_X0, DST\_Y0) is used as the starting co-ordinate in Bitblt, alpha blending, ROP, and font drawing mode. In line mode or triangle fill mode, it is used as one end point. For Bezier curve drawing, it is one of the control points. While in circle drawing mode, it is the center of the circle. Also this filed is used as the starting point of triangle draw.

**DST\_X0** Represented by 12-bit signed integer. Negative co-ordinate is allowed.

**DST\_YO** Represented by 12-bit signed integer. Negative co-ordinate is allowed.

# G2D+030Ch Graphic 2D Engine Destination X and Y Register 1 G2D\_DST\_XY1

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

(DST\_X1, DST\_Y1) is used as one end point in Line drawing and triangle fill mode. For Bezier curve drawing, it is one of the control points. While in circle drawing mode, DST\_X1 must be positive since it is the radius of the circle. Also, Bit 15-0 is used as the vertical end of triangle draw.

**DST X1** Represented by 12-bit signed integer. Negative co-ordinate is allowed.

**DST\_Y1** Represented by 12-bit signed integer. Negative co-ordinate is allowed.

## G2D+0310h Graphic 2D Engine Destination X and Y Register 2 G2D\_DST\_XY2

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



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

(DST\_X2, DST\_Y2) is used as one end point in triangle fill mode. For Bezier curve drawing, it is one of the control points.

- **DST\_X2** Represented by 12-bit signed integer. Negative co-ordinate is allowed.
- **DST\_Y2** Represented by 12-bit signed integer. Negative co-ordinate is allowed.

#### G2D+0318h Graphic 2D Engine Destination Size Register

**G2D DST SIZE** 

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21 2 | 20 | 19 1 | 8   | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|-----|------|----|------|-----|----|----|
| Name  |    |    |    |    |    |    |    |    |    | DST | _W   |    |      |     |    |    |
| Type  |    |    |    |    |    |    |    |    |    | R/\ | N    |    |      |     |    |    |
| Reset |    |    |    |    |    |    |    |    |    | 0   |      |    | - 74 |     |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6   | 5    | 4  | 3    | 2 🗍 | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    | DST | _H   |    |      |     |    |    |
| Type  |    |    |    |    |    |    |    |    |    | R/\ | N    |    | 2    |     |    |    |
| Reset |    |    |    |    |    |    |    |    |    | 0   |      |    |      |     |    |    |

- **SRC\_H** The source height for Bitblt, alpha blending and ROP. It must be positive although represented as 12-bit signed integer.
- **SRC\_W** The source width for Bitblt, alpha blending and ROP. It must be positive although represented as 12-bit signed integer.

#### G2D+0400h Graphic 2D Engine Foreground Color Register

G2D FGCLR

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

**FGCLR** The foreground color used for line/circle drawing and font drawing. It is also the start color of rectangle fill. The format of foreground color depends on the source color mode set in G2D\_FMODE\_CON register.

#### G2D+0404h Graphic 2D Engine Background Color Register

| $\sim$ |   | D  | $\frown$ | $\sim$ |   |
|--------|---|----|----------|--------|---|
| GZ     | U | ים | יט       |        | ᄓ |

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

**BGCLR**The background color of the source. The format of background color depends on the source color mode set in G2D\_FMODE\_CON register. Bit 15-0 also used as the **XY\_SQRT** for anti-aliased line drawing. The XY\_SQRT calculation is listed as bellow.

$$XY \_SQRT = 2 * \sqrt{(DST \_X1 - DST \_X0)^2 + (DST \_Y1 - DST \_Y0)^2}$$

## G2D+0408h Graphic 2D Engine Clipping Minimum Register

| G2L | ) CL | ו או | VIIN |
|-----|------|------|------|
|     |      |      | •••• |

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21     | 20         | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|--------|------------|----|----|----|----|
| Name |    |    |    |    |    |    |    |    |    | CL | IP_MIN | _ <b>X</b> |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    | R/W    |            |    |    |    |    |



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

**CLIP\_MIN\_X** The minimum value of x co-ordinate in clipping window, signed 12-bit integer.

**CLIP MIN Y** The minimum value of y co-ordinate in clipping window, signed 12-bit integer..

#### G2D+040ch Graphic 2D Engine Clipping Maximum Register

|     |      | AAV |
|-----|------|-----|
| GZL | ו או | ИΑХ |
|     |      |     |

| Bit   | 31 | 30 | 29 | 28 | 27 | 26         | 25 | 24 | 23 | 22  | 21     | 20         | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|------------|----|----|----|-----|--------|------------|----|----|----|----|
| Name  |    |    |    |    |    |            |    |    |    | CLI | P_MA)  | <b>(_X</b> |    |    |    |    |
| Type  |    |    |    |    |    | R/W        |    |    |    |     |        |            |    |    |    |    |
| Reset |    |    |    |    |    | 1111111111 |    |    |    |     |        |            |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10         | 9  | 8  | 7  | 6   | 5      | 4          | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |            |    |    |    | CLI | P_MA)  | <u>(_Y</u> |    |    |    |    |
| Type  |    |    |    |    |    |            |    |    |    |     | R/W    |            |    |    |    |    |
| Reset |    |    |    |    |    |            |    |    |    | 111 | 111111 | 111        |    |    |    |    |
|       | •  | •  |    |    |    | •          | •  | •  |    | •   | •      |            |    |    |    |    |

**CLIP\_MAX\_X** The maximum value of x co-ordinate in clipping window, signed 12-bit integer...

**CLIP\_MAX\_Y** The maximum value of y co-ordinate in clipping window, signed 12-bit integer..

#### G2D+0410h Graphic 2D X Alpha Gradient Register

#### G2D\_ALPGR\_X

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

The color gradient of alpha in x direction for rectangle gradient fill. Bit 31-0 is also used as the start address of the buffer used for Bezier curve draw. Also, this field is used for the slope of the right triangle edges represented in signed 12.16 format.

**ALPHA GR X** The color gradient of alpha channel, represented in signed 9.16 format.

#### G2D+0414h Graphic 2D X Red Gradient Register

#### **G2D REDGR X**

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

The color gradient of red in x direction for rectangle gradient fill. Bit 3-0 also used as the times of subdivision for Bezier curve drawing.

RED GR XThe color gradient of red component, represented in signed 9.16 format.

#### G2D+0418h Graphic 2D X Green Gradient Register

G2D\_ GREENGR X

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21    | 20   | 19      | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|-------|------|---------|----|----|----|
| Name |    |    |    |    |    |    |    |    |    | (  | GREEN | GR X | [24:16] |    |    |    |





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

**GREEN\_GR\_X** The color gradient of blue component, represented in signed 9.16 format.

#### G2D+041Ch Graphic 2D X Blue Gradient Register

#### G2D\_BLUEGR\_X

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

**BLUE\_GR\_X** The color gradient of blue component, represented in signed 9.16 format.

#### G2D+0420h Graphic 2D Y Alpha Gradient Register

## G2D\_ALPGR\_Y

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24    | 23    | 22   | <u>2</u> T J | 20   | 19               | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|-----|-------|-------|------|--------------|------|------------------|----|----|----|
| Name  |    |    |    |    |    |    |     |       |       | AL   | PHA_         | GR_\ | <b>/[24:16</b> ] |    |    |    |
| Type  |    |    |    |    |    |    |     |       |       |      |              | R/W  |                  |    |    |    |
| Reset |    |    |    |    |    |    |     |       |       |      |              | 0    |                  |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8     | 7     |      | 5            | 4    | 3                | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    | ALI | PHA_G | R_Y[1 | 5:0] |              |      |                  |    |    |    |
| Type  |    |    |    |    |    |    |     | R/    | W     |      |              |      |                  |    |    |    |
| Reset |    |    |    |    |    |    |     |       | )     |      |              |      |                  |    |    |    |

The color gradient of alpha in x direction for rectangle gradient fill.

ALPHA\_GR\_Y The color gradient of alpha channel, represented in signed 9.16 format.

#### G2D+0424h Graphic 2D Y Red Gradient Register

#### G2D\_REDGR\_Y

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

The color gradient of red in x direction for rectangle gradient fill.

**RED\_GR\_Y**The color gradient of red component, represented in signed 9.16 format.

# G2D+0428h Graphic 2D Y Green Gradient Register

G2D\_ GREENGR Y

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



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

**GREEN\_GR\_Y** The color gradient of blue component, represented in signed 9.16 format.

#### G2D+042Ch Graphic 2D Y Blue Gradient Register

|       |              | _    | - 1 |
|-------|--------------|------|-----|
|       |              |      | ٠,  |
| (コン!) | $\mathbf{H}$ | IFGR |     |
| UZD   |              |      |     |

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

**BLUE\_GR\_Y** The color gradient of blue component, represented in signed 9.16 format.

#### 6.6.2 Command Queue

#### 6.6.2.1 General Description

To enhance MMI display and gaming experiences, a command queue parser is implemented for further offloading of MCU. The command queue with a flexible depth setting is allocated in system memory. If the command queue is enabled, software program has to check if the command queue has free space before writing to the command queue data register. Command queue parser consumes the command queue entries upon 2D engine requests. **Figure 15** shows the command queue and 2D engine block diagram.



Figure 26 The command queue and 2D engine block diagram.

#### 6.6.2.2 Register Definitions

MCU APB bus registers are listed as follows. The base address of the command queue controller is 80660000h.



#### 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  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | WEN | EN  |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W | R/W |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0   | 0   |

**EN** Command queue enable. When EN is LOW, the command queue controller is reset.

**WEN** Command queue in write mode. When WEN is LOW, the command queue consumes the commands in the queue if command queue is not empty.

#### 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 |
|-------|------------|----|----|----|----|----|----|----|----|----|-------|-----|----|----|----|----|
| Name  |            |    |    |    |    |    |    |    |    |    |       |     |    |    |    |    |
| Type  |            |    |    |    |    |    |    |    |    |    |       |     |    |    |    |    |
| Reset |            |    |    |    |    |    |    |    |    |    |       |     |    |    |    |    |
| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5     | 947 | 3  | 2  | 1  | 0  |
| Name  | WR_R<br>DY |    |    |    |    |    |    |    |    |    | FREE  |     |    |    |    |    |
| Type  | RO         |    |    |    |    |    |    |    |    |    | RO    |     |    |    |    |    |
| Reset | 0          |    |    |    |    |    |    |    |    | 10 | 00000 | 00  |    |    |    |    |

**FREE** Number of free command queue entries.

**WR\_RDY** Ready to receive command, command-write is not allowed when this status bit is 0. Software has to check this bit before writing command to gcmq.

#### GCMQ+0008h Graphic Command Queue Data Register

#### GCMQ\_DAT

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25            | 24     | 23 | 22 | 21       | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|---------------|--------|----|----|----------|----|----|----|----|----|
| Name |    |    |    |    |    |    |               | abla I |    | AD | DR       |    |    |    |    |    |
| Type |    |    |    |    |    |    |               |        |    | W  | 0        |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9             | 8      | 7  | 6  | 5        | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    | $\overline{}$ | DA     | TA |    |          |    |    |    |    |    |
| Type |    | ·  |    |    |    |    |               | W      | 0  |    | <u> </u> |    |    |    |    |    |

**ADDR [11:0]** Write address for mapped 2D engine registers.

**DATA [15:0]** Write data for mapped 2D engine registers.

# GCMQ+000Ch Graphic Command Queue Base Address Register

#### GCMQ\_BASE\_ ADD

| Bit  | 31 | 30 | 29 | 28     | 27 | 26 | 25 | 24    | 23     | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|--------|----|----|----|-------|--------|-----|----|----|----|----|----|----|
| Name |    |    |    |        |    |    | BA | SE_AL | DD[31: | 16] |    |    |    |    |    |    |
| Type |    |    |    | $\Box$ |    |    |    | R/    | W      |     |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12_    | 11 | 10 | 9  | 8     | 7      | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |        |    |    | B  | ASE_A | DD[15: | 0]  |    |    |    |    |    |    |
| Type |    |    |    |        |    |    |    | R/    | W      |     |    |    |    |    |    |    |

**BASE\_ADD** Starting address of the command queue in memory.

<u>Note</u>: This field can only be modified while the command queue is not enabled; otherwise the behavior of the command queue is unpredictable.



#### GCMQ+0010h Graphic Command Queue Buffer Length Register

# GCMQ\_LENGT

| 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 |    |    |    |    |    |    |    |    |    | L  | ENGT | 1  |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    | R/W  |    |    |    |    |    |

**LENGTH[9:0]** Length of the command queue. Occupied space of the command queue in the memory is LENGTH \*4Bytes.

<u>Note</u>: This field can only be modified while the command queue is not enabled; otherwise the behavior of the command queue is unpredictable.

#### GCMQ+0014h Graphic Command Queue Current Register

#### GCMQ\_DMA\_A DDR

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24      | 23     | 22   | 21 | 20    | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|-----|---------|--------|------|----|-------|----|----|----|----|
| Name |    |    |    |    |    |    | GCI | $MQ_DI$ | /IA_AD | DR   |    |       |    |    |    |    |
| Type |    |    |    |    |    |    |     | R       | 0      |      |    | 7 D Z |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8       | 7      | 6    | 5  | 4     | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    | GC  | MQ_DI   | /IA_AD | DR 🌰 |    |       |    |    |    |    |
| Type |    | •  |    | •  | •  |    | •   | R       | 0      |      |    |       |    |    |    | •  |

GCMQ DMA ADDR Current read or write DMA address of GCMQ.

6.6.2.3

# 6.7 Capture Resize

# 6.7.1 General Description

This block provides the image resizing function for image and video capturing scenarios. It receives image data from the ISP module, performs the image resizing function and outputs to the IMG\_DMA module. **Figure 27** shows the block diagram. The capture resize is composed of horizontal and vertical resizing blocks. It can scale up or down the input image by any ratio. However, the maximum sizes of input and output images are limited to 2048x2048.



Figure 27 Block diagram of the capture resize

The horizontal resizing function is a combination of 2's power average and bi-linear interpolation. The vertical resizing function is a bi-linear interpolation. The input and output format are both YUV444. But the internal



working memory format is YUV422 to mitigate memory and bandwidth requirements. There is one GMC port employed in the capture resize for the vertical buffer read/write.

#### 6.7.2 **Register Definitions**

| REGISTER ADDRESS | REGISTER NAME                                                      | SYNONYM      |
|------------------|--------------------------------------------------------------------|--------------|
| CRZ+ 0000h       | Capture Resize Configuration Register                              | CRZ_CFG      |
| CRZ + 0004h      | Capture Resize Control Register                                    | CRZ_CON      |
| CRZ + 0008h      | Capture Resize Status Register                                     | CRZ_STA      |
| CRZ + 000Ch      | Capture Resize Interrupt Register                                  | CRZ_INT      |
| CRZ + 0010h      | Capture Resize Source Image Size Register 1                        | CRZ_SRCSZ1   |
| CRZ + 0014h      | Capture Resize Target Image Size Register 1                        | CRZ_TARSZ1   |
| CRZ + 0018h      | Capture Resize Horizontal Ratio Register 1                         | CRZ_HRATIO1  |
| CRZ + 001Ch      | Capture Resize Vertical Ratio Register 1                           | CRZ_VRATIO1  |
| CRZ + 0020h      | Capture Resize Horizontal Residual Register 1                      | CRZ_HRES1    |
| CRZ + 0024h      | Capture Resize Vertical Residual Register 1                        | CRZ_VRES1    |
| CRZ + 0040h      | Capture Resize Fine Resizing Configuration Register                | CRZ_FRCFG    |
| CRZ + 005Ch      | Capture Resize Pixel-Based Resizing Working Memory Base<br>Address | CRZ_PRWMBASE |
| CRZ + 00B0h      | Capture Resize Information Register 0                              | CRZ_INFO0    |
| CRZ + 00B4h      | Capture Resize Information Register 1                              | CRZ_INFO1    |
| CRZ + 00B8h      | Capture Resize Information Register 2                              | CRZ_INFO2    |
| CRZ + 00BCh      | Capture Resize Information Register 3                              | CRZ_INFO3    |
| CRZ + 00C0h      | Capture Resize Information Register 4                              | CRZ_INFO4    |
| CRZ + 00C4h      | Capture Resize Information Register 5                              | CRZ_INFO5    |

#### **Capture Resize Configuration Register** 6.7.2.1

#### CRZ+0000h **Capture Resize Configuration Register**

| 19 | 18   | 17   | 16 |
|----|------|------|----|
|    |      |      |    |
|    |      |      |    |
|    |      |      |    |
| 3  | 2    | 1    | 0  |
|    | PELS | SRC1 |    |
|    | R/   | W    |    |

CRZ\_CFG

| Bit   | 31 | 30 | 29 | 28 | 27 | 26         | 25_ | 24 | 23        | 22 | 21   | 20   | 19 | 18   | 1/   | 16 |
|-------|----|----|----|----|----|------------|-----|----|-----------|----|------|------|----|------|------|----|
| Name  |    |    |    |    |    |            |     |    |           |    |      |      |    |      |      |    |
| Type  |    |    |    |    |    |            |     |    |           |    |      |      |    |      |      |    |
| Reset |    |    |    |    |    |            | 1   |    |           |    |      |      |    |      |      |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | <u> 10</u> | 9   | 8  | 7         | 6  | 5    | 4    | 3  | 2    | 1    | 0  |
| Name  |    |    |    |    |    |            |     |    | LBSE<br>L |    | PSEL | PCON |    | PELS | SRC1 |    |
| Type  |    |    |    | 4  |    | ,          |     |    | R/W       |    | R/W  | R/W  |    | R/   | W    |    |
| Reset |    |    |    |    |    |            |     |    | 0         |    | 0    | 0    |    | 00   | 00   |    |

The register is for global configuration of Capture Resize.

**PELSRC1** The register field specifies which pixel-based image source is serviced.

- Camera Interface
- MPEG4 Encoder DMA
- 2 MPEG4 Decoder DMA
- IBW4 DMA
- 4 IPP
- 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 Capture Resize. If to stop immediately is desired, reset Capture Resize directly. If the last image is desired, set the register bit to '0' first. Then wait until image resizer is not busy again. Finally reset image resizer.

- 0 Single run
- 1 Continuous run

**PSEL** The register field determines if block-based image sources is serviced.

- Block-based image source is serviced.
- Block-based image source is NOT serviced completely. Clock for block-based processes is stopped and block-based image input is blocked completely.

**LBSEL** Line buffer selection.

- Shared memory.
- 1 Dedicated memory.

#### 6.7.2.2 **Capture Resize Control Register**

#### CRZ+0004h **Capture Resize Control Register**

**CRZ CON** 

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18          | 17   | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|------|----|
| Name  |    |    |    |    |    | -  |    |    | -  |    |    |    |    | PELV        | PELH |    |
|       |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RRST</b> | RRST |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W         | R/W  |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    | 0           | 0    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2           | 1    |    |
| Mama  |    |    |    |    |    |    |    |    |    |    |    |    |    | PELV        | PELH |    |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RENA</b> | RENA |    |
| Туре  |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W         | R/W  |    |
| Reset | ,  |    |    |    |    | •  |    |    |    |    |    |    |    | 0           | 0    | •  |

The register is for global control of Capture Resize. Note that software reset does NOT reset all register settings. Remember to trigger Capture Resize first before triggering image sources to Capture Resize.

**PELHRENA** Writing '1' to the register bit causes pixel-based fine horizontal resizing proceed to work. However, if horizontal resizing is not necessary, do not write '1' to the register bit.

**PELVRENA** Writing '1' to the register bit causes pixel-based fine vertical resizing proceed to work. However, if vertical resizing is not necessary, do not write '1' to the register bit.

**PELHRRST** Writing '1' to the register causes pixel-based fine horizontal resizing to stop immediately and have resizing go to normal state, write '0' to the register bit.

**PELVRRST** Writing '1' to the register causes pixel-based fine vertical resizing to stop immediately and have pixel-based fine vertical resizing keep in reset state. In order to have pixel-based fine vertical resizing go to normal state, write '0' to the register bit.

#### 6.7.2.3 **Capture Resize Status Register**

#### CRZ+0008h **Capture Resize Status Register**

**CRZ 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  |  |  |  |  |  |  |    | PELH<br>RBUS<br>Y |  |
|-------|--|--|--|--|--|--|----|-------------------|--|
| Type  |  |  |  |  |  |  | RO | RO                |  |
| Reset |  |  |  |  |  |  | 0  | 0                 |  |

The register indicates global status of Capture Resize.

PELHRBUSY Pixel-based HR (Horizontal Resizing) Busy Status
PELVRBUSY Pixel-based VR (Vertical Resizing) Busy Status

#### 6.7.2.4 Capture Resize Interrupt Register

#### CRZ+000Ch Capture Resize Interrupt Register

29 Bit 31 30 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 6 0 **PELV PELH** Name RINT **RINT** Type Reset

The register shows up the interrupt status of resizer.

PELHRINT Interrupt for PELHR (Pixel-based Horizontal Resizing). No matter the register bit

CRZ\_FRCFG.HRINTEN is enabled or not, the register bit is active whenever PELHR completes. It

could be as software interrupt by polling the register bit. Clear it by reading the register.

PELVRINT Interrupt for PELVR (Pixel -based Vertical Resizing). No matter the register bit

CRZ\_FRCFG.VRINTEN is enabled or not, the register bit is active whenever PELVR completes. It could be as software interrupt by polling the register bit. Clear it by reading the register.

## 6.7.2.5 Capture Resize Source Image Size Register 1

#### CRZ+0010h Capture Resize Source Image Size Register 1 CRZ\_SRCSZ1

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

The register specifies the size of source image after coarse shrink process. The allowable maximum size is 2048x2048. Note that the width of source image must be a multiple of  $8xH_{max}$  and the height of source image must be a multiple of  $8xV_{max}$  when Block Coarse Shrinking is involved.

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.

MediaTek Inc. Confidential

CRZ INT



#### 6.7.2.6 Capture Resize Target Image Size Register 1

#### CRZ+0014h Capture Resize Target Image Size Register 1

CRZ\_TARSZ1

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

The register specifies the size of target image. The allowable maximum size is 2048x2048.

**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.7.2.7 Capture Resize Horizontal Ratio Register 1

#### CRZ+0018h Capture Resize Horizontal Ratio Register

**CRZ HRATIO1** 

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

The register specifies horizontal resizing ratio. It is obtained by CRZ\_SRCSZ.WS \* 2<sup>20</sup> / CRZ\_TARSZ.WT.

#### 6.7.2.8 Capture Resize Vertical Ratio Register 1

#### CRZ+001Ch Capture Resize Vertical Ratio Register 1

CRZ VRATIO1

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

The register specifies vertical resizing ratio. It is obtained by CRZ\_SRCSZ.HS \*  $2^{20}$  / CRZ\_TARSZ.HT.

#### 6.7.2.9 Capture Resize Horizontal Residual Register 1

#### CRZ+0020h Capture Resize Horizontal Residual Register 1

**CRZ 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>—</b> |    |    |    |    |    | RESI | DUAL |    |    |    |    |    |    |    |
| Type |    | <u> </u> |    |    |    |    |    | R/   | W    |    |    |    |    |    |    |    |

MediaTek Inc. Confidential



CRZ+0040h

The register specifies horizontal residual. It is obtained by CRZ\_SRCSZ.WS % CRZ\_TARSZ.WT. The allowable maximum value is 2046.

#### 6.7.2.10 Capture Resize Vertical Residual Register 1

#### CRZ+0024h Capture Resize Vertical Residual Register 1

**CRZ 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 |    |    |    |    |    |    |    | RESII | DUAL |    |    |    |    |    |    |    |
| Type |    |    |    |    | •  |    | •  | R/    | W    |    |    | •  |    |    |    | •  |

The register specifies vertical residual. It is obtained by CRZ\_SRCSZ.HS % CRZ\_TARSZ.HT. The allowable maximum value is 2046.

#### 6.7.2.11 Capture Resize Fine Resizing Configuration Register

# Capture Resize Fine Resizing Configuration Register

CRZ\_FRCFG

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24  | 23  | 22 | 21          | 20          | 19 | 18 | 17 | 16   |
|-------|----|----|----|----|----|----|-----|-----|-----|----|-------------|-------------|----|----|----|------|
| Name  |    |    |    |    |    |    |     | WN  | ISZ |    |             |             |    |    |    |      |
| Type  |    |    |    |    |    |    |     | R/  | W   | 24 |             |             |    |    |    |      |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6  | 5           | 4           | 3  | 2  | 1  | 0    |
| Name  |    |    |    |    |    |    | PCS | SF1 |     |    | VRINT<br>EN | HRIN<br>TEN |    |    |    | VRSS |
| Type  |    |    |    |    |    |    | R/  | W   |     |    | R/W         | R/W         |    |    |    | R/W  |
| Reset |    |    |    |    |    | •  | 0   | 0   |     |    | 0           | 0           |    |    |    | 0    |

The register specifies various setting of control for fine resizing, including of horizontal and vertical resizing. **Note** that all parameters must be set before horizontal and vertical resizing proceeds.

- VRSS The register bit specifies whether subsampling for vertical resizing is enabled. For throughput issue, vertical resizing may be simplified by subsampling lines vertically. The register bit is only valid in pixel-based mode.
  - **0** Subsampling for vertical resizing is disabled.
  - 1 Subsampling for vertical resizing is enabled.
- **HRINTEN** HR (Horizontal Resizing) Interrupt Enable. When interrupt for HR is enabled, an interrupt is generated whenever HR finishes.
  - Interrupt for HR is disabled.
  - 1 Interrupt for HR is enabled.
- **VRINTEN** VR (Vertical Resizing) Interrupt Enable. When interrupt for VR is enabled, an interrupt is generated whenever VR finishes.
  - 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.
  - 00 No coarse shrinking.
  - 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.



**WMSZ** It stands for Working Memory SiZe. The register specifies how many lines after horizontal resizing can be filled into working memory. **Its minimum value is 4.** 

# 6.7.2.12 Capture Resize Pixel-Based Resizing Working Memory Base Address Register

# CRZ+005Ch Capture Resize Pixel-Based Resizing Working Memory Base Address Register

CRZ\_PRWMBASE

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

The register specifies the base address of working memory in pixel-based resizing mode. It must be byte-aligned. When CRZ\_CFG.LB\_SEL is set, this address should be set as 0x40020000.

#### 6.7.2.13 Capture Resize Information Register 0

#### CRZ+00B0h Capture Resize Information Register 0

**CRZ INFO0** 

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

The register shows progress of BLKCS. But they are not real processed width/height. Sampling factors must be taken into consideration. For example, if  $(V_Y, V_U, V_V)=(2,4,4)$  then real processed width/height are two times of the register.

**INFO[31:16]** BLKCS y **INFO[15:00]** BLKCS x

#### 6.7.2.14 Capture Resize Information Register 1

#### CRZ+00B4 Capture Resize Information Register 1

CRZ INFO1

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

The register shows progress of BLK2PEL.

**INFO[31:16]** BLK2PEL y **INFO[15:00]** BLK2PEL x



#### 6.7.2.15 Capture Resize Information Register 2

#### CRZ+00B8 Capture Resize Information Register 2

CRZ\_INFO2

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

The register shows progress of pixels received from BLKCS in fine resizing stage.

**INFO[31:16]** Indicates the account of vertical lines received from BLKCS in fine resizing stage.

**INFO[15:00]** Indicates the account of horizontal pixels received from BLKCS in fine resizing stage. Note that it becomes zero when resizing completes.

#### 6.7.2.16 Capture Resize Information Register 3

#### CRZ+00BC Capture Resize Information Register 3

CRZ\_INFO3

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

The register shows progress of horizontal resizing in fine resizing stage.

**INFO[31:16]** Indicates the account of horizontal resizing in fine resizing stage in horizontal direction.

**INFO[15:00]** Indicates the account of horizontal resizing in fine resizing stage in vertical direction.

#### 6.7.2.17 Capture Resize Information Register 4

#### CRZ+00C0 Capture Resize Information Register 4

CRZ\_INFO4

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

The register shows progress of vertical resizing in fine resizing stage.

**INFO[31:16]** Indicates the account of vertical resizing in fine resizing stage in horizontal direction.

**INFO[15:00]** Indicates the account of vertical resizing in fine resizing stage in vertical direction.

#### 6.7.2.18 Capture Resize Information Register 5

#### CRZ+00C5 Capture Resize Information Register 5

CRZ\_INFO5

| Bit  | 31 | 30 | <sub>1</sub> 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|-----------------|----|----|----|----|-------|--------|----|----|----|----|----|----|----|
| Name |    |    |                 |    |    |    |    | INFO[ | 31:16] |    |    |    |    |    |    |    |
| Type |    |    |                 |    |    |    |    | R     | 0      |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13              | 12 | 11 | 10 | 9  | 8     | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |                 |    |    |    |    | INFO  | [15:0] |    |    |    |    |    |    |    |
| Туре |    |    | •               |    |    |    | •  | R     | 0      | •  |    |    |    |    | •  |    |



The register shows progress of YUV-to-RGB

INFO[31:16] Indicates YUV-to-RGB in horizontal direction.INFO[15:00] Indicates YUV-to-RGB in vertical direction.

#### 6.7.3 Application Notes

- Working memory. Maximum value is 16 and minimum 4. **Remember that each pixel occupies 2 bytes**. Thus minimum requirement for working memory in pixel-based resizing is (pixel number in a line) x2x4 bytes.
- Configuration procedure for pixel-based image sources

```
CRZ_CFG.PSEL=1;
CRZ_CFG.PELSRC = 0;
CRZ_SRCSZ = source image size;
CRZ_TARSZ = target image size;
CRZ_HRATIO = horizontal ratio;
CRZ_VRATIO = vertical ratio;
CRZ_HRES = horizontal residual;
CRZ_VRES = vertical residual;
CRZ_FRCFG = working memory size, interrupt enable;
CRZ_PRWMBASE = working memory base;
CRZ_CON = 0x6;
// Then wait interrupt or polling CRZ_INT.PELHRINT or CRZ_INT.PELVRINT
```

# 6.8 Drop Resize

# 6.8.1 General Description

This block provides a simple resizing function by performing pixel and line dropping. It receives image data from the Video Encode DMA for videophone local display or the IBW3 DMA for thumbnail image dump, performs the image resizing function and outputs to the image process engine module. It can scale down the input image by any ratio. However, the maximum sizes of input and output images are limited to 2048x2048.

# 6.8.2 Register Definitions

#### 6.8.2.1 Register Map

**Table 50** shows the register map.

| REGISTER ADDRESS | REGISTER NAME                              | SYNONYM      |
|------------------|--------------------------------------------|--------------|
| DRZ+ 0000h       | Drop Resize Start Register                 | DRZ_STR      |
| DRZ+ 0004h       | Drop Resize Control Register               | DRZ_CON      |
| DRZ + 0008h      | Drop Resize Status Register                | DRZ_STA      |
| DRZ + 000Ch      | Drop Resize Interrupt Acknowledge Register | DRZ_ACKINT   |
| DRZ + 0010h      | Drop Resize Source Image Size Register     | DRZ_SRC_SIZE |
| DRZ + 0014h      | Drop Resize Target Image Size Register     | DRZ_TAR_SIZE |
| DRZ + 0020h      | Drop Resize Horizontal Ratio Register      | DRZ_RAT_H    |
| DRZ + 0024h      | Drop Resize Vertical Ratio Register        | DRZ_RAT_V    |



Table 50 Register map.

#### 6.8.2.2 Register Description

Followings are detail descriptions of each register.

#### DRZ+0000h Drop Resize Start Register

DRZ\_STR

| Bit         | 31  | 30        | 29  | 28        | 27        | 26        | 25       | 24       | 23       | 22       | 21       | 20       | 19       | 18        | 17       | 16       |
|-------------|-----|-----------|-----|-----------|-----------|-----------|----------|----------|----------|----------|----------|----------|----------|-----------|----------|----------|
| Name        |     |           |     |           |           |           |          |          |          |          |          |          |          | $\square$ |          |          |
| 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        |
| Bit<br>Name |     | 14        |     | 12        | 11        | 10        | 9        | 8        | 7        | 6        | 5        | 4        | 3        | 2         | 1        | 0<br>STR |
| -           |     | 14<br>R/W |     | 12<br>R/W | 11<br>R/W | 10<br>R/W | 9<br>R/W | 8<br>R/W | 7<br>R/W | 6<br>R/W | 5<br>R/W | A<br>R/W | 3<br>R/W | R/W       | 1<br>R/W | U        |

This register controls the activity of Drop Resize. Note that before setting STR to "1", all the configurations shall be done by giving proper values.

STR Start the Drop resize engine. Write 1 to this bit will start the FSM of Drop resize. Write 0 to this bit will reset the FSM of Drop resize.

#### DRZ+0004h Drop Resize Configuration Register

DRZ\_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  |    |    |    |    |    |    |    |    |    |    |    | PSEL | AUTO<br>RSTR |    |    | IT  |
| Type  |    |    |    |    |    |    |    |    |    |    |    | R/W  | R/W          |    |    | R/W |

| Reset |  |  |  |  |  | 0 | 0 |  | 0 |
|-------|--|--|--|--|--|---|---|--|---|

The register specifies the configuration of Drop resize.

- Interrupt Enabling
  - 0 Disable
  - 1 Enable

AUTO RSTR Automatic restart. Drop Resize automatically restarts itself while current frame is finished.

- 0 Disable
- 1 Enable

**PSEL** Pixel engine selection

- Video encode DMA
- 1 IBW3 DMA.

#### DRZ+0008h Drop Resize Status Register

**DRZ STA** 

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

This register helps software program being well aware of the global status of Drop Resize.

- IT Interrupt status for Drop Resize
  - **0** No interrupt is generated.
  - 1 An interrupt is pending and waiting for service.

**RUN** Drop Resize status

- O Drop Resize is stopped or has completed the transfer already.
- 1 Drop Resize is currently running.

#### DRZ+000Ch Drop Resize Interrupt Acknowledge Register

DRZ ACKINT

| 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 |    |    |    |    |    |    | 7  |    |    |    |    |    |    |    |    | ACK |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | WO  |

This register is used to acknowledge the current interrupt request associated with the completion event of Drop Resize 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 Drop Resize

- 0 No effect
- 1 Interrupt request is acknowledged and should be relinquished.

## DRZ+0010h Drop Resize Source Image Size Register

DRZ SRC SIZE

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





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

The register specifies the size of source image. The maximum allowable size is 2048x2048.

V the height of source image-1H the width of source image-1

#### DRZ+0014h Drop Resize Target Image Size Register

DRZ TAR SIZE

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 17                          | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------|----|
| Name  |    |    |    |    |    |    |    | 1  | /  |    |    |    |    |                                |    |
| Type  |    |    |    |    |    |    |    | R/ | W  |    |    |    |    |                                |    |
| Reset |    |    |    |    |    |    |    | (  | )  |    |    |    |    | $\mathcal{I} \cap \mathcal{I}$ |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2 1                            | 0  |
| Name  |    |    |    |    |    |    |    | H  | +  |    |    |    |    |                                |    |
| Type  |    |    |    |    |    |    |    | R/ | W  |    |    |    |    |                                |    |
| Reset | 0  |    |    |    |    |    |    |    |    |    |    |    |    |                                |    |

The register specifies the size of target image. The maximum allowable size is 2048x2048.

V the height of target image-1H the width of target image-1

## DRZ+0020h Drop Resize Horizontal Ratio Register

DRZ RAT H

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

The register specifies horizontal resizing ratio. It is obtained by (the width of source image/the width of target image) = I + Q/P = I + Q/the width of target image.

[31:0] the integer part

Q [31:0] the denominator

## DRZ+0024h Drop Resize Vertical Ratio Register

DRZ RAT V

| Bit   | 31 | 30 | 29 | 28 | 27 26 | 25 | 24    | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|-------|----|-------|------|----|----|----|----|----|----|----|
| Name  |    |    |    |    |       |    | I [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  |    |    |    |    |       |    | Q [1  | 5:0] |    |    |    |    |    |    |    |
| Type  |    |    |    |    |       |    | R/    | W    |    |    |    |    |    |    |    |
| Reset |    |    |    | 2  |       |    | (     | 0    |    |    |    |    |    |    |    |

The register specifies horizontal resizing ratio. It is obtained by (the height of source image/the height of target image) = I + Q/P = I + Q/the height of target image.

[31:0] the integer part

Q [31:0] the denominator



#### 6.9 Post Resize

## 6.9.1 General Description

**Figure 27** shows the block diagram of post resize. It receives image data from a block-based source such as JPEG decoder or from a scan line based source, and then performs image resizing. The capability of resizing in the block is divided into two portions, coarse pass and fine pass. The first pass is coarse resizing pass and it is able to shrink image by a factor of 1, 1/4, 1/16, or 1/64. The second pass is the fine resizing pass, which is composed of horizontal and vertical resizing, and it is able to shrink or enlarge image in fractional ratio. The maximum allowable image size for the fine resizing pass is 2048x2048. Thus the maximum allowable image size for coarse resizing pass is 16384x16384.



Figure 28 Block diagram of the post resize

The strip buffer of coarse resizing pass accumulates de-compressed 8x8 YUV blocks separately. These YUV data are packed into pixels and sent to the fine resizing pass. There is one GMC port employed in the coarse resize for the strip buffer read/write.

The fine resizing pass is composed of horizontal and vertical resizing blocks. It can scale up or down the input image by any ratio. However, the maximum sizes of input and output images are limited to 2048x2048. The horizontal resizing function is a combination of 2's power average and bi-linear interpolation. The vertical resizing function is a bi-linear interpolation. The input and output format are both YUV444. But the internal working memory format is YUV422 to mitigate memory and bandwidth requirements. There is one GMC port employed in the fine resize for the vertical buffer read/write.

# 6.9.2 Working Memories

There are two working memories in post resize. One is the strip buffer, and the other is the vertical buffer.

#### 6.9.2.1 Strip Buffer

Let's 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)$  in a JPEG file. The minimum requirement of memory size for the strip buffer is (the image width of after the coarse resizing pass) \*  $(V_Y * 8 + V_U * 8 + V_V * 8)$  bytes. It is (2048) \* (4 \* 8 + 4 \* 8 + 2 \* 8) = 160K bytes for extreme cases. To enhance the throughput of JPEG decode process, software may use double buffer scheme. Then it becomes 320K



bytes. Please note that the strip buffer is composed of the Y buffer, U buffer, and V buffer. Software can allocate separate memory for them.

#### 6.9.2.2 Vertical Buffer

The minimum requirement of memory for the vertical buffer is (the target image width) \* (the line number of vertical buffer) \* 2 bytes. It is (2048) \* (2) \* 2 = 4K bytes for extreme cases. To enhance throughputs of overall data paths, software may use double buffer scheme. Then it becomes 8K bytes.

#### 6.9.3 Source Image

For the coarse resizing pass, the width of the source image must be multiples of **8** \* (maximum horizontal sampling factor). Similarly, the height of the source image must be multiples of **8** \* (maximum vertical sampling factor). The maximum size of target image is 2048x2048.

For the fine resizing pass, the maximum size of source image and target image are both 2048x2048.

#### 6.9.4 Flow Control

For the coarse resizing pass, the coarse resizing will send pixel data to the fine resizing when they are ready with hand shake signal. If strip buffer is full, the coarse resizing will halt image data input until the strip buffer is available.

For the fine resizing pass, the fine resizing will send pixel data to the image post processing when they are ready with hand shake signal. If vertical buffer is full, the fine resizing will halt image data input until the vertical is available.

#### 6.9.5 Throughput

For block-based image sources, the process time for one pixel is about 3 cycles. Therefore if 15 frames per second are desired and Post Resize is running at 52 MHz then the maximum pixel number per frame is about 1.15M. That is about 1075x1075.

For pixel-based image sources, the process time for one pixel is about 2.25 cycles. Therefore if 15 frames per second are desired and Post Resize is running at 52 MHz then the maximum pixel number per frame is about 1.5M. That is about 1241x1241.

Since memory bandwidth requirements are different for scale up and down, it may be able to enhance throughput by adjusting the register setting of PRZ\_CFG.BWA0/BWB0. When scaling up, memory bandwidth requirement for read is higher than memory bandwidth requirements for write. However, when scaling down, memory bandwidth requirement for write is higher than memory bandwidth requirements for read. Therefore when horizontally scaling up, throughput can be enhance by setting PRZ\_CFG.B0 with higher value than PRZ\_CFG.A0. Similarly when horizontally scaling down, throughput can be enhance by setting PRZ\_CFG.B1 with higher value than PRZ\_CFG.B1. Similarly when vertically scale down throughput can be enhance by setting PRZ\_CFG.B1 with higher value than PRZ\_CFG.B1.

# 6.9.6 Register Definitions

| REGISTER ADDRESS | REGISTER NAME                            | SYNONYM    |
|------------------|------------------------------------------|------------|
| PRZ+ 0000h       | Post Resize Configuration Register       | PRZ_CFG    |
| PRZ + 0004h      | Post Resize Control Register             | PRZ_CON    |
| PRZ + 0008h      | Post Resize Status Register              | PRZ_STA    |
| PRZ + 000Ch      | Post Resize Interrupt Register           | PRZ_INT    |
| PRZ + 0010h      | Post Resize Source Image Size Register 1 | PRZ_SRCSZ1 |



| PRZ + 0014h | Post Resize Target Image Size Register 1                     | PRZ_TARSZ1   |
|-------------|--------------------------------------------------------------|--------------|
| PRZ + 0018h | Post Resize Horizontal Ratio Register 1                      | PRZ_HRATIO1  |
| PRZ + 001Ch | Post Resize Vertical Ratio Register 1                        | PRZ_VRATIO1  |
| PRZ + 0020h | Post Resize Horizontal Residual Register 1                   | PRZ_HRES1    |
| PRZ + 0024h | Post Resize Vertical Residual Register 1                     | PRZ_VRES1    |
| PRZ + 0030h | Post Resize Block Coarse Shrinking Configuration Register    | PRZ_BLKCSCFG |
| PRZ + 0034h | Post Resize Y-Component Line Buffer Memory Base Address      | PRZ_YLMBASE  |
| PRZ + 0038h | Post Resize U-Component Line Buffer Memory Base Address      | PRZ_ULMBASE  |
| PRZ + 003Ch | Post Resize V-Component Line Buffer Memory Base Address      | PRZ_VLMBASE  |
| PRZ + 0040h | Post Resize Fine Resizing Configuration Register             | PRZ_FRCFG    |
| PRZ + 0050h | Post Resize Y Line Buffer Size Register                      | PRZ_YLBSIZE  |
| PRZ + 005Ch | Post Resize Pixel-Based Resizing Working Memory Base Address | PRZ_PRWMBASE |
| PRZ + 00B0h | Post Resize Information Register 0                           | PRZ_INFO0    |
| PRZ + 00B4h | Post Resize Information Register 1                           | PRZ_INFO1    |
| PRZ + 00B8h | Post Resize Information Register 2                           | PRZ_INFO2    |
| PRZ + 00BCh | Post Resize Information Register 3                           | PRZ_INFO3    |
| PRZ + 00C0h | Post Resize Information Register 4                           | PRZ_INFO4    |
| PRZ + 00C4h | Post Resize Information Register 5                           | PRZ_INFO5    |
|             |                                                              |              |

## 6.9.6.1 Post Resize Configuration Register

#### PRZ+0000h Post Resize Configuration Register

PRZ\_CFG

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24             | 23        | 22 | 21   | 20   | 19 | 18   | 17   | 16 |
|-------|----|----|----|----|----|----|----|----------------|-----------|----|------|------|----|------|------|----|
| Name  |    |    |    |    |    |    |    |                |           | BV | VB0  |      |    | BW   | /A0  |    |
| Type  |    |    |    |    |    |    |    |                |           | R  | /W   |      |    | R/   | W    |    |
| Reset |    |    |    |    |    |    |    | $\overline{M}$ |           | 00 | 000  |      |    | 00   | 00   |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8              | 7         | 6  | 5    | 4    | 3  | 2    | 1    | 0  |
| Name  |    |    |    |    |    |    |    | 2              | LBSE<br>L |    | PSEL | PCON |    | PELS | SRC1 |    |
| Type  |    |    |    |    |    |    | 7  |                | R/W       |    | R/W  | R/W  |    | R/   | W    |    |
| Reset |    | •  |    | •  |    |    |    |                | 0         |    | 0    | 0    |    | 00   | 00   |    |

The register is for global configuration of Post Resize.

**PELSRC1** The register field specifies which pixel-based image source is serviced.

- 1 MPEG4 Encoder DMA
- 2 MPEG4 Decoder DMA
- 3 IBW4 DMA
- 5 IPP
- 6 JPEG Decoder

#### **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 Post Resize. If immediate stop is desired, reset Post Resize directly. If the last image is desired, set the register bit to '0' first. Then wait till Post Resize is not busy again. Finally reset Post Resize.

- O Single run
- 1 Continuous run

**PSEL** The register field determines if block-based image sources is serviced.



- Block-based image source will be serviced.
- Block-based image source will NOT be serviced completely. Clock for block-based processes will be stopped and block-based image input will be blocked completely.

LBSEL line buffer selection. When CRZ\_CFG.LB\_SEL is set, this bit should not be set.

- O Shared memory.
- 1 Dedicated memory.

BWA0 Bandwidth selection for port A of memory interface 0. In block-based mode, this is the memory interface between BLKCS and BLKHR. In pixel-based mode, that's 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 BWA0 is set 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 whenever 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 whenever 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 whenever port A gets grant three times.

...

- BWB0 Bandwidth selection for port b of memory interface 0. In block-based mode, this is the memory interface between BLKCS and BLKHR. In pixel-based mode, that's 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 larger value 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 whenever 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 whenever 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 whenever port B gets grant three times.

...

#### 6.9.6.2 Post Resize Control Register

#### PRZ+0004h Post Resize Control Register

PRZ CON

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18           | 17  | 16           |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|-----|--------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    | PELV<br>RRST | 1   | BLKC<br>SRST |
| 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  |    | 4  |    |    |    |    |    |    |    |    |    |    |    | PELV<br>RENA |     | BLKC<br>SENA |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W          | R/W | R/W          |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    | 0            | 0   | 0            |

The register is for global control of Post Resize. Note that block-based and pixel-based resizing cannot execute parallel. Furthermore, software reset will NOT reset all register setting. Remember trigger Post Resize first before trigger image sources to Post Resize.



**BLKCSENA** Writing '1' to the register bit will cause Block Coarse Shrinking proceed to work. Block Coarse

Shrinking is designed to cooperate width JPEG decoder. It works on the fly. Bu it needs to be

restarted every time before working.

**PELHRENA** Writing '1' to the register bit will cause pixel-based fine horizontal resizing proceed to work.

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 proceed to work. However,

if vertical resizing is not necessary, do not write '1' to the register bit.

**BLKCSRST** Writing '1' to the register bit will force Block Coarse Shrinking to stop immediately and have Block

Coarse Shrinking keep in reset state. In order to have Block Coarse Shrinking go to normal state,

writing '0' to the register bit.

**PELHRRST** Writing '1' to the register will cause pixel-based fine horizontal resizing to stop immediately and have

pixel-based fine horizontal resizing keep in reset state. In order to have pixel-based fine horizontal

resizing go to normal state, writing '0' to the register bit.

**PELVRRST** Writing '1' to the register will pixel-based fine vertical resizing to stop immediately and have

pixel-based fine vertical resizing keep in reset state. In order to have pixel-based fine vertical resizing

go to normal state, writing '0' to the register bit.

#### 6.9.6.3 Post Resize Status Register

#### PRZ+0008h Post Resize Status Register

PRZ\_STA

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

The register indicates global status of Post Resize.

**BLKCSBUSY** Block-based CS (Coarse Shrinking) Busy Status

**PELHRBUSY** Pixel-based HR (Horizontal Resizing) Busy Status

**PELVRBUSY** Pixel-based VR (Vertical Resizing) Busy Status

**BLKINTRABSY** Block-based CS (Coarse Shrinking) Intra-Block Busy Status

#### 6.9.6.4 Post Resize Interrupt Register

#### PRZ+000Ch Post Resize Interrupt Register

PRZ 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 | BLKC<br>SINT |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    | RC           | RC           | RC           |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    | 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 PRZ\_BLKCSCFG.INTEN is enabled or not, the register bit will be active whenever BLKCS completes. It could be used as software interrupt by polling the register bit. Clear it by reading the register.

PELHRINT Interrupt for PELHR (Pixel-based Horizontal Resizing). No matter if the register bit PRZ\_FRCFG.HRINTEN is enabled or not, the register bit will be active whenever PELHR completes. It could be used as software interrupt by polling the register bit. Clear it by reading the register.

PELVRINT Interrupt for PELVR (Pixel -based Vertical Resizing). No matter if the register bit

PRZ\_FRCFG.VRINTEN is enabled or not, the register bit will be active whenever PELVR completes. It

could be used as software interrupt by polling the register bit. Clear it by reading the register.

#### 6.9.6.5 Post Resize Source Image Size Register 1

#### PRZ+0010h Post Resize Source Image Size Register 1

PRZ SRCSZ1

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20       | 19         | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----------|------------|----|----|----|
| Name |    |    |    |    |    |    |    | Н  | S  |    |    |          | $\nabla J$ |    |    |    |
| Type |    |    |    |    |    |    |    | R/ | W  |    |    |          |            |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4        | $\sqrt{3}$ | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    | W  | /S |    |    |          |            |    |    |    |
| Type |    |    |    |    |    |    |    | R/ | W  |    |    | <u> </u> |            |    |    |    |

The register specifies the size of source image after coarse shrink process. The maximum allowable size is 2048x2048. Note that for the width of source image must be multiples of  $8xH_{max}$  and the height of source image must be multiples of  $8xV_{max}$  when Block Coarse Shrinking is involved.

WS The register field specifies the width of source image after coarse shrink process.

- 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.9.6.6 Post Resize Target Image Size Register 1

#### PRZ+0014h Post Resize Target Image Size Register 1

PRZ TARSZ1

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

The register specifies the size of target image. The maximum allowable size is 2048x2048.

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.9.6.7 Post Resize Horizontal Ratio Register 1

#### PRZ+0018h Post Resize Horizontal Ratio Register

#### PRZ\_HRATIO1

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

The register specifies horizontal resizing ratio. It is obtained by PRZ\_SRCSZ.WS \* 2<sup>20</sup> / PRZ\_TARSZ.WT.

#### 6.9.6.8 Post Resize Vertical Ratio Register 1

#### PRZ+001Ch Post Resize Vertical Ratio Register 1

#### PRZ VRATIO1

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

The register specifies vertical resizing ratio. It is obtained by PRZ\_SRCSZ.HS \*  $2^{20}$  / PRZ\_TARSZ.HT.

#### 6.9.6.9 Post Resize Horizontal Residual Register 1

## PRZ+0020h Post Resize Horizontal Residual Register 1

#### PRZ HRES1

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24             | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----------------|------|----|----|----|----|----|----|----|
| Name |    |    |    |    |    |    |    | $\mathcal{M}'$ |      |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |                |      |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8              | 7    | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    | RESI           | DUAL |    |    |    |    |    |    |    |
| Type |    | •  |    |    |    | •  |    | R/             | W    | •  | •  |    | •  | •  |    | -  |

The register specifies horizontal residual. It is obtained by PRZ\_SRCSZ.WS % PRZ\_TARSZ.WT. The maximum allowable value is 2046.

## 6.9.6.10 Post Resize Vertical Residual Register 1

#### PRZ+0024h Post Resize Vertical Residual Register 1

#### PRZ\_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 |    |    |    |    |    |    |    | RESI | DUAL |    |    |    |    |    |    |    |
| Type |    | 4  | •  | •  |    | •  |    | R/   | W    | •  |    |    |    |    |    | -  |

The register specifies vertical residual. It is obtained by PRZ\_SRCSZ.HS % PRZ\_TARSZ.HT. The allowable maximum value is 2046.



#### 6.9.6.11 Post Resize Block Coarse Shrinking Configuration Register

# PRZ+0030h Post Resize Block Coarse Shrinking Configuration Register

PRZ\_BLKCSCFG

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

The register is for various configuration of Block Coarse Shrinking in Post Resize. 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 PRZ\_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
  - **00** Horizontal sampling factor for V-component is 1.
  - **01** Horizontal sampling factor for V-component is 2.
  - **10** Horizontal sampling factor for V-component is 4.
  - 11 No V-component.
- VV Vertical sampling factor for V-component
  - **00** Vertical sampling factor for V-component is 1.



- **01** Vertical sampling factor for V-component is 2.
- **10** Vertical sampling factor for V-component is 4.
- 11 No V-component.

INTEN Interrupt Enable. When interrupt for BLKCS is enabled, interrupt will arise whenever BLKCS finishes.

- Interrupt for BLKCS is disabled.
- 1 Interrupt for BLKCS is enabled.

#### 6.9.6.12 Post Resize Y-Component Line Buffer Memory Base Address Register

# PRZ+0034h Post Resize Y-Component Line Buffer Memory Base Address Register

PRZ\_YLMBASE

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23      | 22 | 21 | 20 | 19               | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|-------|---------|----|----|----|------------------|----|----|----|
| Name |    |    |    |    |    |    | YL | MBAS  | E [31:1 | 6] |    |    |                  |    |    |    |
| Type |    |    |    |    |    |    |    | R/    | W       |    |    |    |                  |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7       | 6  | 5  | 4  | $\overline{(3)}$ | 2  | 1  | 0  |
| Name |    |    |    |    |    |    | Y  | LMBAS | SE [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.9.6.13 Post Resize U-Component Line Buffer Memory Base Address Register

# PRZ+0038h Post Resize U-Component Line Buffer Memory Base Address Register PRZ\_ULMBASE

| Bit  | 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23             | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|------|-----|----|----|----|----|----|----|-------|----------------|-----|----|----|----|----|----|----|
| Name |     |    |    |    |    |    | UI | MBAS  | <b>E</b> [31:1 | 16] |    |    |    |    |    |    |
| Type | R/W |    |    |    |    |    |    |       |                |     |    |    |    |    |    |    |
| Bit  | 15  | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7              | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |     |    |    |    |    |    | Ú  | LMBAS | E [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.9.6.14 Post Resize V-Component Line Buffer Memory Base Address Register

# PRZ+003Ch Post Resize V-Component Line Buffer Memory Base Address Register PRZ\_VLMBASE

| Bit  | 31 | 30 | 29 | 28          | 27 | 26 | 25 | 24          | 23      | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|-------------|----|----|----|-------------|---------|-----|----|----|----|----|----|----|
| Name |    |    |    |             |    |    | VL | <b>MBAS</b> | E [31:1 | [6] |    |    |    |    |    |    |
| Type |    |    |    | $\Box \Box$ |    |    |    | R/          | W       |     |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | <u>1</u> 2  | 11 | 10 | 9  | 8           | 7       | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |             |    |    | V  | LMBAS       | SE [15: | 0]  |    |    |    |    |    |    |
| 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.9.6.15 Post Resize Fine Resizing Configuration Register

### PRZ+0040h Post Resize Fine Resizing Configuration Register

PRZ\_FRCFG

| Bit   | 31   | 30 | 29 | 28 | 27  | 26  | 25 | 24  | 23  | 22 | 21          | 20          | 19 | 18 | 17 | 16   |
|-------|------|----|----|----|-----|-----|----|-----|-----|----|-------------|-------------|----|----|----|------|
| Name  |      |    |    |    |     |     |    | WN  | ISZ |    |             |             |    |    |    |      |
| Type  |      |    |    |    |     |     |    | R/  | W   |    |             |             |    |    |    |      |
| Bit   | 15   | 14 | 13 | 12 | 11  | 10  | 9  | 8   | 7   | 6  | 5           | 4           | 3  | 2  | 1  | 0    |
| Name  | OSEL |    |    |    | PCS | SF2 | PC | SF1 |     |    | VRINT<br>EN | HRIN<br>TEN |    |    |    | VRSS |
| Type  | R/W  |    |    |    | R/  | W   | R/ | W   |     |    | R/W         | R/W         |    |    |    | R/W  |
| Reset |      |    |    |    | 0   | 0   | 0  | 0   |     |    | 0           | 0           |    |    |    | 0    |

The register specifies various setting of control for fine resizing, including of horizontal and vertical resizing. **Note that** all parameters must be set before horizontal and vertical resizing proceeds.

VRSS The register bit specifies whether subsampling for vertical resizing is enabled. For throughput issue, vertical resizing may be simplified by subsampling lines vertically. The register bit is only valid in pixel-based mode.

- **0** Subsampling for vertical resizing is disabled.
- 1 Subsampling 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.

- 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.

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

**OSEL** The register bit is used to select output modules.

- Image DMA.
- 1 IPP.

**WMSZ** It stands for Working Memory Size. The register specifies how many lines after horizontal resizing can be filled into working memory. Its minimum value is 4.

### 6.9.6.16 Post Resize Y Line Buffer Size Register

## PRZ+0050h Post Resize Y Line Buffer Size Register

| 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 |    | 721 |    |    |    |    |    | YLE | 3ZE |    |    |    |    |    |    |    |
| Type |    |     |    |    |    | •  | •  | R/  | W   | •  | •  | •  |    |    |    |    |

The register specifies line buffer size for image data after coarse shrinking. It is only useful in block-based mode.



- YLBSZ 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<sub>Y</sub>, V<sub>U</sub>, V<sub>V</sub>)=(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 parallel. The maximum allowable value is 2048.
  - 1 Line buffer size for Y-component is 1 lines.
  - **2** Line buffer size for Y-component is 2 lines.
  - 3 Line buffer size for Y-component is 3 lines.

...

## 6.9.6.17 Post Resize Pixel-Baed Resizing Working Memory Base Address Register

# PRZ+005Ch Post Resize Pixel-Based Resizing Working Memory Base Address Register

PRZ\_PRWMBASE

| Bit  | 31  | 30 | 29 | 28 | 27 | 26 | 25  | 24          | 23      | 22   | 21       | _20 | 19 | 18 | 17 | 16 |
|------|-----|----|----|----|----|----|-----|-------------|---------|------|----------|-----|----|----|----|----|
| Name |     |    |    |    |    |    | PR\ | <b>NMBA</b> | SE [31: | :16] |          | 701 |    |    |    |    |
| Type | R/W |    |    |    |    |    |     |             |         |      |          |     |    |    |    |    |
| Bit  | 15  | 14 | 13 | 12 | 11 | 10 | 9   | 8           | 7       | 6    | <u>5</u> | 4   | 3  | 2  | 1  | 0  |
| Name |     |    |    |    |    |    | PR  | <b>WMBA</b> | SE [15  | :0]  |          |     |    |    |    |    |
| Type |     |    |    |    |    |    |     | R/          | W       |      |          |     |    |    |    |    |

The register specifies the base address of working memory in pixel-based resizing mode. It must be byte-aligned. When PRZ\_CFG.LB\_SEL is set, this address should be set as 0x40020000.

## 6.9.6.18 Post Resize Information Register 0

#### PRZ+00B0h Post Resize Information Register 0

PRZ INFO0

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

The register shows progress of BLKCS. But they are not real processed width/height. Sampling factors must be taken into consideration. For example, if  $(V_Y, V_U, V_Y)=(2,4,4)$  then real processed width/height are two times that of the register value.

**INFO[31:16]** BLKCS y **INFO[15:00]** BLKCS x

#### 6.9.6.19 Post Resize Information Register 1

## PRZ+00B4 Post Resize Information Register 1

PRZ INFO1

| Bit  | 31 | 30 | 29            | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|---------------|----|----|----|----|-------|--------|----|----|----|----|----|----|----|
| Name |    |    | $\overline{}$ |    |    |    |    | INFO[ | 31:16] |    |    |    |    |    |    |    |
| Type |    |    |               |    |    |    |    | R     | 0      |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13            | 12 | 11 | 10 | 9  | 8     | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | 4  |    |               |    |    |    |    | INFO  | [15:0] |    |    |    |    |    |    |    |
| Type |    |    |               |    |    |    |    | R     | 0      |    |    |    | •  | •  |    | •  |



The register shows progress of BLK2PEL.

**INFO[31:16]** BLK2PEL y **INFO[15:00]** BLK2PEL x

#### 6.9.6.20 Post Resize Information Register 2

### PRZ+00B8 Post Resize Information Register 2

PRZ\_INFO2

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22 | 21 | 20 | 1 | 9 | 18         | 17 | 16 |
|------|----|----|----|----|----|----|----|-------|--------|----|----|----|---|---|------------|----|----|
| Name |    |    |    |    |    |    |    | INFO[ | 31:16] |    |    |    |   |   |            |    |    |
| Type |    |    |    |    |    |    |    | R     | 0      |    |    |    |   |   | フラ         |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6  | 5  | 4  | ( | 3 | $\sqrt{2}$ | 1  | 0  |
| Name |    |    |    |    |    |    |    | INFO  | [15:0] |    |    |    |   |   |            |    |    |
| Type |    |    |    |    |    |    |    | R     | 0      |    |    |    |   |   |            |    |    |

The register shows progress of pixels received from BLKCS in fine resizing stage.

**INFO[31:16]** Indicate the account of vertical lines received from BLKCS in fine resizing stage.

**INFO[15:00]** Indicate the account of horizontal pixels received from BLKCS in fine resizing stage. Note that it will become zero when resizing completes.

## 6.9.6.21 Post Resize Information Register 3

#### PRZ+00BC Post Resize Information Register 3

PRZ INFO3

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

The register shows progress of horizontal resizing in fine resizing stage.

**INFO[31:16]** Indicate the account of horizontal resizing in fine resizing stage in horizontal direction.

**INFO[15:00]** Indicate the account of horizontal resizing in fine resizing stage in vertical direction.

# 6.9.6.22 Post Resize Information Register 4

### PRZ+00C0 Post Resize Information Register 4

PRZ\_INFO4

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

The register shows progress of vertical resizing in fine resizing stage.

**INFO[31:16]** Indicate the account of vertical resizing in fine resizing stage in horizontal direction.

**INFO[15:00]** Indicate the account of vertical resizing in fine resizing stage in vertical direction.



# 6.9.6.23 Post Resize Information Register 5

### PRZ+00C5 Post Resize Information Register 5

PRZ\_INFO5

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

The register shows progress of YUV-to-RGB

**INFO[31:16]** Indicate YUV-to-RGB in horizontal direction.

**INFO[15:00]** Indicate YUV-to-RGB in vertical direction.

## 6.9.7 Application Notes

- Determine line buffer size by taking into consideration of CSF and sampling factor. For example, if CSF=3 and (Vy, Vu, Vv)=(4,x,x) then minimum of line buffer could be 4 instead of 32.
- Working memory. Maximum value is 16 and minimum 4. **Remember that each pixel occupies 2 bytes**. Thus minimum requirement for working memory in pixel-based resizing is (pixel number in a line) x2x4 bytes.
- Configuration procedure for block-based image sources

```
PRZ_CFG.PSEL=0;
PRZ_CFG.PELSRC = 5;
PRZ_BLKCSCFG = select CSF, sampling factor, interrupt enable;
PRZ_YLBBASE = memory base for Y-component;
PRZ_ULBBASE = memory base for U-component;
PRZ_VLBBASE = memory base for V-component;
PRZ_YLBSIZE = line buffer size for Y-component;
Other same as that for pixel-based image sources
PRZ_CON = 0x7;
// Then wait interrupt or polling PRZ_INT.BLKCSINT or PRZ_INT.BLKHRINT or
// PRZ_INT.BLKVRINT
```

Configuration procedure for pixel-based image sources

```
PRZ_CFG.PSEL=1;
PRZ_CFG.PELSRC = 1~4;

PRZ_SRCSZ = source (image size;
PRZ_TARSZ = target image size;
PRZ_HRATIO = horizontal ratio;
PRZ_VRATIO = vertical ratio;
PRZ_VRES = horizontal residual;
PRZ_VRES = vertical residual;
PRZ_FRCFG = working memory size, interrupt enable;
PRZ_PRWMBASE = working memory base;
PRZ_CON = 0x6;
// Then wait interrupt or polling PRZ_INT.PELHRINT or PRZ_INT.PELVRINT
```



# 6.10 JPEG Decoder

#### 6.10.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 handles 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 waits 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.10.2 Register Definitions

#### JPEG+0000h JPEG Decoder Control Register

#### JPEG FILE ADDR

| Bit  | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24    | 23     | 22  | 21                   | <b>2</b> 0_ | 19  | 18  | 17  | 16  |
|------|-----|-----|-----|-----|-----|-----|-----|-------|--------|-----|----------------------|-------------|-----|-----|-----|-----|
| Name |     |     |     |     |     |     | FIL | E_ADI | OR[31: | 16] |                      |             |     |     |     |     |
| 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 |     |     |     |     |     |     | FII | LE_AD | DR[15: | 0]  | $\overline{\Lambda}$ |             |     |     |     |     |
| Type | 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

В

| Bit  | 31  | 30    | 29   | 28       | 27  | 26  | 25                        | 24    | 23    | 22   | 21  | 20  | 19  | 18  | 17  | 16  |
|------|-----|-------|------|----------|-----|-----|---------------------------|-------|-------|------|-----|-----|-----|-----|-----|-----|
| Name |     |       |      |          |     |     | STA                       | RT_AL | DR[31 | :16] |     |     |     |     |     |     |
| 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 |     | START | ADDR | R[15:11] |     |     | $\rho \overline{\Lambda}$ |       |       |      |     |     |     |     |     |     |
| 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 |    |    |    |    | H_SA<br>1: |    | V_SAN<br>): | 11 |    | MP_1[<br>0] | V_SAN<br>): |    | H_SA<br>1: |    |    | MP_2[<br>0] |
| Type |    |    |    |    | R/         | W  | R/          | W  | R/ | W           | R/          | W  | R/         | W  | R/ | W           |

This register contains the sampling factor of YUV components. Not affected by global reset and JPEG decoder abort.

**H SAMP** OHorizontal 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** 2Horizontal 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 |    |    |    | COMP0 | _ID[7:0 |    |    |    |    |    |    | COMP1 | _ID[7:0 | )] |    |    |
| Type |    |    |    | R/    | W       |    |    |    |    |    |    | R/    | W       |    |    |    |
| Bit  | 15 | 14 | 13 | 12    |         | 10 | 9  | 8  | 7  | 6  | 5  | 4     | 3       | 2  | 1  | 0  |
| Name |    |    |    | OMP2  | ID[7:0  |    |    |    |    |    |    |       |         |    |    |    |
| Type |    |    |    | R/    | W       |    |    |    |    |    |    |       |         |    |    |    |

This register contains the IDs of YUV components. Not affected by global reset and JPEG decoder abort.

- **COMPO\_ID** The 1<sup>st</sup> component (Y) ID is extracted from SOF marker.
- **COMP1\_ID** The  $2^{nd}$  component (U) ID is extracted from SOF marker.
- **COMP2\_ID** The 3<sup>rd</sup> component (V) ID is 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 |    | 7  |    |    |    |    | TOTAL | MCU   | _NUM[ | 31:16] |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |       | R/    | W     |        |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8     | 7     | 6      | 5  | 4  | 3  | 2  | 1  | 0  |
| Name | 44 |    |    |    |    |    | TOTA  | L_MCl | J_NUM | [15:0] |    |    |    |    |    |    |
| 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 |    |    |    |    |    |    |    |    | INTLV_ | MCU_ | NUM_P | ER_M | CU_RO | W[9:0] |    |    |
| Type |    |    |    |    |    |    |    |    |        |      | R/    | W    |       | 77     |    |    |

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

COMPO\_NONINTLV \_DU\_NUM\_PER\_M CU\_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 |    |    | DUMN | IY_DU |    |     |    | COMP | NON | NTLV | MCU_I | NUM_F | PER_M | CU_RO | W[9:0] |    |
| Type |    |    | R/   | ۱۸/   |    | 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

**COMPO\_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 grows 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 are compressed by encoders in interleaved scans because a complete MCU needs 16x16 pixels. It is different from non-interleaved scans, because in non-interleaved scans a complete MCU only needs 8x8 Y-component pixels. Therefore, among the 13 redundant pixels the first 5 are still compressed as interleaved scans while the last 8 are dropped. In this case, software must program the DUMMY\_DU field to 1 so the hardware knows one 8x8 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\_M CU\_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 |    |    | DUMN | IY_DU |    |    |    | COMP <sup>1</sup> | I_NON | INTLV_ | MCU_ | NUM_F | ER_M | CU_RO | W[9:0] |    |
| Type |    |    | R/   | W     |    |    |    |                   |       |        | R/   | W     |      | 4     |        |    |

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^{nd}$  component (U).

# JPEG+0020h JPEG Decoder Control Register

# COMP2\_NONINTLV \_DU\_NUM\_PER\_M CU 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  | 87    | 7   | 6     | 5    | 4     | 3     | 2     | 1      | 0  |
| Name |    |    | DUMN | IY_DU |    |    |    | COMP2 | NON | INTLV | MCU_ | NUM_F | PER_M | CU_RO | W[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

COMPO\_DATA\_UNI T\_NUM

| Bit  | 31 | 30                        | 29 | 28 | 27 | 26 | 25    | 24    | 23     | 22     | 21  | 20 | 19 | 18 | 17 | 16 |
|------|----|---------------------------|----|----|----|----|-------|-------|--------|--------|-----|----|----|----|----|----|
| Name |    | 74                        |    |    |    | CO | MP0_D | ATA_L | JNIT_N | UM[31: | 16] |    |    |    |    |    |
| Type |    |                           |    |    |    |    |       | R/    | W      |        |     |    |    |    |    |    |
| Bit  | 15 | 14                        | 13 | 12 | 11 | 10 | 9     | 8     | 7      | 6      | 5   | 4  | 3  | 2  | 1  | 0  |
| Name |    | COMPO_DATA_UNIT_NUM[15:0] |    |    |    |    |       |       |        |        |     |    |    |    |    |    |
| 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\_UNI

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25    | 24    | 23     | 22     | 21   | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|-------|-------|--------|--------|------|----|----|----|----|----|
| Name |    |    |    |    |    | CO | MP1_D | ATA_L | JNIT_N | UM[31: | :16] |    |    |    |    |    |
| Type |    |    |    |    |    |    |       | R/    | W      |        |      |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8     | 7      | 6      | 5    | 4  | 3  | 2  | 1, | 0  |
| Name |    |    |    |    |    | CO | MP1_C | ATA_  | UNIT_N | IUM[15 | :0]  |    |    |    | 7  |    |
| Type |    |    |    |    |    |    |       | R/    | W      |        |      |    |    | 27 |    |    |

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\_UNI T NUM

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25    | 24    | 23     | 22          | 21       | 20_ | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|-------|-------|--------|-------------|----------|-----|----|----|----|----|
| Name |    |    |    |    |    | CO | MP2_D | ATA_L | JNIT_N | UM[31:      | 16]      |     |    |    |    |    |
| Type |    |    |    |    |    |    |       | R/    | W      |             |          |     |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8     | 7      | 6           | 5        | 4   | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    | CO | MP2_C | ATA_  | UNIT_N | IUM[15      | :0]      |     |    |    |    |    |
| Type |    |    |    |    |    |    |       | R/    | W      | <u>~</u> _V | <u> </u> |     |    |    |    |    |

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\_C OEFF\_START\_ADD

R

| Bit  | 31 | 30 | 29 | 28 | 27 | 26    | 25    | 24   | 23    | 22    | 21     | 20   | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|-------|-------|------|-------|-------|--------|------|----|----|----|----|
| Name |    |    |    |    | CO | MP0_P | ROGR_ | COEF | F_STA | RT_AD | DR[31  | :16] |    |    |    |    |
| Type |    |    |    |    |    |       |       | R/   | W     |       |        |      |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10    | 9     | 8    | 7     | 6     | 5      | 4    | 3  | 2  | 1  | 0  |
| Name |    |    |    |    | CO | MP0_F | ROGR  | COEF | F_STA | RT_AL | DDR[15 | :0]  |    |    |    |    |
| 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 |    | - 4 |    |    | CO | MP1_P | ROGR_ | COEF | F_STA | RT_AD  | DR[31: | :16] |    |    |    |    |
| Type |    |     |    |    |    |       |       | R/   | W     |        |        |      |    |    |    |    |
| Bit  | 15 | 14  | 13 | 12 | 11 | 10    | 9     | 8    | 7     | 6      | 5      | 4    | 3  | 2  | 1  | 0  |
| Name |    |     |    |    | CO | MP1_P | ROGR  | COEF | F_STA | ART_AL | DDR[15 | :0]  |    |    |    |    |
| Type |    |     |    |    |    |       |       | R/   | W     |        |        |      |    |    |    |    |

This register contains the starting address of the memory space storing the intermediate progressive coefficients of the  $2^{nd}$  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

| Bit  | 31 | 30 | 29 | 28 | 27 | 26    | 25    | 24   | 23    | 22     | 21     | 20   | 19 | 18 | 17       | 16 |
|------|----|----|----|----|----|-------|-------|------|-------|--------|--------|------|----|----|----------|----|
| Name |    |    |    |    | CO | MP2_P | ROGR  | COEF | F_STA | RT_AD  | DR[31  | :16] |    |    |          |    |
| Type |    |    |    |    |    |       |       | R/   | W     |        |        |      |    |    |          |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10    | 9     | 8    | 7     | 6      | 5      | 4    | 3  | 2  | 1        | 0  |
| Name |    |    |    |    | CO | MP2_I | PROGR | COE  | F_ST/ | ART_AI | DDR[15 | :0]  |    |    | <b>b</b> |    |
| Type |    |    |    |    |    |       |       | R/   | W     |        |        |      |    | 4  |          |    |

This register contains the starting address of the memory space storing the intermediate progressive coefficients of the  $3^{rd}$  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      | 719    | 18 | 17     | 16    |
|------|----|-------------------|--------------|---------|----|---------|--------|----|---------|---------|----|---------|--------|----|--------|-------|
| Name |    | JPEG<br>_MOD<br>E |              | )U9[2:0 | ]  | D       | U8[2:0 | ]  | D       | )U7[2:0 | ]  | C       | U6[2:0 | ]  | DU5    | [2:0] |
| Туре |    | R/W               |              | R/W     |    |         | R/W    |    |         | R/W     |    | 942     | R/W    |    | R/     | W     |
| Bit  | 15 | 14                | 13   12   11 |         |    | 10      | 9      | 8  | 7       | 6       | 5_ | 4       | 3      | 2  | 1      | 0     |
| Name |    | D                 | DU4[2:0] D   |         |    | )U3[2:0 | ]      |    | )U2[2:0 |         |    | DU1[2:0 | ]      | D  | U0[2:0 | ]     |
| Type |    |                   | R/W          |         |    | R/W     |        |    | R/W     |         |    | R/W     |        |    | 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 |    |    |    |    |    |    |    | W  | 0  |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    | 7  |    |    |    |    |    |    |    |    |    |    |    |    |    | _  |
| Type |    |    |    |    |    |    |    | W  | 0  |    |    |    |    |    |    |    |

JPEG DEC TRIG triggers JPEG decoding operation no matter what value is programmed.



# JPEG+0044h JPEG Decoder Control Register

# JPEG\_DEC\_ABOR

т

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

JPEG\_DEC\_ABORT aborts 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[3 | 1:16] |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |      | R/    | W     |       |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8     | 7     | 6     | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    | JPEC | _FILE | BRP[  | 15:0] |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |      | R/    | W     |       |    | 7  |    |    |    |    |

JPEG\_DEC\_BRP stands for a 32-bit byte breakpoint address that hardware stalls 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 fires 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\_TOTA L SIZE

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25     | 24    | 23     | 22     | 21  | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|--------|-------|--------|--------|-----|----|----|----|----|----|
| Name |    |    |    |    |    | JP | EG_FIL | E_TO  | TAL_SI | ZE[31: | 16] |    |    |    |    |    |
| Type |    |    |    |    |    |    |        | . □E  | R/W    |        |     |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9_     | 8     | 7      | 6      | 5   | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    | JP |        | LE_TO | DTAL_S | IZE[15 | :0] |    |    |    |    |    |
| Type |    |    |    |    |    |    |        | F     | R/W    |        |     |    |    |    |    |    |

JPEG\_FILE\_TOTAL\_SIZE represents the JPEG source file size in bytes. Hardware fires 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\_MC U INDEX

| Bit  | 31 | 30 | 29 | 28 | 27 | 26  | 25     | 24    | 23     | 22     | 21  | 20 | 19    | 18              | 17 | 16   |
|------|----|----|----|----|----|-----|--------|-------|--------|--------|-----|----|-------|-----------------|----|------|
| Name |    |    |    |    |    |     |        |       |        |        |     |    | INTLV | _FIRST<br>EX[19 |    | _IND |
| Type |    |    |    |    |    |     |        |       |        |        |     |    |       | R/V             | ٧  |      |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10  | 9      | 8     | 7      | 6      | 5   | 4  | 3     | 2               | 1  | 0    |
| Name |    |    |    |    |    | INT | LV_FII | RST_M | CU_INI | DEX[15 | :0] |    |       |                 |    |      |
| Type |    |    |    |    |    |     |        | R/    | W      |        |     |    |       |                 |    |      |



This control register specifies the first MCU index that hardware processes 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\_MC
U INDEX

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25    | 24    | 23     | 22            | 21  | 20 | 19    | 18            | 17 16             |
|------|----|----|----|----|----|----|-------|-------|--------|---------------|-----|----|-------|---------------|-------------------|
| Name |    |    |    |    |    |    |       |       |        |               |     |    | INTLV | LAST<br>EX[19 | _MCU_INI<br>):16] |
| Type |    |    |    |    |    |    |       |       |        |               |     |    |       | R/V           | N                 |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8     | 7      | 6             | 5   | 4  | 3     | 2             | 1 0               |
| Name |    |    |    |    |    | IN | TLV_L | AST_M | CU_INE | <b>EX</b> [15 | :0] |    |       |               |                   |
| Type |    |    |    |    |    |    |       | R/    | W      |               |     |    | -     |               |                   |

This control register specifies the last MCU index that hardware processes 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\_M CU INDEX

| Bit  | 31 | 30 | 29 | 28 | 27 | 26  | 25     | 24    | 23     | 22    | 21   | 20 | 19   | 18              | 17 | 16   |
|------|----|----|----|----|----|-----|--------|-------|--------|-------|------|----|------|-----------------|----|------|
| Name |    |    |    |    |    |     |        |       |        |       |      |    | COMF | 0_FIRS<br>DEX[1 |    | U_IN |
| Type |    |    |    |    |    |     |        |       |        |       |      |    |      | R/V             | N  |      |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10  | 9      | 8     | 7      | 6     | 5    | 4  | 3    | 2               | 1  | 0    |
| Name |    |    |    |    |    | COI | MP0_FI | RST_N | ICU_IN | DEX[1 | 5:0] |    |      |                 |    |      |
| Type |    |    |    |    |    |     |        | R/    | W      |       |      |    |      |                 |    |      |

Only effective in progressive images. This control register specifies the first MCU index that hardware processes 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

# COMPO\_LAST\_M CU INDEX

|      |    |    |    |    |    | _  |       |       |        |       |      |    |      |                 |    |      |
|------|----|----|----|----|----|----|-------|-------|--------|-------|------|----|------|-----------------|----|------|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25    | 24    | 23     | 22    | 21   | 20 | 19   | 18              | 17 | 16   |
| Name |    |    |    |    |    |    |       |       |        |       |      |    | СОМІ | P0_LAS<br>DEX[1 | _  | U_IN |
| Type |    |    |    |    |    |    | 1     |       |        |       |      |    |      | RΛ              | N  |      |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8     | 7      | 6     | 5    | 4  | 3    | 2               | 1  | 0    |
| Name |    |    |    |    |    | CO | MP0_L | AST_N | ICU_IN | DEX[1 | 5:0] |    |      |                 |    |      |
| Type |    |    |    | 4  |    |    |       | R/    | W      |       |      |    |      |                 |    |      |

Only effective in progressive images. This control register specifies the last MCU index that hardware processes 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\_M CU INDEX

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



| Name | COMP1_FIRST_MCU_INDEX[15:0] |
|------|-----------------------------|
| Type | R/W                         |

Only effective in progressive images. This control register specifies the first MCU index that hardware processes 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\_M CU\_INDEX

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25    | 24    | 23     | 22    | 21   | 20 | 19   | 18              | 17 | 16   |
|------|----|----|----|----|----|----|-------|-------|--------|-------|------|----|------|-----------------|----|------|
| Name |    |    |    |    |    |    |       |       |        |       |      |    | COMI | P1_LAS<br>DEX[1 |    | U_IN |
| Type |    |    |    |    |    |    |       |       |        |       |      |    | -    | R/V             | ٧  |      |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8     | 7      | 6     | 5    | 4  | 3    | 2               | 1  | 0    |
| Name |    |    |    |    |    | CO | MP1_L | AST_M | ICU_IN | DEX[1 | 5:0] |    |      |                 |    |      |
| Type |    |    |    |    |    |    |       | R/    | W      |       |      |    |      |                 |    |      |

Only effective in progressive images. This control register specifies the last MCU index that hardware processes 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\_M CU INDEX

| Bit  | 31 | 30 | 29 | 28 | 27 | 26  | 25     | 24    | 23     | 22    | 21   | 20 | 19   | 18               | 17 | 16   |
|------|----|----|----|----|----|-----|--------|-------|--------|-------|------|----|------|------------------|----|------|
| Name |    |    |    |    |    |     |        |       |        |       |      |    | COMF | P2_FIRS<br>DEX[1 | _  | U_IN |
| Type |    |    |    |    |    |     |        |       |        |       |      |    |      | R/\              | Ν  |      |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10  | 9      | 8     | 7      | 6     | 5    | 4  | 3    | 2                | 1  | 0    |
| Name |    |    |    |    |    | COI | MP2_FI | RST_N | ICU_IN | DEX[1 | 5:0] |    |      |                  |    |      |
| Type |    |    |    |    |    |     |        | R/    | W      |       |      |    |      |                  |    |      |

Only effective in progressive images. This control register specifies the first MCU index that hardware processes 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\_M CU INDEX

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25    | 24    | 23     | 22    | 21   | 20 | 19 | 18              | 17 | 16   |
|------|----|----|----|----|----|----|-------|-------|--------|-------|------|----|----|-----------------|----|------|
| Name |    |    |    |    |    |    |       |       |        |       |      |    |    | P2_LAS<br>DEX[1 |    | U_IN |
| Type |    |    |    |    |    |    |       |       |        |       |      |    |    | R/\             | Ν  |      |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8     | 7      | 6     | 5    | 4  | 3  | 2               | 1  | 0    |
| Name |    |    |    |    |    | CO | MP2_L | AST_N | ICU_IN | DEX[1 | 5:0] |    |    |                 |    |      |
| Type |    |    |    |    |    |    |       | R/    | W      |       |      |    |    |                 |    |      |

Only effective in progressive images. This control register specifies the last MCU index that hardware processes 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 |    |    |    |    | CO | MP0_C | T_ID[ | 3:0] | CC | OMP1_ | QT_ID[ | 3:0] | CO | MP2_0 | QT_ID | [3:0] |
| Type |    |    |    |    |    | R/    | W     | _    |    | P     | R/W    | _    |    | R     | /W    |       |

This register contains the quantization table IDs for YUV components. Not affected by global reset and JPEG decoder abort.

**COMPO\_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\_INTE

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

The register reflects the interrupt status.

INT2 Set to 1 by file overflow interruptINT1 Set to 1 by breakpoint interruptINT0 Set to 1 by end of file interrupt

# JPEG+0078h JPEG Decoder Control Register

JPEG\_DEC\_STAT

| Bit  | 31  | 30    | 29     | 28   | 27 | 26    | 25    | 24     | 23 | 22     | 21          | 20    | 19   | 18    | 17     | 16   |
|------|-----|-------|--------|------|----|-------|-------|--------|----|--------|-------------|-------|------|-------|--------|------|
| Name |     | FOS   | BRPS   | EOFS |    | JPEG  | _DEC_ | STATE  | H  | UFF_DE | C_ST        | ATE   | MARK | ER_PA | RSER_  | STAT |
| Туре |     | RO    | RO     | RO   |    |       | RO    | 双心     |    | F      | RO          |       |      | R     | 0      |      |
| Bit  | 15  | 14    | 13     | 12   | 11 | 10    | 9     | 8      | 7  | 6      | 5           | 4     | 3    | 2     | 1      | 0    |
| Name | SOS | _PARS | SER_ST | ATE  |    | DHT_F | PARSE | R_STAT |    | DQT_P  | ARSEI<br>TE | R_STA | DA   | TA_UN | IT_STA | TE   |
| Type |     | R     | 0      |      |    |       | RO    |        |    |        | RO          |       |      | R     | 0      |      |

# 6.11 JPEG Encoder

# **6.11.1 General Descriptions**

The hardware JPEG encoder implements the baseline mode of Standard ISO/IEC 10918-1. It supports YUV 422 and 420 formats for color pictures and grayscale format. With the software assist and suitable destination memory address setting, JFIF/EXIF JPEG format can also be supported. 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 and YUV420 format. For grayscale encoding, only Y component is 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.11.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  |
| JPEG + 00ach     | JPEG encoder frame number register     | JPG_ENC_FRAME_NUM   |
| JPEG + 00b0h     | JPEG encoder frame count register      | JPG_ENC_FRAME_CNT   |
| JPEG + 00b4h     | JPEG encoder base address2 register    | JPG_ENC_DEST_ADDR2  |
| JPEG + 00b8h     | JPEG encoder DMA address2 register     | JPG_ENC_DMA_ADDR2   |
| JPEG + 00bch     | JPEG encoder STALL address2 register   | JPG_ENC_STALL_ADDR2 |

Table 51 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  |    |    |    |    |    |    |    |    |    |    |    | ADDR<br>_RL |    |    |    | RST |
| Type  |    | A  |    |    |    |    |    |    |    |    |    | WC          |    |    |    | R/W |
| Reset |    |    |    |    |    |    |    |    |    |    |    | 0           |    |    |    | 0   |

#### **RST** Reset the JPEG encoder.

ADDR\_RL DMA address reload only for the stall condition. In other condition, this bit cannot be set. This is a Write-Clear register. This register must be set once after the stall destination address is reconfigured in the stall condition.



#### 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  |    |    |    |    |    |    |    |    |    | ADDR<br>_SW | CONT | JPG | YUV | IT  | GRAY | EN  |
| Type  |    |    |    |    |    |    |    |    |    | R/W         | R/W  | R/W | R/W | R/W | R/W  | R/W |
| Reset |    |    |    |    |    |    |    |    |    | 0           | 0    | 0   | 0   | 1 ( | 0    | 0   |

**EN** Enable the JPEG encoder. This bit is cleared by hardware after encoding is done.

**GRAY** Do grayscale encode. Remember that the image DMA should be programmed as grayscale too.

0 color

1 grayscale

Interrupt enabling

0 Disable

1 Enable

YUV YUV format

0 YUV 422

1 YUV 420

JPG JPEG or other application format support

O JPEG

1 JFIF/EXIF

**CONT** JPEG continuous shooting

0 OFF

1 ON

ADDR\_SW JPEG destination address switch in continuous shooting mode

OFF, destination address accumulates

1 ON, destination address switches between JPG\_ENC\_DEST\_ADDR and JPG\_ENC\_DEST\_ADDR2.

# 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  |    |    |    |    | <b>b</b> |    | 7  |    |    |    |            |            |    |    |           |      |
| Reset |    |    |    |    |          |    |    |    |    |    |            |            |    |    |           |      |
| Bit   | 15 | 14 | 13 | 12 | 11       | 10 | 9  | 8  | 7  | 6  | 5          | 4          | 3  | 2  | 1         | 0    |
| Name  |    |    |    |    |          |    |    |    |    |    | STAL<br>L2 | STAL<br>L1 |    |    | STAL<br>L | DONE |
| Type  |    |    |    |    |          |    |    |    |    |    | RO         | RO         |    |    | RO        | RC   |
| Reset |    |    |    |    |          |    |    |    |    |    | 0          | 0          |    |    | 0         | 0    |

**DONE** Indicates that encoding operation is done. This is a Read-Clear bits.

**STALL** Indicates that encoding operation is in the stall condition. This bit is not cleared until the stall condition is cleared and reload bit is set.

**STALL1** Indicates that the current stall condition is caused by DMA\_ADDR and STALL\_ADDR.

**STALL2** Indicates that the current stall condition is caused by DMA\_ADDR2 and STALL\_ADDR2.

# 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  |    |    |    |    |    |    |   | R    | 0   |   |   |   |   |   |   |   |
| Reset |    | •  | •  |    | •  |    |   | (    | )   |   |   |   |   |   |   |   |

**BLK\_CNT** Block count has been encoded.

# JPEG+009ch JPEG encoder quality register

JPG\_ENC\_QUALIT

Υ

| 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  |    |    |    |    |    |    |    |    |    |    |    |    | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ |    | QUA | LITY |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |                                       |    | R/  | W    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |                                       |    | 0   | 0    |

**QUALITY** Encode quality.

**00** Low quality (quality factor =50), 15~20 times compression ratio.

Fair quality (quality factor =75),  $10\sim15$  times compression ratio

**10** Good quality (quality factor =90), 6~10 times compression ratio

11 High quality (quality factor =95), 4~6 times compression ratio

# JPEG+00a0h JPEG encoder base address register

JPG\_ENC\_DEST\_ ADDR

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

**BS\_ADDR** Base address of encoded data.

# JPEG+00a4h JPEG encoder current address register

JPG\_ENC\_CURR\_ ADDR

| Bit   | 31 | 30                                    | 29 | 28    | 27 | 26 | 25 | 24    | 23     | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|---------------------------------------|----|-------|----|----|----|-------|--------|-----|----|----|----|----|----|----|
| Name  |    |                                       |    |       |    |    | DM | A_ADI | OR[31: | 16] |    |    |    |    |    |    |
| Type  |    | RO                                    |    |       |    |    |    |       |        |     |    |    |    |    |    |    |
| Reset |    |                                       |    | - //- |    |    |    | (     | )      |     |    |    |    |    |    |    |
| Bit   | 15 | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 |    |       |    |    |    |       |        |     |    |    |    |    |    |    |
| Name  |    |                                       |    |       |    |    | DI | IA_AD | DR[15: | 0]  |    |    |    |    |    |    |
| Туре  |    |                                       |    |       |    |    |    | R     | 0      |     |    |    |    |    |    |    |
| Reset |    |                                       |    |       |    |    |    | (     | )      |     |    |    |    |    |    |    |

**CURR\_ADDR** The current DMA address during encoding.

# JPEG+00a8h JPEG encoder STALL address register

JPG\_ENC\_STALL\_ ADDR

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



| Name  |    |    |    |    |    |    | STA | LL A  | DR[31 | :16] |   |   |   |   |   |   |
|-------|----|----|----|----|----|----|-----|-------|-------|------|---|---|---|---|---|---|
| Type  |    |    |    |    |    |    |     |       | W     |      |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |     | (     | )     |      |   |   |   |   |   |   |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8     | 7     | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  |    |    |    |    |    |    | ST  | ALL_A | DDR[1 | 5:0] |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |     | R     | W     |      |   |   |   |   |   |   |
| Reset |    | •  |    | •  |    |    |     |       | 0     |      | • |   |   |   |   |   |

**STALL\_ADDR** This field is the upper bound of JPEG encoder's write-address. Note that the stall address must be word-aligned. Whenever the stall address is reached, the JPEG encoder stalls and issues an interrupt to software. After, if the software programs the JPG\_ENC\_STALL\_ADDR to another value, the JPEG encoder resumes 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.

# JPEG+00ach JPEG encoder continuous shooting frame number

JPG\_ENC\_FRA
ME NUM

| 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  |    |    |    |    |    |    |    |    |    |    | ì   |    | FRAM | _NUM |    |    |  |  |  |  |
| Type  |    |    |    |    |    |    |    |    |    |    | R/W |    |      |      |    |    |  |  |  |  |
| Reset |    |    |    |    |    |    |    |    |    |    | 0   |    |      |      |    |    |  |  |  |  |

**FRAME\_NUM** Frame number in continuous shooting is encoded

# JPEG+00b0h JPEG encoder continuous shooting current frame

JPG\_ENC\_CUR
R FRAME CNT

|       |    |    |    |    |    |    | -  |    |    |    |     |    |      | <u></u> |    |    |  |  |  |
|-------|----|----|----|----|----|----|----|----|----|----|-----|----|------|---------|----|----|--|--|--|
| 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  |    |    |    |    |    |    |    |    |    |    |     | -  | FRAM | E_CNT   | -  |    |  |  |  |
| Type  |    |    |    |    |    |    | 1  |    |    |    | R/O |    |      |         |    |    |  |  |  |
| Reset |    |    |    |    |    |    |    |    |    |    | 0   |    |      |         |    |    |  |  |  |

**FRAME\_CNT** Frame count has been encoded.

# JPEG+00b4h JPEG encoder 2<sup>nd</sup> base address register

JPG\_ENC\_DEST\_ ADDR2

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

**BS ADDR** Base address of 2<sup>nd</sup> encoded data.



# JPEG+00b8h JPEG encoder 2<sup>nd</sup> current address register

# JPG\_ENC\_CURR\_ ADDR2

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

**CURR ADDR** The current DMA address during 2<sup>nd</sup> encoding.

#### JPEG+00bch JPEG encoder STALL address2 register

# JPG\_ENC\_STALL\_ ADDR2

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25   | 24    | 23     | 22    | 21 | 20           | <u> 19</u> | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|------|-------|--------|-------|----|--------------|------------|----|----|----|
| Name  |    |    |    |    |    |    | STAI | LL_AD | DR2[31 | 1:16] |    |              |            |    |    |    |
| Type  |    |    |    |    |    |    |      | R/    | W      |       |    |              |            |    |    |    |
| Reset |    |    |    |    |    |    |      | (     | )      |       |    |              |            |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8     | 7      | 6     | 5  | <b>7</b> 4 . | 3          | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    | STA  | LL_AD | DR2[1  | 5:0]  |    |              |            |    |    |    |
| Type  |    |    |    |    |    |    |      | R/    | W      | 4     |    |              |            |    |    |    |
| Reset |    |    | ,  |    | •  | •  | •    | (     | )      |       |    |              | •          | •  | •  |    |

**STALL\_ADDR2**This field is the upper bound of JPEG encoder's write-address2. Note that the stall address2 only works in continuous shooting and memory auto-switch mode.

#### 6.11.2.1 JFIF/EXIF support

In JFIF/EXIF mode, the JPEG encoder does not generate SOI marker and related thumbnail header and small image data. The JPEG encoder just outputs the bitstreams from DQT marker. The software needs to provide the suitable destination address after estimating the size of SOI marker, related thumbnail header and small image data. The SOI marker and related thumbnail header need to be handled by MCU and the small image data can be output by IMGDMA. With the suitable destination address configuration, the JFIF/EXIF JPEG format can be generated. **Figure 2** illustrates the data partition for JFIF/EXIF support. Before JPEG encoding, three suitable address configurations provides. The ADDR1 is provided to SOI maker and the thumbnail header. This part is handled by software. The ADDR2 is provided to IMGDMA to write RGB small image data. The last address, ADDR3, provides to the JPEG encoder to write out remaining bitstreams.





Figure 2. The JFIF/EXIF data structure.

# 6.12 GIF Decoder

# 6.12.1 General Description

GIF Decoder is aimed to decode GIF images. 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 very beneficial for MCU off loading and achieving high performance. Figure 29 shows the GIF file structure. The GIF decoder is aimed to do LZW decompression, on-the-fly resizing down, clipping and pitching; header parsing is performed by software.





Figure 29 GIF file structure

# 6.12.2 Register Definitions

# GIFDEC+0000 Input File Start Address

INFILE\_START\_AD

DR

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

**INFILE\_START\_ADDR** The input file starting address. GIF decoder gets decompression data from this address. The address does not need to be word aligned.

# h Input File count

**INFILE\_COUNT** 

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25   | 24    | 23    | 22   | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|------|-------|-------|------|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    | INFI | LE_CO | UNT31 | :16] |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |      | R/    | W     |      |    |    |    |    |    |    |
| Reset | 27 |    |    |    |    |    |      | (     | )     |      |    |    |    |    |    |    |



| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8      | 7     | 6    | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|-----|--------|-------|------|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    | INF | ILE_CC | DUNT1 | 5:0] |   |   |   |   |   |   |
| Type  |    |    |    |    |    |    |     | R/     | W     |      |   |   |   |   |   |   |
| Reset |    |    | •  |    | •  |    | •   | (      | )     |      |   |   | • |   |   |   |

**INFILE COUNT** 

GIF decoder supports pause-resume mechanism, i.e., gif decoder would stop decompressing when input file is empty, and wait for notice from software. Input file count is assigned for this issue. When gif decoder encounters infile count, it will stop and indicate by interrupt.

GIFDEC+0008 **Color Table Start Address** h

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25   | 24    | 23    | 22     | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|------|-------|-------|--------|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    | CT_S | TART_ | 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  |    |    |    |    |    |    | CT_S | TART_ | ADDR  | [15:0] |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |      | R/    | W     |        |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |      | (     | 0     |        |    |    |    |    |    |    |

CT\_START\_ADDR The color table starting address. It needs to be word aligned, and each palette entry is one word.

# GIFDEC+000C Color Table End Address

CT\_END\_ADDR

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24               | 23     | 22    | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|-----|------------------|--------|-------|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    | CT_ | END_             | ADDR[3 | 1:16] |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |     | F                | ₹/W    |       | ,  |    |    |    |    |    |
| Reset |    |    |    |    |    |    |     |                  | 0      |       |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8                | 7      | 6     | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    | CT  | END <sup>4</sup> | ADDR[1 | 5:0]  |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |     | F                | R/W    |       |    |    |    |    |    |    |
| Reset |    | •  |    | •  |    |    | •   |                  | 0      | •     | •  |    | •  | •  |    |    |

CT END ADDR The color table end address. It needs to be word aligned.

## GIFDEC+0010

# **LZW Decompression Tree Start Address**

TREE\_START\_

**ADDR** 

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25    | 24    | 23    | 22               | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|-------|-------|-------|------------------|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    | TREE_ | START | _ADDF | <b>?[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  |    |    |    |    |    |    | TREE  | STAR  | Γ_ADD | R[15:0]          |    |    |    |    |    |    |
| Type  |    |    |    | 4  |    |    |       | R/    | /W    |                  |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |       | (     | 0     |                  |    |    |    |    |    |    |

**TREE\_START\_ADDR** The LZW decompressing tree starting address. This tree, or called 'dictionary', is essential for LZW decompression. It needs to be word aligned.

# **LZW Decompression Tree END Address**

TREE END AD **DR** 

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





| T = 1 | T. DAU |
|-------|--------|
| Type  | R/W    |
| Reset | 0      |

TREE\_END\_ADDR The LZW decompressing tree end address. The end address is set to prevent gif decoder from writing the wrong memory sections. When this happens, gif decoder would stop and generates an interrupt to inform software. It needs to be word aligned.

# GIFDEC+0018 LZW Decode Stack Start Address

|       |    |    |    |    |    |    |       |       |       |         |    |    |    |     | 7  |    |
|-------|----|----|----|----|----|----|-------|-------|-------|---------|----|----|----|-----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25    | 24    | 23    | 22      | 21 | 20 | 19 | 18  | 17 | 16 |
| Name  |    |    |    |    |    |    | STK_S | TART_ | _ADDR | [31:16] |    |    |    |     |    |    |
| Type  |    |    |    |    |    |    |       | R     | W     |         |    |    |    | TO. |    |    |
| Reset |    |    |    |    |    |    |       |       | 0     |         |    |    |    |     |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8     | 7     | 6       | 5  | 4  | 3  | 2   | 1  | 0  |
| Name  |    |    |    |    |    |    | STK_S | START | _ADDF | R[15:0] |    |    |    |     |    |    |
| Type  |    | •  | •  | •  |    | •  |       | R     | W     |         | •  | •  |    | •   |    | •  |
| Reset |    |    |    |    |    |    |       |       | )     |         |    |    |    |     |    |    |

STK START ADDR The stack starting address. The stack is for LZW decompression usage. It needs word aligned.

# GIFDEC+001C LZW Decode Stack End Address

STK END ADD

R

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

STK END ADDR The stack end address. The end address is set to prevent gif decoder from writing the wrong memory sections. When this happens, gif decoder would stop and generates an interrupt to inform software. It needs to be word aligned.

## GIFDEC+0020

# **Output File Start Address**

OUTFILE\_START\_

**ADDR** 

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

**OUTFILE\_START\_ADDR** Output file start address. It needs word aligned.

# **Output File End Address**

**OUTFILE END AD** 

DR

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



#### MT6228 GSM/GPRS Baseband Processor Data Sheet Revision 1.0

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

**OUTFILE END ADDR** Output file end address. The end address is set to prevent gif decoder from writing the wrong memory sections. When this happens, gif decoder would stop and generates an interrupt to inform software. It needs to be word aligned.

# GIFDEC+0028 GIF Decompression Enable

| 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  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DEC_<br>EN |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W        |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0          |

DEC\_EN GIF decoder enable signal. And it will de-asserted when decompression finishes.

GIFDEC+002C GIF File Boundary h

**BOUNDARY** 

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25   | 24       | 23    | 22     | 21         | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|------|----------|-------|--------|------------|----|----|----|----|----|
| Name  |    |    |    |    |    |    | FILE | BOUND    | AARY[ | 31:16] | <i>3</i> 🗔 |    |    |    |    |    |
| Type  |    |    |    |    |    |    |      | F        | 3     |        |            |    |    |    |    |    |
| Reset |    |    |    |    |    |    |      | (        | )     |        | ,          |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8        | 7     | 6      | 5          | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    | FILE | BOUNI    | DAARY | [15:0] |            |    |    |    |    |    |
| Type  |    |    |    |    |    |    |      | <b>₫</b> | 2     |        |            |    |    |    |    |    |
| Reset |    |    |    |    |    |    |      |          | )     |        |            |    |    |    |    |    |

Report the file boundary that gif decoder just fetched. **BOUNDARY** 

GIFDEC+0030 LZW Min Code Size

MIN\_CODE\_SIZ

E

|       |    |    |    |    |    |          | <i>o 1</i> /li |    |    |    |    |    |               |          |    |    |  |  |  |  |
|-------|----|----|----|----|----|----------|----------------|----|----|----|----|----|---------------|----------|----|----|--|--|--|--|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26       | 25             | 24 | 23 | 22 | 21 | 20 | 19            | 18       | 17 | 16 |  |  |  |  |
| Name  |    |    |    |    |    |          |                |    |    |    |    |    |               |          |    |    |  |  |  |  |
| Type  |    |    |    |    |    | $\Gamma$ | <u> </u>       |    |    |    |    |    |               |          |    |    |  |  |  |  |
| Reset |    |    |    |    |    |          |                |    |    |    |    |    |               |          |    |    |  |  |  |  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10       | 9              | 8  | 7  | 6  | 5  | 4  | 3             | 2        | 1  | 0  |  |  |  |  |
| Name  |    |    |    |    |    |          |                |    |    |    |    |    | MIN_CODE_SIZE |          |    |    |  |  |  |  |
| Type  |    |    |    |    |    |          |                |    |    |    |    |    | R/W           |          |    |    |  |  |  |  |
| Reset |    |    |    |    |    |          |                |    |    |    |    |    |               | R/W<br>0 |    |    |  |  |  |  |

GIF min code size for LZW decompression. Reasonable value is 2-11. MIN CODE SIZE

GIFDEC+0034

# **Interlace Control Register**

**INTERLACE CT** 

RI

| ••      |    | 4  |    |    |    |    |    |    |    |    |    |    |    |    |    |       |
|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|
| 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    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | INTER |
| Ivallio |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | LACE  |

|   | Гуре  |  |  |  |  |  |  |  |   | R/W |
|---|-------|--|--|--|--|--|--|--|---|-----|
| F | Reset |  |  |  |  |  |  |  | _ | 0   |

**INTERLACE** Interlace enable for GIF decoder.

> 0 Non-interlaced

1 Interlaced

#### GIFDEC+0038 Image width and height register h

IMG\_WIDTH\_HEIG

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24     | 23             | 22  | 21 | 20 | 19         | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|-----|--------|----------------|-----|----|----|------------|----|----|----|
| Name  |    |    |    |    |    |    | II. | IG_WII | <b>OTH</b> [15 | :0] |    |    |            | 7  |    |    |
| Type  |    |    |    |    |    |    |     | R/     | W              |     |    |    |            |    |    |    |
| Reset |    |    |    |    |    |    |     | (      | )              |     |    |    |            |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8      | 7              | 6   | 5  | 4  | 3          | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    | IM  | G_HEI  | 3HT[15         | :0] |    |    |            |    |    |    |
| Type  |    |    |    |    |    |    |     | R/     | W              |     |    |    | $\nabla J$ |    |    |    |
| Reset |    |    |    |    |    |    |     | (      | )              |     |    |    |            |    |    |    |

IMG\_WIDTH Image width. **IMG\_HEIGHT** Image height.

# GIFDEC+003C Resize control register

#### **RESIZE CTRL**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23       | 22 | <u>21</u> | 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  |    |    |    |    |    |    | RI | SIZE | H_RAT    | 10 | RE        | SIZE_ | W_RAT | 10 |    | RESIZ<br>E_EN |
| Type  |    |    |    |    |    |    |    | R/   | W        |    |           | R/    | W     |    |    | R/W           |
| Reset |    |    |    |    |    |    |    |      | <u> </u> |    |           | (     | )     |    |    | 0             |

Since input file for gif decoder might be an interlaced file, the gif decoder cannot perform decompress and resize by resizer at the same time. Hence, there needs a built-in resizer in gif decoder. There is a drop line and drop pixel sizing down resizer in gif decoder.

**RESIZE EN** Enable resize on the fly

0: disable

1: enable

RESIZE\_W\_RATIO Resize ratio in width

0: no resize

1: 1/2

2: 1/4

3: 1/8

4: 1/16

5: 1/32

6: 1/64

7: 1/128

8: 1/256

9: 1/512

10: 1/1024

11: 1/2048



12: 1/4096

13: 1/8192

14: 1/16384

15: 1/32768

#### **RESIZE H RATIO** Resize ratio in height

0: no resize

1: 1/2

2: 1/4

3: 1/8

4: 1/16

5: 1/32

6: 1/64

0. 1/0 !

7: 1/128

8: 1/256

9: 1/512

10: 1/1024

11: 1/2048

12: 1/4096

13: 1/8192

14: 1/16384

15: 1/32768

# GIFDEC+0040

h

# **Transparent Control Register**

## TRANS\_CTRL

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24         | 23 | 22    | 21    | 20 | 19 | 18 | 17                 | 16           |
|-------|----|----|----|----|----|----|----|------------|----|-------|-------|----|----|----|--------------------|--------------|
| Name  |    |    |    |    |    |    |    |            |    |       |       |    |    |    |                    |              |
| Type  |    |    |    |    |    |    |    |            |    |       |       |    |    |    |                    |              |
| Reset |    |    |    |    |    |    |    | <b>T</b> . |    |       |       |    |    |    |                    |              |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8          | 7  | 6     | 5     | 4  | 3  | 2  | 1                  | 0            |
| Name  |    |    |    |    |    |    | 5  | 2          | ТІ | RANS_ | CL_KE | Υ  |    |    | TRAN<br>S_TP<br>YE | TRAN<br>S_EN |
| Type  |    |    |    |    |    |    |    | ,          |    | R     | W     |    |    |    | R/W                | R/W          |
| Reset |    |    |    |    |    |    |    |            |    | (     | )     |    |    |    | 0                  | 0            |

Since input file for gif decoder might include transparent color key, gif decoder would handle transparent files according to setting as following.

**TRANS\_EN** Transparent enable.

0: disable transparent

1: enable transparent

TRANS\_TYPE Transparent handling method.

0: replace transparent color as background color.

1: no output when encounter transparent color.

TRANS\_CL\_KEY Transparent color key.

# GIFDEC+0044

h

**Background Color** 

**BG\_COLOR** 

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20    | 19    | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|-------|-------|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    | 3G_CO | LOR_E | 3  |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    | R/    | W     |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    | (     | )     |    |    |    |



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

**BG COLOR R** Background R for transparent output.

**BG COLOR G** Background G for transparent output.

**BG\_COLOR\_B** Background B for transparent output.

# GIFDEC+004C LCD width and height register

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

To speed up gif display and reduce memory usage, gif decoder supports clipping and pitching function. To support clipping and pitching, LCD width and height are essential for gif decoder.

LCD\_W LCD width LCD\_H LCD height

# GIFDEC+0050

h

# **Clipping window XY register**

**CLIP XY** 

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

To speed up gif display and reduce memory usage, gif decoder supports clipping and clipping function. To support clipping and pitching, clipping window-starting point is necessary for gif decoder.

**CLIP X** CLIP\_X[15] sign bit: 0: positive 1: negative

CLIP\_X[14:0] coordinate X for clipping window

**CLIP Y** CLIP\_Y[15] sign bit: 0: positive 1: negative

CLIP\_Y[14:0] coordinate Y for clipping window

## GIFDEC+0054

# Clipping window width and height register

CLIP\_WH

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



h

To speed up gif display and reduce memory usage, gif decoder supports clipping and clipping function. To support clipping and pitching, clipping window dimension is necessary for gif decoder.

**CLIP W** Clipping window width CLIP\_H Clipping window height

# GIFDEC+0058

### **Image XY**

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

To speed up gif display and reduce memory usage, gif decoder supports clipping and clipping function. To support clipping and pitching, image-starting point is necessary for gif decoder.

IMG\_X IMG\_X[15] sign bit: 0: positive 1: negative

IMG\_X[14:0] X for image logic window

IMG Y IMG\_Y[15] sign bit: 0: positive 1: negative

IMG\_Y[14:0] Y for image logic window

h

# GIFDEC+005C Image offset XY

**IMG OFFSET X** 

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

To speed up gif display and reduce memory usage, gif decoder supports clipping and clipping function. To support clipping and pitching, image starting offset is necessary for gif decoder.

**IMG OFFSET X** IMG\_OFFSET\_X[15:0] offset X for image logic window IMG\_OFFSET\_Y[15:0] offset Y for image logic window **IMG OFFSET Y** 

#### GIFDEC+0060

h

# **Interrupt Enable Register**

**IRQ EN** 

| 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  |    |    |    |    |    |    |    |    |    | TREE<br>ERRO<br>R | TREE<br>FULL | STAC<br>KFUL<br>L |     | OUTF<br>ULL | INEM<br>PTY | IMG_C<br>MP |
| Type  |    |    |    |    |    |    |    |    |    | R/W               | R/W          | R/W               | R/W | R/W         | R/W         | R/W         |
| Reset |    |    |    |    |    |    |    |    |    | 0                 | 0            | 0                 | 0   | 0           | 0           | 0           |

IMG CMP

Image decompressed complete interrupt enable.

**INEMPTY** 

Input file empty interrupt enable.



**OUTFULL** Output file full interrupt enable.

**PIXEL** Pixel output num error interrupt enable. STACKFULL Stack output full interrupt enable.

**TREEFULL** Tree full interrupt enable.

TREEERROR Decompression error interrupt enable.

# GIFDEC+0064

# **Interrupt Status**

| 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  |    |    |    |    |    |    |    |    |    | TREE<br>ERRO<br>R | TREE<br>FULL | STAC<br>KFUL<br>L |    | OUTF<br>ULL | INRM<br>PTY | IMG_C<br>MP |
| Type  |    |    |    |    |    |    |    |    |    | R                 | R            | R                 | R  | R           | R           | R           |
| Reset |    |    |    |    |    |    |    |    |    | 0                 | 0            | 0_                | 0  | 0           | 0           | 0           |

**IMG CMP** Image decompressed complete interrupt.

**INEMPTY** Input file empty interrupt. **OUTFULL** Output file full interrupt.

**PIXEL** Pixel output num errors interrupt.

STACKFULL Stack output full interrupt. **TREEFULL** Tree full interrupt.

**TREEERROR** Decompression error interrupt.

# GIFDEC+0068

**GIF Reset RST** 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  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RST |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0   |

**RST** Reset for GIF decoder. Write 0x1201, then hardware will reset itself.

# GIFDEC+006C Color Output Format h

**OUT\_FORMAT** 

| 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  |    | .1 |    | PAC | K_IND | EX_DE | PTH | PACK<br>_INDE<br>X |    |    |    |    | PARTI<br>AL |    | OUT_F | ORMA<br>T |
| Type  |    |    |    |     | R/    | W     |     | R/W                |    |    |    |    |             |    | R/    | W         |
| Reset |    |    |    |     | 'b1   | 000   |     | 0                  |    |    |    |    |             |    | (     | )         |

**OUT FORMAT** To support different applications, gif decoder output data as rgb565, rgb888 and color index mode. 2'b00: RGB565



2'b01: RGB888 2'b10: Index

**PARTIAL** 

To reduce memory usage, gif decoder support pause-resume mechanism when input file is empty according setting as blow.

1: enable partial input, i.e. pause-resume mechanism.

0: disable partial input, i.e. pause-resume mechanism.

PACK\_INDEX To reduce memory usage, gif decoder support pack index when output format is Index mode

1: enable pack index

0: disable pack index

PACK\_INDEX\_DEPTH pack index depth, 1, 2, 4, 8

# GIFDEC+0074 Pack width resize

| Bit   | 31 | 30   | 29     | 28     | 27      | 26 | 25    | 24     | 23  | 22  | 21   | 20       | 19   | 18     | 17    | 16      |
|-------|----|------|--------|--------|---------|----|-------|--------|-----|-----|------|----------|------|--------|-------|---------|
| Name  |    |      |        |        |         | PA | CK_RE | SIZE_V | V_D |     |      |          | PACK | _RESIZ | ZE_W_ | N [9:6] |
| 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  |    | PACK | _RESIZ | ZE_W_I | N [5:0] |    |       |        |     | PAC | K_RE | SIZE_V   | V_Q  |        |       |         |
| Туре  |    |      | R/     |        |         |    |       |        |     |     | R/   | W _      |      |        |       |         |
| Reset |    |      | (      | )      |         |    |       |        |     |     |      | <u> </u> |      |        |       |         |

When in packing index mode, the resizer is different. The resize width ratio doesn't need to be an integer. Resize ratio = PACK\_RESIZE\_W\_Q + (PACK\_RESIZE\_W\_N / PACK\_RESIZE\_W\_D)

# **GIFDEC+0078**

h

#### Pack height resize

**PACK RESIZE** 

| Bit   | 31 | 30   | 29    | 28     | 27      | 26 | 25    | 24   | 23  | 22 | 21    | 20     | 19   | 18    | 17    | 16      |
|-------|----|------|-------|--------|---------|----|-------|------|-----|----|-------|--------|------|-------|-------|---------|
| Name  |    |      |       |        |         | PA | CK_RE | SIZE | H D |    |       |        | PACK | RESIZ | ZE_H_ | N [9:6] |
| 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  |    | PACK | _RESI | ZE_H_I | N [5:0] |    |       |      |     | PA | CK_RE | SIZE_I | 1_Q  |       |       |         |
| Type  |    |      |       | W      |         |    |       |      |     |    | R/    | W      |      |       |       |         |
| Reset |    |      | (     | )      | •       |    |       |      |     | •  | (     | )      |      |       |       | •       |

When in packing index mode, the resizer is different. The resize height ratio doesn't need to be an integer. Resize ratio = PACK\_RESIZE\_H\_Q + (PACK\_RESIZE\_H\_N / PACK\_RESIZE\_H\_D)

#### **PNG Decoder** 6.13

#### **General Description** 6.13.1

PNG Decoder is aimed to decode PNG pictures. This hardware-assisted png 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 very beneficial for MCU off loading and achieving high performance. The PNG decoder is aimed to do ZLIB decompression, on-the-fly resizing down, clipping and pitching; header parsing is performed by software.



0h

# 6.13.2 Register Definitions

## PNGDEC+000

# **Input File Start Address**

#### **INFILE START ADDR**

|       |    |    |    |    | _  |     |        | _     | _     | _       |    | _  |    |    | -          | $\rightarrow$ |
|-------|----|----|----|----|----|-----|--------|-------|-------|---------|----|----|----|----|------------|---------------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26  | 25     | 24    | 23    | 22      | 21 | 20 | 19 | 18 | <u>1</u> 7 | 16            |
| Name  |    |    |    |    |    | II. | NFILE_ | START | _ADDI | R[31:16 | 6] |    |    |    |            |               |
| Type  |    |    |    |    |    |     |        | R/    | W     |         |    |    |    |    |            |               |
| Reset |    |    |    |    |    |     |        | (     | )     |         |    |    |    |    |            |               |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10  | 9      | 8     | 7     | 6       | 5  | 4  | 3  | 2  | 1_1_       | 0             |
| Name  |    |    |    |    |    |     | NFILE  | STAR  | T_ADD | R[15:0  |    |    |    |    |            |               |
| Type  |    |    |    |    |    |     |        | R/    | W     |         |    |    |    |    |            |               |
| Reset |    | •  |    |    |    | •   | •      | (     | )     |         |    | •  |    |    |            | •             |

**INFILE\_START\_ADDR** The input file starting address; PNG decoder would get decompression data from this address. The address hasn't to be word aligned.

#### PNGDEC+000

4h Input File count

#### **INFILE COUNT**

| Bit   | 31 | 30  | 29 | 28 | 27 | 26 | 25   | 24    | 23    | 22          | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|-----|----|----|----|----|------|-------|-------|-------------|----|----|----|----|----|----|
| Name  |    |     |    |    |    |    | INFI | LE_CO | UNT31 | 1:16]       |    |    |    |    |    |    |
| Type  |    | R/W |    |    |    |    |      |       |       |             |    |    |    |    |    |    |
| Reset |    |     |    |    |    |    |      | (     | )     |             |    |    |    |    |    |    |
| Bit   | 15 | 14  | 13 | 12 | 11 | 10 | 9    | 8     | 7     | 6           | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |     |    |    |    |    | INF  | ILE_C | DUNT1 | <b>5:0]</b> |    |    |    |    |    |    |
| Type  |    |     |    |    |    |    |      | R/    | W     |             |    |    |    |    |    |    |
| Reset |    |     |    |    |    |    |      | (     | ) _ ( |             | 7  |    |    |    |    |    |

**INFILE\_COUNT** PNG decoder supports pause-resume mechanism, i.e., png decoder would stop decompressing when input file is empty, and wait for notice from software. Input file count is assigned for this issue. When png decoder encounters infile count, it will stop and indicate by interrupt.

#### PNGDEC+000

8h

0h

# **Color Table Start Address**

#### CT\_START\_ADDR

| Bit   | 31 | 30 | 29 | 28 | 27              | 26 | 25   | 24    | 23    | 22     | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|-----------------|----|------|-------|-------|--------|----|----|----|----|----|----|
| Name  |    |    |    |    |                 |    | CT_S | TART_ | 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  |    |    |    |    |                 |    | CT_S | TART_ | ADDR  | [15:0] |    |    |    |    |    |    |
| Type  |    |    |    |    | $\equiv \nabla$ |    | -    | R     | /W    |        |    |    |    |    |    |    |
| Reset |    |    |    |    | - 74            |    | ·    |       | 0     |        |    |    |    |    |    |    |

**CT\_START\_ADDR** The color table starting address. It needs to be word aligned. And each palette entry is one word.

#### PNGDEC+001

# Output File Start Address

#### OUT\_START\_ADDR

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



4h

8h

0h

**OUT\_START\_ADDR** Output file start address. It needs to be word aligned.

## PNGDEC+001

# Output file End Address

#### OUT\_END\_ADDR

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24    | 23     | 22     | 21 | 20 | 19 | 18  | 17 | 16 |
|-------|----|----|----|----|----|----|-----|-------|--------|--------|----|----|----|-----|----|----|
| Name  |    |    |    |    |    |    | OUT | END_/ | ADDR[3 | 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  |    |    |    |    |    |    | OUT | END   | ADDR[  | 15:0]  |    |    |    |     |    |    |
| Type  |    |    |    |    |    |    |     | R     | /W     |        |    |    |    |     |    |    |
| Reset |    |    |    |    | •  | •  | •   |       | 0      |        |    |    |    | 7   |    | •  |

**OUT\_END\_ADDR** Output file end address. It needs to be word aligned.

# PNGDEC+001

#### **Huffman HCLEN Table Start Address**

## **HCELN START ADDR**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25    | 24    | 23    | 22         | 21                   | 20       | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|-------|-------|-------|------------|----------------------|----------|----|----|----|----|
| Name  |    |    |    |    |    | Н  | CLEN_ | START | _ADD  | R[31:10    | 5]                   |          |    |    |    |    |
| Type  |    |    |    |    |    |    |       | R/    | W     |            |                      |          |    |    |    |    |
| Reset |    |    |    |    |    |    |       | (     | )     |            |                      | <u> </u> |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8     | 7     | 6          | 5                    | 4        | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    | H  | CLEN  | STAR  | T_ADE | DR[15:0    |                      |          |    |    |    |    |
| Type  |    |    |    |    |    |    |       | R/    | W     |            | $\overline{\Lambda}$ |          |    |    |    |    |
| Reset |    |    |    |    |    |    |       | (     | )     | $\Sigma c$ |                      |          |    |    |    |    |

**HCLEN\_START\_ADDR** Huffman code length code table starting address. It needs to be word aligned.

# PNGDEC+002

# **Huffman code length Start Address**

#### LEN\_START\_ADDR

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 24    |        | 22      | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----------|--------|---------|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    | LEN_STAR | _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  |    |    |    |    |    |    | LEN STAR | T_ADDF | R[15:0] |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |          | R/W    |         |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |          | 0      |         |    |    |    |    |    |    |

**LEN\_START\_ADDR** Huffman code length starting address. It needs to be word aligned.

#### PNGDEC+002

# **Huffman HLIT Table Start Address**

#### **HLIT\_START\_ADD**

| 8h    |    |    | nuill | пан г | L  | labit | e Stai | t Aud | 1622  |         |    |    |    |    |    | R  |
|-------|----|----|-------|-------|----|-------|--------|-------|-------|---------|----|----|----|----|----|----|
| Bit   | 31 | 30 | 29    | 28    | 27 | 26    | 25     | 24    | 23    | 22      | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |    |    |       | -     |    |       | HLIT_S | START | ADDR  | [31:16] |    |    |    |    |    |    |
| Type  |    |    |       |       |    |       |        | R/    | W     |         |    |    |    |    |    |    |
| Reset |    |    |       |       |    |       |        | (     | )     |         |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13    | 12    | 11 | 10    | 9      | 8     | 7     | 6       | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |       |       |    |       | HLIT   | START | _ADDF | R[15:0] |    |    |    |    |    |    |
| Type  |    |    |       |       |    |       |        | R/    | W     |         |    |    |    |    |    |    |
| Reset |    |    |       |       |    |       |        | (     | )     |         |    |    |    |    |    |    |

**HLIT\_START\_ADDE** Huffman literal code table starting address. It needs to be word aligned.



## **Huffman HDIST Table Start Address**

# HDIST\_START\_ADD

| un    |    |    |    |    |    |    |        |       |        |         |          |    |    |    |    | R  |
|-------|----|----|----|----|----|----|--------|-------|--------|---------|----------|----|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25     | 24    | 23     | 22      | 21       | 20 | 19 | 18 | 17 | 16 |
| Name  |    |    |    |    |    | H  | HDIST_ | START | _ADDI  | R[31:16 | <u>[</u> |    |    |    |    |    |
| Type  |    |    |    |    |    |    |        | R     | /W     |         |          |    |    |    |    |    |
| Reset |    |    |    |    |    |    |        | (     | 0      |         |          |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9      | 8     | 7      | 6       | 5        | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    | HDIS   | _STAR | T_ADDF | R[15:0] |          |    |    |    |    |    |
| Type  |    |    |    |    |    |    |        | R     | /W     |         |          |    |    |    |    |    |
| Reset |    |    |    |    |    |    |        |       | 0      |         |          |    |    |    |    |    |

**HDIST\_START\_ADDR** Huffman distance code table starting address. It needs to be word aligned.

## PNGDEC+003

8h

0h

# **Line Buffer0 Start Address**

**BUFFO START ADD** 

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25    | 24    | 23     | 22      | 21             | 20         | 719 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|-------|-------|--------|---------|----------------|------------|-----|----|----|----|
| Name  |    |    |    |    |    | В  | UFF0_ | START | _ADD   | R[31:16 | <u>[</u>       |            |     |    |    |    |
| Type  |    |    |    |    |    |    |       | R/    | W      |         |                |            |     |    |    |    |
| Reset |    |    |    |    |    |    |       | (     | )      |         |                |            |     |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8     | 7      | 6       | 5              | 74         | 3   | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    | BUFF  | _STAR | T_ADDI | R[15:0] |                |            |     |    |    |    |
| Type  |    |    |    |    |    |    |       | R/    | W      |         | $ abla \nabla$ | <i>5</i> 🔚 |     |    |    |    |
| Reset |    |    |    |    |    |    |       | (     | )      |         |                |            |     |    |    |    |

**BUFF0\_START\_ADDR** Line buffer0 starting address (for de-filtering). It needs to be word aligned.

# PNGDEC+004

### **Line Buffer1 Start Address**

**BUFF1\_START\_ADD** 

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25         | 24    | 23    | 22      | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|------------|-------|-------|---------|----|----|----|----|----|----|
| Name  |    |    |    |    |    | BU | JFF1_      | START | ADD   | R[31:16 | 6] |    |    |    |    |    |
| Type  |    |    |    |    |    |    |            | B/    | W     |         |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |            |       | 0     |         |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9          | 8     | 7     | 6       | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    | В  | UFF1       | STAR  | T_ADD | R[15:0  |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    | $\nearrow$ | R     | W     |         |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |            |       | 0     |         |    |    |    |    |    |    |

**BUFF1\_START\_ADDR** Line buffer1 starting address (for de-filtering). It needs to be word aligned.

**LZ77 Buffer Start Address** 8h

LZ77\_START\_ADDR

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25     | 24    | 23    | 22       | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|--------|-------|-------|----------|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    | LZ77_9 | START | _ADDF | R[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  |    |    |    |    |    |    | LZ77_  | START | _ADDI | R[15:0]  |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |        | R     | /W    |          |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |        |       | 0     |          |    |    |    |    |    |    |

LZ77 START ADDRLZ77 buffer starting address. It needs to be word aligned.

Color\_Type

COLOR\_TYPE

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

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

**COLOR\_TYPE** Indicate color type of PNG image.

0: greyscale

2: true color

3: palette

4: greyscale with alpha

6: true color with alpha

**COLOR\_DEPTH** Indicate color bit depth of PNG image.

PNGDEC+005 IMG\_WIDTH\_HEIGHT 4h

# IMG\_WIDTH\_HEIGHT

| Bit   | 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24     | 23     | 22  | 21            | 20 | 1 19 | 18 | 17 | 16 |
|-------|-----|----|----|----|----|----|----|--------|--------|-----|---------------|----|------|----|----|----|
| Name  |     |    |    |    |    |    |    |        |        |     |               |    |      |    |    |    |
| Type  | R/W |    |    |    |    |    |    |        |        |     |               |    |      |    |    |    |
| Reset | 0   |    |    |    |    |    |    |        |        |     |               |    |      |    |    |    |
| Bit   | 15  | 14 | 13 | 12 | 11 | 10 | 9  | 8      | 7      | 6   | <b>□</b> 57.J | 4  | 3    | 2  | 1  | 0  |
| Name  |     |    |    |    |    |    | IM | G_HEIG | GHT[15 | :0] | 1             |    |      |    |    |    |
| Type  |     |    |    |    |    |    |    |        |        |     |               |    |      |    |    |    |
| Reset |     |    |    |    |    |    |    |        |        |     |               |    |      |    |    |    |

IMG\_WIDTH Image width. **IMG\_HEIGHT** Image height.

PNGDEC+005

8h

# **Decode Control Register**

# DECODE\_CTRL

| 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  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DECO<br>DE_E<br>N |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W               |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                 |

**DECODE\_EN** Decode enable signal.

# PNGDEC+005

#### **Interlace Enable Register** Ch

#### INTERLACE\_EN

| 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  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | INTER<br>LACE_<br>EN |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W                  |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                    |



INTERLACE\_EN

Interlace enable signal.

## PNGDEC+006

ADLER\_ADDR 0h

**ALER ADDR** 

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

**ADLER** 

Adler checksum data report.

## PNGDEC+006

**LCD Width Height Register** 8h

LCD\_WH

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

LCD\_W

LCD width.

LCD\_H

Ch

LCD height.

## PNGDEC+006

**Clipping XY** 

CLIP\_XY

| Bit   | 31 | 30 | 29 | 28 | 27 | 26             | 25 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----------------|-------|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |                | CLIP  | X  |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |                | R/W   |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |                | 0     |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10             | 9 8   | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |                | CLIP_ | Υ  |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    | $\overline{A}$ | R/W   |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |                | 0     |    |    |    |    |    |    |    |    |

**CLIP X** CLIP\_X[15] sign bit; 0: positive 1: negative

CLIP\_X[14:0] X for clipping window

CLIP\_Y CLIP\_Y[15] sign bit: 0: positive 1: negative

CLIP\_Y[14:0] Y for clipping window

#### PNGDEC+007

0h

### Clipping window width and height register

**CLIP\_WH** 

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|------|-----|----|----|----|----|----|----|----|
| Name  |    | 4  |    |    |    |    |    | CLII | P_W |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R/   | W   |    |    |    |    |    |    |    |
| Reset |    |    | 7  |    |    |    |    | (    | )   |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7   | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    | CLI  | P_H |    |    |    |    |    |    |    |
| Туре  |    | 75 |    |    |    |    |    | R/   | W   |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | (    | )   |    |    |    |    |    |    |    |



CLIP W Clipping window width CLIP\_H Clipping window height

PNGDEC+007

**Image XY** 4h

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23  | 22 | 21 | 20 | 1 | 9 | 18                              | 17 | 16 |
|-------|----|----|----|----|----|----|----|-----|-----|----|----|----|---|---|---------------------------------|----|----|
| Name  |    |    |    |    |    |    |    | IMC | 3_X |    |    |    |   |   |                                 |    |    |
| Type  |    |    |    |    |    |    |    | R/  | W   |    |    |    |   |   |                                 |    |    |
| Reset |    |    |    |    |    |    |    | (   | 0   |    |    |    |   |   |                                 |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7   | 6  | 5  | 4  |   | 3 | 2                               | 1  | 0  |
| Name  |    |    |    |    |    |    |    | IMC | G_Y |    |    |    |   |   |                                 |    |    |
| Type  |    |    |    |    |    |    |    | R/  | W   |    |    |    |   |   | $oldsymbol{oldsymbol{\square}}$ |    |    |
| Reset |    |    | •  |    |    | •  |    | (   | 0   |    |    |    |   |   |                                 |    | •  |

IMG\_X IMG\_X[15] sign bit: 0: positive 1: negative

IMG\_X[14:0] X for image logic window

IMG\_Y IMG\_Y[15] sign bit: 0: positive 1: negative

IMG\_Y[14:0] Y for image logic window

PNGDEC+007

**PNG Reset** 8h

**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** 

Ch

Reset for PNG decoder. Write 0x1201, then hardware will reset itself.

### PNGDEC+007

## **Color Output Format**

OUT\_FORMAT

| 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  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    |    |    |    |    |    |    |    |    | IPP_E<br>N | CLIP_<br>PITCH<br>_EN | PARTIA<br>L_IRQ_<br>CTRL | PARTI<br>AL | OUT_F | ORMA |
| Type  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    |    |    |    |    |    |    |    |    | R/W        | R/W                   | R/W                      | R/W         | R/    | W    |
| Reset | , and the second |    |    |    |    |    |    |    | ·  |    | 0          | 0                     | 0                        | 0           | (     | )    |

**OUT\_FORMAT** Output color format

2'b00: RGB565 2'b01: RGB888 2'b10: ARGB4444 2'b11: ARGB8888

PARTIAL 1: enable partial input 0: disable partial input

PARTIAL IRQ\_CTRL 1: The input file empty irq and block count end irq will be sent out according to which case is encountered first. If the two cases are encountered at the same time, both irqs will be sent out.



0: Both input file empty irq and block count end irq will be sent out if the left byte number of the input file and block are smaller than 4 bytes.

**CLIP\_PITCH\_EN** Clip end pitch enable **IPP\_EN** Enable ipp and png interface

### PNGDEC+008

## 0h Resize Register

RESIZE

| 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  |    |    |    |    | RE | SIZE_ | W_RAT | 10 | RE | SIZE_ | H_RAT | 10 |    |    |    | RESIZ<br>E_EN |
| Type  |    |    |    |    |    | R/    | W     |    |    | R/    | W     |    |    |    |    | R/W           |
| Reset |    |    |    |    |    | (     | )     | •  |    | (     | )     |    | 22 |    |    | 0             |

**RESIZE\_EN** Resize on the fly enable

0: disable

1: enable

**RESIZE W RATIO** Resize ratio in width

0: no resize

1: 1/2

2: 1/4

3: 1/8

4: 1/16 5: 1/32

6: 1/64

7: 1/128

8: 1/256

9: 1/512

10: 1/1024

11: 1/2048

12: 1/4096

13: 1/8192

14: 1/16384

15: 1/32768

**RESIZE\_H\_RATIO** Resize ratio in height

0: no resize

1: 1/2

2: 1/4

3: 1/8

4: 1/16

5: 1/32 6: 1/64

0. 1/04

7: 1/128

8: 1/256 9: 1/512

10: 1/1024

11: 1/2048



4h

12: 1/4096 13: 1/8192 14: 1/16384 15: 1/32768

PNGDEC+008

## **Resume 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  |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    | RESU<br>ME |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |     |    |    | R/W        |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    | 22  |    |    | 0          |

#### Resume when infile empty or block count end RESUME

## PNGDEC+008

**Interrupt Enable Register** 8h

IRQ\_EN

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22         | 21_                               | 20   | 19   | 18                | 17          | 16          |
|-------|----|----|----|----|----|----|----|-----|----|------------|-----------------------------------|------|------|-------------------|-------------|-------------|
| Name  |    |    |    |    |    |    |    |     |    |            |                                   |      |      |                   |             |             |
| Type  |    |    |    |    |    |    |    |     |    |            | <u> </u>                          |      |      |                   |             |             |
| Reset |    |    |    |    |    |    |    |     |    |            |                                   |      |      |                   |             |             |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7  | $\sqrt{6}$ | 5                                 | 4    | 3    | 2                 | 1           | 0           |
| Name  |    |    |    |    |    |    |    |     |    |            | OVER<br>_OUT<br>PUT_<br>ERRO<br>R | R_BY | DEX_ | BLOC<br>K_CN<br>T | INEM<br>PTY | IMG_C<br>MP |
| Type  |    |    |    |    |    |    |    | 717 |    |            | R/W                               | R/W  | R/W  | R/W               | R/W         | R/W         |
| Reset |    |    |    |    |    |    |    |     |    |            | 0                                 | 0    | 0    | 0                 | 0           | 0           |

Image decompressed complete irq enable IMG CMP

**INEMPTY** Input file empty **BLOCK\_CNT** Block count end

**COLOR\_INDEX\_ERROR** output index error

FILTER\_BYTE\_ERROR decoder decode an error filter type

**OVER\_OUTPUT\_ERROR** output over out\_end\_addr

### PNGDEC+008

#### **Interrupt Status** Ch

#### IRQ\_STATUS

| 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  |    |    |    |    |    |    |    |    |    |    | OVER<br>_OUT<br>PUT_<br>ERRO<br>R | FILTE<br>R_BY<br>TE_E<br>RROR | COLO<br>R_IN<br>DEX_<br>ERRO<br>R | BLOC<br>K_CN<br>T | INRM<br>PTY | IMG_C<br>MP |
| Type  |    |    |    |    |    |    |    |    |    |    | R                                 | R                             | R                                 | R                 | R           | R           |
| Reset |    |    | ·  |    |    |    | ·  |    |    |    | 0                                 | 0                             | 0                                 | 0                 | 0           | 0           |



**IMG CMP** Image decompressed complete irq.

**INEMPTY** Input file empty irq **BLOCK\_CNT** Block count end irq

**COLOR\_INDEX\_ERROR** output index error

**FILTER BYTE ERROR** decoder decode an error filter type

**OVER\_OUTPUT\_ERROR** output over out\_end\_addr

PNGDEC+009

**IDAT COUNT Register** 0h

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

**IDAT\_COUNT** The length (byte number) of the IDAT.

## PNGDEC+009

**Chunk type** 4h

**CHUNK TYPE** 

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

#### CHUNK\_TYPE chunk type

8h

PNGDEC+009 CRC

**CRC** 

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

#### CRC read out the crc result

PNGDEC+00A Transparency table start address

TRNS\_ADDR

| Bit   | 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24    | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|-----|----|----|----|----|----|-------|------|----|----|----|----|----|----|----|
| Name  |    | 221 |    |    |    |    |    | TRNS_ | ADDR |    |    |    |    |    |    |    |
| Type  |    |     |    |    |    |    |    | R/    | W    |    |    |    |    |    |    |    |
| Reset |    |     |    |    |    |    |    | (     | )    |    |    |    |    |    |    |    |
| Bit   | 15 | 14  | 13 | 12 | 11 | 10 | 9  | 8     | 7    | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |     |    |    |    |    |    | TRNS_ | ADDR |    |    |    |    |    |    |    |
| Туре  |    |     | •  | •  | •  | •  |    | R/    | W    |    | •  | •  |    | •  | •  | •  |



Reset

TRAN\_ADDR transparency table staring address.

PNGDEC+00A TRNS CTRL 4h

| 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  |    |    |    |    |    |    |    |    |    |    |    |    | TRAN<br>S_OU<br>T_SP<br>EC |     | TRAN<br>S_OU<br>T | TRAN<br>S_EN |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    | R/W                        | R/W | R/W               | R/W          |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    | 0_                         | 0   | 0                 | 0            |

TRANS\_EN Transparent enable

TRANS\_OUT 0: output transparent color as background color

1: no output when transparent

TRANS TABLE Transparent table exist

TRANS\_OUT\_SPEC Transparent color key enable

PNGDEC+00A Transparency key1

TRNS\_KEY1

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

**GREY\_KEY** Transparent color key of grayscale image

**R\_KEY** Transparent color key of red component

PNGDEC+00A Transparency key2

TRNS\_KEY2

| Bit   | 31 | 30 | 29 | 28                      | 27 | 26 | 25 | 24  | 23         | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|-------------------------|----|----|----|-----|------------|----|----|----|----|----|----|----|
| Name  |    |    |    |                         |    |    |    | G_F | <b>(EY</b> |    |    |    |    |    |    |    |
| Type  |    |    |    | 4                       |    |    |    | R/  | W          |    |    |    |    |    |    |    |
| Reset |    |    |    |                         |    |    |    | (   | )          |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12                      | 11 | 10 | 9  | 8   | 7          | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |                         |    |    |    | B_k | <b>(EY</b> |    |    |    |    |    |    |    |
| Type  |    |    |    |                         |    |    |    | R/  | W          |    |    |    |    |    |    |    |
| Reset |    |    |    | $\subseteq \mathcal{L}$ |    |    |    | (   | )          |    |    |    |    |    |    |    |

**G\_KEY** Transparent color key of green component

**B\_KEY** Transparent color key of blue component

PNGDEC+00B

**Background Color BG\_COLOR** 0h Bit 31 28 27 26 25 24 23 22 21 20 19 18 17 16



| Name          |    |                            |  | BG_0 | GREY |  |   |   |   |   |   |   | BG | _R         |   |  |     |
|---------------|----|----------------------------|--|------|------|--|---|---|---|---|---|---|----|------------|---|--|-----|
| Type<br>Reset |    |                            |  | R/   | W    |  |   |   |   |   |   |   | R  | W          |   |  |     |
| Reset         |    | 0                          |  |      |      |  |   |   |   |   |   | ( | )  |            |   |  |     |
| Bit           | 15 | 14   13   12   11   10   9 |  |      |      |  | 8 | 7 | 6 | 5 | 4 | 3 | 2  | 1          | 0 |  |     |
| Name          |    |                            |  | BG   | i_G  |  |   |   |   |   |   |   | BG | _ <b>B</b> |   |  | . ( |
| Type          |    | R/W                        |  |      |      |  |   |   |   |   |   | I | 3  |            |   |  |     |
| Reset         |    | R/W<br>0                   |  |      |      |  |   |   |   | • | • |   | )  |            |   |  |     |

**BG\_GREY** background color of grayscale image BG\_R background color of red component BG G background color of green component BG B background color of blue component

## PNGDEC+00B SPECIAL BLOCK 4h

SPEC BLOCK

| Bit   | 31 | 30               | 29  | 28    | 27    | 26   | 25 | 24 | 23 | 22 | 21  | 20             | 19   | 18   | 17 | 16 |
|-------|----|------------------|-----|-------|-------|------|----|----|----|----|-----|----------------|------|------|----|----|
| Name  |    |                  | SPE | C_BLO | CK_B\ | /TE3 |    |    |    |    | SPE | C_BLC          | CK_B | YTE2 |    |    |
| Type  |    |                  |     | R/    | W     |      |    |    |    |    |     | R              | /W   |      |    |    |
| Reset |    | 0                |     |       |       |      |    |    |    |    |     | 9              | 0    |      |    |    |
| Bit   | 15 | 14               | 13  | 12    | 11    | 10   | 9  | 8  | 7  | 6  | 5   | 4              | 3    | 2    | 1  | 0  |
| Name  |    | SPEC BLOCK BYTE1 |     |       |       |      |    |    |    |    | SPE | C_BLC          | CK_B | YTE0 |    |    |
| Type  |    | R/W              |     |       |       |      |    |    |    |    |     | $\overline{R}$ | /W   |      |    |    |
| Reset |    | 0                |     |       |       |      |    |    |    | 4  |     |                | 0    |      |    |    |

This register is used for the special case when the length of one IDAT is smaller than or equal to 4 bytes.

SPEC\_BLOCK\_BYTEx contains the value of byte x of the IDAT.

**SPEC\_BLOCK\_BYTE0** The byte 0 of the IDAT**SPEC\_BLOCK\_BYTE1** The byte 1 of the

IDATSPEC\_BLOCK\_BYTE2 The byte 2 of the IDAT

### SPEC\_BLOCK\_BYTE3 The byte 3 of the IDAT

#### +00B8h **INDEX NUMBER**

INDEX\_NUM

| Bit   | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24 | 23 | 22 | 21 | 20    | 19  | 18 | 17 | 16 |
|-------|-----|-----|-----|-----|-----|-----|-----|----|----|----|----|-------|-----|----|----|----|
| Name  |     |     |     |     |     |     |     |    |    |    | CO | LOR_N | IUM |    |    |    |
| Type  | 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  |     |     |     |     |     |     |     |    |    |    | TR | ANS_N | UM  |    |    |    |
| Type  | R/W |    |    |    |    | R/W   |     |    |    |    |
| Reset | 0   | 0   | 0   | 0   | 0   |     | 0   |    |    |    |    | 0     |     |    |    |    |

**COLOR\_NUM** color entry number

TRANS\_NUM transparency entry number



#### 6.14 Camera Interface



MT6228 incorporates a feature rich image signal processor to connect with a variety of image sensor components. This processor consists of timing generated unit (TG) and lens/sensor compensation unit and image process unit.

Timing generated unit (TG) cooperates with master type image 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 or external pixel clock synchronization. The main purpose of TG is to create data clock for master type image sensor and accept vertical/horizontal synchronization signal and sensor data, and then generate grabbed area of raw data or YUV422/RGB565 data to the lens/sensor compensation unit.

Lens/sensor compensation unit generates compensated raw data to the color process unit in Bayer raw data input mode. In YUV422/RGB565 input mode, this stage is bypassed.

Image process unit accepts Bayer pattern raw data or YUV422/RGB565 data that is generated by lens/sensor compensation unit. 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 or memory and can be read back by MCU.

## 6.14.1 Register Table

| REGISTER ADDRESS | REGISTER NAME                                        | SYNONYM     |
|------------------|------------------------------------------------------|-------------|
| CAM + 0000h      | TG Phase Counter Register                            | CAM_PHSCNT  |
| CAM + 0004h      | Image Sensor Size Configuration Register             | CAM_CAMWIN  |
| CAM + 0008h      | TG Grab Range Start/End Pixel Configuration Register | CAM_GRABCOL |
| CAM + 000Ch      | TG Grab Range Start/End Line Configuration Register  | CAM_GRABROW |
| CAM + 0010h      | CMOS Sensor Mode Configuration Register              | CAM_CSMODE  |
| CAM + 0014h      | Component Offset Adjustment Register                 | CAM_RGBOFF  |
| CAM + 0018h      | View Finder Mode Control Register                    | CAM_VFCON   |
| CAM + 001Ch      | Camera Module Interrupt Enable Register              | CAM_INTEN   |
| CAM + 0020h      | Camera Module Interrupt Status Register              | CAM_INTSTA  |
| CAM + 0024h      | Camera Module Path Config Register                   | CAM_PATH    |
| CAM + 0028h      | Camera Module Input Address Register                 | CAM_INADDR  |
| CAM + 002Ch      | Camera Module Output Address Register                | CAM_OUTADDR |



| MEDIATEK                                          |                                          |              |
|---------------------------------------------------|------------------------------------------|--------------|
| CAM + 0030h                                       | Preprocessing Control Register 1         | CAM_CTRL1    |
| CAM + 0034h                                       | Component R,G, B Gain Control Register 1 | CAM_RGBGAIN1 |
| CAM + 0038h                                       | Component R,G, B Gain Control Register 2 | CAM_RGBGAIN2 |
| CAM + 003Ch                                       | Histogram Boundary Control Register 1    | CAM_HIS0     |
| CAM + 0040h                                       | Histogram Boundary Control Register 2    | CAM_HIS1     |
| CAM + 0044h                                       | Preprocessing Control Register 2         | CAM_CTRL2    |
| CAM + 0048h                                       | Reserved                                 | Reserved     |
| CAM + 004Ch                                       | Reserved                                 | Reserved     |
| CAM + 0050h                                       | Reserved                                 | Reserved     |
| CAM + 0054h                                       | Reserved                                 | Reserved     |
| CAM + 0058h                                       | ATF Window 1 Register                    | CAM_AEWIN1   |
| CAM + 005Ch                                       | ATF Window 2 Register                    | CAM_ AEWIN2  |
| CAM + 0060h                                       | ATF Window 3 Register                    | CAM_ AEWIN3  |
| CAM + 0064h                                       | ATF Window 4 Register                    | CAM_ AEWIN4  |
| CAM + 0068h                                       | ATF Window 5 Register                    | CAM_ AEWIN5  |
| CAM + 006Ch                                       | AWB Window Register                      | CAM_AWBWIN   |
| CAM + 0070h                                       | Color Processing Stage Control Register  | CAM_CPSCON1  |
| CAM + 0074h                                       | Interpolation Register 1                 | CAM_INTER1   |
| CAM + 0078h                                       | Interpolation Register 2                 | CAM_INTER2   |
| CAM + 007Ch                                       | Edge Core Register                       | CAM_EDGCORE  |
| CAM + 0080h                                       | Edge Gain Register 1                     | CAM_EDGGAIN1 |
| CAM + 0084h                                       | Edge Gain Register 2                     | CAM_EDGGAIN2 |
| CAM + 0088h                                       | Edge Threshold Register                  | CAM_EDGTHRE  |
| CAM + 008Ch                                       | Edge Vertical Control Register           | CAM_EDGVCON  |
| CAM + 0090h                                       | Axis RGB Gain Register                   | CAM_AXGAIN   |
| CAM + 0094h                                       | OPD Configuration Register               | CAM_OPDCFG   |
| CAM + 0098h                                       | OPD Component Parameter Register         | CAM_OPDPAR   |
| CAM + 009Ch                                       | Color Matrix 1 Register                  | CAM_MATRIX1  |
| CAM + 00A0h                                       | Color Matrix 2 Register                  | CAM_MATRIX2  |
| CAM + 00A4h                                       | Color Matrix 3 Register                  | CAM_MATRIX3  |
| CAM + 00A8h                                       | Color Matrix RGB Gain Register           | CAM_MTXGAIN  |
| CAM + 00ACh                                       | Color Process Stage Control Register 2   | CAM_CPSCON2  |
| CAM + 00B0h                                       | AWB RGB Gain Register                    | CAM_AWBGAIN  |
| CAM + 00B4h                                       | Gamma RGB Flare Register                 | CAM_GAMFLRE  |
| CAM + 00B8h                                       | Y Channel Configuration Register         | CAM_YCHAN    |
| CAM + 00BCh                                       | UV Channel Configuration Register        | CAM_UVCHAN   |
| CAM + 00C0h                                       | Space Convert YUV Register 1             | CAM_SCONV1   |
| CAM + 00C4h                                       | Space Convert YUV Register 2             | CAM_SCONV2   |
| CAM + 00C8h                                       | Gamma Operation Register 1               | CAM_GAMMA1   |
| CAM + 00CCh                                       | Gamma Operation Register 2               | CAM_GAMMA2   |
| CAM + 00D0h                                       | Gamma Operation Register 3               | CAM_GAMMA3   |
| $\overline{\text{CAM}} + \overline{00\text{D4h}}$ | OPD Y Result Register                    | CAM_OPDY     |
|                                                   |                                          | l .          |



| MEDIATEK    |                                       |              |
|-------------|---------------------------------------|--------------|
| CAM + 00D8h | OPD MG Result Register                | CAM_OPDMG    |
| CAM + 00DCh | OPD RB Result Register                | CAM_OPDRB    |
| CAM + 00E0h | OPD Pixel Counter Register            | CAM_OPDCNT   |
| CAM + 00E4h | Reserved                              | Reserved     |
| CAM + 00E8h | Reserved                              | Reserved     |
| CAM + 00ECh | Reserved                              | Reserved     |
| CAM + 00F0h | Reserved                              | Reserved     |
| CAM + 00F4h | ATF Result 1 Register                 | CAM_AE5RLT   |
| CAM + 00F8h | ATF Result 2 Register                 | CAM_AE6RLT   |
| CAM + 00FCh | ATF Result 3 Register                 | CAM_AE7RLT   |
| CAM + 0100h | ATF Result 4 Register                 | CAM_AE8RLT   |
| CAM + 0104h | ATF Result 5 Register                 | CAM_AE9RLT   |
| CAM + 0108h | Cam Histogram Result 1                | CAM_HISRLT0  |
| CAM + 010Ch | Cam Histogram Result 2                | CAM_HISRLT1  |
| CAM + 0110h | Cam Histogram Result 3                | CAM_HISRLT2  |
| CAM + 0114h | Cam Histogram Result 4                | CAM_HISRLT3  |
| CAM + 0118h | Cam Histogram Result 5                | CAM_HISRLT4  |
| CAM + 011Ch | Low Pass Filter Control Register      | CAM_LPFCON   |
| CAM + 0120h | Y Low Pass Filter Control Register    | CAM_YLPF     |
| CAM + 0124h | CbCr Low Pass Filter Control Register | CAM_CLPF     |
| CAM + 0128h | Vertical Subsample Control Register   | CAM_VSUB     |
| CAM + 012Ch | Horizontal Subsample Control Register | CAM_HSUB     |
| CAM + 0130h | Sensor Gamma R0 Register              | CAM_SGAMMAR0 |
| CAM + 0134h | Sensor Gamma R1 Register              | CAM_SGAMMAR1 |
| CAM + 0138h | Sensor Gamma R2 Register              | CAM_SGAMMAR2 |
| CAM + 013Ch | Sensor Gamma G0 Register              | CAM_SGAMMAG0 |
| CAM + 0140h | Sensor Gamma G1 Register              | CAM_SGAMMAG1 |
| CAM + 0144h | Sensor Gamma G2 Register              | CAM_SGAMMAG2 |
| CAM + 0148h | Sensor Gamma B0 Register              | CAM_SGAMMAB0 |
| CAM + 014Ch | Sensor Gamma B1 Register              | CAM_SGAMMAB1 |
| CAM + 0150h | Sensor Gamma B2 Register              | CAM_SGAMMAB2 |
| CAM + 0154h | Defect Pixel Configuration Register   | CAM_DEFECT0  |
| CAM + 0158h | Defect Pixel Table Address Register   | CAM_DEFECT1  |
| CAM + 015Ch | Defect Pixel Table Debug Register     | CAM_DEFECT2  |
| CAM + 0160h | Reserved                              | Reserved     |
| CAM + 0164h | Reserved                              | Reserved     |
| CAM + 0168h | Reserved                              | Reserved     |
| CAM + 016Ch | Reserved                              | Reserved     |
| CAM + 0170h | Reserved                              | Reserved     |
| CAM + 0174h | Reserved                              | Reserved     |
| CAM + 0178h | Reserved                              | Reserved     |
| CAM + 017Ch | Reserved                              | Reserved     |



| MEDIATEK      |                                                                   |               |
|---------------|-------------------------------------------------------------------|---------------|
| CAM + 0180h   | Camera Interface Debug Mode Control Register                      | CAM_DEBUG     |
| CAM + 0184h   | Camera Module Debug Information Write Out Destination Address     | CAM_DSTADDR   |
| CAM + 0188h   | Camera Module Debug Information Last Transfer Destination Address | CAM_LSTADDR   |
| CAM + 018Ch   | Camera Module Frame Buffer Transfer Out Count Register            | CAM_XFERCNT   |
| CAM + 0190h   | CMOS Sensor Test Module Configuration Register 1                  | CAM_MDLCFG1   |
| CAM + 0194h   | CMOS Sensor Test Module Configuration Register 2                  | CAM_MDLCFG2   |
| CAM + 0198h   | Reserved                                                          | Reserved      |
| CAM + 019Ch   | Reserved                                                          | Reserved      |
| CAM + 01A0h   | AE Address Register                                               | CAM_AEADDR    |
| CAM + 01A4h   | AE Window Size Register                                           | CAM_AESIZE    |
| CAM + 01A8h   | AE Weight 1 Register                                              | CAM_AEWEIGHT0 |
| CAM + 01ACh   | AE Weight 2 Register                                              | CAM_AEWEIGHT1 |
| CAM + 01B0h   | AE Weight 3 Register                                              | CAM_AEWEIGHT2 |
| CAM + 01B4h   | AE Weight 4 Register                                              | CAM_AEWEIGHT3 |
| CAM + 01B8h   | AE Weight 5 Register                                              | CAM_AEWEIGHT4 |
| CAM + 01BCh   | AE Weight 6 Register                                              | CAM_AEWEIGHT5 |
| CAM + 01C0h   | AE Weight 7 Register                                              | CAM_AEWEIGHT6 |
| CAM + 01C4h   | AE Weight 8 Register                                              | CAM_AEWEIGHT7 |
| CAM + 01C8h   | AE Area Register                                                  | CAM_AEAREA    |
| CAM + 01CCh   | AutoDefect Control 1 Register                                     | CAM_AEDEFECT0 |
| CAM + 01D0h   | AutoDefect Control 2 Register                                     | CAM_AEDEFECT1 |
| CAM + 01D4h   | Flash Control Register                                            | FLASH_CTRL    |
| CAM + 01D8h   | Cam Reset Register                                                | CAM_RESET     |
| CAM + 01DCh   | TG Status Register                                                | TG_STATUS     |
| CAM + 01E0h   | Histogram Boundary Control Register 3                             | CAM_HIS2      |
| CAM + 01E4h   | Histogram Boundary Control Register 4                             | CAM_HIS3      |
| CAM + 01E8h   | Histogram Boundary Control Register 5                             | CAM_HIS4      |
| CAM + 01ECh   | Cam Histogram Result 6                                            | CAM_HISRLT5   |
| CAM + 01F0h   | Cam Histogram Result 7                                            | CAM_HISRLT6   |
| CAM + 01F4h   | Cam Histogram Result 8                                            | CAM_HISRLT7   |
| CAM + 01F8h   | Cam Histogram Result 9                                            | CAM_HISRLT8   |
| CAM + 01FCh   | Cam Histogram Result 10                                           | CAM_HISRLT9   |
| CAM + 0200h   | Cam Histogram Result 11                                           | CAM_HISRLTA   |
| CAM + 0204h   | Cam Histogram Result 12                                           | CAM_HISRLTB   |
| CAM + 0208h   | Cam Histogram Result 13                                           | CAM_HISRLTC   |
| CAM + 020Ch   | Cam Histogram Result 14                                           | CAM_HISRLTD   |
| CAM + 0210h   | Cam Histogram Result 15                                           | CAM_HISRLTE   |
| CAM + 0214h   | Shading Control 1 Register                                        | CAM_SHADING1  |
| CAM + 0218h   | Shading Control 2 Register                                        | CAM_SHADING2  |
| CAM + 021Ch   | Shading R Curve Register 1                                        | CAM_SRCURVE0  |
| CAM + 0220h   | Shading R Curve Register 2                                        | CAM_SRCURVE1  |
| CAWI + 022011 | Shading it car to register 2                                      |               |



| CAM + 0228h | Shading G Curve Register 1         | CAM_SGCURVE0 |
|-------------|------------------------------------|--------------|
| CAM + 022Ch | Shading G Curve Register 2         | CAM_SGCURVE1 |
| CAM + 0230h | Shading G Curve Register 3         | CAM_SGCURVE2 |
| CAM + 0234h | Shading B Curve Register 1         | CAM_SBCURVE0 |
| CAM + 0238h | Shading B Curve Register 2         | CAM_SBCURVE1 |
| CAM + 023Ch | Shading B Curve Register 3         | CAM_SBCURVE2 |
| CAM + 0240h | Cam Image-Processor Hue Register 1 | CAM_HUE0     |
| CAM + 0244h | Cam Image-Processor Hue Register 2 | CAM_HUE1     |
| CAM + 0248h | GMC Debug Register                 | CAM_GMCDEBUG |
| CAM + 024Ch | Cam Version Register               | CAM_VERSION  |
|             |                                    |              |

Table 52 Camera Interface Register Map

#### 6.14.1.1 TG Register Definitions

#### CAM+0000h TG Phase Counter Register

#### CAM PHSCNT

| Bit   | 31            | 30  | 29            | 28         | 27 | 26  | 25  | 24                | 23 | 22  | 21  | 20 | 19     | 18       | 17  | 16 |  |  |
|-------|---------------|-----|---------------|------------|----|-----|-----|-------------------|----|-----|-----|----|--------|----------|-----|----|--|--|
| Name  | PCEN          |     | CLKE<br>N     | CLKP<br>OL |    | CLK | CNT |                   |    | CLI | KRS |    |        | CLI      | KFL |    |  |  |
| 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 5 | 4  | 3      | 2        | 1   | 0  |  |  |
| Name  | HVALI<br>D_EN |     | PXCL<br>K_INV |            |    |     |     | TGCL<br>K_SE<br>L |    | PIX | CNT |    | DLATCH |          |     |    |  |  |
| Туре  | R/W           | R/W | R/W           | R/W        |    |     |     | R/W               |    | R   | /W  |    | R/W    |          |     |    |  |  |
| Reset | 0             | 0   | 0             | 0          |    |     |     | 0                 |    |     | 1   |    |        | R/W<br>1 |     |    |  |  |

**PCEN** TG phase counter enable control

**CLKEN** Enable sensor master clock (mclk) output to sensor

**CLKPOL** Sensor master clock polarity control

**CLKCNT** Sensor master clock frequency divider control.

Sensor master clock will be 52Mhz/CLKCNT, where CLKCNT >=1

CLKRS Sensor master clock rising edge control
CLKFL Sensor master clock falling edge control

**HVALID\_EN** HVALID input enable

**PXCLK EN** Pixel clock input monitor, used in internal clock synchronization mode

**PXCLK\_INV** Pixel clock inverse

PXCLK\_IN 0 Internal clock synchronization

External pixel clock synchronization

Internal clock synchronization example waveform

(CLKCNT=1,CLKRS=0,CLKFL=1,PIXCNT=3,DLATCH=2)





TGCLK\_SEL

Sensor master based clock selection (0: 52 Mhz, 1: 48 Mhz)

PIXCNT DLATCH

Sensor data latch frequency control, used in internal clock synchronization mode Sensor data latch position control, used in internal clock synchronization mode

### 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  |    |    |    |    |    |    |    |    |              | PIX | ELS |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |              | R/  | W   |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |              | F1  | fh  |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | D <u>.</u> 7 | 6   | 5   | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |              | LIN | IES |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |              | R/  | W   |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |              | Ff  | fh  |    |    |    |    |    |

PIXEL Total input pixel number
LINE Total input line number

# CAM+0008h TG Grab Range Start/End Pixel Configuration Register

#### **CAM\_GRABCO**

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

START Grab start pixel number
END Grab end pixel number

| CAM+0000   | h    | TG G | irab F | Range | e Stai | rt/End | d Line | e Con | ifigur | ation |    | (  | CAM_ | _GRA | BRO |
|------------|------|------|--------|-------|--------|--------|--------|-------|--------|-------|----|----|------|------|-----|
| CAIVITUUUC | )  V | Regi | ster   |       |        |        |        |       |        |       |    |    |      |      | W   |
| Bit 31     | 30   | 29   | 28     | 27    | 26     | 25     | 24     | 23    | 22     | 21    | 20 | 19 | 18   | 17   | 16  |



| Name  |    |    |    |    |    |    |   |   |   | STA | ART |   |   |   |   |                    |
|-------|----|----|----|----|----|----|---|---|---|-----|-----|---|---|---|---|--------------------|
| Type  |    |    |    |    |    |    |   |   |   | R/  | W   |   |   |   |   |                    |
| Reset |    |    |    |    |    |    |   |   |   | (   | )   |   |   |   |   |                    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6   | 5   | 4 | 3 | 2 | 1 | 0                  |
| Name  |    |    |    |    |    |    |   |   |   | EN  | ND  |   |   |   |   | $\overline{A}$ (1) |
| Type  |    |    |    |    |    |    |   |   |   | R/  | W   |   |   |   | 1 |                    |
| Reset |    |    |    |    |    |    | • |   |   | (   | )   | • |   | • |   |                    |

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  |    |    |    |    |    |    |    |    | VSPO<br>L | HSPO<br>L | PWR<br>ON | RST | AUTO |    |    | EN  |
| Type  |    |    |    |    |    |    |    |    | R/W       | R/W       | R/W       | R/W | R/W  |    |    | R/W |
| Reset |    |    |    |    |    |    |    |    | 0         | 0         | 0         | _ 0 | 0    | •  |    | 0   |

VSPOL Image sensor VSYNC polarity
HSPOL Image sensor HSYNC polarity

**AUTO** Auto lock sensor input horizontal pixel numbers enable

**EN** Image 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  | S00 |    |    | 0  | FFSET | 00 |    |    | S01 |    |    | 0  | FFSET              | 01 |    |    |
| Type  | R/W |    |    |    | R/W   |    |    |    | R/W |    |    |    | R/W                |    |    |    |
| Reset | 0   |    |    |    | 0     |    |    |    | 0   |    |    |    | 0                  |    |    |    |
| Bit   | 15  | 14 | 13 | 12 | 11    | 10 | 9  | 87 | 7   | 6  | 5  | 4  | 3                  | 2  | 1  | 0  |
| Name  | S10 |    |    | 0  | FFSET | 10 |    |    | S11 |    |    | 0  | FFSET <sup>®</sup> | 11 |    |    |
| Type  | R/W |    |    |    | R/W   |    |    |    | R/W |    |    |    | R/W                |    |    |    |
| Reset | 0   |    |    | •  | 0     | •  |    |    | 0   | •  | •  | •  | 0                  |    | •  | -  |

Sign of raw data (0,0) offset adjustment control, 0 : positive 1: negative

**OFFSET00** Raw data (0,0) offset adjustment

Sign of raw data (0,1) offset adjustment control, 0: positive 1: negative

**OFFSET01** Raw data (0,1) offset adjustment

Sign of raw data (1,0) offset adjustment control, 0 : positive 1: negative

**OFFSET10** Raw data (1,0) offset adjustment

Sign of raw data (1,1) offset adjustment control, 0 : positive 1: negative

**OFFSET11** Raw data (1,1) 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  |    |    |    |    |    | SF | P_DEL/ | AY | SP_M<br>ODE | TAKE<br>_PIC |    |    |    | F  | R_CO | N  |
| Type  |    |    |    |    |    |    | R/W    |    | R/W         | R/W          |    |    |    |    | R/W  |    |
| Reset |    |    |    |    |    |    | 0      |    | 0           | 0            |    |    |    |    | 0    |    |



SP\_DELAYStill Picture Mode delaySP\_MODEStill Picture ModeTAKE\_PICTake Picture Request

**FR\_CON** Frame Sampling Rate Control

**000** Every frame is sampled

One frame is sampled every 2 frames
One frame is sampled every 3 frames
One frame is sampled every 4 frames
One frame is sampled every 5 frames
One frame is sampled every 5 frames
One frame is sampled every 6 frames
One frame is sampled every 7 frames
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 <u></u> | 18               | 17           | 16        |
|-------|----|----|----|----|----|----|----|----------------------|-------|-----|------------|-------------|------------|------------------|--------------|-----------|
| Name  |    |    |    |    |    |    |    | VSYN<br>C_INT<br>_EN |       |     | T          | G_INT       | LINEN      | 0                |              |           |
| Type  |    |    |    |    |    |    |    | R/W                  |       |     |            | 7 h R/      | W          |                  |              |           |
| Reset |    |    |    |    |    |    |    | 0                    |       |     |            | f           | f          |                  |              |           |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                    | 7     | 6   | 5          | 4           | 3          | 2                | 1            | 0         |
| Name  |    |    |    |    |    |    |    |                      | TG_IN | NT  | AEDO<br>NE | ISPD<br>ONE | IDLE       | GMC<br>OVRU<br>N | REZO<br>VRUN | EXPD<br>O |
| 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         |

**VSYNC\_INT\_EN** Vsync interrupt enable, tg\_int will become vsync interrupt when it is enable

**TG\_INT\_LINENO** TG interrupt line number

TG\_INT TG interrupt

AEDONE AE done interrupt enable control ISPDONE ISP done interrupt enable control

LDLEReturning idle state interrupt enable controlGMCOVRUNGMC port over run interrupt enable controlREZOVRUNResizer over run interrupt enable controlEXPDOExposure 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  |    |    |    |    |    |    |    |    | TG_IN<br>T | ATF_I<br>NT | AEDO<br>NE | ISPD<br>ONE | IDLE | GMC<br>OVRU<br>N | REZO<br>VRUN | EXPD<br>O |
| Type  |    |    |    |    |    |    |    |    | R          | R           | R          | R           | R    | R                | R            | R         |
| Reset |    | 4  |    |    |    |    |    |    | 0          | 0           | 0          | 0           | 0    | 0                | 0            | 0         |

Interrupt Status corresponding with 0x1c CAM\_INTEN

| CAM+0024h | Camera Module Path Config Register | CAM_PATH |
|-----------|------------------------------------|----------|
| CAM+0024h | Camera Module Path Config Register | CAM_PATH |

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



| Name  | CNTO<br>N | CNTI | MODE       |                   | WR                        | ITE_LI | EVEL  |     | REZ_<br>DISC<br>ONN | REZ_<br>LPF_<br>OFF |       | PATH_T | BURS | TW_T<br>0] | YPE[2:                     | OUTP<br>ATH_<br>EN |
|-------|-----------|------|------------|-------------------|---------------------------|--------|-------|-----|---------------------|---------------------|-------|--------|------|------------|----------------------------|--------------------|
| Type  | R/W       | R    | /W         |                   |                           | R/W    |       |     | RW                  | RW                  | F     | R/W    |      | R/W        |                            | R/W                |
| Reset | 0         |      | 0          |                   |                           | 7      |       |     | 0                   | 0                   |       | 0      |      | 0          |                            | 0                  |
| Bit   | 15        | 14   | 13         | 12                | 11                        | 10     | 9     | 8   | 7                   | 6                   | 5     | 4      | 3    | 2          | 1                          | 0                  |
| Name  |           |      | SWAP<br>_Y | SWAP<br>_CBC<br>R | INDA<br>TA_F<br>ORM<br>AT |        | TYPE_ | SEL |                     | NPATI               | I_RAT | Έ      |      |            | INPAT<br>H_TH<br>ROTE<br>N | INPA<br>TH_S<br>EL |
| Type  |           | R/W  | R/W        | R/W               | R/W                       |        | R/W   |     |                     | R                   | /W    |        |      |            | R/W                        | R/W                |
| Reset |           | 0    | 0          | 0                 | 0                         | 0      |       |     |                     |                     | 0     |        |      | 4          | 0                          | 0                  |

**CNTON** Enable Debug Mode Data Transfer Counter

**CNTMODE** Data Transfer Count Selection

oo sRGB count

01 YCbCr count

REZ\_LPF\_OFF
WRITE\_LEVEL
OUTPATH\_TYPE
Resizer disconnect enable
Resizer low-Pass disable
Write FIFO threshold level
Outpath Type Select

Bayer FormatISP outputRGB888 FormatRGB565 Format

**BURSTW\_TYPE** Burst write type selecttion

**OUTPATH EN** Enable Output to Memory

SWAP\_Y YCbCr in Swap Y
SWAP\_CBCR YCbCr in Swap Cb Cr
INDATA\_FORMAT Sensor Input Data connection
INTYPE\_SEL Input type selection

000 Bayer Format001 YUV422 Format101 YCbCr422 Format010 RGB Format

INPATH\_RATE Input type rate control
INPATH\_THROTEN Input path throttle enable
INPATH\_SEL Input path selection

Sensor inputFrom memory

### CAM+0028h Camera Module Input Address Register

| C1 | ΑI | VI | IN | IA | υL | JK |  |
|----|----|----|----|----|----|----|--|
|    |    |    |    |    |    |    |  |

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





| Name  | CAM_INADDR[15:0] |
|-------|------------------|
| Type  | R/W              |
| Reset | 0                |

**CAM\_INADDR** Input memory address

### CAM+002Ch Camera Module Output Address Register

CAM\_OUTADD

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24    | 23    | 22    | 21 | 20 | 19 1 | 8 17          | 16 |
|-------|----|----|----|----|----|----|-----|-------|-------|-------|----|----|------|---------------|----|
| Name  |    |    |    |    |    |    | CAM | OUTA  | DDR[3 | 1:16] |    |    |      |               |    |
| Type  |    |    |    |    |    |    |     | R/    | W     |       |    |    |      |               |    |
| Reset |    | 0  |    |    |    |    |     |       |       |       |    |    |      |               |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8     | 7     | 6     | 5  | 4  | 3    | $2 \boxed{1}$ | 0  |
| Name  |    |    |    |    |    |    | CAM | I_OUT | ADDR[ | 15:0] |    |    |      |               |    |
| Type  |    |    |    |    |    |    |     | R/    | W     |       |    |    |      |               |    |
| Reset |    |    |    |    |    |    |     | (     | )     |       |    |    |      |               |    |

**CAM OUTADDR** Output memory address

#### 6.14.1.2 Color Process Register Definition

### 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  |           |                            |      | GAIN_ | COMP |    |      |       |    |            |            | P_     | LIMIT |    |    |    |
| Туре  |           |                            |      | R/    | W    |    |      |       |    |            | $I \equiv$ | F      | R/W   |    |    |    |
| Reset |           |                            |      | (     | )    |    |      |       |    |            |            |        | 0     |    |    |    |
| Bit   | 15        | 14                         | 13   | 12    | 11   | 10 | 9    | 8     | 7  | $\sqrt{6}$ | 5          | 4      | 3     | 2  | 1  | 0  |
| Name  | BYPP<br>G | PGAI<br>N_SC<br>OUNT<br>EN | PIXI | ELID  |      |    | PGAI | N_INT |    |            | PG         | SAIN_F | RAC   |    |    |    |
| Type  | R/W       | R/W                        | R/   | W     |      |    | R/   | W     |    |            |            | R/W    |       |    |    |    |
| Reset | 0         | 0                          | (    | )     |      |    |      |       |    |            |            | 0      |       |    |    |    |

GAIN\_COMP
Gain Compensation Control
P\_LIMIT
Interpolation Limitation Control
BYPPG
Bypass pre-gain operating enable
PGAIN\_SCOUNT\_EN
Pre-gain saturation count
PIXELID
Bayer pixel type of the first pixel

R pixelGr pixelGb pixelB pixel

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  |          |    |    |    |    |    |    |         |    |    |    | GAIN | 1  |    |    |    |  |  |  |
| Type  |          |    |    |    |    |    |    |         |    |    |    | R/W  |    |    |    |    |  |  |  |
| Reset | <u> </u> |    |    |    |    |    |    | 80h     |    |    |    |      |    |    |    |    |  |  |  |
| Bit   | 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7  | 6  | 5  | 4    | 3  | 2  | 1  | 0  |  |  |  |
| Name  |          |    |    |    |    |    |    | GB GAIN |    |    |    |      |    |    |    |    |  |  |  |
| Type  |          |    |    |    |    |    |    | R/W     |    |    |    |      |    |    |    |    |  |  |  |





Reset 80h

**B\_GAIN** B Gain **GB\_GAIN** GB Gain

### CAM+0038h Component R,G,B Gain Control Register 2

**CAM\_RGBGAIN** 

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20     | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|--------|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    | F  | 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  |    |    |    |    |    |    |    |    |    |    | G  | R_GAI  | N  |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    | R/W    |    | 7  |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    | 80h    |    |    |    |    |

R\_GAIN R Gain GR\_GAIN GR Gain

#### CAM+003Ch Histogram Boundary Control Register1

CAM\_HISO

| Bit   | 31 | 30 | 29 | 28  | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20        | 19  | 18 | 17 | 16 |
|-------|----|----|----|-----|-----|----|----|----|----|----|----|-----------|-----|----|----|----|
| Name  |    |    |    | H1_ | BND |    |    |    |    |    |    | <b>H2</b> | BND |    |    |    |
| Type  |    |    |    | R/  | W   |    |    |    |    |    |    | R         | /W  |    |    |    |
| Reset |    |    |    | 1(  | )h  |    |    |    |    |    |    | 2         | :0h |    |    |    |
| Bit   | 15 | 14 | 13 | 12  | 11  | 10 | 9  | 8  | 7  | 6  | 5  | 4         | 3   | 2  | 1  | 0  |
| Name  |    |    |    | H3_ | BND |    |    |    |    |    |    | H4_       | BND |    |    |    |
| Type  |    |    | •  | R/  | W   |    | •  | •  |    | 75 | ,  | R         | /W  | •  | •  | •  |
| Reset |    |    | •  | 30  | )h  |    |    | •  |    |    |    | 4         | 0H  | •  | •  | •  |

H1\_BND Histogram level 0 up boundary value
 H2\_BND Histogram level 1 up boundary value
 H3\_BND Histogram level 2 up boundary value
 H4\_BND Histogram level 3 up boundary value

#### CAM+0040h Histogram Boundary Control Register2

CAM\_HIS1

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

**H5\_BND** Histogram level 4 up 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  |              |            |    |    |            |    |           |      | AEAL<br>L | CNTE<br>N | AEPI<br>D_PO<br>L | AEGI<br>D_PO<br>L | CNTC<br>LR | AEGI | MSEL | AESE<br>L |
| Туре  |              |            |    |    |            |    |           |      | R/W       | R/W       | R/W               | R/W               | R/W        | R/   | W    | R/W       |
| Reset |              |            |    |    |            |    |           |      | 0         | 1         | 0                 | 0                 | 0          | 0    | 0    | 1         |
| Bit   | 15           | 14         | 13 | 12 | 11         | 10 | 9         | 8    | 7         | 6         | 5                 | 4                 | 3          | 2    | 1    | 0         |
| Name  | ATFE<br>DGEN | ATFA<br>LL |    |    | AWB<br>ALL |    | GONL<br>Y | RLEN |           | INTEN     |                   |                   |            |      |      |           |
| Type  | R/W          | R/W        |    |    | R/W        |    | R/W       | R/W  |           | R/W       |                   |                   |            |      |      |           |





Reset

**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

Histogram polarity select enable. AELID\_POL, AEPID\_POL decide the pixel type **RLEN** 

**INTEN** Interpolation FIFO enable

#### CAM+0058h **ATF Window 1 Register**

#### **CAM\_ATFWIN0**

| 31 | 30 | 29 | 28 | 27                                 | 26               | 25                                         | 24                                             | 23                                   | 22                                     | 21                                       | 20                                                             | 19                    | 18                                                                 | 17                                                           | 16                                                                 |
|----|----|----|----|------------------------------------|------------------|--------------------------------------------|------------------------------------------------|--------------------------------------|----------------------------------------|------------------------------------------|----------------------------------------------------------------|-----------------------|--------------------------------------------------------------------|--------------------------------------------------------------|--------------------------------------------------------------------|
|    |    |    | LE | FT                                 |                  |                                            |                                                |                                      |                                        |                                          | RIG                                                            | HT                    |                                                                    |                                                              |                                                                    |
|    |    |    | R/ | W                                  |                  |                                            |                                                |                                      |                                        |                                          | R/                                                             | W                     |                                                                    |                                                              |                                                                    |
|    |    |    | (  | )                                  |                  |                                            |                                                |                                      |                                        |                                          | (                                                              | )                     |                                                                    |                                                              |                                                                    |
| 15 | 14 | 13 | 12 | 11                                 | 10               | 9                                          | 8                                              | 7                                    | 6                                      | 5                                        | 4                                                              | 3                     | 2                                                                  | 1                                                            | 0                                                                  |
|    |    |    | TC | )P                                 |                  |                                            |                                                |                                      |                                        |                                          | BOT                                                            | TOM                   |                                                                    |                                                              |                                                                    |
|    |    |    | R/ | W                                  |                  |                                            |                                                | 7                                    |                                        |                                          | R/                                                             | W                     |                                                                    |                                                              |                                                                    |
|    | •  |    | (  | )                                  | •                |                                            | N                                              |                                      | •                                      | •                                        | (                                                              | )                     | •                                                                  |                                                              |                                                                    |
|    |    | ,  |    | LE<br>R/<br>0<br>15 14 13 12<br>TC | LEFT<br>R/W<br>0 | LEFT R/W 0 15   14   13   12   11   10 TOP | LEFT R/W 0 15   14   13   12   11   10   9 TOP | LEFT R/W 0 15 14 13 12 11 10 9 8 TOP | LEFT R/W 0 15 14 13 12 11 10 9 8 7 TOP | LEFT R/W 0 15 14 13 12 11 10 9 8 7 6 TOP | LEFT R/W 0 15   14   13   12   11   10   9   8   7   6   5 TOP | LEFT   RIC   R/W   R/ | LEFT   RIGHT   R/W   R/W   R/W   O   O   O   O   O   O   O   O   O | LEFT   RIGHT   R/W   R/W   O   O   O   O   O   O   O   O   O | LEFT   RIGHT   R/W   R/W   R/W   O   O   O   O   O   O   O   O   O |

ATF 1th window left side LEFT **RIGHT** ATF 1th window right side ATF 1<sup>th</sup> window top side **TOP** ATF  $1^{th}$  window bottom side **BOTTOM** 

#### CAM+005Ch **ATF Window 2 Register**

#### **CAM ATFWIN1**

| Bit   | 31 | 30 | 29 | 28 | 27   | 26 | 25 | 24 | 23 | 22 | 21 | 20  | 19  | 18 | 17 | 16 |
|-------|----|----|----|----|------|----|----|----|----|----|----|-----|-----|----|----|----|
| Name  |    |    |    | LE | FT   |    |    |    |    |    |    | RIC | HT  |    |    |    |
| Type  |    |    |    | R  | /W   |    |    |    |    |    |    | R/  | W   |    |    |    |
| Reset |    |    |    |    | 0    |    |    |    |    |    |    | (   | )   |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11   | 10 | 9  | 8  | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| Name  |    |    |    | TO | OP T |    |    |    |    |    |    | BOT | TOM |    |    |    |
| Type  |    |    |    | R  | /W   |    |    |    |    |    |    | R/  | W   |    |    |    |
| Reset |    |    |    |    | 0    |    |    |    |    |    |    | (   | )   |    |    |    |

**LEFT** ATF 2th window left side ATF 2<sup>th</sup> window right side **RIGHT** ATF 2<sup>th</sup> window top side **TOP** ATF 2<sup>th</sup> window bottom side **BOTTOM** 

#### **ATF Window 3 Register** CAM+0060h

**CAM ATFWIN2** 

| D:± | 0.1 | 20 | 20 | 00 | 07 | 00 | 25 | 2/ | 00 | 00 | 0.1 | 20 | 10 | 10 | 17 | 5  |
|-----|-----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|
| Bit | 31  | 30 | 29 | 28 | 21 | 26 | 25 | 24 | 23 | 22 | 21  | 20 | 19 | 10 | 17 | 16 |
|     |     |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |





| Name  |    |    |    | LE | FT |    |   |   |   |   |   | RIG | HT  |   |   |                   |
|-------|----|----|----|----|----|----|---|---|---|---|---|-----|-----|---|---|-------------------|
| Type  |    |    |    | R/ | W  |    |   |   |   |   |   | R/  | W   |   |   |                   |
| Reset |    |    |    | (  | )  |    |   |   |   |   |   | (   | )   |   |   |                   |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2 | 1 | 0                 |
| Name  |    |    |    | TC | P  |    |   |   |   |   |   | BOT | TOM |   |   | $\overline{1}$ (1 |
| Type  |    |    |    | R/ | W  |    |   |   |   |   |   | R/  | W   |   |   |                   |
| Reset |    |    |    | (  | )  |    |   |   |   |   |   | (   | )   |   |   |                   |

**LEFT** ATF 3<sup>th</sup> window left side **RIGHT** ATF 3<sup>th</sup> window right side **TOP** ATF 3<sup>th</sup> window top side **BOTTOM** ATF 3<sup>th</sup> window bottom side

#### CAM+0064h ATF Window 4 Register

#### **CAM ATFWIN3**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20              | 19  | 18 | 17 | 16               |
|-------|----|----|----|----|----|----|----|----|----|----|----|-----------------|-----|----|----|------------------|
| Name  |    |    |    | LE | FT |    |    |    |    |    |    | RIC             | GHT |    |    |                  |
| Type  |    |    |    | R/ | W  |    |    |    |    |    |    | R               | /W  |    |    |                  |
| Reset |    |    |    | (  | )  |    |    |    |    |    |    |                 | 0   |    |    |                  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4               | 3   | 2  | 1  | 0                |
| Name  |    |    |    | TC | P  |    |    |    |    |    |    | BOT             | TOM |    |    |                  |
| Type  |    |    |    | R/ | W  |    |    |    |    |    |    | $I \subseteq A$ | /W  |    |    |                  |
| Reset |    |    |    | (  | )  |    |    |    |    |    |    |                 | 0   |    |    | , and the second |

RIGHT ATF 4<sup>th</sup> window left side

RIGHT ATF 4<sup>th</sup> window right side

TOP ATF 4<sup>th</sup> window top side

BOTTOM ATF 4<sup>th</sup> window bottom side

#### CAM+0068h ATF Window 5 Register

#### **CAM ATFWIN4**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20  | 19  | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|-----|----|----|----|-----|-----|----|----|----|
| Name  |    |    |    | LE | FT |    |    |     |    |    |    | RIG | HT  |    |    |    |
| Type  |    |    |    | R/ | W  |    |    | 7.7 | 77 |    |    | R/  | W   |    |    |    |
| Reset |    |    |    | (  | )  |    |    |     |    |    |    | (   | )   |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| Name  |    |    |    | TC | )P |    |    |     |    |    |    | BOT | TOM |    |    |    |
| Type  |    |    |    | R/ | W  |    | 70 |     |    |    |    | R/  | W   |    |    |    |
| Reset |    |    |    | (  | )  |    |    |     |    | •  |    | (   | )   |    | •  | •  |

**LEFT** ATF 5<sup>th</sup> window left side **RIGHT** ATF 5<sup>th</sup> window right side **TOP** ATF 5<sup>th</sup> window top side **BOTTOM** ATF 5<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  |    |    |    | LE | FT |    |    |    |    |    |    | RIC | HT  |    |    |    |
| Type  |    |    |    | R/ | W  |    |    |    |    |    |    | R/  | W   |    |    |    |
| Reset |    |    |    |    | )  |    |    |    |    |    |    | (   | )   |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| Name  |    |    |    | TC | P  |    |    |    |    |    |    | BOT | TOM |    |    |    |
| Type  |    |    |    | R/ | W  |    |    |    |    |    |    | R/  | W   |    |    |    |
| Reset |    |    |    | (  | )  |    |    |    |    |    |    | (   | )   |    |    |    |

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  |    |    |    |    |    |    |    |    |            |    |    |    |            |      |            | 7     |
| Type  |    |    |    |    |    |    |    |    |            |    |    |    |            |      |            |       |
| Reset |    |    |    |    |    |    |    |    |            |    |    |    |            |      |            |       |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7          | 6  | 5  | 4  | 3          | 2    | 1          | 0     |
| Name  |    |    |    |    |    |    |    |    | BYPI<br>NT |    |    |    | NONL<br>IN | GAVG | LEDG<br>EN | DISLJ |
| Type  |    |    |    |    |    |    |    |    | R/W        |    |    |    | R/W        | R/W  | R/W        | R/W   |
| Reset |    |    |    |    |    |    |    |    | 0          |    |    |    | 0          | _0_  | 1          | 0     |

**BYPINT** Interpolation first 4 invalid output pixel used enable **NONLIN** Nonlinear mode enable in color correction operation

**GAVG** G channel average mode **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 | $\left[\begin{array}{c} \overline{20} \end{array}\right]$ | 19 | 18     | 17 | 16 |
|-------|----|----|----|----|------|------|----|----|----|-----|----|-----------------------------------------------------------|----|--------|----|----|
| Name  |    |    |    |    | THR  | E_V  |    |    |    |     |    | 10                                                        |    | THRE_S | M  |    |
| Type  |    |    |    |    | R/   | W    |    |    |    |     |    |                                                           |    | R/W    |    |    |
| Reset |    |    |    |    | 0/   | ∖h   |    |    |    |     |    |                                                           |    | 05h    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11   | 10   | 9  | 8  | 7  | 6   | 5  | 4                                                         | 3  | 2      | 1  | 0  |
| Name  |    |    |    |    | THRE | _DHV |    |    |    |     |    |                                                           | •  | THRE_F | RT |    |
| Type  |    |    |    |    | R/   | W    |    |    |    | ZÁS |    |                                                           |    | R/W    |    |    |
| Reset |    |    |    |    | 19   | 9h   |    |    |    |     |    |                                                           |    | 10h    |    |    |

THRE\_V Interpolation parameter
THRE\_SM Interpolation parameter
THRE\_DHV Interpolation parameter
THRE\_RT Interpolation parameter

#### 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  |    |    |    |    |    |    |    |    |    |            |    | THE | RE_LEC | GE |    |    |  |  |  |
| Type  |    |    |    |    |    |    |    |    |    | R/W        |    |     |        |    |    |    |  |  |  |
| Reset |    |    |    |    |    |    |    |    |    | R/W<br>14h |    |     |        |    |    |    |  |  |  |

THRE\_LEDGE Interpolation parameter

#### CAM+007Ch Edge Core Register

#### **CAM\_EDGCOR**

Е

| Bit   | 31 | 30 | 29 | 28 | 27   | 26 | 25  | 24 | 23                | 22          | 21 | 20 | 19    | 18  | 17 | 16 |
|-------|----|----|----|----|------|----|-----|----|-------------------|-------------|----|----|-------|-----|----|----|
| Name  |    |    |    |    | CORE |    |     |    | EMBO<br>SS1       | EMBO<br>SS2 |    |    | COF   | EH2 |    |    |
| Type  |    |    |    |    | R/W  |    |     |    | R/W               | R/W         |    |    | R/    | W   |    |    |
| Reset |    |    |    |    | 08h  |    |     |    | 0                 | 0           |    |    | 16    | -h  |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11   | 10 | 9   | 8  | 7                 | 6           | 5  | 4  | 3     | 2   | 1  | 0  |
| Name  |    |    |    |    |      | СО | REV |    | TOP_<br>SLOP<br>E |             |    | CC | ORE_C | ON  |    |    |



#### MT6228 GSM/GPRS Baseband Processor Data Sheet Revision 1.0

| Type  |  |  | R/W | R/W | R/W |
|-------|--|--|-----|-----|-----|
| Reset |  |  | 8h  | 0   | 14h |

**COREH** Edge parameter

EMBOSS1 Emboss effect mode 1 enable
EMBOSS2 Emboss effect mode 2 enable

**COREH2** Edge parameter

**COREV** [3:2] Negative Slope [1:0] Positive Slope

**TOP\_SLOPE** Edge parameter **CORE\_CON** Edge parameter

### CAM+0080h Edge Gain Register 1

CAM\_EDGGAIN

| Bit   | 31   | 30    | 29    | 28        | 27         | 26       | 25   | 24 | 23        | 22 | 21  | 20   | 19 | 18    | 17     | 16 |
|-------|------|-------|-------|-----------|------------|----------|------|----|-----------|----|-----|------|----|-------|--------|----|
| Name  | SPEC | IGAIN | SPECI | PONL<br>/ |            | EGA      | IN_H |    |           |    |     |      | 71 | EGAI  | N_H2   |    |
| Type  | R/   | W     | R/    | W         |            | R/W<br>1 |      |    |           |    |     |      |    | R/    | W      |    |
| Reset | (    | )     | (     | )         | 1 1 10 0 8 |          |      |    |           |    |     |      |    | (     | 3      |    |
| Bit   | 15   | 14    | 13    | 12        | 11 10 9 8  |          |      | 7  | 6         | 5  | 4   | 3    | 2  | 1     | 0      |    |
| Name  |      |       |       |           | EGAIN_VB   |          |      |    | OILE<br>N |    | KNE | ESEL |    | EGAIN | ILILNE |    |
| Type  |      |       |       |           | R/W        |          |      |    | R/W       |    |     | W    |    | R/    | W      |    |
| Reset |      |       |       |           |            | (        | 3    |    | 0         |    |     | 3    |    | 2     | 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 Knee select

**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  |    |    |    |    |    |    |    |    | SPEC<br>IABS | SPEC<br>IINV |    | EGAIN_HC |    |     |    |    |  |  |
| Type  |    |    |    |    |    |    |    |    | R/W          | 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\_EDGTHR

E

| Bit  | 31 | 30 | 29 | 30 29 28 27 26 25 |    |  |  |  |  | 22 | 21 | 20  | 19  | 18 | 17 | 16 |
|------|----|----|----|-------------------|----|--|--|--|--|----|----|-----|-----|----|----|----|
| Name | 44 |    |    | ET                | H3 |  |  |  |  |    |    | ETH | CON |    |    |    |
| Type |    |    |    | R/                | W  |  |  |  |  |    |    | R/  | W   |    |    |    |





| Reset |      |    |    | 32   | 2h   |     |   |   |   |   |   | 80   | )h    |     |   |     |
|-------|------|----|----|------|------|-----|---|---|---|---|---|------|-------|-----|---|-----|
| Bit   | 15   | 14 | 13 | 12   | 11   | 10  | 9 | 8 | 7 | 6 | 5 | 4    | 3     | 2   | 1 | 0   |
| Name  | ONLY |    |    | THRE | EDGE | SUP |   |   |   |   |   | THRL | _EDGE | SUP |   |     |
| Type  | R/W  |    |    |      | R/W  |     |   |   |   |   |   |      | R/W   |     |   | 7 a |
| Reset | 0    |    |    | •    | 07h  |     |   | • |   |   |   |      | 07h   |     | • |     |

ETH3 Edge threshold value ETH\_CON Edge parameter

**ONLYC** Edge enhanced C component only enable

THRE\_EDGE\_SUP Edge parameter THRL\_EDGE\_SUP Edge parameter

### 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  | <b>HPEN</b> |    |    | E  | _TH1_ | V   |     |          |    |    |    |       | HAL  | .F_V |    |    |
| Type  | R/W         |    |    |    | R/W   |     |     |          |    |    |    |       | R    | W    |    |    |
| Reset | 0           |    |    |    | 18h   |     |     |          |    |    |    |       | 11   | -h   |    |    |
| Bit   | 15          | 14 | 13 | 12 | 11    | 10  | 9   | 8        | 7  | 6  | 5  | 4     | 3    | 2    | 1  | 0  |
| Name  |             |    |    |    | SUI   | P_V | SDI | <u> </u> |    |    |    | (E_TF | 13_V |      |    |    |
| Type  |             |    |    |    | R/    | W   | R/  | W        |    |    |    | R/    | W    |      |    |    |
| Reset |             |    |    |    | (     | )   | 2   | 2        |    | 4  |    | 32    | 2h   |      |    |    |

HPEN Edge high pass enable

E\_TH1\_V
HALF\_V
Edge parameter
SUP\_V
Edge parameter
SDN\_V
Edge parameter
E\_TH3\_V
Edge parameter

### 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  |    |    |    |    |     |     |    |    |    |    |     |    | R_C | AIN |    |    |  |  |  |
| Type  |    |    |    |    |     |     |    |    |    |    |     |    | R   | W   |    |    |  |  |  |
| Reset |    |    |    |    |     |     |    |    |    |    | 3Fh |    |     |     |    |    |  |  |  |
| Bit   | 15 | 14 | 13 | 12 | 11  | 10  | 9  | 8  | 7  | 6  | 5   | 4  | 3   | 2   | 1  | 0  |  |  |  |
| Name  |    |    |    |    | G_G | AIN |    |    |    |    |     |    | B_G | AIN |    |    |  |  |  |
| Type  |    |    |    |    |     | W   |    |    |    |    | R/W |    |     |     |    |    |  |  |  |
| Reset |    |    |    | •  | 31  | Fh  |    |    |    |    | 3Fh |    |     |     |    |    |  |  |  |

R\_GAIN Axis R component gain
G\_GAIN Axis G component gain
B\_GAIN Axis B component gain

#### CAM+0094h AWB Configuration Register

**CAM OPDCFG** 

|       |           |            |    |    | 3  |        | - 3   |    |    |    |    |    |    |        | _    |    |
|-------|-----------|------------|----|----|----|--------|-------|----|----|----|----|----|----|--------|------|----|
| Bit   | 31        | 30         | 29 | 28 | 27 | 26     | 25    | 24 | 23 | 22 | 21 | 20 | 19 | 18     | 17   | 16 |
| Name  | OPDE<br>N | OPDC<br>LR |    |    |    |        | SUPSE | L  |    |    |    |    |    | U_GAII | N    |    |
| Type  | R/W       | R/W        |    |    |    |        | R/W   |    |    |    |    |    |    | R/W    |      |    |
| Reset | 1         | 0          |    |    |    |        | 3     |    |    |    |    |    |    | 1Fh    |      |    |
| Bit   | 15        | 14         | 13 | 12 | 11 | 10     | 9     | 8  | 7  | 6  | 5  | 4  | 3  | 2      | 1    | 0  |
| Name  |           |            |    |    | 1  | V_GAII | 1     |    |    |    |    |    |    | Y_L    | IMIT |    |
| Type  |           |            |    |    | •  | R/W    | •     | •  |    |    |    |    |    | R/     | W    |    |
| Reset |           |            |    |    |    | 1Fh    |       |    |    |    |    |    |    | (      | 3    |    |





OPDEN AWB counter enable
OPDCLR AWB counter clear enable

**SUPSEL** AWB accumulated maximum value setting. Equation is (192 + 8 \* SUPSEL).

U\_GAIN AWB U gain valueV\_GAIN AWB V gain value

**Y\_LIMIT** AWB white point minimum value,

#### 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  |    |         |    | ,  | S_RB_F | •  |    |    |    |    |    |    | S_RB_I | N    |    |    |
| Type  |    |         |    |    | R/W    |    |    |    |    |    |    |    | R/W    |      |    |    |
| Reset |    | 7Fh 7Fh |    |    |        |    |    |    |    |    |    |    |        |      |    |    |
| Bit   | 15 | 14      | 13 | 12 | 11     | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3      | 2    | 1  | 0  |
| Name  |    |         |    | 5  | S_MG_I | •  |    |    |    |    |    | ,  | S_MG_I | N    |    |    |
| Type  |    | R/W     |    |    |        |    |    |    |    |    |    |    |        |      |    |    |
| Reset |    |         |    |    | 7Fh    |    |    |    |    |    |    |    | 7Fh    |      |    |    |

S\_RB\_P AWB SR Bp value
S\_RB\_N AWB SR Bn value
S\_MG\_P AWB SM Gp value
S\_MG\_N AWB SN Gn value

#### CAM+009Ch Color Matrix 1 Register

#### **CAM MATRIX1**

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

M11 Color matrix 11 value
M12 Color matrix 12 value
M13 Color matrix 13 value

#### CAM+00A0h Color Matrix 2 Register

#### **CAM MATRIX2**

| 31 | 30 | 29 | 28 | 27               | 26 | 25                              | 24                                | 23                                  | 22                                | 21                                      | 20                                        | 19                                          | 18                                                                              | 17                                                                                                                        | 16                                                           |  |  |
|----|----|----|----|------------------|----|---------------------------------|-----------------------------------|-------------------------------------|-----------------------------------|-----------------------------------------|-------------------------------------------|---------------------------------------------|---------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|--|--|
|    |    |    |    |                  |    | )                               |                                   |                                     |                                   |                                         | M                                         | 21                                          |                                                                                 |                                                                                                                           |                                                              |  |  |
|    |    |    |    |                  |    |                                 |                                   |                                     |                                   |                                         | R/                                        | W                                           |                                                                                 |                                                                                                                           |                                                              |  |  |
|    |    |    |    |                  |    |                                 | 80h                               |                                     |                                   |                                         |                                           |                                             |                                                                                 |                                                                                                                           |                                                              |  |  |
| 15 | 14 | 13 | 12 | 11               | 10 | 9                               | 8                                 | 7                                   | 6                                 | 5                                       | 4                                         | 3                                           | 2                                                                               | 1                                                                                                                         | 0                                                            |  |  |
|    |    |    | M  | 22               |    |                                 |                                   |                                     |                                   |                                         | M                                         | 23                                          |                                                                                 |                                                                                                                           |                                                              |  |  |
|    |    |    | R/ | W                |    |                                 |                                   |                                     |                                   |                                         | R/                                        | W                                           |                                                                                 |                                                                                                                           |                                                              |  |  |
|    |    | •  | 20 | )h               |    |                                 | •                                 |                                     |                                   |                                         | 80                                        | )h                                          | •                                                                               | •                                                                                                                         |                                                              |  |  |
|    |    |    |    | 15 14 13 12<br>M |    | 15 14 13 12 11 10<br>M22<br>R/W | 15 14 13 12 11 10 9<br>M22<br>R/W | 15 14 13 12 11 10 9 8<br>M22<br>B/W | 15 14 13 12 11 10 9 8 7  M22  R/W | 15 14 13 12 11 10 9 8 7 6<br>M22<br>R/W | 15 14 13 12 11 10 9 8 7 6 5<br>M22<br>R/W | 15 14 13 12 11 10 9 8 7 6 5 4  M22  R/W  R/ | M21   R/W   80h   15   14   13   12   11   10   9   8   7   6   5   4   3     3 | M21   R/W   80h   15   14   13   12   11   10   9   8   7   6   5   4   3   2     M22   R/W   R/W   R/W   R/W   R/W   R/W | M21 R/W 80h 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1  M22 R/W R/W |  |  |

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>- - - - - - - - - -</b> |    |    |    |    |    |    |    |    |    |    | M  | 31 |    |    |    |
| Type  |                            |    |    |    |    |    |    |    |    |    |    | R/ | W  |    |    |    |
| Reset |                            |    |    |    |    |    |    |    |    |    |    | 80 | )h |    |    |    |
| Bit   | 15                         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |





| Name  | M32 | M33 |
|-------|-----|-----|
| Type  | R/W | R/W |
| Reset | 80h | 20h |

M31 Color matrix 31 valueM32 Color matrix 32 valueM33 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  |    |    |    |    |     |     |    |    |    |    |     |    | R_GAIN |    |    |  |  |  |  |
| Type  |    |    |    |    |     |     |    |    |    |    |     |    | R/W    |    |    |  |  |  |  |
| Reset |    |    |    |    |     |     |    |    |    |    |     |    | 20h    |    |    |  |  |  |  |
| Bit   | 15 | 14 | 13 | 12 | 11  | 10  | 9  | 8  | 7  | 6  | 5   | 4  | 3 2    | 1  | 0  |  |  |  |  |
| Name  |    |    |    |    | G_G | AIN |    |    |    |    |     |    | B_GAIN |    |    |  |  |  |  |
| Type  |    |    |    |    | R/  | W   |    |    |    |    | R/W |    |        |    |    |  |  |  |  |
| Reset |    |    |    |    | 20  | )h  |    |    |    |    | 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  |    |    |    |    |    |    |    |    |           | 7            |            |               |    |     |      |    |
| Type  |    |    |    |    |    |    |    |    |           |              |            |               |    |     |      |    |
| Reset |    |    |    |    |    |    |    |    |           |              | ·          |               |    |     |      |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7         | 6            | 5          | 4             | 3  | 2   | 1    | 0  |
| Name  |    |    |    |    |    |    |    |    | BYPG<br>M | RGBE<br>DGEN | YEDG<br>EN | OPRG<br>M_IVT |    | Y_E | GAIN |    |
| Type  |    |    |    |    |    |    |    |    | R/W       | R/W          | R/W        | R/W           |    | R/  | W    |    |
| Reset |    |    |    |    |    |    |    |    | 1         | 0            | 0          | 0             | •  | 2   | 2    |    |

BYPGM Bypass gamma enable
RGBEDGAINEN Edge enhance before gamma

YEDGEN Edge enhance after gamma

**OPDGM\_IVT** Gamma output inverse mode enable

**Y\_EGAIN** Y channel edge gain value

### CAM+00B0h AWB RGB Gain Register

#### CAM\_AWBGAI

Ν

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

AWB\_RGAIN
AWB\_GGAIN
AWB\_BGAIN
AWB B component gain value
AWB\_BGAIN



### CAM+00B4h Gamma RGB Flare Register

## CAM\_GAMFLR

| Bit   | 31         | 30 | 29 | 28 | 27    | 26   | 25 | 24 | 23         | 22 | 21                    | 20 | 19   | 18   | 17 | 16 |  |  |
|-------|------------|----|----|----|-------|------|----|----|------------|----|-----------------------|----|------|------|----|----|--|--|
| Name  |            |    |    |    |       |      |    |    | SIGN<br>_R |    |                       |    | FLAF | RE_R | 1  |    |  |  |
| Type  |            |    |    |    |       |      |    |    | R/W        |    |                       |    | R/   | W    | -  |    |  |  |
| Reset |            |    |    |    |       |      |    |    | 0          |    | 0                     |    |      |      |    |    |  |  |
| Bit   | 15         | 14 | 13 | 12 | 11    | 10   | 9  | 8  | 7          | 6  | 6 5 4 3 2 1           |    |      |      |    |    |  |  |
| Name  | SIGN_<br>G |    |    |    | FLAII | RE_G |    |    | SIGN<br>_B |    | 5   4   3   2   1   ( |    |      |      |    |    |  |  |
| Туре  | R/W        |    |    |    | R/    | W    |    |    | R/W        |    | R/W                   |    |      |      |    |    |  |  |
| Reset | 0          |    |    |    | (     | )    |    |    | 0          |    | 0                     |    |      |      |    |    |  |  |

SIGN\_R R flare sign
FLARE\_R R flare
SIGN\_G G flare sign
FLARE\_G G flare
SIGN\_B R flare sign
FLARE\_B G flare

#### 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  |           |    |    |      |       |      |    |          |    |           |              | CONT | <b>RAST</b> | GAIN  |       |    |
| Type  |           |    |    |      |       |      |    |          |    | $\square$ |              |      | R/W         |       |       |    |
| Reset |           |    |    |      |       |      |    |          |    |           |              |      | 40h         |       |       |    |
| Bit   | 15        | 14 | 13 | 12   | 11    | 10   | 9  | 8        | 7  | 6         | 5            | 4    | 3           | 2     | 1     | 0  |
| Name  | FFSE<br>T |    |    | BRIG | HT_OF | FSET |    | <b>*</b> |    |           | UV_L<br>P_EN |      | CSUP        | _EDGE | _GAIN |    |
| Type  | R/W       |    |    |      | R/W   |      |    | Z        |    |           | R/W          |      |             | R/W   |       |    |
| Reset | 1         |    |    |      | 0     |      |    |          |    |           | 0            |      |             | 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 UV\_LP\_EN UV channel low pass enable

**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  |       |    |    | U1  | 1        |    |    |    |      |    |    | V:         | 22    |    |    |    |
| Type  |       |    |    | R/V | <u> </u> |    |    |    |      |    |    | R/         | W     |    |    |    |
| Reset |       |    |    | 20  | h        |    |    |    |      |    |    | 20         | )h    |    |    |    |
| Bit   | 15    | 14 | 13 | 12  | 11       | 10 | 9  | 8  | 7    | 6  | 5  | 4          | 3     | 2  | 1  | 0  |
|       | SIGN_ |    |    |     |          |    |    |    |      |    |    |            |       |    |    |    |
| Name  |       |    |    | U_  | OFFS     | ET |    |    | V_OF |    |    | <b>V</b> _ | OFFSI | EΤ |    |    |
|       | FSET  |    |    |     |          |    |    |    | FSET |    |    |            |       |    |    |    |
| Type  | R/W   |    |    |     | R/W      |    |    |    | R/W  |    |    |            | R/W   |    |    |    |
| Reset | 0     |    |    |     | 0        |    |    |    | 0    |    |    |            | 0     |    |    |    |

V11 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  |    |    |    |     |     |    |    |    |     |    |    |  | Y_0 | AIN |    |     |    |  |
| Type  |    |    |    |     |     |    |    |    |     |    |    |  | R   | W   |    |     | `  |  |
| Reset |    |    |    |     |     |    |    |    | FFh |    |    |  |     |     |    |     |    |  |
| Bit   | 15 | 14 | 13 | 12  | 11  | 10 | 9  | 8  | 7   | 6  | 5  |  | 4   | 3   | 2  | . 1 | 0  |  |
| Name  |    |    |    | U_G | AIN |    |    |    |     |    |    |  | V_0 | AIN |    |     |    |  |
| Type  |    |    |    | R/  | W   |    |    |    |     |    |    |  | R   | W   |    |     |    |  |
| Reset |    |    |    | 91  | h   |    |    |    |     |    |    |  | В   | 3h  |    |     |    |  |

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  |    |    |    |      |      |    |    |                   |    |    |    | Y_OF   | FSET |    |    |    |  |
| Type  |    |    |    |      |      |    |    |                   |    |    |    | I = R/ | W    |    |    |    |  |
| Reset |    |    |    |      |      |    |    | 01h               |    |    |    |        |      |    |    |    |  |
| Bit   | 15 | 14 | 13 | 12   | 11   | 10 | 9  | 8 7 6 5 4 3 2 1 0 |    |    |    |        |      |    |    |    |  |
| Name  |    |    |    | U_OF | FSET |    |    |                   |    |    | 7  | V_OF   | FSET |    |    |    |  |
| Type  |    |    |    | R/   | W    |    |    |                   |    | 70 |    | R/     | W    |    |    |    |  |
| Reset |    |    |    | 80   | )h   |    |    |                   |    |    |    | 80     | )h   |    |    |    |  |

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  |    |    |    | GAMN | IA_B1 |    |              |    |    |    |    | GAMI | IA_B2 |    |    |    |
| Type  |    |    |    | R/   | W     |    |              |    |    |    |    | R/   | W     |    |    |    |
| Reset |    |    |    | 32   | 2h    |    | $\mathbf{Z}$ |    |    |    |    | 50   | )h    |    |    |    |
| Bit   | 15 | 14 | 13 | 12   | 11    | 10 | 9            | 8  | 7  | 6  | 5  | 4    | 3     | 2  | 1  | 0  |
| Name  |    |    |    | GAMN | IA_B3 |    | 7.5          |    |    |    |    | GAM  | IA_B4 |    |    |    |
| Type  |    |    |    | R/   | W     |    |              |    |    |    |    | R/   | W     |    |    |    |
| Reset |    |    |    | 65   | 5h    |    |              |    |    |    |    | 76   | 3h    |    | ·  | -  |

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  |         |    |                 | GAMN | IA_B5 |    |    |    |    |    |    | GAMI | IA_B6 |    |    |    |
| Type  |         | 4  |                 | R/   | W     |    |    |    |    |    |    | R/   | W     |    |    |    |
| Reset | 94h Aeh |    |                 |      |       |    |    |    |    |    |    |      |       |    |    |    |
| Bit   | 15      | 14 | <sub>1</sub> 13 | 12   | 11    | 10 | 9  | 8  | 7  | 6  | 5  | 4    | 3     | 2  | 1  | 0  |
| Name  |         |    | 5               | GAMN | IA_B7 |    |    |    |    |    |    | GAMI | IA_B8 |    |    |    |
| Type  |         |    |                 | R/   | W     |    |    |    |    |    |    | R/   | W     |    |    |    |
| Reset |         |    |                 | C    | 5h    |    |    |    |    |    |    | D    | ah    |    |    |    |

**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  |    |    |    | GAMN        | IA_B9 |    |    |    |    |    |    | <b>GAMM</b> | A_B10 | )  |    |    |
| Type  |    |    |    | R/          | W     |    |    |    |    |    |    | R/          | W     |    |    |    |
| Reset |    |    |    | Ε           | 1h    |    |    |    |    |    |    | E           | Ͻh    |    |    |    |
| Bit   | 15 | 14 | 13 | 12          | 11    | 10 | 9  | 8  | 7  | 6  | 5  | 4           | 3     | 2  | 1  | 0  |
| Name  |    |    |    | <b>GAMM</b> | A_B11 |    |    |    |    |    |    |             |       |    |    |    |
| Type  |    |    |    | R/          | W     |    |    |    |    |    |    |             |       |    |    |    |
| Reset |    | •  | •  | F           | 7h    | •  | •  |    |    |    |    |             |       |    |    |    |

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  |    |    |    |    |    |    | (  | OPD_Y | <b>[31:16]</b> |    |    | , <b>5</b> - |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R     | 0              |    |    |              |    |    |    |    |
| Reset |    |    |    |    |    |    |    | (     | 0              |    |    |              |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7              | 6  | 5  | 4            | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    | OPD_' | Y[15:0]        |    |    |              |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R     | 0              |    |    |              |    |    |    |    |
| Reset |    |    |    |    |    |    |    | (     | 0              |    | 7  |              |    |    |    |    |

**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  |    |    |    |    |    |    |                  | OPD_N | IG[31:10 | 6] |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |                  |       | 30       |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |                  |       | 0        |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9                | 8     | 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |                  | OPD_I | MG[15:0  | )] |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    | $\sigma \Lambda$ | F     | 30       |    |    |    |    |    |    |    |
| 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  |    |    |    |    |    |    | C  | PD_RI | B[31:16 | <u>[</u> |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R     | 0       |          |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | (     | )       |          |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7       | 6        | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    | OPD_R | B[15:0] |          |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R     | 0       |          |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | (     | )       |          |    |    |    |    |    |    |

OPD\_RB OPD RB component accumulation result

#### CAM+00E0h OPD Pixel Count Register

#### CAM\_OPDCNT

| Bit  | 31 | 3 | 0 - | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20  | 19 | 18 | 17 | 16 |
|------|----|---|-----|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|
| Name |    |   |     |    |    |    |    |    |    |    |    |    | PXL |    |    |    |    |



#### MT6228 GSM/GPRS Baseband Processor Data Sheet Revision 1.0

| Type  |        |    |    |    |    |    |   |   |   |   |   | F | 3 |   |   |   |
|-------|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Reset |        |    |    |    |    |    |   |   |   |   |   | ( | ) |   |   |   |
| Bit   | 15     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | PXLCNT |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  |        |    |    |    |    |    |   | R | 0 |   |   |   |   |   |   | ( |
| Reset |        | •  | •  |    | •  | •  | • | ( | ) | • | • |   |   |   | 1 |   |

**PXLCNT** 

OPD pixel counter accumulation result

### CAM+00F4h ATF Result 1 Register

#### CAM AE5RLT

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23     | 22    | 21     | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|-------|--------|-------|--------|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |       | SUM    | ATF1[ | 28:16] |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |       |        | RO    |        |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |       |        | 0     |        |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7      | 6     | 5      | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    | S  | UM_AT | F1[15: | 0]    |        |    | 2  |    |    |    |
| Type  |    |    |    |    |    |    |    | R     | 0      |       |        |    |    |    |    |    |
| Reset |    | •  |    | •  |    |    | •  | (     | )      | •     |        |    |    | •  |    | •  |

SUM\_ATF1

ATF window 1 accumulation result

#### CAM+00F8h ATF Result 2 Register

#### CAM\_ AE6RLT

| Bit   | 31 | 30 | 29 | 28 | 27      | 26 | 25 | 24    | 23        | 22    | 21     | 20 | 19 | 18 | 17 | 16 |  |  |
|-------|----|----|----|----|---------|----|----|-------|-----------|-------|--------|----|----|----|----|----|--|--|
| Name  |    |    |    |    |         |    |    |       | SUM       | ATF2[ | 28:16] |    |    |    |    |    |  |  |
| Type  |    |    |    |    | RO<br>0 |    |    |       |           |       |        |    |    |    |    |    |  |  |
| Reset |    |    |    |    |         |    |    |       |           | 0     |        |    |    |    |    |    |  |  |
| Bit   | 15 | 14 | 13 | 12 | 11      | 10 | 9  | 8     | 7         | 6     | 5      | 4  | 3  | 2  | 1  | 0  |  |  |
| Name  |    |    |    |    |         |    | S  | UM_AT | F2[15:    | 0]    |        |    |    |    |    |    |  |  |
| Type  |    |    |    |    |         |    |    | R     | 5         |       |        |    |    |    |    |    |  |  |
| Reset |    |    |    |    |         |    | 4  | 0     | ) <u></u> |       |        |    |    |    |    |    |  |  |

SUM\_ATF2

ATF window 2 accumulation result

### CAM+00FCh ATF Result 3 Register

#### CAM\_ AE7RLT

| Bit   | 31 | 30 | 29 | 28 | 27       | 26 | <u>2</u> 5 | 24    | 23     | 22    | 21     | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----------|----|------------|-------|--------|-------|--------|----|----|----|----|----|
| Name  |    |    |    |    |          |    |            |       | SUM    | ATF3[ | 28:16] |    |    |    |    |    |
| Type  |    |    |    |    |          |    | 2          |       |        | RO    |        |    |    |    |    |    |
| Reset |    |    |    |    |          |    |            |       |        | 0     |        |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | <u> </u> | 10 | 9          | 8     | 7      | 6     | 5      | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |          |    | SI         | JM_AT | F3[15: | 0]    |        |    |    |    |    |    |
| Type  |    |    |    |    |          |    |            | R     | 0      |       |        |    |    |    |    |    |
| Reset |    |    |    |    |          |    |            | (     | 0      |       |        |    |    |    |    |    |

**SUM ATF3** 

ATF window 3 accumulation result

#### CAM+0100h ATF Result 4 Register

### **CAM\_ AE8RLT**

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



**SUM ATF4** ATF window 4 accumulation result

#### CAM+0104h ATF Result 5 Register

## CAM\_ AE9RLT

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                  | 23                           | 22                      | 21                                                                            | 20                                                                | 19                                                                  | 18                                                                    | 17                                                                     | 16                                                                          |  |
|----|----|----|----|----|----|----|---------------------|------------------------------|-------------------------|-------------------------------------------------------------------------------|-------------------------------------------------------------------|---------------------------------------------------------------------|-----------------------------------------------------------------------|------------------------------------------------------------------------|-----------------------------------------------------------------------------|--|
|    |    |    |    |    |    |    |                     | SUM                          | ATF5[                   | 28:16]                                                                        |                                                                   |                                                                     |                                                                       |                                                                        |                                                                             |  |
|    |    |    |    | RO |    |    |                     |                              |                         |                                                                               |                                                                   |                                                                     |                                                                       |                                                                        |                                                                             |  |
|    |    |    |    | 0  |    |    |                     |                              |                         |                                                                               |                                                                   |                                                                     |                                                                       |                                                                        |                                                                             |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                   | 7                            | 6                       | 5                                                                             | 4                                                                 | 3                                                                   | 2                                                                     | 1                                                                      | 0                                                                           |  |
|    |    |    |    |    |    | S  | UM_A1               | F5[15:                       | 0]                      |                                                                               |                                                                   |                                                                     | 4                                                                     |                                                                        |                                                                             |  |
|    |    |    |    |    |    |    | R                   | 0                            |                         |                                                                               |                                                                   |                                                                     |                                                                       |                                                                        |                                                                             |  |
|    |    |    |    |    |    |    | (                   | 0                            |                         |                                                                               |                                                                   |                                                                     |                                                                       |                                                                        |                                                                             |  |
|    |    |    |    |    |    |    | 15 14 13 12 11 10 9 | 15 14 13 12 11 10 9 8 SUM_AT | 15 14 13 12 11 10 9 8 7 | SUM_ATF5[15:0]  SUM_ATF5[15:0]  RO 0 15 14 13 12 11 10 9 8 7 6 SUM_ATF5[15:0] | SUM_ATF5[28:16]  RO 0 15 14 13 12 11 10 9 8 7 6 5  SUM_ATF5[15:0] | SUM_ATF5[28:16]  RO 0 15 14 13 12 11 10 9 8 7 6 5 4  SUM_ATF5[15:0] | SUM_ATF5[28:16]  RO 0 15 14 13 12 11 10 9 8 7 6 5 4 3  SUM_ATF5[15:0] | SUM_ATF5[28:16]  RO 0 15 14 13 12 11 10 9 8 7 6 5 4 3 2 SUM_ATF5[15:0] | SUM_ATF5[28:16]  RO  0  15 14 13 12 11 10 9 8 7 6 5 4 3 2 1  SUM_ATF5[15:0] |  |

#### SUM ATF5 ATF window 5 accumulation result

#### CAM+0108h CAM Histogram Result 1

#### CAM HISRLTO

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

**CAM\_HISRLT1** Histogram level 1 count result

### CAM+010Ch CAM Histogram Result 2

### CAM\_HISRLT1

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

**CAM\_HISRLT2** Histogram level 2 count result

#### CAM+0110h CAM Histogram Result 3

#### CAM\_HISRLT2

| Bit   | 31 | 30 | 29 | 28         | 27 | 26 | 25  | 24      | 23       | 22   | 21 20 19 18 17 16<br>CAM_HISRLT3[21:16] |     |       |        |      |  |  |  |  |
|-------|----|----|----|------------|----|----|-----|---------|----------|------|-----------------------------------------|-----|-------|--------|------|--|--|--|--|
| Name  |    |    |    |            |    |    |     |         |          |      |                                         | CAN | _HISR | LT3[21 | :16] |  |  |  |  |
| Type  |    |    |    |            |    |    |     |         |          |      |                                         |     | R     | )      |      |  |  |  |  |
| Reset |    |    |    |            |    |    |     |         |          |      | 0                                       |     |       |        |      |  |  |  |  |
| Bit   | 15 | 14 | 13 | 12         | 11 | 10 | 9   | 8       | 7        | 6    | 5 4 3 2 1 0                             |     |       |        |      |  |  |  |  |
| Name  |    |    |    | <b>7</b> C | 7  |    | CAI | /I_HISF | RLT3[1   | 5:0] |                                         |     |       |        |      |  |  |  |  |
| Type  |    |    |    | 7          |    |    |     | R       | <b>O</b> |      |                                         |     |       |        |      |  |  |  |  |
| Reset |    |    |    |            |    | 0  |     |         |          |      |                                         |     |       |        |      |  |  |  |  |

**CAM\_HISRLT3** Histogram level 3 count result

### CAM+0114h CAM Histogram Result 4

#### **CAM\_HISRLT3**

| Bit   | 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20  | 19     | 18     | 17   | 16 |  |
|-------|------------------|----|----|----|----|----|----|----|----|----|----|-----|--------|--------|------|----|--|
| Name  |                  |    |    |    |    |    |    |    |    |    |    | CAN | I_HISR | LT4[21 | :16] |    |  |
| Type  |                  |    |    |    |    |    |    |    |    |    |    |     | R      | )      |      |    |  |
| Reset | $\mathbb{Z}^{5}$ |    |    |    |    |    |    |    |    |    | 0  |     |        |        |      |    |  |
| Bit   | 15               | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4   | 3      | 2      | 1    | 0  |  |



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

**CAM\_HISRLT4** Histogram level 4 count result

#### CAM+0118h CAM Histogram Result 5

#### CAM HISRLT4

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24            | 23     | 22   | 21 | 20  | 19     | 18     | 17   | 16 |  |  |
|-------|----|----|----|----|----|----|-----|---------------|--------|------|----|-----|--------|--------|------|----|--|--|
| Name  |    |    |    |    |    |    |     |               |        |      |    | CAN | I_HISF | LT5[21 | :16] |    |  |  |
| Type  |    |    |    |    |    |    |     |               |        |      |    |     | R      | 0      |      |    |  |  |
| Reset |    |    |    |    |    |    |     |               |        |      |    |     | (      | )      |      |    |  |  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8             | 7      | 6    | 5  | 4   | 3      | 2      | 1    | 0  |  |  |
| Name  |    |    |    |    |    |    | CAI | <b>I_HISF</b> | RLT5[1 | 5:0] |    |     |        |        |      |    |  |  |
| Type  |    |    |    |    |    |    |     | R             | )      |      |    |     |        |        |      |    |  |  |
| Reset |    |    |    |    |    |    |     | C             | )      |      |    |     |        |        |      |    |  |  |

**CAM\_HISRLT5** Histogram level 5 count result

#### CAM+011Ch Low Pass Filter Control Register

#### CAM LPFCON

| Bit   | 31          | 30 | 29 | 28          | 27 | 26 | 25 | 24 | 23 | 22         | 21 | 20  | <u> 19</u> | 18 | 17 | 16           |
|-------|-------------|----|----|-------------|----|----|----|----|----|------------|----|-----|------------|----|----|--------------|
| Name  |             |    |    |             |    |    |    |    |    |            |    | 107 |            |    |    | V_LP<br>F_EN |
| Type  |             |    |    |             |    |    |    |    |    |            |    |     |            |    |    | R/W          |
| Reset |             |    |    |             |    |    |    |    |    |            |    |     |            |    |    | 0            |
| Bit   | 15          | 14 | 13 | 12          | 11 | 10 | 9  | 8  | 7  | 6          | 5  | 4   | 3          | 2  | 1  | 0            |
| Name  | Y_LP<br>FEN |    |    | C_LP<br>FEN |    |    |    |    |    | <b>\</b> ' |    |     |            |    |    |              |
| Type  | R/W         |    |    | R/W         |    |    |    |    |    |            |    |     |            |    |    |              |
| Reset |             |    | •  | 1           | •  |    |    |    |    |            |    |     |            |    |    |              |

V\_LPF\_EN Enable vertical low pass filter. Vertical low pass filter will only be available in following two cases:

- 1. Output image size smaller than 640 pixels.
- 2. Y\_LPFEN or C\_LPFEN is turned on
- **Y\_LPFEN** Enable Luminance channel low pass filter, if **V\_LPF\_EN** is off, only do horizontal low pass
- **C\_LPFEN** Enable Chrominance channel low pass filter, if **V\_LPF\_EN** is off, only do horizontal low pass

#### CAM+0120h Y Low Pass Filter Control Register

#### CAM\_LPFY

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

LPFY\_WEIGHT0Y low pass filter weighting 0LPFY\_WEIGHT1Y low pass filter weighting 1LPFY\_WEIGHT2Y low pass filter weighting 2LPFY\_WEIGHT3Y low pass filter weighting 3

#### CAM+0124h CbCr Low Pass Filter Control Register

#### CAM\_LPFC

| Bit   | 31  | 30 | 29  | 28   | 27     | 26   | 25 | 24 | 23 | 22 | 21  | 20   | 19    | 18   | 17 | 16 |
|-------|-----|----|-----|------|--------|------|----|----|----|----|-----|------|-------|------|----|----|
| Name  |     | 7  | LPF | C_WE | IGHT0[ | 7:0] |    |    |    |    | LPF | C_WE | GHT1[ | 7:0] |    |    |
| Type  | 111 |    |     | R/   | W      |      |    |    |    |    |     | R/   | W     |      |    |    |
| Reset |     |    |     | (    | )      |      |    |    |    |    | •   | (    | )     | •    | •  |    |





| Bit   | 15 | 14 | 13  | 12   | 11    | 10   | 9 | 8 | 7 | 6 | 5   | 4    | 3      | 2    | 1 | 0 |
|-------|----|----|-----|------|-------|------|---|---|---|---|-----|------|--------|------|---|---|
| Name  |    |    | LPF | C_WE | IGHT2 | 7:0] |   |   |   |   | LPI | C_WE | IGHT[7 | 7:0] |   |   |
| Type  |    |    |     | R/   | W     |      |   |   |   |   |     | R/   | W      |      |   |   |
| Reset |    |    |     | (    | )     |      |   |   |   |   |     | (    | )      |      |   |   |

LPFC\_WEIGHT0 CbCr low pass filter weighting 0
LPFC\_WEIGHT1 CbCr low pass filter weighting 1
LPFC\_WEIGHT2 CbCr low pass filter weighting 2
LPFC\_WEIGHT3 CbCr low pass filter weighting 3

#### CAM+0128h Vertical Subsample Control Register

**CAM VSUB** 

| Bit   | 31 | 30 | 29 | 28           | 27 | 26 | 25 | 24 | 23 | 22   | 21    | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|--------------|----|----|----|----|----|------|-------|----|----|----|----|----|
| Name  |    |    |    | V_SU<br>B_EN |    |    |    |    |    | V_SL | IB_IN |    |    | X  |    |    |
| Type  |    |    |    | R/W          |    |    |    |    |    | R/   | W     |    |    |    |    |    |
| Reset |    |    |    | 0            |    |    |    |    |    | (    | )     |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12           | 11 | 10 | 9  | 8  | 7  | 6    | 5     | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |              |    |    |    |    |    | V_SU | 3_OUT |    |    |    |    |    |
| Type  |    |    |    |              |    |    |    |    |    | R    | W     |    |    |    |    |    |
| Reset |    |    |    |              | •  |    |    |    | •  | (    | )     |    |    |    | •  |    |

V\_SUB\_EN Vertical sub-sample enableV\_SUB\_IN Source vertical sizeV\_SUB\_OUT Sub-sample vertical size

### CAM+012ch Horizontal Subsample Control Register

**CAM HSUB** 

| Bit   | 31 | 30 | 29 | 28           | 27 | 26 | 25 | 24     | 23 | 22    | 21   | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|--------------|----|----|----|--------|----|-------|------|----|----|----|----|----|
| Name  |    |    |    | H_SU<br>B_EN |    |    |    |        |    | H_SU  | B_IN |    |    |    |    |    |
| Type  |    |    |    | R/W          |    |    |    |        |    | R/    | W    |    |    |    |    |    |
| Reset |    |    |    | 0            |    |    |    |        |    | C     | )    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12           | 11 | 10 | 9  | 8 _    | 7  | 6     | 5    | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |              |    |    |    | abla I |    | H_SUE | OUT  |    |    |    |    |    |
| Type  |    |    |    |              |    |    | -  |        |    | R/    | W    |    |    |    |    |    |
| Reset |    |    |    |              | •  | •  |    |        |    | C     |      | •  |    | •  |    |    |

H\_SUB\_EN Horizontal sub-sample enableH\_SUB\_IN Source horizontal sizeH\_SUB\_OUT Sub-sample horizontal size

### CAM+0130h Sensor Gamma R0 Register

CAM\_SGAMMA

R0

| Bit   | 31 | 30      | 29 | 28                | 27 | 26 | 25 | 24                 | 23 | 22 | 21 | 20 | 19         | 18 | 17 | 16 |
|-------|----|---------|----|-------------------|----|----|----|--------------------|----|----|----|----|------------|----|----|----|
| Name  |    |         |    | SGAM<br>MA_E<br>N |    |    |    | SGAM<br>MA_I<br>VT |    |    |    | R_ | B1         |    |    |    |
| Type  |    |         |    | R/W               |    |    |    | R/W                |    |    |    | R/ | W          |    |    |    |
| Reset |    |         |    | 0                 |    |    |    | 0                  |    |    |    | 32 | 2h         |    |    |    |
| Bit   | 15 | 14      | 13 | 12                | 11 | 10 | 9  | 8                  | 7  | 6  | 5  | 4  | 3          | 2  | 1  | 0  |
| Name  |    |         |    | R_                | B2 |    |    |                    |    |    |    | R_ | <b>B</b> 3 |    |    |    |
| Type  |    | R/W R/W |    |                   |    |    |    |                    |    |    |    |    |            |    |    |    |
| Reset |    |         |    | 50                | )h |    |    |                    |    |    |    | 65 | 5h         |    |    |    |

SGAMMA\_EN Sensor Gamma enable
SGAMMA\_IVT Sensor Gamma output invert
R\_B1 Gamma operating B1 value
R\_B2 Gamma operating B2 value



**R B3** 

Gamma operating B3 value

### CAM+0134h Sensor Gamma R1 Register

### CAM\_SGAMMA

R1

| Bit   | 31 | 30 | 29 | 28 | 27        | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19         | 18 | 17 | 16 |
|-------|----|----|----|----|-----------|----|----|----|----|----|----|----|------------|----|----|----|
| Name  |    |    |    | R_ | B4        |    |    |    |    |    |    | R_ | <b>B</b> 5 |    |    |    |
| Type  |    |    |    | R/ | W         |    |    |    |    |    |    | R/ | W          |    |    |    |
| Reset |    |    |    | 76 | 3h        |    |    |    |    |    |    | 94 | \$h        |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11        | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3          | 2  | 1  | 0  |
| Name  |    |    |    | R_ | <b>B6</b> |    |    |    |    |    |    | R_ | <b>B</b> 7 |    |    |    |
| Type  |    |    |    | R/ | W         |    |    |    |    |    |    | R/ | W          |    |    |    |
| Reset |    |    |    | AE | Eh        |    | •  | •  |    |    |    | C  | 5h         |    |    |    |

R\_B4 Gamma operating B4 value
 R\_B5 Gamma operating B5 value
 R\_B6 Gamma operating B6 value
 R\_B7 Gamma operating B7 value

### CAM+0138h Sensor Gamma R2 Register

CAM\_SGAMMA

**R2** 

| Bit   | 31 | 30 | 29 | 28  | 27         | 26 | 25 | 24 | 23 | 22 | 21        | 7 | 20 | 19  | 18 | 17 | 16 |
|-------|----|----|----|-----|------------|----|----|----|----|----|-----------|---|----|-----|----|----|----|
| Name  |    |    |    | R_  | <b>B</b> 8 |    |    |    |    | 4  |           |   | R  | B9  |    |    |    |
| Type  |    |    |    | R/  | W          |    |    |    |    |    | 72        |   | R  | W   |    |    |    |
| Reset |    |    |    | D/  | 4h         |    |    |    |    |    | $\Lambda$ |   | D  | 4h  |    |    |    |
| Bit   | 15 | 14 | 13 | 12  | 11         | 10 | 9  | 8  | 7  | 6  | -5        |   | 4  | 3   | 2  | 1  | 0  |
| Name  |    |    |    | R_I | 310        |    |    |    |    |    | ,         |   | R_ | 311 |    |    |    |
| Type  |    |    |    | R/  | W          |    |    |    |    |    |           |   | R  | W   |    |    |    |
| Reset |    |    |    | E   | Dh         |    |    |    |    |    |           |   | F  | 7h  |    |    |    |

R\_B8 Gamma operating B8 value
R\_B9 Gamma operating B9 value
R\_B10 Gamma operating B10 value
R\_B11 Gamma operating B11 value

### CAM+013ch Sensor Gamma G0 Register

CAM\_SGAMMA

G<sub>0</sub>

| Bit   | 31 | 30 | 29 | 28 | 27         | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19         | 18 | 17 | 16 |
|-------|----|----|----|----|------------|----|----|----|----|----|----|----|------------|----|----|----|
| Name  |    |    |    | G_ | <b>B</b> 1 |    |    |    |    |    |    | G_ | B2         |    |    |    |
| Type  |    |    |    | R/ | W          |    | ľ  |    |    |    |    | R/ | W          |    |    |    |
| Reset |    |    |    | 32 | 2h         |    |    |    |    |    |    | 50 | )h         |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11         | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3          | 2  | 1  | 0  |
| Name  |    |    |    | G_ | <b>B3</b>  |    |    |    |    |    |    | G_ | <b>B</b> 4 |    |    |    |
| Type  |    |    |    | R/ | W          |    |    |    |    |    |    | R/ | W          |    |    |    |
| Reset | •  |    | •  | 65 | 5h         | •  |    | •  |    |    |    | 70 | 3h         | •  | •  |    |

G\_B1 Gamma operating B1 value
 G\_B2 Gamma operating B2 value
 G\_B3 Gamma operating B3 value
 G\_B4 Gamma operating B4 value

### CAM+0140h Sensor Gamma G1 Register

**CAM\_SGAMMA** 

G1

| Bit  | 31 | 30 | 29 | 28 | 27        | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19        | 18 | 17 | 16 |
|------|----|----|----|----|-----------|----|----|----|----|----|----|----|-----------|----|----|----|
| Name |    |    |    | G_ | <b>B5</b> |    |    |    |    |    |    | G_ | <b>B6</b> |    |    |    |
| Type |    |    |    | R/ | W         |    |    |    |    |    |    | R/ | W         |    |    |    |





| Reset |     |    |    | 94 | 4h         |    |   |   |   |   |   | Al | Ξh         |   |   |                |
|-------|-----|----|----|----|------------|----|---|---|---|---|---|----|------------|---|---|----------------|
| Bit   | 15  | 14 | 13 | 12 | 11         | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3          | 2 | 1 | 0              |
| Name  |     |    |    | G_ | <b>B</b> 7 |    |   |   |   |   |   | G_ | <b>B</b> 8 |   |   |                |
| Type  | R/W |    |    |    |            |    |   |   |   |   |   | R/ | W          |   |   |                |
| Reset |     |    |    | C; | 5h         |    |   |   |   |   |   | D  | ٩h         |   |   | $\overline{A}$ |

G\_B5
 Gamma operating B5 value
 G\_B6
 Gamma operating B6 value
 G\_B7
 Gamma operating B7 value
 G\_B8
 Gamma operating B8 value

### CAM+0144h Sensor Gamma G2 Register

#### CAM SGAMMA

G2

| Bit   | 31 | 30 | 29 | 28  | 27         | 26 | 25 | 24 | 23 | 22 | 21 | 20 19        | 18 | 17 | 16 |
|-------|----|----|----|-----|------------|----|----|----|----|----|----|--------------|----|----|----|
| Name  |    |    |    | G_  | <b>B</b> 9 |    |    |    |    |    |    | G_B10        |    |    |    |
| Type  |    |    |    | R/  | W          |    |    |    |    |    |    | R/W          |    |    |    |
| Reset |    |    |    | Ε   | 4h         |    |    |    |    |    |    | EDh          |    |    |    |
| Bit   | 15 | 14 | 13 | 12  | 11         | 10 | 9  | 8  | 7  | 6  | 5  | 4 3          | 2  | 1  | 0  |
| Name  |    |    |    | G_I | 311        |    |    |    |    |    |    |              |    |    |    |
| Type  |    |    |    | R/  | W          |    |    |    |    |    |    |              |    |    |    |
| Reset |    |    |    | F   | 7h         |    |    |    |    |    |    | 7 • <u>4</u> |    |    |    |

G\_B9 Gamma operating B9 value
 G\_B10 Gamma operating B10 value
 G\_B11 Gamma operating B11 value

#### CAM+0148h Sensor Gamma B0 Register

CAM\_SGAMMA

**B**0

| Bit   | 31 | 30 | 29 | 28 | 27         | 26 | 25 | 24      | 23 | 22 | 21 | 20         | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|------------|----|----|---------|----|----|----|------------|----|----|----|----|
| Name  |    |    |    | B_ | <b>B</b> 1 |    |    |         |    |    |    | <b>B</b> _ | B2 |    |    |    |
| Type  |    |    |    | R/ | W          |    |    |         |    |    |    | R/         | W  |    |    |    |
| Reset |    |    |    | 32 | 2h         |    | 4  | M       |    |    |    | 50         | 0h |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11         | 10 | 9  | 8       | 7  | 6  | 5  | 4          | 3  | 2  | 1  | 0  |
| Name  |    |    |    | B  | B3         |    |    | <u></u> |    |    |    | B_         | B4 |    |    |    |
| Type  |    |    |    | R/ | W          |    |    |         |    |    |    | R/         | W  |    |    |    |
| Reset |    |    | •  | 65 | h          |    | 4  |         |    | •  | •  | 76         | 6h |    |    |    |

B\_B1 Gamma operating B1 value
B\_B2 Gamma operating B2 value
B\_B3 Gamma operating B3 value
B\_B4 Gamma operating B4 value

### CAM+014ch Sensor Gamma B1 Register

CAM\_SGAMMA

**B1** 

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19        | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|----|----|
| Name  |    |    |    | B_ | B5 |    |    |    |    |    |    | B_ | <b>B6</b> |    |    |    |
| Type  |    |    |    | R/ | W  |    |    |    |    |    |    |    | W         |    |    |    |
| Reset |    |    |    | 94 | ₽h |    |    |    |    |    |    | Α  | Eh        |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3         | 2  | 1  | 0  |
| Name  |    |    |    | B_ | B7 |    |    |    |    |    |    | B_ | B8        |    |    |    |
| Type  |    |    |    | R/ | W  |    |    |    |    |    |    | R  | W         |    |    |    |
| Reset |    |    |    | C: | 5h | •  |    | •  |    | •  | •  | D. | Ah        | •  |    | •  |

B\_B5 Gamma operating B5 value
B\_B6 Gamma operating B6 value

B\_B7 Gamma operating B7 value



**B B**8

Gamma operating B8 value

#### CAM+0150h **Sensor Gamma B2 Register**

#### **CAM SGAMMA**

| 31 | 30 | 29 | 28  | 27                      | 26                                            | 25                                                    | 24                                                      | 23                                           | 22                                                          | 21                                                                   | 20                                                      | 19                                                                                 | 18   | 17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----|----|----|-----|-------------------------|-----------------------------------------------|-------------------------------------------------------|---------------------------------------------------------|----------------------------------------------|-------------------------------------------------------------|----------------------------------------------------------------------|---------------------------------------------------------|------------------------------------------------------------------------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |    |    | B_  | <b>B9</b>               |                                               |                                                       |                                                         |                                              |                                                             |                                                                      | B_E                                                     | 310                                                                                |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|    |    |    | R/  | W                       |                                               |                                                       |                                                         |                                              |                                                             |                                                                      | R/                                                      | W                                                                                  |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|    |    |    | Ε   | 1h                      |                                               |                                                       |                                                         |                                              |                                                             |                                                                      | E                                                       | )h                                                                                 |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15 | 14 | 13 | 12  | 11                      | 10                                            | 9                                                     | 8                                                       | 7                                            | 6                                                           | 5                                                                    | 4                                                       | 3                                                                                  | 2    | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|    |    |    | B_E | 311                     |                                               |                                                       |                                                         |                                              |                                                             |                                                                      |                                                         |                                                                                    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|    |    |    | R/  | W                       |                                               |                                                       |                                                         |                                              |                                                             |                                                                      |                                                         |                                                                                    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|    |    |    | F7  | 7h                      |                                               |                                                       |                                                         |                                              |                                                             |                                                                      |                                                         |                                                                                    |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|    |    |    |     | B R/ E4 15 14 13 12 BEE | B B9<br>R/W<br>E4h<br>15 14 13 12 11<br>B B11 | BB9<br>R/W<br>E4h<br>15 14 13 12 11 10<br>BB11<br>R/W | BB9<br>R/W<br>E4h<br>15 14 13 12 11 10 9<br>BB11<br>R/W | B_B9 R/W E4h 15 14 13 12 11 10 9 8 B_B11 R/W | BB9<br>R/W<br>E4h<br>15 14 13 12 11 10 9 8 7<br>BB11<br>R/W | B_B9 R/W E4h  15   14   13   12   11   10   9   8   7   6  B_B11 R/W | B B9  R/W  E4h  15 14 13 12 11 10 9 8 7 6 5  B B11  R/W | BB9 R/W R/ E4h E[  15   14   13   12   11   10   9   8   7   6   5   4    BB11 R/W | B B9 | B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         1         B | B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B         B |

**B\_B9** Gamma operating B9 value **B\_B10** Gamma operating B10 value **B\_B11** Gamma operating B11 value

#### CAM+00154h Defect Pixel Configuration Register

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

**DEFECT\_EN** Defect table correct enable

#### CAM+0158h **Defect Pixel Table Address Register**

CAM\_DEFECT1

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 24   | 23      | 22     | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|---------|---------|--------|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    | DEFFECT | ADDR[3  | 31:16] |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |         | RW      |        |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    | 2       | 2000h   |        |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 8     | 7       | 6      | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    | DEFECT  | _ADDR[1 | 5:0]   |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    | Y 🗸     | RW      |        |    |    |    |    |    |    |
| Reset |    | •  | •  | •  |    |    |         | 0       | •      | •  | •  | •  | •  | •  | •  |

Defect table location address **DEFECT ADDR** 

#### **Camera Interface Debug Mode Control Register** CAM+0180h

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  |    |    |    |    |    |    |    |    |    |    |    | -  |    |    |    |    |
| Type  |    | 4  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    | ·  |    |    |    |    |

#### **Camera Module Debug Information Write Out** CAM\_DSTADD CAM+0184h **Destination Address**

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

R



| 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  | e DST_ADD[15:0] |    |    |    |    |    |   |   |   |   |   |   |   |   |   | . (1 |
| Type  | R/W             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |      |
| Reset | 0000h           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |      |

**DST\_ADD** Debug Information Write Output Destination Address

# CAM+0188h Camera Module Debug Information Last Transfer CAM\_LASTA Destination Address

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

**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 | <u>21</u> | 20 | 19 | 18 | 17 | 16 |
|-------|-----------------------|----|----|----|----|----|----|----|----|----|-----------|----|----|----|----|----|
| Name  |                       |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |
| Type  | e RO                  |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |
| Reset | 0                     |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |
| Bit   | 15                    | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5         | 4  | 3  | 2  | 1  | 0  |
| Name  | Name XFER_COUNT[15:0] |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |
| Type  |                       |    |    |    |    |    |    | R  | 0  |    |           |    |    |    |    |    |
| Reset |                       |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |

**XFER COUNT** Pixel Transfer Count per Frame

## CAM+0190h CMOS Sensor Test Model Configuration Register 1

CAM\_MDLCFG

| Bit   | 31 | 30 | 29 | 28 | 27  | 26 | 25  | 24  | 23                  | 22 | 21    | 20 | 19      | 18 | 17 | 16 |  |
|-------|----|----|----|----|-----|----|-----|-----|---------------------|----|-------|----|---------|----|----|----|--|
| Name  |    |    |    | VS | /NC | 76 |     |     | IDLE_PIXEL_PER_LINE |    |       |    |         |    |    |    |  |
| Type  |    |    |    | R/ | W   |    |     |     | R/W                 |    |       |    |         |    |    |    |  |
| Reset |    |    |    | (  | ) ( |    |     |     | 0                   |    |       |    |         |    |    |    |  |
| Bit   | 15 | 14 | 13 | 12 | 11  | 10 | 9   | 8   | 7                   | 6  | 5     | 4  | 3       | 2  | 1  | 0  |  |
| Name  |    |    |    |    |     |    | ON  | RST | STILL               | P  | ATTER | N  | CLK_DIV |    |    |    |  |
| Type  |    |    |    |    |     | 1  | R/W | R/W | R/W                 |    | R/W   |    | R/W     |    |    |    |  |
| Reset |    |    |    |    |     |    | 0   | 0   | 0                   |    | 0     |    | 0       |    |    |    |  |

**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



Reset

## CAM +0194h CMOS Sensor Test Model Configuration Register 2

## CAM\_MDLCFG

LINE Name Type R/W 0 Reset Bit 15 14 13 12 11 10 8 5 0 **PIXEL** Name R/W Type Reset 0

LINE CMOS Sensor Model Line Number

PIXEL CMOS Sensor Model Pixel Number (HSYNC high duration in pixel unit)

| CAM   | +019 | 8h | Rese | rved |    |    |    |    |    |    |    |    |    | R  | ESE | RVI | ED |
|-------|------|----|------|------|----|----|----|----|----|----|----|----|----|----|-----|-----|----|
| Bit   | 31   | 30 | 29   | 28   | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 1   | 16 |
| Name  |      |    |      |      |    |    |    |    |    |    |    |    |    |    |     |     |    |
| Type  |      |    |      |      |    |    |    |    |    |    |    |    |    |    |     |     |    |
| Reset |      |    |      |      |    |    |    |    |    |    |    |    |    |    |     |     |    |
| Bit   | 15   | 14 | 13   | 12   | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 74 | 3  | 2  | 1   | (   | 0  |
| Name  |      |    |      |      |    |    |    |    |    |    |    |    |    |    |     |     |    |
| Type  |      |    |      |      |    |    |    |    |    |    |    | 4  |    |    |     |     |    |

| CAM   | +019 | 9Ch |   | Res | er | ved | ı |    |    |    |   |     |    |    |                           |    |   |   |   |    |    | F  | RE | SE | R۷ | ED |
|-------|------|-----|---|-----|----|-----|---|----|----|----|---|-----|----|----|---------------------------|----|---|---|---|----|----|----|----|----|----|----|
| Bit   | 31   | 30  | ) | 29  |    | 28  |   | 27 | 26 | 25 |   | 24  |    | 23 | $^{	extstyle 	imes}$ $(2$ | 22 | 2 | 1 | 2 | 20 | 19 | 18 |    | 17 |    | 16 |
| Name  |      |     |   |     |    |     |   |    |    |    |   |     |    |    |                           |    |   |   |   |    |    |    |    |    |    |    |
| Type  |      |     |   |     |    |     |   |    |    |    |   |     |    |    |                           |    |   |   |   |    |    |    |    |    |    |    |
| Reset |      |     |   |     |    |     |   |    |    |    |   |     |    |    |                           |    |   |   |   |    |    |    |    |    |    |    |
| Bit   | 15   | 14  |   | 13  |    | 12  |   | 11 | 10 | 9  |   | 8   | T. | 7  |                           | 6  | Ę | , |   | 4  | 3  | 2  |    | 1  |    | 0  |
| Name  |      |     |   |     |    |     |   |    |    |    |   | T Ŧ | Λ  | 7  |                           |    |   |   |   |    |    |    |    |    |    |    |
| Type  |      |     |   |     |    |     |   |    |    |    | X | V   |    |    |                           |    |   |   |   |    |    |    |    |    |    |    |
| Reset |      |     |   |     |    |     |   |    |    |    |   |     | Þ  |    |                           |    |   |   |   |    |    |    |    |    |    |    |

## CAM+01A0h AE Address Register

### **CAM AEADDR**

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

AE ADDR

AE Statistic writed out address.

High bandwidth is required, recommend to set in sram

## CAM+01A4h AE Window Size Register

### CAM\_AESIZE

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



AE\_VSIZE AE window vertical size
AE\_HSIZE AE window horizontal size

Notes: Total number of AE statistic window is 63 limited. When AE is on, vertical size and

horizontal size must be set to avoid ae window exceed 63

## CAM+01A8h AE Weight 1 Register

**CAM\_AEWEIG** 

HT0

| Bit   | 31 | 30  | 29    | 28   | 27 | 26  | 25    | 24   | 23 | 22  | 21    | 20   | 19 | 18         | 17    | 16  |
|-------|----|-----|-------|------|----|-----|-------|------|----|-----|-------|------|----|------------|-------|-----|
| Name  |    | AE_ | WEIGH | IT00 |    | AE_ | WEIGH | IT01 |    | AE_ | WEIGH | IT02 |    | AE         | WEIGH | T03 |
| Type  |    |     | R/W   |      |    |     | R/W   |      |    |     | R/W   |      |    | $I \cup I$ | R/W   |     |
| Reset |    |     | 1     |      |    |     | 1     |      |    |     | 1     |      |    |            | 1     |     |
| Bit   | 15 | 14  | 13    | 12   | 11 | 10  | 9     | 8    | 7  | 6   | 5     | 4    | 3  | 2          | 1     | 0   |
| Name  |    | AE_ | WEIGH | IT04 |    | AE_ | WEIGH | IT05 |    | AE_ | WEIGH | IT06 |    | AE_        | WEIGH | T07 |
| Type  |    |     | R/W   |      |    |     | R/W   |      |    |     | R/W   |      |    |            | R/W   |     |
| Reset |    |     | 1     |      |    |     | 1     |      |    |     | 1     |      |    |            | 1     |     |

**AE\_WEIGHT00~07** AE window 00~07 weight

## CAM+01ACh AE Weight 2 Register

**CAM\_AEWEIG** 

HT1

| Bit   | 31 | 30  | 29    | 28   | 27 | 26  | 25    | 24   | 23 | 22 | 21    | 20   | 19 | 18  | 17    | 16   |
|-------|----|-----|-------|------|----|-----|-------|------|----|----|-------|------|----|-----|-------|------|
| Name  |    | AE_ | WEIGH | 1T08 |    | AE_ | WEIGH | IT09 |    | AE | WEIGH | 1T10 |    | AE_ | WEIGH | łT11 |
| Type  |    |     | R/W   |      |    | R/W |       |      |    |    | R/W   |      |    |     | R/W   |      |
| Reset |    |     | 1     |      |    | 1   |       |      |    |    | 1     |      |    |     | 1     |      |
| Bit   | 15 | 14  | 13    | 12   | 11 | 10  | 9     | 8    | 7  | 6  | 5     | 4    | 3  | 2   | 1     | 0    |
| Name  |    | AE_ | WEIGH | IT12 |    | AE_ | WEIGH | IT13 |    | AE | WEIGH | HT14 |    | AE_ | WEIGH | łT15 |
| Type  |    |     | R/W   |      |    |     | R/W   |      |    |    | R/W   |      |    |     | R/W   |      |
| Reset |    |     | 1     |      |    | •   | 1     |      |    |    | 1     |      |    |     | 1     |      |

**AE\_WEIGHT08~15** AE window 08~15 weight

## CAM+01B0h AE Weight 3 Register

**CAM\_AEWEIG** 

HT2

| Bit   | 31 | 30  | 29    | 28   | 27 | 26  | 25    | 24   | 23 | 22  | 21    | 20   | 19 | 18  | 17    | 16  |
|-------|----|-----|-------|------|----|-----|-------|------|----|-----|-------|------|----|-----|-------|-----|
| Name  |    | AE_ | WEIGH | IT16 |    | AE  | WEIGH | T17  |    | AE_ | WEIGH | IT18 |    | AE_ | WEIGH | T19 |
| Type  |    |     | R/W   |      
| Reset |    |     | 1     |      |    |     | 1     |      |    |     | 1     |      |    |     | 1     |     |
| Bit   | 15 | 14  | 13    | 12   | 11 | 10  | 9     | 8    | 7  | 6   | 5     | 4    | 3  | 2   | 1     | 0   |
| Name  |    | AE_ | WEIGH | IT20 |    | AE_ | WEIGH | 1T21 |    | AE_ | WEIGH | IT22 |    | AE_ | WEIGH | T23 |
| Type  |    |     | R/W   |      |    | R/W |       |      |    |     | R/W   |      |    |     | R/W   |     |
| Reset |    |     | 1     |      |    | 1   |       |      |    |     | 1     |      |    |     | 1     |     |

**AE\_WEIGHT16~23** AE window 16~23 weight

## CAM+01B4h AE Weight 4 Register

CAM\_AEWEIG

**HT3** 

| Bit   | 31 | 30       | 29    | 28  | 27 | 26  | 25    | 24   | 23 | 22  | 21    | 20   | 19 | 18  | 17    | 16   |
|-------|----|----------|-------|-----|----|-----|-------|------|----|-----|-------|------|----|-----|-------|------|
| Name  |    | AE       | WEIGH | T24 |    | AE_ | WEIGH | IT25 |    | AE_ | WEIGH | IT26 |    | AE_ | WEIGH | HT27 |
| Type  |    |          | R/W   |     |    |     | R/W   |      |    |     | R/W   |      |    |     | R/W   |      |
| Reset |    | 1        |       |     |    |     | 1     |      |    |     | 1     |      |    |     | 1     |      |
| Bit   | 15 | 14 13 12 |       |     | 11 | 10  | 9     | 8    | 7  | 6   | 5     | 4    | 3  | 2   | 1     | 0    |
| Name  |    | AE       |       |     |    | AE_ | WEIGH | IT29 |    | AE_ | WEIGH | 1T30 |    | AE_ | WEIGH | 1T31 |
| Type  |    |          | R/W   |     |    |     | R/W   |      |    |     | R/W   |      |    |     | R/W   |      |
| Reset |    | 1        |       |     |    |     | 1     |      |    |     | 1     |      |    |     | 1     |      |



**AE\_WEIGHT24~31** AE window 24~31 weight

## CAM+01B8h AE Weight 5 Register

## **CAM\_AEWEIG**

**1T4** 

| Bit   | 31 | 30  | 29    | 28   | 27 | 26  | 25    | 24   | 23 | 22  | 21    | 20   | 19 | 18  | 17    | 16   |
|-------|----|-----|-------|------|----|-----|-------|------|----|-----|-------|------|----|-----|-------|------|
| Name  |    | AE_ | WEIGH | IT32 |    | AE_ | WEIGH | IT33 |    | AE_ | WEIGH | IT34 |    | AE_ | WEIGH | IT35 |
| Type  |    |     | R/W   |      |
| Reset |    |     | 1     |      |    |     | 1     |      |    |     | 1     |      |    |     | 1     |      |
| Bit   | 15 | 14  | 13    | 12   | 11 | 10  | 9     | 8    | 7  | 6   | 5     | 4    | 3  | 2   | 1     | 0    |
| Name  |    | AE_ | -     |      |    | AE_ | WEIGH | IT37 |    | AE_ | WEIGH | IT38 |    | AE₄ | WEIGH | IT39 |
| Type  |    |     | R/W   |      |
| Reset |    | •   | 1     |      |    |     | 1     |      |    |     | 1     |      |    |     | 1     |      |

**AE\_WEIGHT 32~39** AE window 32~39 weight

## CAM+01BCh AE Weight 6 Register

CAM\_AEWEIG

HT5

| Bit   | 31 | 30  | 29    | 28   | 27 | 26  | 25    | 24   | 23  | 22        | 21    | 20  | 19 | 18  | 17    | 16   |
|-------|----|-----|-------|------|----|-----|-------|------|-----|-----------|-------|-----|----|-----|-------|------|
| Name  |    | AE_ | WEIGH | IT40 |    | AE_ | WEIGH | IT41 |     | AE_       | WEIGH | T42 |    | AE_ | WEIGH | IT43 |
| Type  |    |     | R/W   |      |    |     | R/W   |      | R/W |           |       |     |    |     | R/W   |      |
| Reset |    |     | 1     |      |    |     | 1     |      |     | 1         |       |     |    |     | 1     |      |
| Bit   | 15 | 14  | 13    | 12   | 11 | 10  | 9     | 8    | 7   | 7 6 5 4 3 |       |     |    | 2   | 1     | 0    |
| Name  |    | AE_ | WEIGH | IT44 |    | AE_ | WEIGH | IT45 |     | AE        | WEIGH | T46 |    | AE_ | WEIGH | IT47 |
| Type  |    |     | R/W   |      |    |     | R/W   |      |     |           | R/W   |     |    |     | R/W   |      |
|       |    |     | 1     |      |    |     |       |      |     |           |       |     |    |     |       |      |

**AE\_WEIGHT 40~47** AE window 40~47 weight

## CAM+01C0h AE Weight 7 Register

**CAM\_AEWEIG** 

**HT6** 

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

**AE\_WEIGHT 48~55** AE window 48~55 weight

## CAM+01C4h AE Weight 8 Register

CAM\_AEWEIG

HT7

| Bit   | 31 | 30 | 29     | 28         | 27 | 26 | 25     | 24   | 23 | 22  | 21    | 20   | 19 | 18  | 17    | 16  |
|-------|----|----|--------|------------|----|----|--------|------|----|-----|-------|------|----|-----|-------|-----|
| Name  |    | AE | _WEIGH | 1T56       |    | AE | _WEIGI | HT57 |    | AE_ | WEIGH | 1T58 |    | AE_ | WEIGH | T59 |
| Type  |    |    | R/W    |            |    |    | R/W    |      |    |     | R/W   |      |    |     | R/W   |     |
| Reset |    |    | 1      | <u>-5\</u> |    |    | 1      |      |    |     | 1     |      |    |     | 1     |     |
| Bit   | 15 | 14 | 13     | 12         | 11 | 10 | 9      | 8    | 7  | 6   | 5     | 4    | 3  | 2   | 1     | 0   |
| Name  |    | AE | WEIGH  | HT60       |    | AE | WEIGH  | HT61 |    | AE  | WEIGH | 1T62 |    |     |       |     |
| Type  |    |    | R/W    |            |    |    | R/W    |      |    |     | R/W   |      |    |     |       |     |
| Reset |    |    | 1      | •          |    |    | 1      | •    |    |     | 1     |      |    |     |       |     |

**AE\_WEIGHT 56~62** AE window 56~62 weight

## CAM+01C8h AE Area Register

**CAM\_AEAREA** 

| Bit 3 | 31 | 30 | 29 | 28   | 27 | 26  | 25 | 24 | 23 | 22 | 21 | 20    | 19    | 18  | 17 | 16 |
|-------|----|----|----|------|----|-----|----|----|----|----|----|-------|-------|-----|----|----|
| Name  |    |    | AE | _VOF |    | :0] |    |    |    |    | AE | _HOFF | SET[7 | :0] |    |    |





| Type  |    |    |    | R/   | W           |      |   |   |   |   |   | R/ | W    |      |      |   |
|-------|----|----|----|------|-------------|------|---|---|---|---|---|----|------|------|------|---|
| Reset |    |    |    | (    | )           |      |   |   |   |   |   | (  | )    |      |      |   |
| Bit   | 15 | 14 | 13 | 12   | 11          | 10   | 9 | 8 | 7 | 6 | 5 | 4  | 3    | 2    | 1    | 0 |
| Name  |    |    | AE | FRAM | <b>ECNT</b> | 7:0] |   |   |   |   |   | AE | _ARE | ACNT | 5:0] |   |
| Type  |    |    |    | F    | 7           |      |   |   |   |   |   |    |      | R    |      |   |
| Reset |    |    |    | (    | )           | •    | • |   |   |   |   |    |      | 0    |      |   |

**AE\_VOFFSET** AE window vertical offset

**AE\_HOFFSET** AE window horizontal offset

**AE\_FRAMECNT** AE Frame interval counter

**AE\_AREACNT** AE Window Area counter

## CAM+01CCh AutoDefect Control 1 Register

CAM\_ADEFEC TO

| Bit   | 31         | 30         | 29         | 28         | 27         | 26                | 25   | 24    | 23   | 22 | 21 | 20    | <u> 19</u> | 18 | 17    | 16 |
|-------|------------|------------|------------|------------|------------|-------------------|------|-------|------|----|----|-------|------------|----|-------|----|
| Name  | ADC_<br>EN | ADL_<br>EN | ADR_<br>EN | ADU_<br>EN | ADD_<br>EN | DEAD<br>CHEC<br>K | GCHE | CKSEL | RBCH |    | BR | IGHTT | HD         | BL | ACKTH | ID |
| 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     |    |
| Bit   | 15         | 14         | 13         | 12         | 11         | 10                | 9    | 8     | 7    | 6  | 5  | 4     | 3          | 2  | 1     | 0  |
| Name  |            |            |            | AE_IN1     | ERVA       | L                 |      |       |      |    |    |       |            |    |       |    |
| Type  |            |            |            | R          | /W         |                   |      |       |      |    |    |       |            |    |       |    |
| Reset |            |            |            | (          | 0          |                   |      |       |      | 7  |    |       |            |    |       |    |

ADC\_En Center Autodefect cell enable
ADL\_En Left Autodefect cell enable
ADR\_En Right Autodefect cell enable
ADU\_En Up Autodefect cell enable
ADD\_En Down Autodefect cell enable
DEADCHECK Dead pixel check enable

**GCHECKSEI** G pixel check method selection

near group check only

**01** near and far groups check

10 far group check only

11 reserved

**RBCHECKSEI** RB pixel check method selection

near group check onlynear and far groups checkfar group check only

11 reserved

BRIGHTTHD Black pixel threshold = BRIGHTTHD \*4

BLACKTHD Black pixel threshold = BLACKTHD \*4

**AE INTERVAL** AE frame interval

## CAM+01D0h AutoDefect Control 2 Register

**CAM ADEFECT** 

1

| Bit   | 31 | 30 | 29 | 28          | 27    | 26 | 25 | 24 | 23 | 22 | 21 | 20    | 19    | 18 | 17 | 16 |
|-------|----|----|----|-------------|-------|----|----|----|----|----|----|-------|-------|----|----|----|
| Name  |    |    |    | <b>GCHE</b> | CKTHD |    |    |    |    |    | F  | RBCHE | CKTHE | )  |    |    |
| Type  |    |    |    | R/          | W     |    |    |    |    |    |    | R/    | W     |    |    |    |
| Reset |    |    |    | (           | )     |    |    |    |    |    |    | (     | )     |    |    |    |



| Bit   | 15 | 14 | 13 | 12   | 11    | 10 | 9 | 8 | 7 | 6 | 5  | 4    | 3    | 2              | 1 | 0 |
|-------|----|----|----|------|-------|----|---|---|---|---|----|------|------|----------------|---|---|
| Name  |    |    | G  | CORR | ECTTH | D  |   |   |   |   | RE | CORF | ECTT | <del>I</del> D |   |   |
| Type  |    |    |    | R/   | W     |    |   |   |   |   |    | R/   | W    |                |   |   |
| Reset |    |    |    | (    | )     |    |   |   |   |   |    | (    | )    |                |   |   |

GCHECKTHD G pixel check threshold
RBCHECKTHD RB pixel check threshold
GCORRECTTHD G pixel correct threshold
RBCORRECTTHD RB pixel correct threshold

### CAM+01D4h Flash Control Register

### **CAM FLASH**

| Bit   | 31                | 30 | 29   | 28           | 27    | 26     | 25 | 24                         | 23 | 22 | 21 | 20                | 19  | 18     | 17                  | 16   |
|-------|-------------------|----|------|--------------|-------|--------|----|----------------------------|----|----|----|-------------------|-----|--------|---------------------|------|
| Name  | FLAS<br>H_OU<br>T |    |      | FLAS<br>H_EN |       |        |    | FLAS<br>H_ST<br>ARTP<br>NT |    |    |    | FLAS<br>H_PO<br>L | FLA | ASH_LN | IUNIT[:             | 3:0] |
| Type  | R                 |    |      | RW           |       |        |    | RW                         |    |    |    | RW                |     | R۱     | W                   |      |
| Reset |                   |    |      | 0            |       |        |    | 0                          |    |    |    | 0_                |     | C      | )                   |      |
| Bit   | 15                | 14 | 13   | 12           | 11    | 10     | 9  | 8                          | 7  | 6  | 5  | 4                 | 3   | 2      | 1                   | 0    |
| Name  |                   |    | FLAS | H_LNU        | NIT_N | O[7:0] |    |                            |    |    |    |                   |     |        | FLAS<br>AME_<br>Y[1 | DELA |
| Type  |                   |    |      | R'           | W     |        |    |                            |    |    |    |                   |     |        | R\                  | W    |
| Reset |                   | •  |      | (            | )     |        | •  |                            |    |    |    |                   |     |        | (                   | )    |

FLASH\_OUT Flash out status

**FLASH\_EN** Flash enable

**FLASH\_STARTPNT** Flash start point

• Start from vsync start

1 Start from expdone

**FLASH\_POL** Flash line polarity

**FLASH\_LNUNIT** Flash line unit, 0~15 lines

**FLASH\_LNUNIT\_NO** Flash line unit count

FLASH\_FRAME\_DELAY Flash frame delay

### CAM +01D8h CAM RESET Register

### CAM\_RESET

| Bit   | 31 | 30  | 29    | 28   | 27   | 26      | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18   | 17 | 16                |
|-------|----|-----|-------|------|------|---------|----|----|----|----|----|----|----|------|----|-------------------|
| Name  |    |     |       |      |      |         |    |    |    |    |    |    | TG | STAT | US |                   |
| Type  |    |     |       |      |      |         |    |    |    |    |    |    |    | R    |    |                   |
| Reset |    |     |       |      |      |         |    |    |    |    |    |    |    |      |    |                   |
| Bit   | 15 | 14  | 13    | 12   | 11   | 10      | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2    | 1  | 0                 |
| Name  |    |     | ISP_F | RAME | COUN | IT[7:0] |    |    |    |    |    |    |    |      |    | ISP_<br>RES<br>ET |
| Type  |    | - 4 |       | R'   | W    |         |    |    |    |    |    |    |    |      |    | RW                |
| Reset |    |     | •     | (    | )    |         | •  |    |    |    |    |    |    |      |    | 0                 |

**ISP FRAME COUNT** ISP frame counter

**ISP\_RESET** ISP reset



## CAM +01DCh TG STATUS Register

# TG\_STATUS

| Bit   | 31 | 30 | 29 | 28           | 27 | 26 | 25 | 24 | 23   | 22    | 21     | 20   | 19 | 18 | 17 | 16 |
|-------|----|----|----|--------------|----|----|----|----|------|-------|--------|------|----|----|----|----|
| Name  |    |    |    | SYN_<br>VFON |    |    |    |    | LIN  | E_COL | JNT[11 | :0]  |    |    |    |    |
| Type  |    |    |    | R            |    |    |    |    |      | R     | 1      |      |    |    |    |    |
| Reset |    |    |    |              |    |    |    |    |      |       |        |      |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12           | 11 | 10 | 9  | 8  | 7    | 6     | 5      | 4    | 3  | 2  | 1  | 0  |
| Name  |    |    |    |              |    |    |    |    | PIXE | L_CO  | UNT[1  | 1:0] |    |    |    |    |
| Type  |    |    |    |              |    |    |    |    |      | R     | l      |      |    |    |    |    |
| Reset | ,  |    |    |              |    | •  |    | •  | •    |       | •      |      |    | 4  |    |    |

SYN\_VFON TG view finder status
LINE\_COUNT TG line counter
PIXEL\_COUNT TG pixel counter

### CAM+01E0h Histogram Boundary Control Register3

## CAM\_HIS2

| Bit   | 31 | 30 | 29 | 28   | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20 19  | 18 | 17 | 16 |
|-------|----|----|----|------|-----|----|----|----|----|----|----|--------|----|----|----|
| Name  |    |    |    | H6_I | BND |    |    |    |    |    |    | H7_BND |    |    |    |
| Type  |    |    |    | R/   | W   |    |    |    |    |    |    | R/W    |    |    |    |
| Reset |    |    |    | 60   | )h  |    |    |    |    |    |    | 70h    |    |    |    |
| Bit   | 15 | 14 | 13 | 12   | 11  | 10 | 9  | 8  | 7  | 6  | 5  | 4 3    | 2  | 1  | 0  |
| Name  |    |    |    | H8_I | BND |    |    |    |    |    |    | H9_BND |    |    |    |
| Type  |    |    |    | R/   | W   |    |    |    |    |    |    | R/W    |    |    |    |
| Reset |    |    |    | 80   | )h  |    |    |    |    |    |    | 90H    |    |    |    |

H6\_BNDHistogram level 6 up boundary valueH7\_BNDHistogram level 7 up boundary valueH8\_BNDHistogram level 8 up boundary valueH9\_BNDHistogram level 9 up boundary value

## CAM+01E4h Histogram Boundary Control Register4

### CAM\_HIS3

| Bit   | 31 | 30 | 29 | 28  | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20  | 19  | 18 | 17 | 16 |
|-------|----|----|----|-----|-----|----|----|----|----|----|----|-----|-----|----|----|----|
| Name  |    |    |    | HA_ | BND |    |    |    |    |    |    | HB_ | BND |    |    |    |
| Type  |    |    |    | R/  | W   |    |    |    |    |    |    | R   | W   |    |    |    |
| Reset |    |    |    | a(  | )h  |    |    |    |    |    |    | b   | 0h  |    |    |    |
| Bit   | 15 | 14 | 13 | 12  | 11  | 10 | 9  | 8  | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| Name  |    |    |    | HC_ | BND |    |    |    |    |    |    | HD_ | BND |    |    |    |
| Type  |    |    |    | R/  | W   |    |    |    |    |    |    | R   | W   |    |    |    |
| Reset |    |    |    | c(  | )h  |    |    | •  |    | •  | •  | d   | DΗ  | •  |    |    |

HA\_BND Histogram level A up boundary value
HB\_BND Histogram level B up boundary value
HC\_BND Histogram level C up boundary value
HD\_BND Histogram level D up boundary value

## CAM+01E8h Histogram Boundary Control Register5

### CAM\_HIS4

| Bit   | 31 | 30            | 29 | 28  | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20  | 19  | 18 | 17 | 16 |
|-------|----|---------------|----|-----|-----|----|----|----|----|----|----|-----|-----|----|----|----|
| Name  |    |               |    | HE_ | BND |    |    |    |    |    |    | HF_ | BND |    |    |    |
| Type  |    |               |    | R/  | W   |    |    |    |    |    |    | R/  | W   |    |    |    |
| Reset |    |               |    | e(  | )h  |    |    |    |    |    |    | f0  | )h  |    |    |    |
| Bit   | 15 | 14            | 13 | 12  | 11  | 10 | 9  | 8  | 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| Name  |    |               |    |     |     |    |    |    |    |    |    |     |     |    |    |    |
| Type  |    | $\overline{}$ |    |     |     |    |    |    |    |    |    |     |     |    |    |    |
| Reset |    |               |    |     |     |    |    |    |    |    |    |     |     |    |    |    |

HDE\_ND Histogram level E up boundary value



HEF ND

Histogram level F up boundary value

## CAM+01ECh CAM Histogram Result 6

## CAM\_HISRLT5

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

**CAM\_HISRLT6** Histogram level 6 count result

## CAM+01F0h CAM Histogram Result 7

### **CAM HISRLT6**

| 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24                  | 23                              | 22                      | 21                                           | 20                                             | 19                                               | 18                                                             | 17                 | 16                                                                             |
|----|----|----|----|----|----|-----|---------------------|---------------------------------|-------------------------|----------------------------------------------|------------------------------------------------|--------------------------------------------------|----------------------------------------------------------------|--------------------|--------------------------------------------------------------------------------|
|    |    |    |    |    |    |     |                     |                                 |                         |                                              | CAN                                            | /_HISR                                           | LT7[21                                                         | 1:16]              |                                                                                |
|    |    |    |    |    |    |     |                     |                                 |                         |                                              |                                                | R                                                | 0                                                              |                    |                                                                                |
|    |    |    |    |    |    |     |                     |                                 |                         |                                              |                                                |                                                  | )                                                              |                    |                                                                                |
| 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8                   | 7                               | 6                       | 5                                            | 4                                              | 3                                                | 2                                                              | 1                  | 0                                                                              |
|    |    |    |    |    |    | CAI | /I_HISF             | RLT7[15                         | 5:0]                    |                                              |                                                |                                                  |                                                                |                    |                                                                                |
|    |    |    |    |    |    |     | R                   | )                               |                         |                                              |                                                |                                                  |                                                                |                    |                                                                                |
|    |    |    |    |    |    |     | 0                   | )                               |                         |                                              |                                                |                                                  |                                                                |                    |                                                                                |
|    |    |    |    |    |    |     | 15 14 13 12 11 10 9 | 15 14 13 12 11 10 9 8  CAM_HISE | 15 14 13 12 11 10 9 8 7 | 15 14 13 12 11 10 9 8 7 6  CAM_HISRLT7[15:0] | 15 14 13 12 11 10 9 8 7 6 5  CAM_HISRLT7[15:0] | 15 14 13 12 11 10 9 8 7 6 5 4  CAM_HISRLT7[15:0] | 15 14 13 12 11 10 9 8 7 6 5 4 7 3  CAM_HISR  CAM_HISRLT7[15:0] | CAM_HISRLT7[2*  RO | CAM_HISRLT7[21:16] RO 0 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1  CAM_HISRLT7[15:0] |

**CAM\_HISRLT7** Histogram level 7 count result

## CAM+01F4h CAM Histogram Result 8

### CAM\_HISRLT7

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

**CAM\_HISRLT8** Histogram level 8 count result

## CAM+01F8h CAM Histogram Result 9

### **CAM HISRLT8**

|       |    |    |    |    | •   |    |     |               |        |      |    |     |        | _      | _    |    |
|-------|----|----|----|----|-----|----|-----|---------------|--------|------|----|-----|--------|--------|------|----|
| Bit   | 31 | 30 | 29 | 28 | 27  | 26 | 25  | 24            | 23     | 22   | 21 | 20  | 19     | 18     | 17   | 16 |
| Name  |    |    |    |    |     |    |     |               |        |      |    | CAM | I_HISR | LT9[21 | :16] |    |
| Type  |    |    |    |    |     |    |     |               |        |      |    |     | R      | 0      |      |    |
| Reset |    |    |    |    |     |    |     |               |        |      |    |     | C      | )      |      |    |
| Bit   | 15 | 14 | 13 | 12 | 11  | 10 | 9   | 8             | 7      | 6    | 5  | 4   | 3      | 2      | 1    | 0  |
| Name  |    |    |    |    | 1/2 | ,  | CAI | <b>M_HISF</b> | RLT9[1 | 5:0] |    |     |        |        |      |    |
| Type  |    |    |    |    |     |    |     | R             | 0      | _    |    |     |        |        |      |    |
| Reset |    |    |    |    |     |    |     | C             | )      |      |    |     |        |        |      |    |

**CAM\_HISRLT9** Histogram level 9 count result

## CAM+01FCh CAM Histogram Result 10

## **CAM\_HISRLT9**

| Bit           | 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24      | 23    | 22   | 21 | 20  | 19    | 18     | 17   | 16 |  |  |  |  |  |
|---------------|----|----|----|----|----|----|-----|---------|-------|------|----|-----|-------|--------|------|----|--|--|--|--|--|
| Name          |    |    |    |    |    |    |     |         |       |      |    | CAM | _HISR | LTA[21 | :16] |    |  |  |  |  |  |
| Type          |    |    |    |    |    |    |     |         |       |      |    |     | R     | 0      |      |    |  |  |  |  |  |
| Reset         |    |    |    |    |    |    |     |         |       |      | 0  |     |       |        |      |    |  |  |  |  |  |
| Bit           | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8       | 7     | 6    | 5  | 4   | 3     | 2      | 1    | 0  |  |  |  |  |  |
| Name          |    |    |    |    |    |    | CAN | /I_HISF | LTA[1 | 5:0] |    |     |       |        |      |    |  |  |  |  |  |
| Type<br>Reset |    |    |    |    |    |    |     | R       | 0     |      |    |     |       |        |      |    |  |  |  |  |  |
| Reset         |    |    |    |    | •  | •  |     | C       | )     |      | •  | •   |       | •      |      |    |  |  |  |  |  |



#### **CAM\_HISRLTA** Histogram level 10 count result

## CAM+0200h CAM Histogram Result 11

## **CAM HISRLTA**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24             | 23    | 22   | 21 | 20  | 19     | 18    | 17    | <u> 16</u> √ |
|-------|----|----|----|----|----|----|-----|----------------|-------|------|----|-----|--------|-------|-------|--------------|
| Name  |    |    |    |    |    |    |     |                |       |      |    | CAM | _HISRI | LTB[2 | 1:16] |              |
| Type  |    |    |    |    |    |    |     |                |       |      |    |     | R      | )     |       |              |
| Reset |    |    |    |    |    |    |     |                |       |      |    |     | 0      | )     |       |              |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8              | 7     | 6    | 5  | 4   | 3      | 2     | 1     | 0            |
| Name  |    |    |    |    |    |    | CAN | <u>/I_HISR</u> | LTB[1 | 5:0] |    |     |        |       |       |              |
| Type  |    |    |    |    |    |    |     | R              | 0     |      |    |     |        |       |       |              |
| Reset |    |    |    |    |    |    |     | C              | )     |      |    |     |        |       |       |              |

**CAM\_HISRLTB** Histogram level 11 count result

## CAM+0204h CAM Histogram Result 12

## CAM\_HISRLTB

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24      | 23    | 22   | 21 | 20  | 19   | 18      | 17  | 16 |
|-------|----|----|----|----|----|----|-----|---------|-------|------|----|-----|------|---------|-----|----|
| Name  |    |    |    |    |    |    |     |         |       |      |    | CAM | HISR | LTC[21: | 16] |    |
| Type  |    |    |    |    |    |    |     |         |       |      |    |     | R    | )       |     |    |
| Reset |    |    |    |    |    |    |     |         |       |      |    |     | 0    |         |     |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8       | 7     | 6    | 5  | 0.4 | 3    | 2       | 1   | 0  |
| Name  |    |    |    |    |    |    | CAN | /I_HISR | LTC[1 | 5:0] |    |     |      |         |     |    |
| Type  |    |    |    |    |    |    |     | R       | 0     |      |    |     |      |         |     |    |
| Reset |    |    |    |    |    |    |     | C       | )     |      |    |     |      |         |     |    |

**CAM\_HISRLTC** Histogram level 12 count result

## CAM+0208h CAM Histogram Result 13

## **CAM\_HISRLTC**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24     | 23    | 22   | 21 | 20  | 19     | 18     | 17    | 16 |
|-------|----|----|----|----|----|----|-----|--------|-------|------|----|-----|--------|--------|-------|----|
| Name  |    |    |    |    |    |    |     |        |       |      |    | CAM | _HISRI | LTD[21 | 1:16] |    |
| Type  |    |    |    |    |    |    |     |        |       |      |    |     | R      | С      |       |    |
| Reset |    |    |    |    |    |    |     |        |       |      |    |     | 0      | )      |       |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8 🗇    | 7     | 6    | 5  | 4   | 3      | 2      | 1     | 0  |
| Name  |    |    |    |    |    |    | CAI | I_HISR | LTD[1 | 5:0] |    |     |        |        |       |    |
| Type  |    |    |    |    |    |    |     | R      | O C   |      |    |     |        |        |       |    |
| Reset |    |    |    |    |    |    |     | 0      | )     |      |    |     |        |        |       |    |

**CAM\_HISRLTD** Histogram level 13 count result

## CAM+020Ch CAM Histogram Result 14

### **CAM\_HISRLTD**

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

**CAM\_HISRLTE** Histogram level 14 count result

## CAM+0210h ▲ CAM Histogram Result 15

### **CAM HISRLTE**

| Bit          | 31 | 30       | 29 | 28 | 27 | 26 | 25  | 24      | 23     | 22   | 21     | 20  | 19     | 18     | 17   | 16 |  |  |  |  |
|--------------|----|----------|----|----|----|----|-----|---------|--------|------|--------|-----|--------|--------|------|----|--|--|--|--|
| Name         |    |          |    |    |    |    |     |         |        |      |        | CAN | I_HISR | LTF[21 | :16] |    |  |  |  |  |
| Type         |    |          |    |    |    |    |     |         |        |      | RO     |     |        |        |      |    |  |  |  |  |
| Reset        |    |          |    |    |    |    |     |         |        |      | 0<br>0 |     |        |        |      |    |  |  |  |  |
| Bit          | 15 | 14       | 13 | 12 | 11 | 10 | 9   | 8       | 7      | 6    | 5      | 4   | 3      | 2      | 1    | 0  |  |  |  |  |
| Name<br>Type |    | 6        |    |    |    |    | CAI | /I_HISF | RLTF[1 | 5:0] |        |     |        |        |      |    |  |  |  |  |
| Type         |    | <u> </u> |    |    |    |    |     | R       | 0      |      |        |     |        |        |      |    |  |  |  |  |



Reset 0

**CAM\_HISRLTF** Histogram level 15 count result

## CAM+00214h Shading Cotrol 1 Register

## CAM\_SHADING

| Bit   | 31   | 30                           | 29    | 28                 | 27 | 26                        | 25 | 24 | 23    | 22    | 21   | 20      | 19 | 18 | 17 | 16 |  |  |
|-------|------|------------------------------|-------|--------------------|----|---------------------------|----|----|-------|-------|------|---------|----|----|----|----|--|--|
| Name  |      | SHAD<br>ING_<br>RANG<br>E[8] | 11144 | SHAD<br>ING_E<br>N |    |                           |    |    | SHADI | NG_CE | NTER | Y[11:0] |    |    |    |    |  |  |
| Type  |      | RW                           | RW    | RW                 |    |                           |    |    |       | R\    | W    |         |    |    |    |    |  |  |
| Reset |      | 0                            | 0     | 0                  |    |                           |    |    |       | (     | )    |         |    | u  |    |    |  |  |
| Bit   | 15   | 14                           | 13    | 12                 | 11 | 10                        | 9  | 8  | 7     | 6     | 5    | 4       | 3  | 2  | 1  | 0  |  |  |
| Name  | K_FA | CTOR                         | RADIU | JS_FA<br>OR        |    |                           |    |    | SHADI | NG_CE | NTER | X[11:0] |    |    |    |    |  |  |
| Туре  | R/   | W                            | R/    | W                  |    | SHADING_CENTERX[11:0]  RW |    |    |       |       |      |         |    |    |    |    |  |  |
| Reset | (    | )                            | (     | )                  | •  |                           | •  |    | •     | (     | )    |         |    |    | •  | •  |  |  |

**SHADING\_RANGE[8]** Shading range bit 8

**SHADING\_RANGE\_EN** Shading range enable

SHADING\_EN Shading enable

Shading\_out = Shading\_in\*(1+Compensation\_Ratio)

Where Compensation\_Ratio = Effective\_Range\*(K>>(26-K\_FACTOR))

K = KR when R pixel, KG when G pixel, KB when B pixel

**K\_FACTOR** Shading parameter factor, used to scale up parameter.

**RADIUS\_FACTOR** Radius factor, select effective radius range.

Effective\_Range =  $((effective\_diffx)^2) + ((effective\_diffy)^2)$ 

Where effective\_diffx =  $(x-centerx) >> (3-RADIUS_FACTOR)$ 

effective\_diffy = (y-centery)>>(3-RADIUS\_FACTOR)

Because of hardware limitation,

effective maximum radius(range between center) is

**00** Effective maximum radius : 4095

**01** Effective maximum radius : 2047

**O2** Effective maximum radius : 1023

**03** Effective maximum radius: 511

**SHADING\_CENTERY** Shading center y coordinate x 2

**SHADING\_CENTERX** Shading center x coordinate x 2

## CAM+0218h Shading Control 2 Register

**CAM\_SHADING** 

2

| Bit  | 31 | 30 | 29 | 28     | 27 | 26         | 25 | 24 | 23 | 22 | 21 | 20           | 19    | 18  | 17 | 16 |
|------|----|----|----|--------|----|------------|----|----|----|----|----|--------------|-------|-----|----|----|
| Name |    |    | SH | IADING |    | <b>:0]</b> |    |    |    |    | SH | <b>ADING</b> | _KG[7 | :0] |    |    |
| Type |    |    |    | R      | W  |            |    |    |    |    |    | R\           | Ν     |     |    |    |





| Reset |    |    |    | (      | )     |             |   |   |   |   |      | (      | )     |       |   |   |
|-------|----|----|----|--------|-------|-------------|---|---|---|---|------|--------|-------|-------|---|---|
| Bit   | 15 | 14 | 13 | 12     | 11    | 10          | 9 | 8 | 7 | 6 | 5    | 4      | 3     | 2     | 1 | 0 |
| Name  |    |    | SH | IADING | LKB[7 | <b>:</b> 0] |   |   |   |   | SHAI | DING_F | RANGE | [7:0] |   |   |
| Type  |    |    |    | R'     | W     |             |   |   |   |   |      | R/     | W     |       |   |   |
| Reset |    |    |    | (      | )     |             |   |   |   |   |      | F      | f     |       |   |   |

SHADING\_KR Shading R pixel parameter

**SHADING\_KG** Shading G pixel parameter

**SHADING\_KB** Shading B pixel parameter

**SHADING\_RANGE** Shading range, bit8 refer to 0x214 bit 30

## CAM+021Ch Shading R Curve Register 1

CAM\_SRCURV

E<sub>0</sub>

| Bit   | 31                  | 30 | 29 | 28                           | 27    | 26                  | 25   | 24            | 23 | 22 | 21                   | 20     | 19     | 18 | 17 | 16 |
|-------|---------------------|----|----|------------------------------|-------|---------------------|------|---------------|----|----|----------------------|--------|--------|----|----|----|
| Name  |                     |    |    | SHAD<br>ING_<br>CURV<br>E_EN |       | SHAD<br>ING_I<br>VT | SHAD | ING_C<br>_SEL |    |    | S                    | SHADIN | IG_R_E | 31 |    |    |
| Туре  |                     |    |    | R/W                          |       | R/W                 | R/   | W             |    |    |                      | 7 R    | /W     |    |    |    |
| Reset |                     |    |    |                              |       |                     |      |               |    |    |                      | 2      | 0h     |    |    |    |
| Bit   | 15 14 13 12 11 10 9 |    |    |                              |       |                     |      |               | 7  | 6  | 5                    | 4      | 3      | 2  | 1  | 0  |
| Name  |                     |    | S  | HADIN                        | G_R_E | 32                  |      |               |    |    | 7.                   | HADIN  | IG_R_E | 33 |    |    |
| Type  |                     |    |    | R/                           | W     |                     |      |               |    |    | $\overline{\lambda}$ | R      | /W     |    |    |    |
| Reset |                     |    |    | 40                           | )h    |                     |      |               |    |    | 5 —                  | 6      | 0h     |    |    |    |

**SHADING\_CURVE\_EN** Shading curve enable

SHADING\_IVT Shading curve output invert
SHADING\_CURVE\_SEL Shading curve input selection

1/8 Effective\_Range input
1/4 Effective\_Range input
1/2 Effective\_Range input
Effective Range input

SHADING\_R\_B1 R shading curve operating B1 value
SHADING\_R\_B2 R shading curve operating B2 value
SHADING\_R\_B3 R shading curve operating B3 value

## CAM+0220h Shading R Curve Register 2

CAM\_SRCURV

=1

| Bit   | 31 | 30 | 29 | 28    | 27     | 26 | 25 | 24 | 23 | 22 | 21 | 20    | 19    | 18       | 17 | 16 |
|-------|----|----|----|-------|--------|----|----|----|----|----|----|-------|-------|----------|----|----|
| Name  |    |    | S  | HADIN | IG_R_I | 34 |    |    |    |    | S  | HADIN | G_R_E | <b>5</b> |    |    |
| Type  |    |    |    | R     | /W     |    |    |    |    |    |    | R/    | W     |          |    |    |
| Reset |    |    |    | 8     | 0h     |    |    |    |    |    |    | 90    | )h    |          |    |    |
| Bit   | 15 | 14 | 13 | 12    | 11     | 10 | 9  | 8  | 7  | 6  | 5  | 4     | 3     | 2        | 1  | 0  |
| Name  |    |    | S  | HADIN | IG_R_E | 36 |    |    |    |    | S  | HADIN | G_R_E | 37       |    |    |
| Type  |    |    |    | , R   | /W     |    |    |    |    |    |    | R/    | W     |          |    |    |
| Reset |    |    |    | A     | 0h     |    |    |    |    |    |    | В     | )h    |          |    |    |

SHADING\_R\_B4

SHADING\_R\_B5

SHADING\_R\_B6

R shading curve operating B4 value
R shading curve operating B5 value
R shading curve operating B6 value
SHADING\_R\_B7

R shading curve operating B7 value



## CAM+0224h Shading R Curve Register 3

## **CAM\_SRCURV**

**E**2

| Bit   | 31 | 30 | 29 | 28     | 27    | 26 | 25 | 24 | 23 | 22 | 21 | 20     | 19    | 18 | 17 | 16 |
|-------|----|----|----|--------|-------|----|----|----|----|----|----|--------|-------|----|----|----|
| Name  |    |    | S  | HADIN  | G_R_E | 88 |    |    |    |    | S  | HADIN  | G_R_E | 39 |    |    |
| Type  |    |    |    | R/     | W     |    |    |    |    |    |    | R/     | W     |    |    |    |
| Reset |    |    |    | C      | 0h    |    |    |    |    |    |    | D      | )h    |    |    |    |
| Bit   | 15 | 14 | 13 | 12     | 11    | 10 | 9  | 8  | 7  | 6  | 5  | 4      | 3     | 2  | 1  | 0  |
| Name  |    |    | SI | HADING | G_R_B | 10 |    |    |    |    | SI | HADING | G_R_B | 11 |    |    |
| Type  |    |    |    | R/     | W     |    |    |    |    |    |    | R/     | W     |    |    |    |
| Reset |    | •  |    | E      | 0h    |    |    | •  |    | •  |    | F(     | )h    |    |    |    |

SHADING\_R\_B8R shading curve operating B8 valueSHADING\_R\_B9R shading curve operating B9 valueSHADING\_R\_B10R shading curve operating B10 valueSHADING\_R\_B11R shading curve operating B11 value

## CAM+0228h Shading G Curve Register 1

CAM\_SGCURV

E0

| Bit   | 31 | 30 | 29 | 28    | 27    | 26 | 25 | 24 | 23 | 22 | 21                        | 20    | 19      | 18 | 17 | 16 |
|-------|----|----|----|-------|-------|----|----|----|----|----|---------------------------|-------|---------|----|----|----|
| Name  |    |    | S  | HADIN | G_G_E | 81 |    |    |    |    | S                         | HADIN | $G_G_I$ | 32 |    |    |
| Type  |    |    |    | R/    | W     |    |    |    |    |    | $\mathbb{Z}^{\mathbb{Z}}$ | R     | W       |    |    |    |
| Reset |    |    |    | 20    | )h    |    |    |    |    |    | 2                         | 40    | )h      |    |    |    |
| Bit   | 15 | 14 | 13 | 12    | 11    | 10 | 9  | 8  | 7  | 6  | 5                         | 4     | 3       | 2  | 1  | 0  |
| Name  |    |    | S  | HADIN | G_G_E | 33 |    |    |    |    | S                         | HADIN | G_G_I   | 34 |    |    |
| Type  |    |    |    | R/    | W     |    |    |    |    |    |                           | R     | W       |    |    |    |
| Reset |    |    |    | 60    | )h    |    |    |    | -  |    |                           | 8     | )h      |    |    |    |

SHADING\_G\_B1 G shading curve operating B1 value
SHADING\_G\_B2 G shading curve operating B2 value
SHADING\_G\_B3 G shading curve operating B3 value
SHADING\_G\_B4 G shading curve operating B4 value

## CAM+022Ch Shading G Curve Register 2

**CAM\_SGCURV** 

E1

| Bit   | 31 | 30 | 29 | 28    | 27      | 26 | 25    | 24 | 23 | 22 | 21 | 20    | 19    | 18 | 17 | 16 |
|-------|----|----|----|-------|---------|----|-------|----|----|----|----|-------|-------|----|----|----|
| Name  |    |    | S  | HADIN | G_G_I   | 35 | Y / / |    |    |    | S  | HADIN | G_G_E | 36 |    |    |
| Type  |    |    |    | R/    | W       |    |       |    |    |    |    | R/    | W     |    |    |    |
| Reset |    |    |    | 90    | )h      |    |       |    |    |    |    | A     | 0h    |    |    |    |
| Bit   | 15 | 14 | 13 | 12    | 11      | 10 | 9     | 8  | 7  | 6  | 5  | 4     | 3     | 2  | 1  | 0  |
| Name  |    |    | S  | HADIN | $G_G_I$ | 37 |       |    |    |    | S  | HADIN | G_G_E | 88 |    |    |
| Type  |    |    |    | R/    | W       |    |       |    |    |    |    | R/    | W     |    |    |    |
| Reset |    |    |    | B     | )h      |    |       |    |    |    |    | C     | 0h    |    |    |    |

SHADING\_G\_B5
G shading curve operating B5 value
SHADING\_G\_B6
G shading curve operating B6 value
G shading curve operating B7 value
G shading curve operating B7 value
G shading curve operating B8 value

## CAM+0230h Shading G Curve Register 3

**CAM\_SGCURV** 

:2

| Bit   | 31 | 30 | 29 | 28    | 27    | 26 | 25 | 24 | 23 | 22 | 21 | 20    | 19  | 18 | 17 | 16 |
|-------|----|----|----|-------|-------|----|----|----|----|----|----|-------|-----|----|----|----|
| Name  |    |    | S  | HADIN | G_G_E | 9  |    |    |    |    | SI | ADING | G_B | 10 |    |    |
| Type  |    |    |    | R/    | W     |    |    |    |    |    |    | R/    | W   |    |    |    |
| Reset | 27 |    |    | D     | )h    |    |    |    |    |    |    | E     | )h  |    |    |    |





| Bit   | 15 | 14 | 13 | 12    | 11  | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|-------|-----|----|---|---|---|---|---|---|---|---|---|---|
| Name  |    |    | SH | ADING | G_B | 11 |   |   |   |   |   |   |   |   |   |   |
| Type  |    |    |    | R/    | W   |    |   |   |   |   |   |   |   |   |   |   |
| Reset |    |    |    | F(    | )h  | •  |   |   |   |   |   |   |   |   |   |   |

SHADING\_G\_B9 G shading curve operating B9 value
SHADING\_G\_B10 G shading curve operating B10 value
SHADING\_G\_B11 G shading curve operating B11 value

## CAM+0234h Shading B Curve Register 1

CAM\_SBCURV

E0

| Bit   | 31 | 30 | 29 | 28    | 27    | 26 | 25 | 24 | 23 | 22 | 21 | 20    | 19     | 18 | 17 | 16 |
|-------|----|----|----|-------|-------|----|----|----|----|----|----|-------|--------|----|----|----|
| Name  |    |    | S  | HADIN | G_B_B | 81 |    |    |    |    | S  | HADIN | IG_B_E | 2  |    |    |
| Type  |    |    |    | R/    | W     |    |    |    |    |    |    | R     | /W     |    |    |    |
| Reset |    |    |    | 20    | )h    |    |    |    |    |    |    | 4     | 0h     |    |    |    |
| Bit   | 15 | 14 | 13 | 12    | 11    | 10 | 9  | 8  | 7  | 6  | 5  | 4     | 3      | 2  | 1  | 0  |
| Name  |    |    | S  | HADIN | G_B_B | 3  |    |    |    |    | S  | HADIN | G_B_B  | 34 |    |    |
| Type  |    |    |    | R/    | W     |    |    |    |    |    |    | R     | W      |    |    |    |
| Reset |    |    | •  | 60    | )h    | •  | •  |    |    | •  | •  | 8     | 0h     |    | •  | •  |

SHADING\_B\_B1

SHADING\_B\_B2

SHADING\_B\_B3

SHADING\_B\_B4

B shading curve operating B1 value
B shading curve operating B2 value
B shading curve operating B3 value
B shading curve operating B4 value

## CAM+0238h Shading B Curve Register 2

CAM\_SGCURV

**E**1

| Bit   | 31 | 30 | 29 | 28    | 27    | 26        | 25 | 24  | 23           | 22 | 21 | 20    | 19    | 18 | 17 | 16 |
|-------|----|----|----|-------|-------|-----------|----|-----|--------------|----|----|-------|-------|----|----|----|
| Name  |    |    | S  | HADIN | G_B_E | 35        |    |     |              |    | S  | HADIN | G_B_E | 36 |    |    |
| Type  |    |    |    | R/    | W     |           |    |     |              |    |    | R/    | W     |    |    |    |
| Reset |    |    |    | 90    | )h    |           |    |     |              |    |    | A     | 0h    |    |    |    |
| Bit   | 15 | 14 | 13 | 12    | 11    | 10        | 9  | 8   | □ <u>)</u> 7 | 6  | 5  | 4     | 3     | 2  | 1  | 0  |
| Name  |    |    | S  | HADIN | G_B_E | <b>37</b> | 4  | 1/2 |              |    | S  | HADIN | G_B_E | 38 |    |    |
| Type  |    |    |    | R/    |       |           |    | 1   |              |    |    | R/    | W     |    |    |    |
| Reset |    |    |    | B     | )h    |           |    |     |              |    |    | С     | 0h    |    |    |    |

SHADING\_B\_B5 G shading curve operating B5 value
SHADING\_B\_B6 G shading curve operating B6 value
SHADING\_B\_B7 G shading curve operating B7 value
SHADING\_B\_B8 G shading curve operating B8 value

## CAM+023Ch Shading B Curve Register 3

CAM\_SBCURV

**E2** 

| Bit   | 31 | 30 | 29 | 28        | 27    | 26  | 25 | 24 | 23 | 22 | 21 | 20     | 19    | 18 | 17 | 16 |
|-------|----|----|----|-----------|-------|-----|----|----|----|----|----|--------|-------|----|----|----|
| Name  |    |    | S  | HADIN     | G_B_I | 39  |    |    |    |    | SI | HADING | 3_B_B | 10 |    |    |
| Type  |    |    |    | R/        | W     |     |    |    |    |    |    | R/     | W     |    |    |    |
| Reset |    |    |    | <u>D(</u> | )h    |     |    |    |    |    |    | E(     | )h    |    |    |    |
| Bit   | 15 | 14 | 13 | 12        | 11    | 10  | 9  | 8  | 7  | 6  | 5  | 4      | 3     | 2  | 1  | 0  |
| Name  |    |    | SH | HADING    | 3_B_E | 811 |    |    |    |    |    |        |       |    |    |    |
| Type  |    |    |    | R/        | W     |     |    |    |    |    |    |        |       |    |    |    |
| Reset |    |    |    | FC        | )h    |     |    |    |    |    |    |        |       |    |    |    |

SHADING B B9

B shading curve operating B9 value

B shading curve operating B10 value

SHADING B B11

B shading curve operating B11 value



### CAM+0240h CAM IMAGE-PROCOR HUE Register 1

## **CAM HUE0**

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

## CAM+0244h CAM IMAGE-PROCOR HUE Register 2

### **CAM HUE1**

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

#### **HUE EN** Hue enable

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_0 \\ 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.

**HUE11** The coefficient C11 of the transformation matrix in 2's complement format.

**HUE12** The coefficient C12 of the transformation matrix in 2's complement format.

**HUE21** The coefficient C21 of the transformation matrix in 2's complement format.

**HUE22** The coefficient C22 of the transformation matrix in 2's complement format.

### CAM +0248h CAM GMC DEBUG 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  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

## CAM +024Ch CAM VERSION Register

### CAM\_VERSION

| D:+ O   | 0.0 |    |    | 07 |    | 25 |    | 00 | 22 | 01 |    | - 10 | 10 |      | ,  |
|---------|-----|----|----|----|----|----|----|----|----|----|----|------|----|------|----|
| I Bit 3 |     | 29 | 28 | ツ/ | 26 |    | 24 |    |    |    | 20 | 19   | 18 | 1 1/ | 16 |
| Dit     |     |    |    |    |    | 20 |    | 20 |    |    |    | 10   | 10 |      |    |
|         |     |    |    |    |    |    |    |    |    |    |    |      |    |      |    |



| III EDIATE | <u> </u> |            |    |      |         |    |   |   |   |   |   |      |        |   |   |                  |
|------------|----------|------------|----|------|---------|----|---|---|---|---|---|------|--------|---|---|------------------|
| Name       |          | YEAR[16:0] |    |      |         |    |   |   |   |   |   |      |        |   |   |                  |
| Type       |          | R          |    |      |         |    |   |   |   |   |   |      |        |   |   |                  |
| Reset      |          |            |    |      |         |    |   |   |   |   |   |      |        |   |   |                  |
| Bit        | 15       | 14         | 13 | 12   | 11      | 10 | 9 | 8 | 7 | 6 | 5 | 4    | 3      | 2 | 1 | 0                |
| Name       |          |            |    | MONT | H[15:0] |    |   |   |   |   |   | DATE | [15:0] |   |   | $\overline{A}$ 1 |
| Type       |          |            |    | F    | 7       |    |   |   |   |   |   |      | R      |   |   |                  |
| Reset      |          |            | •  | •    | •       |    | • |   |   |   | • | •    | •      | • |   |                  |

YEAR Year ASCII
MONTH Month ASCII
DATE Date ASCII

## 6.15 Image DMA

## 6.15.1 General Description

Image DMA plays the role of moving image data between different image modules and memory. illustrates the interconnections around Image DMA. The major functions of Image DMA are list below.

- Data movement
- Color format conversion (RGB565 ⇔ RGB888, YUV444 ⇔ YUV420, YUV444 ⇒ YUV422)
- Data stream flow control on JPEG Encoder DMA
- Auto double buffer switching for video capture/playback
- Hardware handshaking with LCD DMA, and direct couple interface to LCD DMA
- Image panning
- Supporting BMP image file formats.

Image DMA consists of nine DMA engines. They are JPEG Encode DMA, Video Encode DMA, Video Decode DMA, Image Buffer Write 1 DMA (IBW1 DMA), Image Buffer Write 2 DMA (IBW2 DMA), Image Buffer Write 3 DMA (IBW3 DMA), Image Buffer Write 4 DMA (IBW4 DMA), Image Buffer Read 1 DMA (IBR1 DMA), and Image Buffer Read 2 DMA (IBR2 DMA). Each DMA engine has specific purposes. The details of each DMA engine are described in following sections.





Figure 30 inter-connection around Image DMA

### 6.15.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 YUV422/ YUV420 data to JPEG Encoder by 8 X 8 blocks.

#### 6.15.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 capturing from the 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 the Image Signal Process and Capture Resize modules.

#### 6.15.1.1.2 Data format conversion

Since the JPEG encoder needs data of signed 2's complement format. The JPEG Encoder DMA takes the responsibility to handle the data format conversion. Each of Y, U, or V component values of input data is of 8-bit unsigned format, which represents a value ranging from 0 to 255. The component value of the data is converted into 8-bit 2's complement format, which represents a value ranging from –128 to 127.

#### 6.15.1.1.3 Padding

For pictures whose frame size are not multiples of  $16 \times 8$  blocks for YUV422 mode or  $16 \times 16$  blocks for YUV420 mode, 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 multiples of 8 for YUV422 mode or 16 for YUV420 mode in vertical direction. An example of YUV422 mode is illustrated in . In this case, the original frame size is  $(16n + 13) \times (8n + 6)$ , which is not multiple of  $16 \times 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 31 Frame Padding for YUV422 mode

#### 6.15.1.1.4 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 YUV422 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 or 16 X 16 block in normal mode.

#### 6.15.1.1.5 Auto-Restart

To overlap the Codec processing time with that of file system manipulations, an Auto-Restart mode is designed. JPEG Encoder DMA automatically restarts itself to receive next frame without being re-configured and re-enabled by MCU. This can enhance the Shot-to-Shot Delay performance a lot since the file system manipulations would take a long time. JPEG Encoder DMA will not stop transfer until it is disabled by MCU. Note that associated settings must be programmed in the Capture/Post Resize and other Image Engines as well.

#### 6.15.1.2 Video Encode DMA

The main function of the Video Encode DMA is to move data from Capture Resize to Video Buffer. 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.

For MPEG4/H.263 encoding, Video Encode DMA receives data from Capture Resize, 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.

#### 6.15.1.2.1 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. 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 Capture Resize and Image Engine as well.



#### 6.15.1.3 Video Decode DMA

The main function of the Video Decode DMA is to move data from Video Buffer to Post Resize. Video Buffer is used to contain YUV420 image data after MPEG4/H.263 codec. It consists of three continuous memory buffers for Y, U, and V component data. Data format for the Post Resize is YUV444, and therefore color format conversion is needed during data movement.

For MPEG4/H.263 decoding, MPEG4/H.263 decoder writes out decoded data to video buffer, and Video Decode DMA is then triggered by software to move data to the Post Resize.

### 6.15.1.4 Image Buffer Write 1, 2 DMA

The main function of IBW1, IBW2 DMA is to move RGB data from Image Engine to memory or LCD, and the format of the written data is RGB565 or RGB888. 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. Besides, IBW1 also plays the role of writing local display under videophone scenario.

#### 6.15.1.4.1 Auto-Restart

IBW1, IBW2 DMA can restart itself to receive next frame, and switch base address at every restart.

#### 6.15.1.4.2 Hardware Handshake with LCD DMA

IBW1, 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.15.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 IBW1, IBW2 DMA and LCD, as depicted in , and consists of request, acknowledge, and 24-bit data bus. In this mode, frame data skips the frame buffer and are written to LCD directly. LCD 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.15.1.4.4 Image Panning

IBW1, IBW2 DMA can grab a part of the image frame as a new image, as illustrated in . 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, IMGDMA\_IBW2\_CON.

#### 6.15.1.4.5 Destination Pitch

To write the memory, a pitch register is defined to indicate the memory address jump per line for each base address. This can save memory usage when writing a rectangular area of a LCD layer.

### 6.15.1.5 Image Buffer Write 3,4 DMA

The main function of IBW3 DMA is to move data from a Pixel Image Engine to the DRZ, and the format is YUV444 or RGB888. IBW3 provides the route for thumbnail image dumping. The main function of IBW4 DMA is to move data from a Pixel Image Engine to the PRZ, and the format is YUV444 or RGB888. IBW4 provides the route for preview scenario.



#### 6.15.1.5.1 Auto-Restart

IBW3 DMA can restart itself to receive next frame.

### 6.15.1.6 Image Buffer Read 1 DMA

The main function of IBR1 DMA is to move RGB data from memory to Image Post Processor. The data format to Image Post Processor is RGB888 and the data formats from memory can be RGB565, RGB888 and BGR888 (which support BMP data format). The data placement in memory is illustrated in .

With IBR1 DMA, RGB image data in memory can be directly used for video encoding, JPEG encoding, and image panning.



Figure 32 RGB data in memory

### 6.15.1.7 Image Buffer Read 2 DMA

The main function of IBR2 DMA is to read photo frame from memory, resize it to the capturing image size, look-up palette table and overlay it onto the capturing image. The photo frame mask data format can be 1, 2, 4, 8-bpp color index modes. A 256-entries in 24-bit YUV format palette provides a color index to color value lookup table.

#### 6.15.1.7.1 Auto-Restart

IBR2 DMA can restart itself to read the same photo frame again and again while video capture scenario.

## 6.15.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  $\rightarrow$  Capture Resize  $\rightarrow$  Image Engine  $\rightarrow$  Video DMA  $\rightarrow$  Video Buffer. Video DMA has to be enabled before Image Processor, Capture Resize and Camera module.

The second example is video playback. The data path is Video Buffer  $\rightarrow$  Video DMA  $\rightarrow$  Post Resize  $\rightarrow$  IPP Engine  $\rightarrow$  IBW2 DMA  $\rightarrow$  LCD frame buffer. IBW2 DMA has to be enabled before Post Resize and Image Engine and then Video DMA.

## 6.15.3 Register Definitions

| Register Address | Register Function         | Acronym    |
|------------------|---------------------------|------------|
| IMGDMA + 0000h   | Image DMA Status Register | IMGDMA_STA |



| MEDIATEK       |                                            |                       |
|----------------|--------------------------------------------|-----------------------|
| 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        | IMGDMA_JPEG_FFWRLIDX  |
| IMGDMA + 0138h | JPEG FIFO Read Line Index Register         | IMGDMA_JPEG_FFRDLIDX  |
| IMGDMA + 0200h | Video Encode DMA Start Register            | IMGDMA_VDOENC_STR     |
| IMGDMA + 0204h | Video Encode DMA Control Register          | IMGDMA_VDOENC_CON     |
| IMGDMA + 0210h | Video Encode DMA Y Base Address 1 Register | IMGDMA_VDOENC_Y_BASE1 |
| IMGDMA + 0214h | Video Encode DMA U Base Address 1 Register | IMGDMA_VDOENC_U_BASE1 |
| IMGDMA + 0218h | Video Encode DMA V Base Address 1 Register | IMGDMA_VDOENC_V_BASE1 |
| IMGDMA + 0220h | Video Encode DMA Y Base Address 2 Register | IMGDMA_VDOENC_Y_BASE2 |
| IMGDMA + 0224h | Video Encode DMA U Base Address 2 Register | IMGDMA_VDOENC_U_BASE2 |
| IMGDMA + 0228h | Video Encode DMA V Base Address 2 Register | IMGDMA_VDOENC_V_BASE2 |
| IMGDMA + 0230h | Video Encode DMA Horizontal Size Register  | IMGDMA_VDOENC_HSIZE   |
| IMGDMA + 0234h | Video Encode DMA Vertical Size Register    | IMGDMA_VDOENC_VSIZE   |
| IMGDMA + 0238h | Video Encode DMA Horizontal Count Register | IMGDMA_VDOENC_HCNT    |
| IMGDMA + 023Ch | Video Encode DMA Vertical Count Register   | IMGDMA_VDOENC_VCNT    |
| IMGDMA + 0280h | Video Decode DMA Start Register            | IMGDMA_VDODEC_STR     |
| IMGDMA + 0284h | Video Decode DMA Control Register          | IMGDMA_VDODEC_CON     |
| IMGDMA + 0290h | Video Decode DMA Y Base Address 1 Register | IMGDMA_VDODEC_Y_BASE1 |
| IMGDMA + 0294h | Video Decode DMA U Base Address 1 Register | IMGDMA_VDODEC_U_BASE1 |
| IMGDMA + 0298h | Video Decode DMA V Base Address 1 Register | IMGDMA_VDODEC_V_BASE1 |
| IMGDMA + 02A0h | Video Decode DMA Y Base Address 2 Register | IMGDMA_VDODEC_Y_BASE2 |
| IMGDMA + 02A4h | Video Decode DMA U Base Address 2 Register | IMGDMA_VDODEC_U_BASE2 |
| IMGDMA + 02A8h | Video Decode DMA V Base Address 2 Register | IMGDMA_VDODEC_V_BASE2 |
| IMGDMA + 02B0h | Video Decode DMA Horizontal Size Register  | IMGDMA_VDODEC_HSIZE   |
| IMGDMA + 02B4h | Video Decode DMA Vertical Size Register    | IMGDMA_VDODEC_VSIZE   |
| IMGDMA + 02B8h | Video Decode DMA Horizontal Count Register | IMGDMA_VDODEC_HCNT    |
| IMGDMA + 02BCh | Video Decode DMA Vertical Count Register   | IMGDMA_VDODEC_VCNT    |
| IMGDMA + 0300h | Image Buffer Write DMA1 Start Register     | IMGDMA_IBW1_STR       |
| IMGDMA + 0304h | Image Buffer Write DMA1 Control Register   | IMGDMA_IBW1_CON       |
|                |                                            | •                     |



| MEDIATEK       |                                                 |                     |
|----------------|-------------------------------------------------|---------------------|
| IMGDMA + 0308h | Image Buffer Write DMA1 Base Address 1 Register | IMGDMA_IBW1_BSADDR1 |
| IMGDMA + 030Ch | Image Buffer Write DMA1 Base Address 2 Register | IMGDMA_IBW1_BSADDR2 |
| IMGDMA + 0310h | Image Buffer Write DMA1 Horizontal Size         | IMGDMA_IBW1_HSIZE   |
| IMGDMA + 0314h | Image Buffer Write DMA1 Vertical Size           | IMGDMA_IBW1_VSIZE   |
| IMGDMA + 0318h | Image Buffer Write DMA1 CLIP LR                 | IMGDMA_IBW1_CLIPLR  |
| IMGDMA + 031Ch | Image Buffer Write DMA1 CLIP TB                 | IMGDMA_IBW1_CLIPTB  |
| IMGDMA + 0320h | Image Buffer Write DMA1 Destination Pitch 1     | IMGDMA_IBW1_DPITCH1 |
| IMGDMA + 0324h | Image Buffer Write DMA1 Destination Pitch2      | IMGDMA_IBW1_DPITCH2 |
| IMGDMA + 0328h | Image Buffer Write DMA1 Horizontal Count        | IMGDMA_IBW1_HCNT    |
| IMGDMA + 032Ch | Image Buffer Write DMA1 Vertical Count          | IMGDMA_IBW1_VCNT    |
| IMGDMA + 0400h | Image Buffer Write DMA2 Start Register          | IMGDMA_IBW2_STR     |
| IMGDMA + 0404h | Image Buffer Write DMA2 Control Register        | IMGDMA_IBW2_CON     |
| IMGDMA + 0408h | Image Buffer Write DMA2 Base Address 1 Register | IMGDMA_IBW2_BSADDR1 |
| IMGDMA + 040Ch | Image Buffer Write DMA2 Base Address 2 Register | IMGDMA_IBW2_BSADDR2 |
| IMGDMA + 0410h | Image Buffer Write DMA2 Horizontal Size         | IMGDMA_IBW2_HSIZE   |
| IMGDMA + 0414h | Image Buffer Write DMA2 Vertical Size           | IMGDMA_IBW2_VSIZE   |
| IMGDMA + 0418h | Image Buffer Write DMA2 CLIP LR                 | IMGDMA_IBW2_CLIPLR  |
| IMGDMA + 041Ch | Image Buffer Write DMA2 CLIP TB                 | IMGDMA_IBW2_CLIPTB  |
| IMGDMA + 0420h | Image Buffer Write DMA2 Destination Pitch 1     | IMGDMA_IBW2_DPITCH1 |
| IMGDMA + 0424h | Image Buffer Write DMA2 Destination Pitch2      | IMGDMA_IBW2_DPITCH2 |
| IMGDMA + 0428h | Image Buffer Write DMA2 Horizontal Count        | IMGDMA_IBW2_HCNT    |
| IMGDMA + 042Ch | Image Buffer Write DMA2 Vertical Count          | IMGDMA_IBW2_VCNT    |
| IMGDMA + 0500h | Image Buffer Write DMA3 Start Register          | IMGDMA_IBW3_STR     |
| IMGDMA + 0504h | Image Buffer Write DMA3 Control Register        | IMGDMA_IBW3_CON     |
| IMGDMA + 0510h | Image Buffer Write DMA3 Horizontal Size         | IMGDMA_IBW3_HSIZE   |
| IMGDMA + 0514h | Image Buffer Write DMA3 Vertical Size           | IMGDMA_IBW3_VSIZE   |
| IMGDMA + 0528h | Image Buffer Write DMA3 Horizontal Count        | IMGDMA_IBW3_HCNT    |
| IMGDMA + 052Ch | Image Buffer Write DMA3 Vertical Count          | IMGDMA_IBW3_VCNT    |
| IMGDMA + 0580h | Image Buffer Write DMA4 Start Register          | IMGDMA_IBW4_STR     |
| IMGDMA + 0584h | Image Buffer Write DMA4 Control Register        | IMGDMA_IBW4_CON     |
| IMGDMA + 0590h | Image Buffer Write DMA4 Horizontal Size         | IMGDMA_IBW4_HSIZE   |
| IMGDMA + 0594h | Image Buffer Write DMA4 Vertical Size           | IMGDMA_IBW4_VSIZE   |
| IMGDMA + 05A8h | Image Buffer Write DMA4 Horizontal Count        | IMGDMA_IBW4_HCNT    |
| IMGDMA + 05ACh | Image Buffer Write DMA4 Vertical Count          | IMGDMA_IBW4_VCNT    |
| IMGDMA + 0600h | Image Buffer Read DMA1 Start Register           | IMGDMA_IBR1_STR     |
| IMGDMA + 0604h | Image Buffer Read DMA1 Control Register         | IMGDMA_IBR1_CON     |
| IMGDMA + 0608h | Image Buffer Read DMA1 Base Address Register    | IMGDMA_IBR1_BSADDR  |
| IMGDMA + 060Ch | Image Buffer Read DMA1 Number of Pixels         | IMGDMA_IBR1_PXLNUM  |
| IMGDMA + 0610h | Image Buffer Read DMA1 Remaining Pixels         | IMGDMA_IBR1_PXLCNT  |
| IMGDMA + 0700h | Image Buffer Read DMA2 Start Register           | IMGDMA_IBR2_STR     |
| IMGDMA + 0704h | Image Buffer Read DMA2 Control Register         | IMGDMA_IBR2_CON     |
| IMGDMA + 0708h | Image Buffer Read DMA2 Base Address Register    | IMGDMA_IBR2_BSADDR  |
|                |                                                 |                     |



| IMGDMA + 070Ch                   | Image Buffer Read DMA2 Configuration Register | IMGDMA_IBR2_CFG   |
|----------------------------------|-----------------------------------------------|-------------------|
| IMGDMA + 0710h                   | Image Buffer Read DMA2 Horizontal Size        | IMGDMA_IBR2_HSIZE |
| IMGDMA + 0714h                   | Image Buffer Read DMA2 Vertical Size          | IMGDMA_IBR2_VSIZE |
| IMGDMA + 0718h                   | Image Buffer Read DMA2 Horizontal Count       | IMGDMA_IBR2_HCNT  |
| IMGDMA + 071Ch                   | Image Buffer Read DMA2 Vertical Count         | IMGDMA_IBR2_VCNT  |
| IMGDMA + 0800h<br>IMGDMA + 0bfch | Image Buffer Read DMA2 Palette memory         | IMGDMA_PAL00~FF   |
|                                  |                                               |                   |

Table 53 Tracer Registers

## IMGDMA+000 0h

## **Image DMA Status Register**

#### **IMGDMA STA**

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25          | 24          | 23          | 22          | 21          | 20          | 19_               | 18                 | 17                 | 16          |
|--------------|----|----|----|----|----|----|-------------|-------------|-------------|-------------|-------------|-------------|-------------------|--------------------|--------------------|-------------|
| Name         |    |    |    |    |    |    | IBW4<br>RUN | IBW3<br>RUN | IBR2<br>RUN | IBR1<br>RUN | IBW2<br>RUN | IBW1<br>RUN | VDOD<br>EC<br>RUN | VDOE<br>NCR<br>RUN | VDOE<br>NCW<br>RUN | JPEG<br>RUN |
| Type         |    |    |    |    |    |    | RO                | RO                 | RO                 | RO          |
| Reset        |    |    |    |    |    |    | 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         |    |    |    |    |    |    | IBW4<br>IT  | IBW3        | IBR<br>2IT  | IBR1<br>IT  | IBW2        | IBW1<br>IT  | VDOD<br>EC IT     | VDOE<br>NCR<br>IT  | VDOE<br>NCW<br>IT  | JPEG<br>IT  |
| Name<br>Type |    |    |    |    |    |    |             |             |             |             |             |             | שטטע              | NCR                | _                  | JPEG        |

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

IT Interrupt status for DMA

- 2 No interrupt is generated.
- 3 An interrupt is pending and waiting for service.

**RUN** DMA status

- O DMA is stopped or has completed the transfer already.
- 1 DMA is currently running.

#### IMGDMA+000

4h

## Image DMA Interrupt Acknowledge Register

## IMGDMA\_ACKI NT

Bit 31 30 29 28 27 24 23 22 21 20 19 18 17 16 Name Туре Bit 15 14 13 12 10 9 8 6 3 0 VDOD VDOE VDOE IBW2 IBW<sub>1</sub> **JPEG** IBW4 IBW3 **IBR2** IBR<sub>1</sub> Name NCR **NCW** EC **ACK ACK ACK ACK ACK ACK ACK** WO WO WO WO WO WO WO WO Type 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+010

#### **JPEG DMA Start Register** 0h

| 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 shall be done by giving proper values.

STR Start control for a DMA channel

stop DMA

activate DMA 1

## IMGDMA+010

#### **JPEG DMA Control Register** 4h

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  |    |    |    |    |    |    |    |    | PSEL |    |    |    | AUTO<br>RSTR | MODE<br>1 | MODE<br>0 | IT  |
| Type  |    |    |    |    |    |    |    |    | R/W  |    |    |    | R/W          | R/W       | R/W       | R/W |
| Reset |    |    |    |    |    |    |    |    | 0    |    |    |    | 0            | 0         | 0         | 0   |

**AUTO RSTR** Automatic restart. JPEG Encoder DMA automatically restarts while current frame is finished.

0 Disable

1 Enable

**MODE** Interrupt Enabling

00 YUV422

**01** Gray

**10** YUV420

11 reserved

IT Interrupt Enabling

> 0 Disable

Enable

**PSEL** Pixel engine selection

Capture resize

Post resize

## IMGDMA+010 8h

## **JPEG DMA Base Address Register**

JPEG\_BSADDR

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



Ch

**ADDR** Base address of the JPEG DMA FIFO.

### IMGDMA+010

## JPEG DMA Horizontal Size Register

JPEG 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 |    | HSIZE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**HSIZE** Horizontal dimension of image. 0 stands for 1 pixels, and n-1 stands for n pixels.

### IMGDMA+011

# Oh JPEG DMA Vertical Size Register

JPEG 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 |    |    |    |    |    |    |    | VS | ΙΖΕ |    |    | ( • ) <u> </u> |    |    |    |
| Type |    |    |    |    |    |    |    | R/ | W   |    |    |                |    |    |    |

**VSIZE** Vertical dimension of image. 0 stands for 1 pixels, and n-1 stands for n pixels.

### IMGDMA+011

4h

## JPEG DMA FIFO Length Register

### JPEG\_FIFOLEN

| 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 |    |    |    |    |    |    | 4  | FIFO | LEN |    |    |    |    |    |    |    |
| 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{\textit{HSIZE}}{16} \right\rceil \times 16 \times \textit{FIFOLEN} \times 2 \text{ bytes for YUV422 mode, } \left\lceil \frac{\textit{HSIZE}}{16} \right\rceil \times 16 \times \textit{FIFOLEN} \times 3 \text{ bytes for YUV420}$$

mode, and  $\left\lceil \frac{HSIZE}{8} \right\rceil \times 8 \times FIFOLEN$  bytes for gray mode.

**FIFOLEN** JPEG DMA FIFO Length. FIFOLEN must be the multiple of 8. recommended values are 24 for YUV422 mode, 16 for YUV420 mode, and 16 for gray mode.

## IMGDMA+011 8h

## **JPEG Write Pointer Register**

## JPEG WRPTR

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

**WRPTR** Write pointer to display current writing address.



Ch

### IMGDMA+011

## **JPEG Write Horizontal Count Register**

## 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 |    |    |    |    |    |    |    | WRH | CNT |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R   | 0   |    |    |    |    |    |    |    |

WRHCNT Displays the horizontal pixel count. This is a down-count counter. Hence this register reflects the remaining pixels of a line.

## IMGDMA+012

#### **JPEG Write Vertical Count Register** 0h

### 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 |    |    |    |    |    |    |    | WRV | CNT |    |    |     |    |    |    |    |
| Type |    |    |    |    |    |    |    | R   | 0   |    |    | 401 |    |    |    |    |

WRVCNT Displays the vertical pixel count. This is a down-count counter. Hence this register reflects the remaining lines.

## IMGDMA+012

#### **JPEG Read Pointer Register** 4h

## JPEG\_RDPTR

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

RDPTR Read pointer to display current reading address.

## IMGDMA+012

8h

# **JPEG Read Horizontal Count Register**

### 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 |    |    |    | 4  |    |    |    | RDH | CNT |    |    |    |    |    |    |    |
| Type |    | •  |    |    |    |    |    | R   | 0   |    |    |    |    |    |    |    |

RDHCNT Displays the horizontal pixel count. This is a down-count counter. Hence this register reflects the remaining pixels of a line.

## IMGDMA+012 Ch

## **JPEG Read Vertical Count Register**

### 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         |    |    |    |    |    |    |    | RDV | CNT |    |    |    |    |    |    |    |
| Name<br>Type |    | >  |    |    |    |    |    | R   | 0   |    |    |    |    |    |    |    |



**RDVCNT** 

Displays the vertical pixel count. This is a down-count counter. Hence this register reflects the remaining

## IMGDMA+013

#### **JPEG FIFO Line Count Register** 0h

JPEG FFCN

| 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 |    |    |    |    |    |    |    | FFC | CNT |    |    |    |    |        |    |    |
| Type |    |    |    |    |    |    |    | R   | 0   |    |    |    |    | $\Box$ |    |    |

**FFCNT** Displays the FIFO Line Count of JPEG FIFO.

## IMGDMA+013

4h

## JPEG Write Line Index Register

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

**YIDX** Displays which FIFO line JPEG DMA is writing. YIDX = 1 ~ FIFOLEN.

## IMGDMA+013

8h

## **JPEG Read Line Index Register**

JPEG FFRDLID

| 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  | <u>8_</u> [ | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    | -  | YID         | X  |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | RC          | )  |    |    |    |    |    |    |    |

**YIDX** Displays which FIFO line JPEG DMA is reading, YIDX =  $1 \sim FIFOLEN$ .

## IMGDMA+020

#### 0h

## Video Encode DMA Start Register

## **VDOENC\_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.

Start control for a DMA channel STR

- stop DMA
- activate DMA



4h

#### IMGDMA+020

## Video Encode DMA Control Register

VDOENC\_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  |    |    |    |    |    |    |    |    | PSEL | RSEL |    | AUTO<br>RSTR | RD IT | W2R |    | WR IT |
| Type  |    |    |    |    |    |    |    |    | R/W  | R/W  |    | R/W          | R/W   | R/W |    | R/W   |
| Reset |    |    |    |    |    |    |    |    | 0    | 0    |    | 0            | 0     | 0   |    | 0     |

**WR IT** WDMA Done Interrupt Enable. Interrupt issues when all of the transfers are done. For auto-restart mode, interrupt issues at every restart.

- 0 Disable
- 1 Enable

W2R WDMA hardware trigger to RDMA. While this function is enabled, Video Encode WDMA will write data to video buffer first, and then a start pulse will issue to Video Encode RDMA to read back from the same buffer. These data will pass through Resize to convert to LCD frame size.

- 0 Disable
- 1 Enable

**RD IT** RDMA Done Interrupt Enable.

- O Disable
- Enable

**AUTO RSTR** Automatic restart. Video DMA automatically restarts while current frame is finished. Base address will be automatically switched between VDO\_BSADD1 and VDO\_BSADDR2. For single buffer application, please set VDO\_BSADD1 and VDO\_BSADDR2 with the same value.

- O Disable
- 1 Enable

**RSEL** RDMA output destination selection.

- O Post resize
- 1 Drop resize

**PSEL** WDMA input pixel engine selection

- Capture resize
- 1 Post resize

#### IMGDMA+021

0h

## Video Encode Y Base Address 1 Register

VDOENC\_Y\_BA SE1

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

**ADDR** First base address of video frame buffer.

#### IMGDMA+021

Video Encode U Base Address 1 Register

VDOENC\_U\_BA

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



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

**ADDR** First base address of video frame buffer.

## IMGDMA+021 8h Video Encode VBase Address 1 Register

VDOENC\_V\_BA

SE<sup>1</sup>

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

**ADDR** First base address of video frame buffer.

## IMGDMA+022

0h

4h

8h

## Video Encode Y Base Address 2 Register

VDOENC\_Y\_BA

SE<sub>2</sub>

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

**ADDR** Second base address of video frame buffer.

#### IMGDMA+022

## Video Encode U Base Address 2 Register

VDOENC\_U\_BA

SE<sub>2</sub>

| 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 |    |    |    |    |    |    | 70 | ADDR  |    |    |    |    |    |    |    |
| Type |    | •  |    |    | •  |    |    | R/W   | •  | •  | •  | •  |    |    | •  |

**ADDR** Second base address of video frame buffer.

## IMGDMA+022

#### Video Encode V Base Address 2 Register

VDOENC\_V\_BA

SE<sub>2</sub>

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

**ADDR** Second base address of video frame buffer.

#### MCDMA 1033

## **Video Encode Horizontal Size Register**

VDOENC\_HSIZ

0h

| 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 |    |    |    |    |    |    |   |   |   |   | SI |   |   |   |   |   |
| 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+023

## **Video Encode Vertical Size Register**

**VDOENC V** 

| 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

4h

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+023

#### **Video Encode Horizontal Count Register** 8h

## **VDOENC 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_5 | 4   | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    | COL | JNT |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    | R   | 0   |    |    |    |    |

**COUNT** 

Horizontal pixel count. 1 stands for 1 pixel, and n stands for n pixels.

## IMGDMA+023

#### **Video Encode Vertical Count Register** Ch

### VDOENC\_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 |    |    |    |    |    |    |    |    |    |    | (  | COUNT | Ī  |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    | RO    |    |    |    |    |

Vertical pixel count. 1 stands for 1 pixel, and n stands for n pixels. **COUNT** 

#### IMGDMA+028

#### **Video Decode DMA Start Register** 0h

### VDODEC\_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



- stop DMA
- 1 activate DMA

### **Video Decode DMA Control Register** 4h

VDODEC CO

| 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  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DONE<br>IT |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W        |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0          |

**DONE IT** DMA Done Interrupt Enabling. Interrupt issues when all of the transfers are done. For auto-restart mode, interrupt issues at every restart.

- Disable
- 1 Enable

## IMGDMA+029

0h

## **Video Decode Y Base Address 1 Registe**

**VDODEC Y BA** 

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

**ADDR** First base address of video frame buffer.

#### Video Decode U Base Address 1 Register 4h

VDODEC\_U\_BA SE<sub>1</sub>

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

**ADDR** First base address of video frame buffer.

## IMGDMA+029

8h

# Video Decode V Base Address 1 Register

VDODEC\_V\_BA SE<sub>1</sub>

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

**ADDR** First base address of video frame buffer.



0h

## IMGDMA+02A

## **Video Decode Y Base Address 2 Register**

# VDODEC\_Y\_BA

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

**ADDR** 

4h

Second base address of video frame buffer.

## IMGDMA+02A

## Video Decode U Base Address 2 Register

VDODEC\_U\_BA SE2

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

**ADDR** 

8h

Second base address of video frame buffer.

## IMGDMA+02A

## Video Decode V Base Address 2 Register

VDODEC\_V\_BA SE2

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

**ADDR** 

Second base address of video frame buffer.

### IMGDMA+02B

## **Video Decode Horizontal Size Register**

**VDODEC HSIZ** 

| n | _ |
|---|---|
|   | п |
| v |   |
|   |   |

| 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 |    |    |    |    |    |    |     |    |    |    | SI | ZE |    |    |    |    |  |  |
| Type |    |    |    |    |    |    | R/W |    |    |    |    |    |    |    |    |    |  |  |

SIZE

4h

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+02B

## **Video Decode Vertical Size Register**

VDODEC\_VSIZ

Ε

| 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 | Z  |    |    |    |    |    |    | R/W |    |    |    |      |    |    |    |    |  |  |



8h

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.

## **Video Decode Horizontal Count Register**

VDODEC HCN

| 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 |    |    |    |    |    |    |    |    |    |    | COL | JNT |    |    |    |    |
| Type |    |    |    |    |    |    |    |    | •  | •  | R   | 0   |    |    |    | ·  |

**COUNT** Horizontal pixel count. 1 stands for 1 pixel, and n stands for n pixels.

### **Video Decode Vertical Count Register** Ch

## DODEC 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    | 74    | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    |    |    |    |      | COUNT |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    | -(7) | RO    |    |    |    |    |

COUNT Vertical pixel count. 1 stands for 1 pixel, and n stands for n pixels.

## IMGDMA+030

0h

## **Image Buffer Write DMA1 Start Register**

## IBW1\_STR

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24          | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16  |
|-------|----|----|----|----|----|----|----|-------------|----|----|----|----|----|----|----|-----|
| Name  |    |    |    |    |    |    |    |             |    |    |    |    |    |    |    |     |
| Type  |    |    |    |    |    |    |    |             |    |    |    |    |    |    |    |     |
| Reset |    |    |    |    |    |    |    | <b>T</b> 5. |    |    |    |    |    |    |    |     |
| 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 value

**STR** Start control for a DMA channel

- stop DMA
- 1 activate DMA

#### IMGDMA+030

#### Image Buffer Write DMA1 Control Register 4h

**IBW1 CON** 

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24        | 23        | 22   | 21  | 20  | 19           | 18  | 17    | 16  |
|-------|----|----|----|----|----|----|----|-----------|-----------|------|-----|-----|--------------|-----|-------|-----|
| Name  |    |    |    |    |    |    |    |           |           |      |     |     |              |     |       |     |
| Type  |    |    |    |    |    |    |    |           |           |      |     |     |              |     |       |     |
| Reset |    | 4_ |    |    |    |    |    |           |           |      |     |     |              |     |       |     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8         | 7         | 6    | 5   | 4   | 3            | 2   | 1     | 0   |
| Name  |    |    |    |    |    |    |    | PSEL<br>1 | PSEL<br>0 | 888M | PAN | DC  | AUTO<br>RSTR | LCD | PITCH | IT  |
| Type  |    |    |    |    |    |    |    | 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   |

Interrupt Enabling



- 0 Disable
- 1 Enable

**PITCH** Destination pitch jump.

- O Disable
- 1 Enable

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.

- O Disable
- 1 Enable

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 CLIP\_L, CLIP\_R, CLIP\_T, and CLIP\_B are dumped. The pan window is defined as **Figure 33**.



Figure 33 Picture Panning

- O Disable
- 1 Enable

888M Output format control

- 0 RGB565
- 1 RGB888

**PSEL** Pixel engine selection

- **00** IPP 1
- **01** IPP 2
- 10 Capture resize
- 11 Post resize



8h

Ch

0h

4h

8h

## IMGDMA+030

## Image Buffer Write DMA1 Base Address 1 Register

## **IBW1 BSADDR**

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

**ADDR** First base address of the LCD frame buffer.

### IMGDMA+030

## Image Buffer Write DMA1 Base Address 2 Register

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

**ADDR** Second base address of the LCD frame buffer.

### IMGDMA+031

## Image Buffer Write DMA1 Horizontal Size Register

### IBW1\_HSIZE

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

SIZE Horizontal size of a frame. 0 stands for 1 pixel, and n-1 stands for n pixels.

### IMGDMA+031

## Image Buffer Write DMA1 Vertical Size Register

### IBW1\_VSIZE

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | <u>2</u> 5 | 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 |    |    |    |    |    |    |            | SI | ZE |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |            | R/ | W  |    |    |    |    |    |    |    |

SIZE Vertical size of a frame. 0 stands for 1 pixel, and n-1 stands for n pixels.

#### IMGDMA+031

# Image Buffer Write DMA1 Clip LR Register

### **IBW1 CLIP LR**

| 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 |    |    | -  |    |    |    |    | RIG | HT |    |    |    |    |    |    |    |
| Type |    |    |    | ·  |    |    |    | R/  | W  |    |    |    |    |    |    |    |

Left boundary of a frame. 0 stands for the first pixel, and n-1 stands for the n<sup>th</sup> pixel. LEFT

**RIGHT** Right boundary of a frame. 0 stands for the first pixel, and n-1 stands for the n<sup>th</sup> pixel.



Ch

### IMGDMA+031

## **Image Buffer Write DMA1 Clip TB Register**

IBW1\_CLIP\_TB

| 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 |    |    |    |    |    |    |    | BOT | TOM |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R/  | W   |    |    |    |    |    |    |    |

TOP

Top boundary of a frame. 0 stands for the first pixel, and n-1 stands for the n<sup>th</sup> pixel.

Bottom boundary of a frame. 0 stands for the first pixel, and n-1 stands for the n<sup>th</sup> pixel. **BOTTOM** 

## IMGDMA+032

Image Buffer Write DMA1 Destination Pitch1 Register IBW1\_DPITCH1 0h

| 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 |    |    |    |    |    |    |    | PIT | CH |    |    |                |    |    |    |    |
| Type |    |    |    |    |    |    |    | R/  | W  |    |    | ( <sup>-</sup> |    |    |    |    |

**PITCH** Line pitch in bytes corresponds to IBW2\_BSADDR1.

## IMGDMA+032

Image Buffer Write DMA1 Destination Pitch2 Register IBW1\_DPITCH2 4h

| 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 |    |    |    |    |    |    |    |    | CH        |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R/ | Ŵ <u></u> |    |    |    |    |    |    |    |

Line pitch in bytes corresponds to IBW2\_BSADDR1. **PITCH** 

### IMGDMA+032

**Image Buffer Write DMA1 Horizontal Count Register IBW1 HCNT** 8h

| 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 |    |    |    |    |    |    |    | CI | <b>IT</b> |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R  | 0         |    |    |    |    |    |    |    |

**CNT** Horizontal pixel count. 0 stands for 1 pixel, and n-1 stands for n pixels.

### IMGDMA+032

**Image Buffer Write DMA1 Vertical Count Register IBW1 VCNT** Ch

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

Vertical line count. 0 stands for 1 line, and n-1 stands for n lines.



0h

### IMGDMA+040

## Image Buffer Write DMA2 Start Register

**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  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | $\sim$ | STR |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 7      | 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+040

4h

# Image Buffer Write DMA2 Control Registe

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  |    |    |    |    |    |    |    | PSEL<br>1 | PSEL<br>0 | 888M | PAN | DC  | AUTO<br>RSTR | LCD | PITCH | IT  |
| Type  |    |    |    |    |    |    |    | R/W       | R/W       | R/W  | R/W | R/W | R/W          | R/W | R/W   | R/W |
| Reset |    |    |    |    |    |    | 4  | 0         | 0_0       | 0    | 0   | 0   | 0            | 0   | 0     | 0   |

IT Interrupt Enabling

- 0 Disable
- 1 Enable

**PITCH** Destination pitch jump.

- 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.

- O Disable
- 1 Enable

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.

- O 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 33**.

0 Disable

1 Enable

888M Output format control

0 RGB565

1 RGB888

**PSEL** Pixel engine selection

**00** IPP 1

**01** IPP 2

10 Capture resize

11 Post resize

#### IMGDMA+040

8h

Ch

0h

4h

## Image Buffer Write DMA2 Base Address 1 Register

IBW2\_BSADDR

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

**ADDR** First base address of the LCD frame buffer.

### IMGDMA+040

## Image Buffer Write DMA2 Base Address 2 Register

IBW2\_BSADDR

2

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

**ADDR** Second base address of the LCD frame buffer.

### IMGDMA+041

## Image Buffer Write DMA2 Horizontal Size Register

**IBW2 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 |     |    |    |    |    |    |    | SI | ZE |    |    |    |    |    |    |    |
| Type | R/W |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**SIZE** Horizontal size of a frame. 0 stands for 1 pixel, and n-1 stands for n pixels.

## IMGDMA+041

## **Image Buffer Write DMA2 Vertical Size Register**

**IBW2 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 |    |    |    |    |    |    |    | SI | ZE |    |    |    |    |    |    |    |





R/W Type

**SIZE** Vertical size of a frame. 0 stands for 1 pixel, and n-1 stands for n pixels.

#### IMGDMA+041

#### Image Buffer Write DMA2 Clip LR Register 8h

| 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 |    |    |    |    |    |    |    | RIG | HT |    |    |    |    |        |    |    |
| Type |    |    | •  | •  |    |    |    | R/  | W  |    | •  |    |    | $\Box$ |    | •  |

Left boundary of a frame. 0 stands for the first pixel, and n-1 stands for the n<sup>th</sup> pixel. LEFT

Right boundary of a frame. 0 stands for the first pixel, and n-1 stands for the n<sup>th</sup> pixel. **RIGHT** 

#### IMGDMA+041

#### Image Buffer Write DMA2 Clip TB Register Ch

**IBW2 CLIP TB** 

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

Top boundary of a frame. 0 stands for the first pixel, and n-1 stands for the n<sup>th</sup> pixel. **TOP** 

Bottom boundary of a frame. 0 stands for the first pixel, and n-1 stands for the n<sup>th</sup> pixel. BOTTOM

#### IMGDMA+042

#### Image Buffer Write DMA2 Destination Pitch1 Register IBW2\_DPITCH1 0h

| 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 |    |    |    |    |    |    | 70 | PIT | CH |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R/  | W  |    |    |    |    |    |    |    |

Line pitch in bytes corresponds to IBW2\_BSADDR1. **PITCH** 

#### IMGDMA+042

4h

8h

# Image Buffer Write DMA2 Destination Pitch2 Register IBW2 DPITCH2

| 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 |    |    |    |    |    |    |    | PIT | CH |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R/  | W  |    |    |    |    |    |    |    |

**PITCH** Line pitch in bytes corresponds to IBW2\_BSADDR1.

### IMGDMA+042

#### **Image Buffer Write DMA2 Horizontal Count Register IBW2 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  |

433/616

MediaTek Inc. Confidential





| Name | CNT |
|------|-----|
| Type | RO  |

CNT H

Horizontal pixel count. 0 stands for 1 pixel, and n-1 stands for n pixels.

IMGDMA+042

# **Image Buffer Write DMA2 Vertical Count Register**

**IBW2 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 |    |    |    |    |    |    |    | CI | <b>IT</b> |    |    |    |    |    | 7  |    |
| Type |    |    |    |    |    |    |    | R  | 0         |    |    |    |    |    |    |    |

CNT

0h

Ch

Vertical line count. 0 stands for 1 line, and n-1 stands for n lines.

#### IMGDMA+050

# **Image Buffer Write DMA3 Start Register**

**IBW3 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 value

**STR** Start control for a DMA channel

- stop DMA
- 1 activate DMA

#### IMGDMA+050

4h

# Image Buffer Write DMA3 Control Register

IBW3\_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  |    |    |    |    |    |    |    | PSEL<br>1 | PSEL<br>0 |    |    |    | AUTO<br>RSTR |    |    | Ŧ   |
| Type  |    |    |    |    |    |    |    | R/W       | R/W       |    |    |    | R/W          |    |    | R/W |
| Reset |    |    |    |    |    |    |    | 0         | 0         |    |    |    | 0            |    |    | 0   |

- IT Interrupt Enabling
  - O Disable
  - 1 Enable

**AUTO RSTR** Automatic restart. IBW2 DMA automatically restarts itself while current frame is finished.

- O Disable
- Enable

**PSEL** Pixel engine selection

- **00** IPP 1
- **01** IPP 2



10 Capture resize

11 Post resize

# **Image Buffer Write DMA3 Horizontal Size Register**

**IBW3 HSIZI** 

| 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 |    |    |    |    |    |    |    | SI | ZE |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R/ | W  |    |    |    |    |    |    |    |

SIZE Horizontal size of a frame. 0 stands for 1 pixel, and n-1 stands for n pixels.

#### **Image Buffer Write DMA3 Vertical Size Register** 4h

**IBW3 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  | 947 | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    | SIZ | ZE |    |    |     |    |    |    |    |
| Type |    |    |    |    |    |    |    | R/  | W  |    |    |     |    |    |    |    |

SIZE Vertical size of a frame. 0 stands for 1 pixel, and n-1 stands for n pixels.

### IMGDMA+052

8h

# **Image Buffer Write DMA3 Horizontal Count Register**

IBW3\_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 |    |    |    |    |    |    |    | CI CI | vit) |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    | -  | R     | 0    |    |    |    |    |    |    |    |

CNT Horizontal pixel count. 0 stands for 1 pixel, and n-1 stands for n pixels.

### IMGDMA+052

#### Image Buffer Write DMA3 Vertical Count Register Ch

IBW3\_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 |    |    |    | 4  |    |    |    | CI | NT . |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R  | 0    |    |    |    |    |    |    |    |

CNT Vertical line count. 0 stands for 1 line, and n-1 stands for n lines.

## IMGDMA+058

0h

## **Image Buffer Write DMA4 Start Register**

**IBW4 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

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

- stop DMA
- activate DMA

#### IMGDMA+058

#### **Image Buffer Write DMA4 Control Register** 4h

**IBW4 CON** 

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24        | 23        | 22 | 21 | 20 | 19           | <u>1</u> 8 | 17 | 16  |
|-------|----|----|----|----|----|----|----|-----------|-----------|----|----|----|--------------|------------|----|-----|
| Name  |    |    |    |    |    |    |    |           |           |    |    |    |              |            |    |     |
| Type  |    |    |    |    |    |    |    |           |           |    |    |    |              |            |    |     |
| Reset |    |    |    |    |    |    |    |           |           |    |    |    |              |            |    |     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8         | 7         | 6  | 5  | 4  | 3            | 2          | 1  | 0   |
| Name  |    |    |    |    |    |    |    | PSEL<br>1 | PSEL<br>0 |    |    |    | AUTO<br>RSTR |            |    | I   |
| Type  |    |    |    |    |    |    |    | R/W       | R/W       |    |    | 70 | R/W          |            |    | R/W |
| Reset | •  |    |    |    | ·  |    |    | 0         | 0         |    |    |    | 0            | •          |    | 0   |

Interrupt Enabling IT

- Disable
- 1 Enable

Automatic restart. IBW2 DMA automatically restarts itself while current frame is finished. **AUTO RSTR** 

- Disable
- Enable

**PSEL** Pixel engine selection

- **00** IPP 1
- **01** IPP 2
- 10 Capture resize
- 11 Post resize

#### IMGDMA+059

#### Image Buffer Write DMA4 Horizontal Size Register 0h

**IBW4 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 |    |    |    |    | 75 |    |    | SI | ZE |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R/ | W  |    |    |    |    |    |    |    |

**SIZE** Horizontal size of a frame. 0 stands for 1 pixel, and n-1 stands for n pixels.

#### IMGDMA+059

#### Image Buffer Write DMA4 Vertical Size Register 4h

**IBW4 VSIZE** 

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

Vertical size of a frame. 0 stands for 1 pixel, and n-1 stands for n pixels.



#### **IMGDMA+05A**

# **Image Buffer Write DMA4 Horizontal Count Register**

**IBW4 HCN** 

| 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 |    |    |    |    |    |    |    | CI | TV |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R  | 0  |    |    |    |    |    |    |    |

CNT

Horizontal pixel count. 0 stands for 1 pixel, and n-1 stands for n pixels.

### IMGDMA+05A

#### **Image Buffer Write DMA4 Vertical Count Register** Ch

| 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 |    |    |    |    |    |    |    | CI | <b>IT</b> |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R  | 0         |    |    |    |    |    |    |    |

CNT

0h

Vertical line count. 0 stands for 1 line, and n-1 stands for n lines.

#### IMGDMA+060

# Image Buffer Read DMA1 Start Registe

IBR1\_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

- stop DMA
- 1 activate DMA

#### IMGDMA+060

#### **Image Buffer Read DMA1 Control Register** 4h

**IBR1 CON** 

| Dit   | 21 | 20 | 20 | 20 | 07 | 26 | ΩE | 24 | 22 | 22 | 21 | 20 | 10 | 10        | 17  | 16  |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|-----|-----|
| 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<br>R | FMT | I   |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    | R/W       | R/W | R/W |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    | 0         | 0   | 0   |

IT Interrupt Enabling

- Disable
- Enable



Ch

Data format

**RGB565** 

**RGB888** 

**ORDER** Data order

BGR888, from MSB to LSB.

RGB888, from MSB to LSB.

IMGDMA+060

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 |    |     |    |    |    |    |    | AD | DR |    |    |    |          | マス |    |    |
| Type |    | R/W |    |    |    |    |    |    |    |    |    |    |          |    |    |    |
| Bit  | 15 | 14  | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3        | 2  | 1  | 0  |
| Name |    |     |    |    |    |    |    | AD | DR |    |    |    |          |    |    |    |
| Type |    |     |    |    |    |    |    | R/ | W  |    |    |    | <u> </u> |    |    |    |

**ADDR** Base address of the image buffer.

IMGDMA+060

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 |    |     |    |    |    |    |    | NU | JM |    |    |    |    |    |    |    |
| Type |    | R/W |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14  | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |     |    |    |    |    |    | NU | JM |    |    |    |    |    |    |    |
| Type |    |     |    |    |    |    |    | R/ | W  |    |    |    |    |    |    |    |

Number of pixels of the transferred image. 0 represents 1 pixel, and n-1 represents n pixels. **NUM** 

IMGDMA+061

Image Buffer Read DMA1 Remaining Pixels Register IBR1\_PXLCNT 0h

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

**COUNT** Pixel count. 0 represents 1 pixel, and n-1 represents n pixels.

IMGDMA+070

Image Buffer Read DMA2 Start Register 0h

**IBR2 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  |    | 4  |    |    |    |    |    |    |    |    |    |    |    |    |    | 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+070

# Image Buffer Read DMA2 Control Register

IBR2 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  |    |    |    |    |    |    |    |    | PSEL |    |    | PALE<br>N | AUTO<br>RSTR |     | MODE<br>0 | IT  |
| Type  |    |    |    |    |    |    |    |    | R/W  |    |    | R/W       | R/W          | R/W | R/W       | R/W |
| Reset |    |    |    |    |    |    |    |    | 0    | •  |    | 0         | 0            | 0   | 0         | 0   |

IT Interrupt Enabling

- O Disable
- Enable

**MODE** Interrupt Enabling

- 00 1-bpp mode
- **01** 2-bpp mode
- **10** 4-bpp mode
- 11 8-bpp mode

**AUTO RSTR** Automatic restart. IBR2 DMA automatically restarts itself while current frame is finished.

- Disable
- 1 Enable

**PALEN** Photo frame palette Enabling. Please set this bit before any operation with the palette memory.

- O Disable.
- 1 Enable.

**PSEL** Pixel engine selection

- O Capture Resize.
- 1 Post Resize.

#### IMGDMA+070

8h

Ch

# Image Buffer Read DMA2 Base Address Register

IBR2\_BSADDR

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

**ADDR** Base address of the photo frame.

#### IMGDMA+070

### **Image Buffer Read DMA2 Configuration Register**

IBR2\_CFG

|      |    | 4  |    |    |    |    |    |    |    |     |     |    |    |     |     |    |
|------|----|----|----|----|----|----|----|----|----|-----|-----|----|----|-----|-----|----|
| 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 |    |    |    | K  | Υ  |    |    |    |    | VRA | TIO |    |    | HRA | TIO |    |
| Type |    |    |    | R/ | W  |    |    |    |    | R/  | W   |    |    | R/  | W   |    |



4h

8h

Ch

**KEY** Transparent color key for overlay function.

**VRATIO** Horizontal scaling ratio. **HRATIO** Vertical scaling ratio.

IMGDMA+071

# Image Buffer Read DMA2 Horizontal Size Register

IBR2\_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 |    |    |    |    |    |    |    | SI | ZE |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R/ | W  |    |    |    |    | u  |    |    |

**SIZE** Horizontal size of the photo frame.

IMGDMA+071

# Image Buffer Read DMA2 Vertical Size Register

IBR2\_VSIZE

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

**SIZE** Vertical size of the photo frame.

IMGDMA+071

### **Image Buffer Read DMA2 Horizontal Count Register**

**IBR2\_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  | <u>8</u> | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    | CN       | IT |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    | R        | )  |    |    |    |    |    |    |    |

**CNT** Horizontal pixel count. 0 stands for 1 pixel, and n-1 stands for n pixels.

IMGDMA+071

# Image Buffer Read DMA2 Vertical Count Register

IBR2\_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 |    |    |    |    |    |    |    | CI | <b>IT</b> |    |    |    |    |    |    |    |
| Type | •  |    |    |    |    |    |    | R  | 0         |    |    |    |    |    |    |    |

**CNT** Vertical line count. 0 stands for 1 line, and n-1 stands for n lines.

IMGDMA+080

**IMGDMA PALO** 

0h Image Buffer Read DMA2 Palette Register 00~FF

IMGDMA+0BI

~FF

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



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

**COLOR** [23:0] Palette entry color value in YUV format.

### 6.16 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.

The image Engine includes three independent sub image engines. The first sub image engine, IPP1, is in charge of the main functions of the engine (pixel adjustment and filtering effect). The second sub image engine, IPP2, only performs YUV to RGB color conversion. This sub engine can be used to output the RGB data in the image compression or videophone. The third sub image engine, IPP3, mainly performs RGB to YUV color space conversion and then output to Post Resizer.

# 6.16.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    |



| D. (C : 01201          | C 1                                           | MCDDOC COLODIZELI    |
|------------------------|-----------------------------------------------|----------------------|
| 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                          | IMGPROC_MASK31       |
| IMG+015Ch              | Mask coefficient C32                          | IMGPROC_MASK32       |
| IMG+0160h              | Mask coefficient C33                          | IMGPROC_MASK33       |
| IMG+0164h              | Mask down-scaling coefficient                 | IMGPROC_SCALE        |
| IMG+0170h              | Gamma correction offset for segment 0         | IMGPROC_GAMMA_OFF0   |
| IMG+0174h              | Gamma correction offset for segment 1         | IMGPROC_GAMMA_OFF1   |
| IMG+0178h              | Gamma correction offset for segment 2         | IMGPROC_GAMMA_OFF2   |
| IMG+017Ch              | Gamma correction offset for segment 3         | IMGPROC_GAMMA_OFF3   |
| IMG+0180h              | Gamma correction offset for segment 4         | IMGPROC_GAMMA_OFF4   |
| IMG+0184h              | Gamma correction offset for segment 5         | IMGPROC_GAMMA_OFF5   |
| IMG+0188h              | Gamma correction offset for segment 6         | IMGPROC_GAMMA_OFF6   |
| IMG+018Ch              | Gamma correction offset for segment 7         | IMGPROC_GAMMA_OFF7   |
| IMG+0190h              | Gamma correction slope for segment 0          | IMGPROC_GAMMA_SLP0   |
| IMG+0194h              | Gamma correction slope for segment 1          | IMGPROC_GAMMA_SLP1   |
| IMG+0198h              | Gamma correction slope for segment 2          | IMGPROC_GAMMA_SLP2   |
| IMG+019Ch              | Gamma correction slope for segment 3          | IMGPROC_GAMMA_SLP3   |
| IMG+01A0h              | Gamma correction slope for segment 4          | IMGPROC_GAMMA_SLP4   |
| IMG+01A4h              | Gamma correction slope for segment 5          | IMGPROC_GAMMA_SLP5   |
| IMG+01A8h              | Gamma correction slope for segment 6          | IMGPROC_GAMMA_SLP6   |
| IMG+01ACh              | Gamma correction slope for segment 7          | IMGPROC_GAMMA_SLP7   |
| IMG+01B0h              | Gamma correction control register             | IMGPROC_GAMMA_CON    |
| IMG+0200h              | Color adjustment offset x for red segment 1   | IMGPROC_COLOR1R_OFFX |
| IMG+0204h              | Color adjustment offset x for red segment 2   | IMGPROC_COLOR2R_OFFX |
| IMG+0208h              | Color adjustment offset x for green segment 1 | IMGPROC_COLOR1G_OFFX |
| IMG+020Ch              | Color adjustment offset x for green segment 2 | IMGPROC_COLOR2G_OFFX |
| IMG+0210h              | Color adjustment offset x for blue segment 1  | IMGPROC_COLOR1B_OFFX |
| IMG+0214h              | Color adjustment offset x for blue segment 2  | IMGPROC_COLOR2B_OFFX |
| IMG+0220h              | Color adjustment offset y for red segment 1   | IMGPROC_COLOR1R_OFFY |
| IMG+0224h              | Color adjustment offset y for red segment 2   | IMGPROC_COLOR2R_OFFY |
| IMG+0228h              | Color adjustment offset y for green segment 1 | IMGPROC_COLOR1G_OFFY |
| IMG+022Ch              | Color adjustment offset y for green segment 2 | IMGPROC_COLOR2G_OFFY |
| IMG+0230h              | Color adjustment offset y for blue segment 1  | IMGPROC_COLOR1B_OFFY |
| IMG+0230h<br>IMG+0234h | Color adjustment offset y for blue segment 2  |                      |
|                        |                                               | IMGPROC_COLOR1C_SLR  |
| IMG+0240h              | Color adjustment slope for red segment 0      | IMGPROC_COLOR1G_SLP  |



| IMG+0244h | Color adjustment slope for red segment 1 | IMGPROC_COLOR1G_SLP |
|-----------|------------------------------------------|---------------------|
| IMG+0248h | Color adjustment slope for red segment 2 | IMGPROC_COLOR2G_SLP |
| IMG+0250h | Color adjustment slope for red segment 0 | IMGPROC_COLOR1G_SLP |
| IMG+0254h | Color adjustment slope for red segment 1 | IMGPROC_COLOR1G_SLP |
| IMG+0258h | Color adjustment slope for red segment 2 | IMGPROC_COLOR2G_SLP |
| 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    |
| IMG+0318h | RGB to YUV source select                 | IMGPROC_R2Y_SRC     |
| IMG+031Ch | Thumbnail output enable                  | IMGPROC_TNL_EN      |
| IMG+0320h | Image engine process enable              | IMGPROC_EN          |
|           |                                          |                     |

Table 54 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  |    | GM | ODE |    |    | MA | SK |                         | RGB | GMA | CLR | INV | CBA |   | HSA |   |
| Type  |    | R/ | W   |    |    | R/ | W  | $\overline{\mathbf{U}}$ | R/W | R/W | R/W | R/W | R/W |   | R/W |   |
| Reset |    | (  | )   |    |    | (  | )  |                         | 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 RGB format (565/888) of image data can be both supported by the RGB control bit. 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 in image encoding, such as JPEG encoding. IPP2 path can be enabled to support the thumbnail RGB data format. In this mode, we assume no image effects are to be applied.
- 0101 IMGPROC mode. (RGB to YUV and YUV 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. This mode can also apply on GIF/PNG decoding.
- **MPEG mode.** (YUV to RGB) In this mode, the image is converted from YUV color space to RGB color space in video showing. This mode is mainly used for video mode.
- 0010 Capture mode. (YUV to RGB and YUV to RGB) In this mode, the captured image in YUV color space and performed color space conversion for thumbnail output. This mode is mainly used for image capture. This mode can be applied on videophone mode. Thumbnail path can be enabled.
- **Preview 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.

#### MASK Mask filtering effect enabling control. (Source and destination image are both in memory)

- **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

#### RGB S65/888 selection for filter path (only for filtering effect)

- 0 RGB565
- 1 RGB888
- **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

| IN | IG+0004 | 1  | Mask | filte | ring ( | Contr | ol reg | gister | • |   |   |   | II | MGPF | ROC_ | CON |
|----|---------|----|------|-------|--------|-------|--------|--------|---|---|---|---|----|------|------|-----|
| E  | 3it 15  | 14 | 13   | 12    | 11     | 10    | 9      | 8      | 7 | 6 | 5 | 4 | 3  | 2    | 1    | 0   |



#### MT6228 GSM/GPRS Baseband Processor Data Sheet Revision 1.0

| Name  |  |  |  |  |  | INIT |  | STOP | STAR<br>T |
|-------|--|--|--|--|--|------|--|------|-----------|
| 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

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | $\overline{2}$ | 1 | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|----------------|---|-----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |                |   | EN  |
| 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 | 1 | 4 | 3 | 2 | 1 | 0    |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|------|
| Name  |    |    |    |    |    |    |   |   |   |   |   | 7 |   |   |   |   | INTR |
| 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 | V  | 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  |    |    |    |    |    |    |   |   |   |   |   | C. | 11 |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | R/ | W  |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 40 | )h |   |   |   |

### 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  |    |    |    |    |    |    |   |   |     |   |   | C. | 12 |   |   |   |  |  |
| Type  |    |    |    |    |    |    |   |   | R/W |   |   |    |    |   |   |   |  |  |
| Reset |    |    |    |    |    |    |   |   | 0   |   |   |    |    |   |   |   |  |  |



### IMG+0108h Hue adjustment coefficient C21

# IMGPROC\_HUE

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

### 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  |    |    |    |    |    |    |   |   |   |   |   | C  | 22 |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | R/ | W  |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   | • | 4( | )h |   |   |   |

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_0 \\ v_0 \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 |    |    |    |    |    | $\exists \succeq$ |    |   |   |   |   |   |   | 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 127, 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\_BRI ADJ1

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



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\_BRI

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

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                    | - 7 | 4  | 3  | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|----------------------|-----|----|----|---|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |                      | ٧.  | CC | ON |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   | 1                    |     | R/ | W  |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   | $\overline{\Lambda}$ |     | 20 | )h |   |   |   |

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  |    |    |    |    |    |    | 7 |   |   |   |   | UC | OM |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | R/ | W  |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   | • | • | (  | )  |   | • |   |

### IMG+0134h Colorize v component coefficient

IMGPROC\_COL ORIZEV

| Bit   | 15 | 14 | 13 | 12 | 1   | 1 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|-------|----|----|----|----|-----|---|----|---|---|---|---|---|----|----|---|---|---|
| Name  |    |    |    |    | 1   |   |    |   |   |   |   |   | VC | OM |   |   |   |
| Type  |    |    |    |    |     |   |    |   |   |   |   |   | R/ | W  |   |   |   |
| Reset |    |    |    |    | D I |   |    |   |   |   |   |   | (  | )  |   |   |   |

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 |     |    |     |    |    |     |    |   |   |   |   |   |   |   |   |   |   |
|-------------------------------------------|-----|----|-----|----|----|-----|----|---|---|---|---|---|---|---|---|---|---|
|                                           | Di+ | 15 | 1.4 | 10 | 10 | 11  | 10 | ٥ | 0 | 7 | 6 | _ | 1 | 2 | 2 | 1 | 0 |
|                                           | DIL | 13 | 14  | 10 | 12 | 1.1 | 10 | 9 | 0 | / | 0 | 5 | 4 | J | ~ |   | ı |



| MT6228     | GSM/GPRS     | Rasehand  | Processor  | Data | Sheet | Revision  | 1 0 |
|------------|--------------|-----------|------------|------|-------|-----------|-----|
| 101 1 0220 | adivi/al 110 | Dastballu | 1 10003301 | Dala | OHEEL | ILEVISION | 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  |    |    |    |    |    |    |   |   |   |   | $\Delta =$ |   |   | C21 |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |            |   |   | R/W |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |            |   | • | 0   |   | • |

#### IMG+0150h Mask coefficient C22

IMGPROC\_MAS

**K22** 

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

### IMG+0154h Mask coefficient C23

IMGPROC\_MAS

**K23** 

| Bit   | 15 | 14 | 13 | 12 | 11 | 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  |    | 4  |    |    |    |    |   |   |   |   |   |   |   | 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 |   |   |



| a | V    | 4        | 2 |
|---|------|----------|---|
| M | EDIA | TE STATE | ċ |

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

#### IMG+0160h Mask coefficient C33

IMGPROC\_MAS

| 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 \end{bmatrix}$ 

C21 C22 C23

C31 C32 C33

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  |    |    |    |    |    |    |   | V |   |   |   |   |   |   | SCA |   |   |
| Type  |    |    |    |    |    |    |   |   | V |   |   |   |   |   | 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\_GA
MMA OFF0

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

This register stores the y-offset value of the segment 0 for gamma correction.

**OFFO** Offset value.

For offset values of other segments, please refer to Table 55.



### IMG+0190h Gamma correction slope value for segment 0

IMGPROC\_GA MMA\_SLP0

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

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 55.

### IMG+01B0h Gamma correction control register

IMGPROC\_GAM MA\_CON

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | <u>√3</u> 7 | 2 | 1 | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|-------------|---|---|-----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |             |   |   | GTO |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   | 7           |   |   | 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 55 Gamma correction offset and slope register list



# IMG+0200h Color adjustment offset x for 2<sup>nd</sup> segment, red

IMGPROC\_COL OR1R OFFX

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

# IMG+0220h Color adjustment offset y for 2<sup>nd</sup> segment, red

IMGPROC\_COL OR1R OFFY

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

# IMG+0240h Color adjustment slope for 2<sup>nd</sup> segment, red

IMGPROC\_COL OR1R\_SLP

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 0.4        | ] 3 | 2   | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|------------|-----|-----|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   |   | <b>∢</b> ¬ |     | SLP |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   |            |     | R/W |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   | 7          |     | 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, green and blue components, the bit-width of the offset value is 8.

**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<br>Address | Register Function                                            | Bit-width | Acronym              |
|---------------------|--------------------------------------------------------------|-----------|----------------------|
| IMG+0200h           | Color adjustment offset x for 2 <sup>nd</sup> segment, red   | 8         | IMGPROC_COLOR1R_OFFX |
| IMG+0204h           | Color adjustment offset x for 3 <sup>rd</sup> segment, red   | 8         | IMGPROC_COLOR2R_OFFX |
| IMG+0208h           | Color adjustment offset x for 2 <sup>nd</sup> segment, green | 8         | IMGPROC_COLOR1G_OFFX |
| IMG+020Ch           | Color adjustment offset x for 3 <sup>rd</sup> segment, green | 8         | IMGPROC_COLOR2G_OFFX |
| IMG+0210h           | Color adjustment offset x for 2 <sup>nd</sup> segment, blue  | 8         | IMGPROC_COLOR1R_OFFX |
| IMG+0214h           | Color adjustment offset x for 3 <sup>rd</sup> segment, blue  | 8         | IMGPROC_COLOR2R_OFFX |
| IMG+0220h           | Color adjustment offset y for 2 <sup>nd</sup> segment, red   | 8         | IMGPROC_COLOR1R_OFFY |
| IMG+0224h           | Color adjustment offset y for 3 <sup>rd</sup> segment, red   | 8         | IMGPROC_COLOR2R_OFFY |
| IMG+0228h           | Color adjustment offset y for 2 <sup>nd</sup> segment, green | 8         | IMGPROC_COLOR1G_OFFY |
| IMG+022Ch           | Color adjustment offset y for 3 <sup>rd</sup> segment, green | 8         | IMGPROC_COLOR2G_OFFY |
| IMG+0230h           | Color adjustment offset y for 2 <sup>nd</sup> segment, blue  | 8         | IMGPROC_COLOR1R_OFFY |
| IMG+0234h           | Color adjustment offset y for 3 <sup>rd</sup> segment, blue  | 8         | IMGPROC_COLOR2R_OFFY |



| Color adjustment slope for 1st segment, red               | 6                                                                                                                                                                                                                                                                                                                                                                                                               | IMGPROC_COLOR0R_SLOPE                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Color adjustment slope for 2 <sup>nd</sup> segment, red   | 6                                                                                                                                                                                                                                                                                                                                                                                                               | IMGPROC_COLOR1R_SLOPE                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Color adjustment slope for 3 <sup>rd</sup> segment, red   | 6                                                                                                                                                                                                                                                                                                                                                                                                               | IMGPROC_COLOR1R_SLOPE                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Color adjustment slope for 1st segment, green             | 6                                                                                                                                                                                                                                                                                                                                                                                                               | IMGPROC_COLOR0G_SLOPE                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Color adjustment slope for 2 <sup>nd</sup> segment, green | 6                                                                                                                                                                                                                                                                                                                                                                                                               | IMGPROC_COLOR1G_SLOPE                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Color adjustment slope for 3 <sup>rd</sup> segment, green | 6                                                                                                                                                                                                                                                                                                                                                                                                               | IMGPROC_COLOR1G_SLOPE                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Color adjustment slope for 1st segment, blue              | 6                                                                                                                                                                                                                                                                                                                                                                                                               | IMGPROC_COLOR0B_SLOPE                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Color adjustment slope for 2 <sup>nd</sup> segment, blue  | 6                                                                                                                                                                                                                                                                                                                                                                                                               | IMGPROC_COLOR1B_SLOPE                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Color adjustment slope for 3 <sup>rd</sup> segment, blue  | 6                                                                                                                                                                                                                                                                                                                                                                                                               | IMGPROC_COLOR1B_SLOPE                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                 | 40                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                                           | Color adjustment slope for 2 <sup>nd</sup> segment, red Color adjustment slope for 3 <sup>rd</sup> segment, red Color adjustment slope for 1 <sup>st</sup> segment, green Color adjustment slope for 2 <sup>nd</sup> segment, green Color adjustment slope for 3 <sup>rd</sup> segment, green Color adjustment slope for 1 <sup>st</sup> segment, blue Color adjustment slope for 2 <sup>nd</sup> segment, blue | Color adjustment slope for 2 <sup>nd</sup> segment, red  Color adjustment slope for 3 <sup>rd</sup> segment, red  Color adjustment slope for 1 <sup>st</sup> segment, green  Color adjustment slope for 2 <sup>nd</sup> segment, green  Color adjustment slope for 3 <sup>rd</sup> segment, green  Color adjustment slope for 1 <sup>st</sup> segment, blue  Color adjustment slope for 2 <sup>nd</sup> segment, blue  Color adjustment slope for 2 <sup>nd</sup> segment, blue  6 |

Table 56 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 | $\Box$ 0 $\Box$ |
|-------|----|----|----|----|----|----|---|---|---|------|----|---|---|---|---|-----------------|
| Name  |    |    |    |    |    |    |   |   |   | ll l | VI |   |   |   |   |                 |
| Type  |    |    |    |    |    |    |   |   |   | R/   | W  |   |   |   |   |                 |
| Reset |    |    |    |    |    |    |   |   |   | (    | )  |   |   |   |   |                 |

This register is the image frame width register. The maximum allowable frame width is 4095. 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

MGPROC\_IMG HEIGHT

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

This register is the image frame height register. The maximum allowable frame height is 4095. 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[3 | 31:16] |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | R/    | W      |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    | 4  | 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 |    |    | 4   |    |    |    |    | (    | 0      |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13  | 12 | 11 | 10 | 9  | 8    | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    | 7 = |    |    |    |    | 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  |    |    |    |    |    |    |   |   |   |   |   | DUN | /MY |   | <b>5</b> |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | R/  | W   |   |          |   |   |
| Reset |    |    |    |    |    |    |   |   |   | • |   | (   | )   |   |          |   |   |

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.

### IMG+0318h R2Y source select

IMGPROC\_R2Y\_

**SRC** 

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

This register defines the RGB source of IPP3 in *IMGPROC mode*. (Only one source can be enabled)

**ON** 1 **OFF** 0

### IMG+031Ch Thumbnail output enable

IMGPROC\_TNL\_

ΕN

|       |    |    |    |    |    |    |            | v |   |   |   |   |   |   |   |     |
|-------|----|----|----|----|----|----|------------|---|---|---|---|---|---|---|---|-----|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | $\sqrt{9}$ | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
| Name  |    |    |    |    |    |    |            |   |   |   |   |   |   |   |   | TNL |
| Type  |    |    |    |    | 4  | 見て |            |   |   |   |   |   |   |   |   | R/W |
| Reset |    |    |    |    |    |    |            |   |   |   |   |   |   |   |   | 0   |

This register defines if enable the thumbnail data path

**ON** 1 **OFF** 0

### IMG+0320h Image machine enable

**IMGPROC EN** 

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

This register defines the enable and software reset signal of the image processor. Before performing image effect adjustment, the reset is necessary.

**EN** 0: Machine disable, pixel-base and filtering path are both disable.

MediaTek Inc. Confidential



1: Machine enable

**RSTB** 0: low-level Reset, all configurations will be initialized.

1: Not Reset.

### 6.16.2 Image Engine in MT6228

The Image Engine (IPP) plays the important role in MT6228 multimedia data path. It performs the necessary color space conversion for next-stage needs. The path from Post-RESZ to IPP1 can also been applied the image effect. Fig.1 shows its input/output data format and the relation with other multimedia module.



Fig. 1. Image Engine in MT6228.

The Graph mode setting depends on what kinds of data paths and image engines that we used. The Details are all listed in Table 4.

| Graph mode   | Used Engine | Function                                   | Note                                                                |
|--------------|-------------|--------------------------------------------|---------------------------------------------------------------------|
| Preview      | IPP1        | IPP1: Y2R, YUV/RGB image effect            |                                                                     |
| Capture      | IPP1, IPP2  | IPP1 : Y2R, YUV/RGB image effect IPP2: Y2R | Thumbnail enable must be set if using IPP2                          |
| MPEG         | IPP1        | IPP1: Y2R, YUV/RGB image effect            |                                                                     |
| IMGPROC      | IPP1, IPP3  | IPP1: Y2R, YUV/RGB image effect IPP3: R2Y  | R2Y source (image_dma, gif, png decorder) must be selected for IPP3 |
| IMAGE Encode | IPP2, IPP3  | IPP2: Y2R<br>IPP3: R2Y                     | Thumbnail enable must be set if using IPP2                          |

Table 57. Graph mode of Image Engine.

# 6.16.3 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.

MediaTek Inc. Confidential



- 5. Gamma correction.
- 6. Color adjustment.
- 7. Linear filtering.
- 8. Nonlinear filtering.

The format of the coefficients is listed in **Table 58**.

| Function                | Parameter group                                | Range (normalized factor) | Format         |
|-------------------------|------------------------------------------------|---------------------------|----------------|
| Hue                     | C11, C12, C21, C22                             | -64 ~ 64 (64)             | 2's complement |
| Saturation              | SAT                                            | 0~127 (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,<br>C23, C31, C32, C33 | -16~15                    | 2's complement |
|                         | Dummy pixel                                    | 0~63                      | Unsigned       |

Table 58 Coefficients format table

#### 6.16.3.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 than 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.16.3.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 = \begin{bmatrix} \frac{1}{b+2} \end{bmatrix}^{2} \cdot \begin{bmatrix} 1 & b & 1 \\ b & b^{2} & b \\ 1 & b & 1 \end{bmatrix}, where b is a positive number$$

$$H_1 = \begin{bmatrix} \frac{1}{9} \end{bmatrix} \cdot \begin{bmatrix} 1 & 1 & 1 \\ 1 & 1 & 1 \\ 1 & 1 & 1 \end{bmatrix}, H_2 = \begin{bmatrix} \frac{1}{10} \end{bmatrix} \cdot \begin{bmatrix} 1 & 1 & 1 \\ 1 & 2 & 1 \\ 1 & 1 & 1 \end{bmatrix}, \text{ and } H_3 = \begin{bmatrix} \frac{1}{16} \end{bmatrix} \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:

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.16.3.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.16.4 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.17 MPEG-4/H.263 Video CODEC

## 6.17.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 34. The encoder block diagram is shown in Figure 35

The decode specification is 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
- 4. Deblocking filter



Source images are coded in blocks of pixels. Since correlation among spatially adjacent blocks is not taken into account during coding, this results in block boundaries being visible when the decoded image is reconstructed. The purpose of deblocking filter is to reduce blocking artifacts while keeping image edge intact. Blocking effect can be reduced efficiently and image will be smooth after applying deblocking filter. A high quality deblocking filter is embedded in the MPEG-4 Decoder. It performs both horizontal and vertical deblocking filtering simultaneously while decoding. Memory access bandwidth is minimized in the design. Luminance as well as chrominance data is filtered.

The encoder specification is as follows:

- 5. Support ISO/IEC 14496-2 MPEG-4 simple profile @ level 0, partially support MPEG-4 simple profile @ level 1
- 6. Support H.263 profile 0 level 10
- 7. 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 34 Block Diagram of Decoder



Figure 35 Block Diagram of Encoder



### 6.17.2 Register Definitions

#### 6.17.2.1 Main Control

### MP4+0000h Video CODEC Command Register

MP4\_CODEC\_C

| 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 | -  | -  | •  | -  | -  | -  | -  | -  | -  | -  | -  | DEC_<br>STAR<br>T | ENC<br>STAR<br>T | DEC_<br>RST | ENC_<br>RST | CORE<br>_RST |
| Type |    |    |    |    |    |    |    |    |    |    |    | WO                | WO               | WO          | WO          | WO           |

This register is the main command register for video CODEC.

**CORE\_RST** Software reset control. Writing 1 to this bit will reset the hardware core excluding APB control register set of decoder and encoder.

**ENC\_RST** Software reset control. Writing 1 to this bit will reset the APB control register set of encoder. Note that this bit won't reset the hardware core.

**DEC\_RST** Software reset control. Writing 1 to this bit will reset the APB control register set of decoder. Note that this bit won't reset the hardware core.

**ENC\_START** Start the encode operation if writing 1 to this bit. The encode operation will start only when no decode operation is running; otherwise the encode operation will queue until decode operation is done.

**DEC\_START** Start the decode operation if writing 1 to this bit. The decode operation will start only when no encode operation is running; otherwise the decode operation will queue until encode operation is done.

### MP4+0004h VLC DMA Command Register

MP4\_VLC\_DMA \_COMD

| 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 | -  | -  | -  | -  | - 5 |    | -  | -  | -  | -  | -  | -  | -  | -  | RESU<br>ME | STOP |
| Туре |    |    |    |    |     |    |    |    |    |    |    |    |    |    | WO         | WO   |

This register is the main control of VLC DMA.

**STOP** Stop the VLC DMA. Stop VLC DMA activities through SW rather than HW state machine.

**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 occured. After re-allocating the target address, SW writes RESUME to unfreeze the encoding process.



#### 6.17.2.2 Encoder

#### 6.17.2.2.1 Control

### MP4+0100h Encoder Configuration Register

MP4\_ENC\_COD

| Bit   | 31 | 30 | 29  | 28                  | 27  | 26        | 25  | 24   | 23    | 22    | 21  | 20  | 19        | 18  | 17  | 16           |
|-------|----|----|-----|---------------------|-----|-----------|-----|------|-------|-------|-----|-----|-----------|-----|-----|--------------|
| Name  | -  | -  | -   | -                   | -   | -         | -   | -    | -     | -     | -   | -   | -         | 1   | -   | CHEC<br>K_TV |
| Type  |    |    |     |                     |     |           |     |      |       |       |     |     |           |     |     |              |
| Reset | 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  | •  | -  | -   | MC_B<br>URST<br>_EN | PMV | DQUA<br>N | FME | HALF | STEP_ | LIMIT |     |     | VPGO<br>B | DCT | IRQ | ENC          |
| 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          |
| 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

- Enable JPEG CODEC Operation
- Enable MPEG-4 Video CODEC Operation

**VPGOB** Control for decoding Video Packet Header; keep this for legacy reason.

- O 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 Plane 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

- O Disable. Perform full pel motion estimation only
- 1 Enable. Perform full pel motion estimation first, then half pel motion estimation

**FME** Fast Motion Enhancement

- 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; keep this for legacy reason.

- O 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

MediaTek Inc. Confidential



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.

- O Disable
- 1 Enable MC\_BURST\_EN 2-beat Burst mode enable signal in MC.
  - O Diable
  - 1 Enable

**CHECK** TVEnable signal to check if TV codec is busy before starting encoding operation.

- O Do not check TV codec
- 1 Check TV codec

### MP4+0104h Encoder Status Register

**MP4 ENC STS** 

| D:-  | 21 | 00 | 00 | 00 | 27 | 00 | 0.5 | 0.4 | 00    | 00 | - 04 |    | 40 | 40 | 47 | 4.0 |
|------|----|----|----|----|----|----|-----|-----|-------|----|------|----|----|----|----|-----|
| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24  | 23    | 22 | 21   | 20 | 19 | 18 | 17 | 16  |
| Name |    |    |    |    |    |    |     | STA | ATE . |    |      |    |    |    |    |     |
| Type | RO  | 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 |    |    |    |    |    |    |     | STA | ATE / |    |      |    |    |    |    |     |
| Type | RO  | RO  | RO    | RO | RO   | RO | RO | RO | RO | 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+0108h Encoder Interrupt Mask Register

MP4\_ENC\_IRQ\_ MASK

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18   | 17                 | 16           |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|-----|------|--------------------|--------------|
| Name  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -   | -    | -                  | -            |
| Type  |    |    |    |    |    |    |    | 1  |    |    |    |    |     |      |                    |              |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |     |      |                    |              |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3   | 2    | 1                  | 0            |
| Name  | -  | -  | -  | -  | -  |    | -  | -  | -  | -  | -  | -  | DMA | PACK | BLOC<br>K_DO<br>NE | ENC_<br>DONE |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    | R/W | R/W  | R/W                | R/W          |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    | 1   | 1    | 1                  | 1            |

This register contains mask bit for each interrupt source in MPEG-4 Video encoder. 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 VLE DMA Limit interrupt.

PACK Mask of video packet bit count expire interrupt.

**BLOCK\_DONE** Mask of block procedure complete interrupt.

**ENC DONE** Mask of encode complete interrupt.

MediaTek Inc. Confidential

464/616



### MP4+010Ch Encoder Interrupt Status Register

MP4\_ENC\_IRQ\_

| 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_DO<br>NE |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    | 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 MP4\_ENC\_CODEC\_CONF 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 Exceed interrupt. If a video packet size is larger than defined the interrupt will happen.

**BLOCK\_DONE** Block decode or encode complete. A normal complete flag if the SW needs a block-based HW decoding or encoding.

**ENC\_DONE** Encode complete. A normal condition when encoding procedure is done.

### MP4+0110h Encoder Interrupt Acknowledge Register

MP4\_ENC\_IRQ\_ ACK

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24  | 23 | 22 | 21 | 20 | 19  | 18 | 17                 | 16 |
|------|----|----|----|----|----|----|-----|-----|----|----|----|----|-----|----|--------------------|----|
| Name | -  | -  | -  | -  | -  | -  | - ( | 7.7 | )  | -  | -  | -  | -   | -  | -                  | -  |
| Type |    |    |    |    |    |    |     |     |    |    |    |    |     |    |                    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7  | 6  | 5  | 4  | 3   | 2  | 1                  | 0  |
| Name | -  | -  | -  | -  | -  | -  |     | -   | -  | -  | -  | -  | DMA |    | BLOC<br>K_DO<br>NE |    |
| Type |    |    |    |    |    |    |     |     |    |    |    |    | 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 and clear the corresponding bit in MP4\_ENC\_IRQ\_STS.

**ENC DONE** Encode Task Complete

**BLOCK DONE** Block Task Complete

PACK Video Packet Bit Count Expired

DMA VLC DMA Buffer Limit Reached

### MP4+0114h 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  | -  |    |    | -  | -  |     |     |     |     | PACI | CNT |     |     |     |     | <b>PACK</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 |    |    | T. |    |    | 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  | -   | -   |     |     | INT | RA  |     |     | - | - |     |     | SK  | (IP |     |     |
| 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$ ) <= 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 SADy < *intra\_threshold\**1024. Otherwise, *mb\_type* is set to 3'h3 (Intra\_MB)

**PACK** Use Video Packet Mode

- O 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.17.2.2.2 Base Addresses

### MP4+0124h Encoder Current VOP Base Address Register

MP4\_ENC\_VOP
ADDR

| Bit  | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24   | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|------|-----|-----|-----|-----|-----|-----|-----|------|-----|-----|-----|-----|-----|-----|-----|-----|
| Name |     |     |     |     |     |     |     | V    | OP  |     |     |     |     |     |     |     |
| Type | 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 |     |     |     |     |     |     | V   | OP _ |     |     |     |     |     |     | -   | -   |
| Type | R/W  | R/W | R/W | R/W | R/W | R/W | 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.

### MP4+0128h Encoder Reference VOP Base Address Register

MP4\_ENC\_REF\_ ADDR

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





MP4\_ENC\_REC

| Bit  | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name |     |     |     |     |     |     |     | RE  | С   |     |     |     |     |     |     |     |
| Type | RO  | R/W | R/W |
| Bit  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name |     |     |     |     |     |     | RI  | C   |     |     |     |     |     |     | -   | -   |
| Type | 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+0130h VLE Data Load-Store LSB Base Address Register

MP4\_ENC\_DAT A\_STORE\_ADD

**R** 

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

This register describes the LSB address of VLE 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 VLE Data Load-Store buffer

# MP4+0134h DC/AC Prediction Storage LSB Base Address Register

MP4\_ENC\_DAC P\_ADDR

| Bit  | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name |     |     |     |     |     |     |     | DA  | CP  |     |     |     |     |     |     |     |
| Type |     |     |     |     |     |     |     |     |     |     |     |     |     |     | R/W | R/W |
| Bit  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name |     |     |     |     | 70  |     | DA  | CP  |     |     |     |     |     |     | -   | -   |
| Type | 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: 1K bytes and 4K bytes, respectively.

**DACP** LSB address of DC/AC Prediction Storage buffer

### MP4+0138h Motion Vector Storage LSB Base Address Register

MP4\_ENC\_MVP ADDR

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

MediaTek Inc. Confidential



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

This register describes the LSB address of Motion Vector Storage buffer. Note that this base address should be 4-byte aligned. And the required buffer size for encoder should be mb\_x\_limit \* 2 \* 4 bytes, which equals to 320 Bytes for VGA size.

MVP ADDR LSB address of Motion Vector Storage buffer

6.17.2.2.3 Data Structure

### MP4+0140h Encoder VOP Structure 0 Register

MP4\_ENC\_VOP STRUCTO

| Bit  | 31  | 30     | 29  | 28  | 27  | 26    | 25  | 24  | 23  | 22    | 21  | 20        | 19  | 18   | 17   | 16        |
|------|-----|--------|-----|-----|-----|-------|-----|-----|-----|-------|-----|-----------|-----|------|------|-----------|
| Name | -   | -      | -   | -   | -   | -     | -   | -   | -   | -     | -   |           | -   | -    |      | ROUN<br>D |
| Туре |     |        |     |     |     |       |     |     |     |       |     |           |     |      |      | R/W       |
| Bit  | 15  | 14     | 13  | 12  | 11  | 10    | 9   | 8   | 7   | 6     | 5   | 4         | 3   | 2    | 1    | 0         |
| Name | ١   | /LCTHI | 3   |     |     | QUANT |     |     |     | FCODE | V   | SHOR<br>T | -   | RVLC | DATA | 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 Plane that is going to be processed by video CODEC.

**TYPE** vop\_coding\_type definition, for both decode and encode.

- O This is a P-VOP frame (inter frame)
- 1 This is an I-VOP frame (intra frame)

**DATA** data\_partitioned, for decode only; keep this for legacy reason.

- O Data stream is in non-data-partitioned mode
- Data stream is in data-partitioned mode

**RVLC** resversible\_vlc, for decode only; keep this for legacy reason.

- **0** Data stream contains no reversible VLC information
- 1 Data stream uses reversible VLC tables.

SHORT short\_video\_header; for both decode and encode

- Normal MPEG-4 format
- 1 H.263 Compatible format

**FCODE** fcode size setting for both decode and encode, ranges from 0 to 7.

**QUANT**vop\_quant. For both decode and encode. 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. For decode only. 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+0144h Encoder VOP Structure 1 Register

MP4\_ENC\_VOP \_STRUCT1

| Bit  | 31  | 30  | 29  | 28  | 27  | 26     | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18     | 17   | 16  |
|------|-----|-----|-----|-----|-----|--------|-----|-----|-----|-----|-----|-----|-----|--------|------|-----|
| Name | -   | -   | -   |     |     | HECBIT |     |     | -   | -   | -   | -   |     | MBLE   | NGTH |     |
| 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 | 1   |     | -   | -   | -   |     |     | 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 Plane 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. 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+0148h Encoder VOP Structure 2 Register

MP4\_ENC\_VOP \_STRUCT2

| 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 | -  | -  | -  |     | V   | P_YPO | S   |     | -   | -   | -   |             | V   | P_XPO | S   |     |
| 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 Plane that is going to be processed by video CODEC.

**VP XPOS** Starting position of the current Video Packet in X coordinate.

**VP\_YPOS** Starting position of the current Video Packet in Y coordinate.

MBNO Macroblock count limit for a video packet or frame. For a CIF frame the value will be 396.

## MP4+014Ch VOP Structure 3 Register

MP4\_VOP\_STR UCT3

| 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 | <u> </u> | 10          | 9  | 8  | 7  | 6  | 5  | 4           | 3  | 2           | 1  | 0  |
| Name | -  | -  | -  |    |          | <b>YPOS</b> |    |    | -  | -  | -  |             |    | <b>XPOS</b> |    |    |
| Туре |    |    |    | 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+0150h MB Structure 0 Register

MP4\_ENC\_MB\_ STRUCTO

| Bit  | 31  | 30  | 29        | 28  | 27  | 26  | 25  | 24  | 23   | 22  | 21  | 20  | 19  | 18   | 17     | 16   |
|------|-----|-----|-----------|-----|-----|-----|-----|-----|------|-----|-----|-----|-----|------|--------|------|
| Name | •   | -   | -         | -   | -   | -   | -   | -   | -    | -   | -   | -   | -   | QU   | IANTIZ | ER   |
| Type |     |     |           |     |     |     |     |     |      |     |     |     |     | R/W  | R/W    | R/W  |
| Bit  | 15  | 14  | 13        | 12  | 11  | 10  | 9   | 8   | 7    | 6   | 5   | 4   | 3   | 2    | 1      | 0    |
| Name |     |     | DCVL<br>C | AC  | DQU | ANT |     |     | PATI | ERN |     |     |     | TYPE |        | CODE |
| 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. Also used to provide hardware certain header information if all header parsing is done by software instead of hardware.

**CODED** not\_coded flag of current macroblock; not\_coded can be decoded by hardware from macroblock header.

**TYPE** mb\_coding\_type of current macroblock; mb\_coding\_type can be decoded by hardware from mcbpc in

macroblck header.

PATTERN pattern\_code of current macroblock; pattern\_code can be decoded by hardware from cbpc and cbpy in

macroblock header.

**DQUANT** dquant. It can be -2, -1, +1 or +2; total 4 possible choices using 2 bits to represent; dquant can be decoded by

hardware from macroblock header.

AC ac\_pred\_flag. It decides whether AC prediction is needed; always 0 in encoder; ac\_pred\_flag can be decoded

by hardware from macroblock header.

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

6.17.2.2.4 VLC DMA

## MP4+0160h Encoder VLC DMA Base Address Register

MP4\_ENC\_VLC\_ BASE ADDR

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

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\_ENC\_VLC\_ BASE BITCNT

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





| Name | - | - | - | - | - | - | - | - | - | - | - |     |     | BIT |     |     |
|------|---|---|---|---|---|---|---|---|---|---|---|-----|-----|-----|-----|-----|
| Type |   |   |   |   |   |   |   |   |   |   |   | R/W | R/W | R/W | R/W | R/W |

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".

Start of Bit at the 1<sup>st</sup> Code Word of 1<sup>st</sup> DMA Buffer

### MP4+0168h Encoder VLC DMA Buffer Limit Register

MP4\_ENC\_VLC\_

| 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  |     |     |     |     |     |     |     | LIN | /IIT |     |     |     | 7   |     |     |     |
| Type  | 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   |

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+016Ch Encoder VLC DMA Current Word Register

MP4\_ENC\_VLC\_ WORD

| Bit  | 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|------|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|----|
| Name |      |    |    |    |    |    |    | AD  | DR |    |    |    |    |    |    |    |
| Type | RO   | RO | RO | RO | RO | RO | RO | 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 | 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+0170h Encoder VLC DMA Current Bit Count Register

MP4\_ENC\_VLC\_ BITCNT

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



## MP4+0174h

# **Encoder VLC DMA Ring Buffer Ending Address Register**

MP4\_ENC\_VLC\_ JUMP\_FROM\_A

| Bit   | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24     | 23    | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|-------|-----|-----|-----|-----|-----|-----|-----|--------|-------|-----|-----|-----|-----|-----|-----|-----|
| Name  |     |     |     |     |     |     | JUI | /IP_FR | OM_AD | DR  |     |     |     |     |     |     |
| 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   |
| Bit   | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8      | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name  |     |     |     |     |     |     | JUI | /IP_FR | OM_AD | DR  |     |     |     |     | ,   |     |
| 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   |

JUMP\_FROM\_ADDR

The ending address of the current DMA buffer; when a jump takes place in VLC DMA address counter, the address will jump from the ending address of the current DMA buffer, which is JUMP\_FROM\_ADDR, to the starting address of the next DMA buffer, which is JUMP\_TO\_ADDR. To disable the ring buffer feature, set this register to all ones; note that the address counter will not jump until done with the content in memory with address as JUMP\_FROM\_ADDR. So the memory content with address JUMP\_FROM\_ADDR will be executed by hardware.

## MP4+0178h

# **Encoder VLC DMA Ring Buffer Starting Address Register**

MP4\_ENC\_VLC\_ JUMP\_TO\_ADD

| Bit   | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24    | 23    | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|-------|-----|-----|-----|-----|-----|-----|-----|-------|-------|-----|-----|-----|-----|-----|-----|-----|
| Name  |     |     |     |     |     |     | Jl  | JMP_T | O_ADD | R   |     |     |     |     |     |     |
| 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   |
| Bit   | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8 🗇   | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name  |     |     |     |     |     |     | Jl  | JMP_T | O_ADD | R   |     |     |     |     |     |     |
| 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   | T     | 1     | 1   | 1   | 1   | 1   | 1   | 1   | 1   |

JUMP\_TO\_ADDR The starting address of the next DMA buffer; when a jump takes place in VLC DMA address counter, the address will jump from the ending address of the current DMA buffer, which is JUMP\_FROM\_ADDR, to the starting address of the next DMA buffer, which is JUMP\_TO\_ADDR; note that the address counter will not jump until done with the content in memory with address as JUMP\_FROM\_ADDR. So the memory content with address JUMP\_FROM\_ADDR will be executed by hardware.

#### 6.17.2.2.5 Resync Marker

#### MP4+0180h

# MPEG4 Encoder Resync Marker Configuration 0 Register

MP4\_ENC\_RES
YNC CONF0

| Bit   | 31  | 30   | 29  | 28  | 27  | 26  | 25  | 24  | 23    | 22     | 21  | 20  | 19  | 18  | 17  | 16  |
|-------|-----|------|-----|-----|-----|-----|-----|-----|-------|--------|-----|-----|-----|-----|-----|-----|
| Name  | EN  | MODE |     |     |     |     |     |     | PERIO | D_BITS |     |     |     |     |     |     |
| 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    | 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  |     |     |     |     |     |     |     | PERIO | D_BITS |     |     |     |     |     |     |     |
|-------|-----|-----|-----|-----|-----|-----|-----|-------|--------|-----|-----|-----|-----|-----|-----|-----|
| 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   |     |

**EN** Resync marker insertion enable

- O Disable resync marker insertion
- 1 Enable resync marker insertion

**MODE** Resync Marker insertion mode selection

- o resync marker is inserted based on number of bits
- 1 resync marker is inserted based on number of macroblocks

**PERIOD\_BITS** Period in number of bits to insert resync marker; only effective when MODE is set to 0; hardware will insert resync marker at the next macroblock boundary once the bit length of a video packet exceeds this value.

## MP4+0184h

# MPEG4 Encoder Resync Marker Configuration 1 Register

MP4\_ENC\_RES
YNC CONF1

| Bit   | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24    | 23   | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|-------|-----|-----|-----|-----|-----|-----|-----|-------|------|-----|-----|-----|-----|-----|-----|-----|
| Name  | -   | -   | -   | -   | -   | -   | -   | -     | -    | -   | -   |     | -   | -   | -   | HEC |
| Type  | R/W   | R/W  | R/W | R/W | P/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  |     |     |     |     |     |     |     | PERIC | D_MB |     | 2_  |     |     |     |     |     |
| 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   |

**HEC** Header Extension Code; indicates the value of header\_extension\_code in MPEG4 standard (ISO/IEC 14496-2)

- **0** header extension code is 0.
- 1 header\_extension\_code is 1.

**PERIOD\_MB** Period in number of macroblocks (MB) to insert resync marker; only effective when MODE is set to 1; hardware will insert resync marker at the next macroblock boundary once the number of macroblock in current video packet exceeds this value.

## MP4+0188h MPEG4 Encoder Local Time Base Register

MP4\_ENC\_TIME BASE

| Bit   | 31  | 30  | 29  | 28  | 27  | 26                       | 25               | 24    | 23           | 22     | 21    | 20  | 19  | 18  | 17  | 16  |
|-------|-----|-----|-----|-----|-----|--------------------------|------------------|-------|--------------|--------|-------|-----|-----|-----|-----|-----|
| Name  | -   | -   | -   | -   | - 4 | $\overline{\mathcal{A}}$ | ) / <del>-</del> |       | <b>IODUL</b> | O_TIMI | E_BAS | E   |     | В   | W   |     |
| 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  |     |     |     |     | 7   |                          | VOP              | TIME_ | <b>NCRE</b>  | MENT   |       |     |     |     |     |     |
| 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   |

**MODULO\_TIME\_BASE** Represent the value of modulo\_time\_base; value ranges from 0 to 31.

Bit width of vop\_time\_increment. The real bit-width of vop\_time\_increment is (BW + 1), ranging from 1 to 16.

**VOP\_TIME\_INCREMENT** Carries the value of vop\_time\_increment defined in MPEG4 standard (ISO/IEC 14496-2); the meaningful bit width of vop\_time\_increment is signaled by BW field.



#### 6.17.2.3 Decoder

#### MP4+0200h Decoder Configuration Register

MP4\_DEC\_COD EC CONF

| Bit   | 31          | 30           | 29  | 28                 | 27  | 26        | 25  | 24   | 23  | 22   | 21    | 20  | 19        | 18  | 17  | 16           |
|-------|-------------|--------------|-----|--------------------|-----|-----------|-----|------|-----|------|-------|-----|-----------|-----|-----|--------------|
| Name  | -           | -            | -   | -                  | -   | -         | -   | -    | -   | -    | -     | -   | -         | •   |     | CHEC<br>K_TV |
| 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  | DEBL<br>OCK | COPY<br>_REC | -   | MC_B<br>URST<br>EN | PMV | DQUA<br>N | FME | HALF |     | STEP | LIMIT |     | VPGO<br>B | DCT | IRQ | ENC          |
| 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            |

This register is used to configure the operating conditions and modes of video CODEC

**ENC** Video CODEC Operation Mode

- Decode Mode
- 1 Encode Mode

IRQ Control for interrupt request

- O Disable the interrupt reporting mechanism
- 1 Enable the interrupt reporting mechanism

**DCT** DCT Control

- Enable JPEG CODEC Operation
- 1 Enable MPEG-4 Video CODEC Operation

**VPGOB** Control for decoding Video Packet Header; keep this for legacy reason.

- O 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 Plane Level

**STEP\_LIMIT** Step limit for Motion Estimation, for encode only; keep this for legacy reason. 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, for encode only; keep this for legacy reason.

- O Disable. Perform full pel motion estimation only
- 1 Enable. Perform full pel motion estimation first, then half pel motion estimation

**FME** Fast Motion Enhancement, for encode only; keep this for legacy reason.

- 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.

- O Disable
- 1 Enable
- PMV Predictive Motion Vector Search, for encode only; keep this for legacy reason. 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.

- O Disable
- 1 Enable

**COPY REC** Enable signal to copy reconstructed memory to deblocking memory.

- 0 Disable
- 1 Enable

**DEBLOCK** Enable signal for deblocking mode. 3 different combination of DEBLOCK and COPY\_REC are shown below

- **00** (DECLOCK = 0 & COPY\_REC = 0): disable both deblocking filter and memory copy from reconstructed memory to deblocking memory.
- **01** (DECLOCK = 0 & COPY\_REC = 1): disable both deblocking filter and memory copy from reconstructed memory to deblocking memory.
- **10** (DECLOCK = 1 & COPY\_REC = 0): Enable deblocking filter and save deblocked frame to deblocking memory.
- 11 (DECLOCK = 1 & COPY\_REC = 1): Disable deblocking filter and save non-deblocked frame to deblocking memory.

**CHECK** TVEnable signal to check if TV codec is busy before starting decoding operation.

- O Do not check TV codec
- 1 Check TV codec

### MP4+0204h Decoder Status Register

MP4 DEC STS

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|-------|-----|----|----|----|----|----|----|----|
| Name |    |    |    |    |    |    |    | STA   | ATE |    |    |    |    |    |    |    |
| 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 |    |    |    |    |    |    |    | > ST/ | ATE |    |    |    |    |    |    |    |
| Type | RO    | RO  | RO | RO | RO | RO | RO | RO | 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+0208h Decoder Interrupt Mask Register

MP4\_DEC\_IRQ\_ MASK

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21  | 20                 | 19           | 18         | 17  | 16  |
|-------|----|----|----|----|----|----|----|----|----|----|-----|--------------------|--------------|------------|-----|-----|
| Name  | -  | -  | -  |    | -  | -  | -  | -  | -  | -  | -   | -                  | -            | -          | -   | -   |
| Type  |    |    |    |    | 4  |    |    |    |    |    |     |                    |              |            |     |     |
| Reset |    |    |    |    |    |    |    |    |    |    |     |                    |              |            |     |     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5   | 4                  | 3            | 2          | 1   | 0   |
| Name  | 1  | 7  |    | -  | -  | -  | -  | -  | -  | -  | DMA | BLOC<br>K_DO<br>NE | DEC_<br>DONE | MARK<br>ER | RLD | VLD |
| Type  |    |    |    |    |    |    |    |    |    |    | R/W | R/W                | R/W          | R/W        | R/W | R/W |
| Reset |    |    |    |    |    |    |    |    |    |    | 1   | 1                  | 1            | 1          | 1   | 1   |





**DMA** Mask of VLC DMA interrupt.

**BLOCK\_DONE** Mask of block procedure complete interrupt.

**DEC DONE** 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+020Ch Decoder Interrupt Status Register

MP4\_DEC\_IRQ\_ STS

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22  | 21  | 20                 | 19 | 18   | 17  | 16  |
|------|----|----|----|----|----|----|----|----|----|-----|-----|--------------------|----|------|-----|-----|
| Name | -  | -  | -  | -  | -  | -  | -  | -  | -  | -   |     | 0) <u>-</u>        | -  | -    | -   | -   |
| Type |    |    |    |    |    |    |    |    |    |     |     |                    |    |      |     |     |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6   | 5   | 4                  | 3  | 2    | 1   | 0   |
| Name | •  | -  | -  | •  | •  | -  | -  | -  |    | · 1 | DMA | BLOC<br>K_DO<br>NE |    | MARK | RLD | VLD |
| Type |    |    |    |    |    |    |    |    |    |     | 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 MP4\_DEC\_CODEC\_CONF 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.

**BLOCK\_DONE** Block decode or encode complete. A normal complete flag if the SW needs a block-based HW decoding or encoding..

**DEC\_DONE** Decode complete. A normal condition when decoding procedure is done.

MARK Marker decode error occurred.

Run length coding error. Generated when the accumulated run value is larger than 64 (the 8x8 block memory size).

VLD error of decoding process. Generated when a code can not be correctly referenced in VLD table

# MP4+0210h Decoder Interrupt Acknowledge Register

MP4\_DEC\_IRQ\_

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





| Name | - | - | - | - | - | - | - | - | - | - | DMA | BLOC<br>K_DO<br>NE | DEC_<br>DONE | MARK | RLD | VLD |
|------|---|---|---|---|---|---|---|---|---|---|-----|--------------------|--------------|------|-----|-----|
| Type |   |   |   |   |   |   |   |   |   |   | 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\_DONE** Decode Task Complete

**BLOCK\_DONE** Block Task Complete

**DMA** VLC DMA Buffer Limit Reached

#### 6.17.2.3.1 Base Address

## MP4+0224h Decoder Reference VOP Base Address Register

MP4\_DEC\_REF\_ ADDR

| Bit  | 31  | 30  | 29  | 28  | 27  | 26  | 25   | 24   | 23   | 22   | 21  | 20  | 19  | 18  | 17  | 16  |
|------|-----|-----|-----|-----|-----|-----|------|------|------|------|-----|-----|-----|-----|-----|-----|
| Name |     |     |     |     |     |     |      | REF_ | ADDR |      |     |     |     |     |     |     |
| Type | 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 |     |     |     |     |     |     | REF_ | ADDR |      |      |     |     |     |     | -   | -   |
| Type | R/W  | R/W  | R/W  | R/W  | R/W | R/W | R/W | 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.

## MP4+0228h Decoder Reconstructed VOP Base Address Register

MP4\_DEC\_REC ADDR

| Bit  | 31  | 30  | 29  | 28  | 27  | 26_ | 25   | 24   | 23   | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|------|-----|-----|-----|-----|-----|-----|------|------|------|-----|-----|-----|-----|-----|-----|-----|
| Name |     |     |     |     |     |     |      | REC_ | ADDR |     |     |     |     |     |     |     |
| Type | 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 |     |     |     |     |     |     | REC_ | ADDR |      |     |     |     |     |     | -   | -   |
| Type | 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.

## MP4+022Ch Decoder Deblocking Base Address Register

MP4\_DEC\_DEB LOCK\_ADDR

| Bit  | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24           | 23    | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|------|-----|-----|-----|-----|-----|-----|-----|--------------|-------|-----|-----|-----|-----|-----|-----|-----|
| Name |     |     |     |     |     |     | D   | <b>EBLOC</b> | K_ADD | R   |     |     |     |     |     |     |
| 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   |



MP4+0230h

| Name |     |     |     |     |     | DI  | <b>EBLOC</b> | K_ADD | R   |     |     |     |     |     | - | - |  |
|------|-----|-----|-----|-----|-----|-----|--------------|-------|-----|-----|-----|-----|-----|-----|---|---|--|
| Type | R/W          | R/W   | R/W | R/W | R/W | R/W | R/W | R/W |   |   |  |

This register describes the starting address of deblocking 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).

**DEBLOCK\_ADDR** Deblocking Base Address.

# MP4\_DEC\_DAT

Decoder Data Load-Store LSB Base Address Register A\_STORE\_ADD

| NI       |     |     | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|----------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name     |     |     |     |     |     |     | STC | RE  |     |     |     |     |     |     |     |
| Type     |     |     |     |     |     |     |     |     |     |     |     |     |     | R/W | R/W |
| Bit 15   | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name     |     |     |     |     |     | STO | ORE |     |     |     |     |     |     | -   | -   |
| Type R/W |     |     |

This register describes the LSB address of memory buffer used to store the macroblock header, Intra DC values and motion vectors as decoding data-partitioned MPEG4 files. 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 VLE Data Load-Store buffer

## MP4+0234h DC/AC Prediction Storage LSB Base Address Register

MP4\_DEC\_DAC P ADDR

| Bit  | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24    | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|------|-----|-----|-----|-----|-----|-----|-----|-------|-----|-----|-----|-----|-----|-----|-----|-----|
| Name |     |     |     |     |     |     |     | DA    | CP  |     |     |     |     |     |     |     |
| Type |     |     |     |     |     |     |     |       |     |     |     |     |     |     | R/W | R/W |
| Bit  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8     | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name |     |     |     |     |     |     | DA  | ICP - |     |     |     |     |     |     | -   | -   |
| Type | 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: 1K bytes and 4K bytes, respectively.

**DACP** LSB address of DC/AC Prediction Storage buffer

## MP4+0238h Motion Vector Storage LSB Base Address Register

MP4\_DEC\_MVP ADDR

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

This register describes the LSB address of Motion Vector Storage buffer. Note that this base address should be 4-byte aligned. And the required buffer size for encoder should be mb\_x\_limit \* 2 \* 4 bytes, which equals to 320 Bytes for VGA size.

478/616

MVP\_ADDR LSB address of Motion Vector Storage buffer



6.17.2.3.2 Data Structure

### MP4+0240h Decoder VOP Structure 0 Register

MP4\_DEC\_VOP STRUCT0

| Bit  | 31  | 30    | 29  | 28  | 27  | 26    | 25  | 24  | 23  | 22    | 21  | 20        | 19  | 18   | 17   | 16        |
|------|-----|-------|-----|-----|-----|-------|-----|-----|-----|-------|-----|-----------|-----|------|------|-----------|
| Name | -   | -     | -   | -   | -   | -     | •   | -   | -   | -     | -   | -         | -   | -    |      | ROUN<br>D |
| Type |     |       |     |     |     |       |     |     |     |       |     |           |     | .0   |      | R/W       |
| Bit  | 15  | 14    | 13  | 12  | 11  | 10    | 9   | 8   | 7   | 6     | 5   | 4         | 3   | 2    | 1    | 0         |
| Name | \   | /LCTH | 3   |     | (   | QUANT | •   |     |     | FCODE |     | SHOR<br>T | -   | 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 Plane that is going to be processed by video CODEC.

**TYPE** vop\_coding\_type definition, for both decode and encode.

- O This is a P-VOP frame (inter frame)
- 1 This is an I-VOP frame (intra frame)

**DATA** data\_partitioned, for decode only.

- **0** Data stream is in non-data-partitioned mode
- 1 Data stream is in data-partitioned mode

**RVLC** resversible\_vlc, for decode only.

- **0** Data stream contains no reversible VLC information
- 1 Data stream uses reversible VLC tables.

**SHORT** short\_video\_header; for both decode and encode

- Normal MPEG-4 format
- 1 H.263 Compatible format

**FCODE** fcode size setting for both decode and encode, ranges from 0 to 7.

**QUANT**vop\_quant. For both decode and encode. 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. For decode only. 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+0244h Decoder VOP Structure 1 Register

MP4\_DEC\_VOP \_STRUCT1

| Bit  | 31  | 30  | 29  | 28   | <del></del> 27 | 26            | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18     | 17   | 16  |
|------|-----|-----|-----|------|----------------|---------------|-----|-----|-----|-----|-----|-----|-----|--------|------|-----|
| Name |     | -   | -   |      |                | HECBIT        |     |     | -   | -   | -   | -   | 1.0 | MBLE   | NGTH |     |
| 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 | -   | -   | 4 - |      |                | <b>YLIMIT</b> |     |     | -   | -   | -   |     |     | 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 Plane 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. For larger MBCNT, we have larger MBLENGTH.

MBLENGTH is ranged from 1 to 14.

**HECBIT** Bit count of header extension code in Video Packet Header; this section includes modulo\_time\_base, vop\_time\_increment, vop\_coding\_type, intra\_dc\_vlc\_thr and vop\_fcode\_forward(only in P-VOP).

### MP4+0248h Decoder VOP Structure 2 Register

MP4\_DEC\_VOP STRUCT2

| Bit  | 31 | 30 | 29 | 28  | 27  | 26    | 25  | 24  | 23  | 22  | 21  | 20          | 19,  | <u> </u> | 17  | 16  |
|------|----|----|----|-----|-----|-------|-----|-----|-----|-----|-----|-------------|------|----------|-----|-----|
| Name | -  | -  | -  | -   | -   | -     | -   |     |     |     |     | <b>MBNO</b> | 7/5  |          |     |     |
| 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 | -  | -  | -  |     | ٧   | P_YPO | S   |     | -   | -   | -   |             | V    | P_XPO    | S   |     |
| 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 Plane that is going to be processed by video CODEC.

**VP\_XPOS** Starting position of the current Video Packet in X coordinate.

**VP YPOS** Starting position of the current Video Packet in Y coordinate.

MBNO Macroblock count limit for a video packet or frame. For a CIF frame the value will be 396.

## MP4+024Ch Decoder MB Structure 0 Register

MP4\_DEC\_MB\_ STRUCT0

| Bit  | 31   | 30    | 29        | 28  | 27  | 26  | 25  | 24         | 23  | 22   | 21  | 20  | 19  | 18   | 17     | 16   |
|------|------|-------|-----------|-----|-----|-----|-----|------------|-----|------|-----|-----|-----|------|--------|------|
| Name | -    | -     | -         | -   | -   | -   | -   | •          | -   | -    | -   | -   | -   | QL   | JANTIZ | ER   |
| Type |      |       |           |     |     |     |     | <b>T</b> 1 |     |      |     |     |     | R/W  | R/W    | R/W  |
| Bit  | 15   | 14    | 13        | 12  | 11  | 10  | 9   | 8          | 7   | 6    | 5   | 4   | 3   | 2    | 1      | 0    |
| Name | QUAN | TIZER | DCVL<br>C | AC  | DQU | ANT |     |            | PAT | ΓERN |     |     |     | TYPE |        | CODE |
| 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 the current macroblock. This register is mostly used for debugging. Also used to provide hardware certain header information if all header parsing is done by software instead of hardware.

**CODED** not\_coded flag of current macroblock; not\_coded can be decoded by hardware from macroblock header.

**TYPE** mb\_coding\_type of current macroblock; mb\_coding\_type can be decoded by hardware from mcbpc in macroblck header.

**PATTERN** pattern\_code of current macroblock; pattern\_code can be decoded by hardware from cbpc and cbpy in macroblock header.

**DQUANT** dquant. It can be -2, -1, +1 or +2; total 4 possible choices using 2 bits to represent; dquant can be decoded by hardware from macroblock header.

ac\_pred\_flag. It decides whether AC prediction is needed; always 0 in encoder; ac\_pred\_flag can be decoded by hardware from macroblock header.

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

MediaTek Inc. Confidential

480/616



6.17.2.3.3 VLC DMA

## MP4+0260h Decoder VLC DMA Base Address Register

MP4\_DEC\_VLC\_ BASE\_ADDR

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

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+0264h Decoder VLC DMA Base Bit Count Register

MP4\_DEC\_VLC\_ BASE\_BITCNT

| 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 |    |    |    |    |    |    |    |    |    |    |    | R/W | R/W | R/W | R/W | R/W |

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".

Start of Bit at the 1<sup>st</sup> Code Word of 1<sup>st</sup> DMA Buffer

## MP4+0268h Decoder VLC DMA Buffer Limit Register

MP4\_DEC\_VLC\_

| 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  |     |     |     |     |     |     |     | LIN | /IIT |     |     |     |     |     |     |     |
| Type  | 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   |

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+026Ch Decoder VLC DMA Current Word Register

MP4\_DEC\_VLC\_ WORD

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



| Туре | RO   | RO | RO | RO | RO | RO | RO | 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 | 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 decode of a frame is done.

**ADDR** VLC DMA current Address

### MP4+0270h Decoder VLC DMA Current Bit Count Register

MP4\_DEC\_VLC\_ BITCNT

| 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 | RO |

This register provides the bit position information of a certain Code Word that is under process of video CODEC.

**BITCNT** Current Bit Count

MP4+0274h

# Decoder VLC DMA Ring Buffer Ending Address Register

MP4\_DEC\_VLC\_ JUMP\_FROM\_A DDR

| Bit   | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24    | 23    | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|-------|-----|-----|-----|-----|-----|-----|-----|-------|-------|-----|-----|-----|-----|-----|-----|-----|
| Name  |     |     |     |     |     |     | JUI | MP_FR | OM_AD | DR  |     |     |     |     |     |     |
| 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   |       | 7     | 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  |     |     |     |     |     |     | JUI | MP_FR | OM_AD | DR  |     |     |     |     |     |     |
| 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   |

JUMP\_FROM\_ADDR

The ending address of the current DMA buffer; when a jump takes place in VLC DMA address counter, the address will jump from the ending address of the current DMA buffer, which is JUMP\_FROM\_ADDR, to the starting address of the next DMA buffer, which is JUMP\_TO\_ADDR. To disable the ring buffer feature, set this register to all ones; note that the address counter will not jump until done with the content in memory with address as JUMP\_FROM\_ADDR. So the memory content with address JUMP\_FROM\_ADDR will be executed by hardware.

MP4+0278h

# **Decoder VLC DMA Ring Buffer Starting Address Register**

MP4\_DEC\_VLC\_ JUMP\_TO\_ADD R

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



JUMP\_TO\_ADDR The starting address of the next DMA buffer; when a jump takes place in VLC DMA address counter, the address will jump from the ending address of the current DMA buffer, which is JUMP\_FROM\_ADDR, to the starting address of the next DMA buffer, which is JUMP\_TO\_ADDR; note that the address counter will not jump until done with the content in memory with address as JUMP\_FROM\_ADDR. So the memory content with address JUMP\_FROM\_ADDR will be executed by hardware.

#### 6.17.2.4 Core

#### MP4+0300h Core Configuration Register

MP4\_CORE\_CO

| Bit   | 31                 | 30           | 29  | 28                 | 27  | 26        | 25  | 24   | 23  | 22   | 21    | 20  | 19            | 18  | 17  | 16  |
|-------|--------------------|--------------|-----|--------------------|-----|-----------|-----|------|-----|------|-------|-----|---------------|-----|-----|-----|
| Name  | -                  | -            | -   | -                  | -   | -         | -   | -    | -   | -    | -     | - 7 | <u>( ) - </u> | -   | -   | -   |
| 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  | DEBL<br>OCKI<br>NG | COPY<br>_REC | -   | MC_B<br>URST<br>EN | PMV | DQUA<br>N | FME | HALF |     | STEP | LIMIT |     | VPGO<br>B     | DCT | IRQ | ENC |
| 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   |

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

- O Disable the interrupt reporting mechanism
- 1 Enable the interrupt reporting mechanism

**DCT** DCT Control

- Enable JPEG CODEC Operation
- 1 Enable MPEG-4 CODEC Operation

**VPGOB** Control for decoding Video Packet Header.

- 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 Plane 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

- O Disable. Perform full pel motion estimation only
- 1 Enable. Perform full pel motion estimation first, then half pel motion estimation

**FME** Fast Motion Enhancement

- O 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.

- O Disable
- 1 Enable

MC BURST EN 2-beat Burst mode enable signal in MC.

- O Diable
- 1 Enable

**COPY\_REC** Enable signal to copy reconstructed memory to deblocking memory

- Disable
- 1 Enable

**DEBLOCK** Enable signal for deblocking mode. Please remember to configure Deblocking Base Address Register when DEBLOCK mode is enable.

3 different combination of DEBLOCK and COPY\_REC are shown below

- **00** (DECLOCK = 0 & COPY\_REC = 0): disable both deblocking filter and memory copy from reconstructed memory to deblocking memory.
- **01** (DECLOCK = 0 & COPY\_REC = 1): disable both deblocking filter and memory copy from reconstructed memory to deblocking memory.
- **10** (DECLOCK = 1 & COPY\_REC = 0): Enable deblocking filter and save deblocked frame to deblocking memory.
- 11 (DECLOCK = 1 & COPY\_REC = 1): Disable deblocking filter and save non-deblocked frame to deblocking memory.

## MP4+0304h Core Encoder Configuration Register

MP4\_CORE\_EN
C CONF

| Bit   | 31  | 30  | 29  | 28  | 27  | 26         | 25  | 24  | 23  | 22   | 21   | 20  | 19  | 18  | 17  | 16          |
|-------|-----|-----|-----|-----|-----|------------|-----|-----|-----|------|------|-----|-----|-----|-----|-------------|
| Name  | -   | -   | -   | -   |     |            |     |     |     | PACI | CONT |     |     |     |     | <b>PACK</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           |
| Bit   | 15  | 14  | 13  | 12  | 11  | 10         | 9   | 8   | 7   | 6    | 5    | 4   | 3   | 2   | 1   | 0           |
| Name  | -   | -   |     |     | INT | <b>TRA</b> |     |     | -   | -    |      |     | Sk  | (IP |     |             |
| 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         |
| 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$ ) <= 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 SADy < *intra\_threshold\**1024. Otherwise, *mb\_type* is set to 3'h3 (Intra\_MB)

**PACK** Use Video Packet Mode

- O 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

### MP4+0308h Half Duplex Controller Status Register

MP4\_DUPLEX\_S

TS

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24           | 23   | 22 | 21 | 20           | 19   | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|--------------|------|----|----|--------------|------|----|----|----|
| Name |    |    |    |    |    |    |    |              |      |    | D  | <b>UPLEX</b> | STAT | E  |    |    |
| Type |    |    |    |    |    |    |    |              | 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 |    |    |    |    |    |    | D  | <b>UPLEX</b> | STAT | E  |    |              |      |    |    |    |
| Type | RO           | RO   | RO | RO | RO           | RO   | RO | RO | RO |

This register is used to read back the current state of duplex controller in MPEG4 Codec.

**DUPLEX\_STATE** Current state of duplex controller.

#### 6.17.2.4.1 Base Addresses

### MP4+0310h Core MSB Base Address Register

MP4\_CORE\_BA

SE

| Bit  | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24                 | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16 |
|------|-----|-----|-----|-----|-----|-----|-----|--------------------|-----|-----|-----|-----|-----|-----|-----|----|
| Name |     |     |     |     |     | COI | DEC | $\overline{\chi}V$ |     |     |     |     | -   | -   | -   | -  |
| Type | R/W                | R/W | R/W | R/W | R/W | R/W | R/W |     |    |
| Bit  | 15  | 14  | 12  | 12  | 11  | 10  | 0   |                    | 7   | 6   | 5   | 1   | 2   | 2   | - 1 | 0  |
| ווט  | 2   | 14  | 13  | 14  | 11  | 10  | 9 " | 0                  | 1   | b   | 5   | 4   | J   |     | ı   | U  |
| Name |     | -   | -   |     | -   | -   | -   | - ° -              | -   | -   | •   | -   | -   | -   | -   | -  |

This register describes the MSB address that is used for VLE 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+0314h Current VOP Base Address Register

MP4\_CORE\_VO

P\_ADDR

| Bit  | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name |     |     |     |     |     |     |     | VC  | )P  |     |     |     |     |     |     |     |
| Type | RO  | R/W | R/W |
| Bit  | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name |     |     | 1 — | 7   |     |     | V   | )P  |     |     |     |     |     |     | -   | -   |
| 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.

### MP4+0318h Core Reference VOP Base Address Register

MP4\_CORE\_RE F ADDR

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

### MP4+031Ch Core Reconstructed VOP Base Address Register

MP4\_CORE\_RE
C ADDR

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

## MP4+0320h Core Deblocking Base Address Register

MP4\_CORE\_DE BLOCK\_ADDR

| Bit  | 31  | 30  | 29  | 28  | 27  | 26  | 25           | 24           | 23    | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|------|-----|-----|-----|-----|-----|-----|--------------|--------------|-------|-----|-----|-----|-----|-----|-----|-----|
| Name |     |     |     |     |     |     | DI           | <b>EBLOC</b> | K_ADD | R   |     |     |     |     |     |     |
| Type | 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 |     |     |     |     |     | DI  | <b>EBLOC</b> | K_ADD        | R     |     |     |     |     |     | -   | -   |
| Type | R/W          | R/W          | R/W   | R/W | R/W | R/W | R/W | R/W |     |     |

This register describes the starting address of deblocking 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).

**DEBLOCK\_ADDR** Deblocking Base Address.





# MP4+0324h Core VLE Data Load-Store LSB Base Address Register TA\_STORE\_AD DR

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

This register describes the LSB address of VLE 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 VLE Data Load-Store buffer

# MP4+0328h Core DC/AC Prediction Storage LSB Base Address Register

MP4\_CORE\_DA
CP ADDR

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

# MP4+032Ch Core Motion Vector Storage LSB Base Address Register

MP4\_CORE\_MV
P ADDR

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

This register describes the LSB address of Motion Vector Storage buffer. Note that this base address should be 4-byte aligned. And the required buffer size for encoder should be mb\_x\_limit \* 2 \* 4 bytes, which equals to 320 Bytes for VGA size.

MVD\_ADDR LSB address of Motion Vector Storage buffer

6.17.2.4.2 Data Structure

## MP4+0330h Core VOP Structure 0 Register

MP4\_CORE\_VO
P STRUCTO

| ;   | 4   | 20 | 20 | 20 | 27 | 26 | 25 | 24 | 22 | 22 | 21 | 20 | 10 | 18 | 17 | 10 |
|-----|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit | 31  | 30 | 29 | 28 | 21 | ∠0 | 25 | 24 | 23 | 22 |    | 20 | 19 | 10 | 17 | 16 |
|     | _ ` |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |





| Name | -   | -            | -   | -   | -   | -   | -   | -   | -   | -     | -   | -         | -   | -    |      | ROUN |
|------|-----|--------------|-----|-----|-----|-----|-----|-----|-----|-------|-----|-----------|-----|------|------|------|
| Type |     |              |     |     |     |     |     |     |     |       |     |           |     |      |      | R/W  |
| Bit  | 15  | 14           | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6     | 5   | 4         | 3   | 2    | 1_/  | 0    |
| Name | ١   | VLCTHR QUANT |     |     |     |     |     |     |     | FCODE |     | SHOR<br>T | -   | 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 Plane that is going to be processed by video CODEC.

**TYPE** vop coding type definition, for both decode and encode.

- This is a P-VOP frame (inter frame)
- 1 This is an I-VOP frame (intra frame)

**DATA** data\_partitioned, for decode only.

- **0** Data stream is in non-data-partitioned mode
- 1 Data stream is in data-partitioned mode

**RVLC** resversible\_vlc, for decode only.

- Data stream contains no reversible VLC information
- 1 Data stream uses reversible VLC tables.

**SHORT** short\_video\_header; for both decode and encode

- O Normal MPEG-4 format
- 1 H.263 Compatible format

**FCODE** fcode size setting for both decode and encode, ranges from 0 to 7.

**QUANT**vop\_quant. For both decode and encode. 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. For decode only. 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+0334h Core VOP Structure 1 Register

# MP4\_CORE\_VO P\_STRUCT1

| Bit  | 31  | 30  | 29  | 28  | 27 26   | 25    | 24  | 23  | 22  | 21  | 20  | 19  | 18     | 17   | 16  |
|------|-----|-----|-----|-----|---------|-------|-----|-----|-----|-----|-----|-----|--------|------|-----|
| Name | -   | -   | -   |     | HECE    | HT    |     | -   | -   | -   | -   |     | MBLE   | NGTH |     |
| 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 | -   | -   | -   |     | YLIM    | IT    |     | -   | -   | -   |     |     | XLIMIT |      |     |
| 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 Plane 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. 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+0338h Core VOP Structure 2 Register

MP4\_CORE\_VO P\_STRUCT2

| 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 | -  | -  | -  |     | V   | P_YPO | S   |     | -   | -   | -   |             | V   | P_XPO | S   |     |
| 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 Plane that is going to be processed by video CODEC.

**VP XPOS** Starting position of current Video Packet in X coordinate that the SW wants to update.

**VP YPOS** Starting position of current Video Packet 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 396.

### MP4+033Ch Core VOP Structure 3 Register

MP4\_CORE\_VO
P STRUCT3

| 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  | $\Box 6$ | 5  | 4           | 3  | 2           | 1  | 0  |
| Name | -  | -  | -  |    |    | <b>YPOS</b> |    |    | 7  |          | -  |             |    | <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+0340h Core MB Structure 0 Register

MP4\_CORE\_MB
\_STRUCT0

| Bit  | 31   | 30  | 29  | 28  | 27       | 26  | 25  | 24  | 23   | 22  | 21  | 20  | 19  | 18   | 17     | 16   |
|------|------|-----|-----|-----|----------|-----|-----|-----|------|-----|-----|-----|-----|------|--------|------|
| Name | •    | -   | -   | -   | <u> </u> |     | -   | -   | -    | -   | -   | -   | -   | QL   | JANTIZ | ER   |
| Type |      |     |     |     |          |     |     |     |      |     |     |     |     | R/W  | R/W    | R/W  |
| Bit  | 15   | 14  | 13  | 12  | 11       | 10  | 9   | 8   | 7    | 6   | 5   | 4   | 3   | 2    | 1      | 0    |
| Name | DCVI |     |     |     |          | ANT |     |     | PATI | ERN |     |     |     | TYPE |        | CODE |
| Туре | 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. Also used to provide hardware certain header information if all header parsing is done by software instead of hardware.

coded flag of current macroblock; not\_coded can be decoded by hardware from macroblock header.

489/616

**TYPE** mb\_coding\_type of current macroblock; mb\_coding\_type can be decoded by hardware from mcbpc in macroblck header.

**PATTERN** pattern\_code of current macroblock; pattern\_code can be decoded by hardware from cbpc and cbpy in macroblock header.





**DQUANT** 

dquant. It can be -2, -1, +1 or +2; total 4 possible choices using 2 bits to represent; dquant can be decoded by hardware from macroblock header.

AC

ac\_pred\_flag. It decides whether AC prediction is needed; always 0 in encoder; ac\_pred\_flag can be decoded by hardware from macroblock header.

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+0344h Core MB Structure 1 Register

MP4\_CORE\_MB
STRUCT1

| Bit  | 31 | 30 | 29 | 28 | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | <u> </u> | 17  | 16  |
|------|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----------|-----|-----|
| Name | -  | -  | -  | -  |     |     |     |     |     | DC  | [1] |     | 7/5 |          |     |     |
| Type |    |    |    |    | R/W      | R/W | R/W |
| Bit  | 15 | 14 | 13 | 12 | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2        | 1   | 0   |
| Name | -  | -  | -  | -  |     |     |     |     |     | DC  | [0] |     |     |          |     |     |
| Type |    |    |    |    | R/W      | R/W | 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+0348h Core MB Structure 2 Register

MP4\_CORE\_MB STRUCT2

| Bit  | 31 | 30 | 29 | 28 | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|------|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name | -  | -  | -  | -  |     |     |     |     |     | DC  | [3] |     |     |     |     |     |
| Type |    |    |    |    | R/W |
| Bit  | 15 | 14 | 13 | 12 | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name | -  | -  | -  | -  |     |     |     |     |     | DC  | [2] |     |     |     |     |     |
| 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+034Ch Core MB Structure 3 Register

MP4\_CORE\_MB STRUCT3

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

490/616

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+0350h Core MB Structure 4 Register

## MP4\_CORE\_MB STRUCT4

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23     | 22  | 21  | 20  | 19   | 18  | 17  | 16  |  |  |
|------|----|----|----|----|----|----|----|----|--------|-----|-----|-----|------|-----|-----|-----|--|--|
| Name | -  | -  | -  | -  | -  | -  | -  | -  |        |     |     | MV' | Y[0] |     |     |     |  |  |
| 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 | -  | -  | -  | -  | -  | -  | -  | -  | MVX[0] |     |     |     |      |     |     |     |  |  |
| 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 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+0354h Core MB Structure 5 Register

# MP4\_CORE\_MB STRUCT5

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22  | 217 | <u>20</u> | 19   | 18  | 17  | 16  |
|------|----|----|----|----|----|----|----|----|-----|-----|-----|-----------|------|-----|-----|-----|
| Name | -  | -  | -  | -  | -  | -  | -  | -  |     |     |     | MV        | Y[1] |     |     |     |
| 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 | -  | -  | -  | -  | -  | -  | -  | -  |     |     |     | MV        | X[1] |     |     |     |
| 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+0358h Core MB Structure 6 Register

# MP4\_CORE\_MB STRUCT6

| Bit  | 31 | 30 | 29 | 28 | 27  | 26           | 25    | 24 | 23  | 22  | 21  | 20  | 19   | 18  | 17  | 16  |
|------|----|----|----|----|-----|--------------|-------|----|-----|-----|-----|-----|------|-----|-----|-----|
| Name | -  | -  | -  | -  | -   | -            | Y 🕒 🖯 | -  |     |     |     | MV' | Y[2] |     |     |     |
| Type |    |    |    |    |     |              |       |    | R/W | R/W | R/W | R/W | R/W  | R/W | R/W | R/W |
| Bit  | 15 | 14 | 13 | 12 | 11  | <u></u> 710□ | 9     | 8  | 7   | 6   | 5   | 4   | 3    | 2   | 1   | 0   |
| Name | -  | -  | -  | -  | - 7 | -            | -     | -  |     |     |     | MV  | X[2] |     |     |     |
| 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+035Ch Core MB Structure 7 Register

MP4\_CORE\_MB STRUCT7

| Bit  | 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22  | 21  | 20  | 19   | 18  | 17  | 16  |
|------|----|-----|----|----|----|----|----|----|-----|-----|-----|-----|------|-----|-----|-----|
| Name | -  | T.  | -  | -  | -  | -  | -  | -  |     |     |     | MV' | Y[3] |     |     |     |
| 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 | _ | - | - | - | - | - | - | - |     |     |     | MV  | <b>K[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.17.2.5 VLC DMA

### MP4+0370h Core VLC DMA Status Register

MP4\_CORE\_VL C DMA STS

| Bit  | 31 | 30 | 29         | 28        | 27   | 26        | 25  | 24   | 23    | 22   | 21 | 20 | 19 | 18  | 17 | 16 |
|------|----|----|------------|-----------|------|-----------|-----|------|-------|------|----|----|----|-----|----|----|
| Name |    |    |            |           |      |           |     | GADD | R_LSB |      |    |    | 5  |     |    |    |
| Type | RO | RO | RO         | RO        | RO   | RO        | RO  | 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 | -  | -  | GLCO<br>MD | GDRD<br>Y | FULL | EMPT<br>Y | VLD | VLE  | PACK  | GREQ | 7  |    | ST | ATE |    |    |
| Type |    |    | RO         | RO        | RO   | RO        | RO  | RO   | RO    | 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.

**GREQ** request for data read/write.

- No request.
- 1 Request for data read/write.

PACK VLE Buffer Maximum Size Meet.

**VLE** VLE Stream Ready

- VLE is not ready
- 1 VLE is ready

VLD VLD Stream Ready

- **0** VLD is not ready
- 1 VLD is ready

**EMPTY** FIFO Empty

- VLC DMA FIFO is not empty
- 1 VLC DMA FIFO is empty.

FULL FIFO Full

- VLC DMA FIFO is not full
- 1 VLC DMA FIFO is full

**GDRDY** Waiting for gdrdy, a signal from GMC, to return.

- **0** gdrdy has been received.
- 1 Waiting for gdrdy to return.

**GLCOMD** Waitinf for glcomd, a signal from GMC, to return.

- glcomd has been received.
- Waiting for gloomd to return.

**GADDR\_LSB** Lower 16 bit value of gaddr, a signal to GMC.



### MP4+0374h Core VLE Status Register

MP4\_CORE\_VL

E\_STS

| Bit  | 31 | 30 | 29          | 28 | 27 | 26 | 25  | 24    | 23  | 22 | 21 | 20 | 19   | 18 | 17    | 16 |
|------|----|----|-------------|----|----|----|-----|-------|-----|----|----|----|------|----|-------|----|
| Name |    |    |             |    |    |    |     |       |     |    |    |    |      |    |       |    |
| Type | RO | RO | RO          | RO | RO | RO | RO  | 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>GREQ</b> |    |    |    | REL | OAD_0 | CNT |    |    |    | DONE |    | STATE |    |
| Type | RO | RO | RO          | RO | RO | RO | RO  | RO    | RO  | RO | RO | RO | RO   | RO | RO    | RO |

This register shows the status of MPEG4 VLE block and is used for hardware debugging.

**STATE** VLE State

**DONE** DC/AC coefficient reload done.

**RELOAD\_CNT** DC/AC coefficient reload count.

**GREQ** VLE request to GMC.

## MP4+0378h Core VLC DMA Base Address Register

MP4\_CORE\_VL C BASE ADDR

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |    |    |    |    |    |    |    | BA | SE |    |    |    |    |    |    |    |
| Type | WO |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    | BA | SE |    |    |    |    |    |    | -  | -  |
| 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+037Ch Core VLC DMA Base Bit Count Register

MP4\_CORE\_VL C\_BASE\_BITCN

Ť

| Bit  | 31 | 30 | 29 | 28 | 27 | 26       | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18  | 17 | 16 |
|------|----|----|----|----|----|----------|----|----|----|----|----|----|----|-----|----|----|
| Name | -  | -  | -  | -  | -  | <b>—</b> | -  | -  | -  | -  | -  | -  | -  | -   | -  | -  |
| 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 | 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".

Start of Bit at the 1<sup>st</sup> Code Word of 1<sup>st</sup> DMA Buffer

## MP4+0380h Core VLC DMA Buffer Limit Register

MP4\_CORE\_VL C 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  |     |     |     |     |     |     |     | LIN | /IIT |     |     |     |     |     |     |     |
| Type  | 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   |     |

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+0384h Core VLC DMA Current Word Register

MP4\_CORE\_VL

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |    |    |    |    |    |    |    | AD | DR |    |    |    |    |    |    |    |
| Type | RO |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    | AD | DR |    |    |    |    |    |    | -  | -  |
| Type | 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+0388h Core VLC DMA Current Bit Count Register

MP4\_CORE\_VL C BITCNT

| 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 |    |    |    |    |    |    |    | 7  |    |    |    | RO | 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

## MP4+038Ch Core VLC DMA Ring Buffer Ending Address Register

MP4\_CORE\_VL C JUMP FROM

\_ADDR

| Bit   | 31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 30  | 29  | 28  | 27     | 26  | 25  | 24    | 23    | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|-----|--------|-----|-----|-------|-------|-----|-----|-----|-----|-----|-----|-----|
| Name  | JUMP_FROM_ADDR           pe         R/W         R/W |     |     |     |        |     |     |       |       |     |     |     |     |     |     |     |
| 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   |     | $\Box$ | 1   | 1   | 1     | 1     | 1   | 1   | 1   | 1   | 1   | 1   | 1   |
| Bit   | 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 14  | 13  |     | 11     | 10  | 9   | 8     | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |     |     |        |     | JUI | MP_FR | OM_AD | DR  |     |     |     |     |     |     |
| 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   |

JUMP\_FROM\_ADDR The ending address of the current DMA buffer; when a jump takes place in VLC DMA address counter, the address will jump from the ending address of the current DMA buffer, which is JUMP\_FROM\_ADDR, to the starting address of the next DMA buffer, which is JUMP\_TO\_ADDR. To disable the

MediaTek Inc. Confidential

494/616



ring buffer feature, set this register to all ones; note that the address counter will not jump until done with the content in memory with address as JUMP\_FROM\_ADDR. So the memory content with address JUMP\_FROM\_ADDR will be executed by hardware.

#### MP4 CORE VL

## MP4+0390h Core VLC DMA Ring Buffer Starting Address Register

C\_JUMP\_TO\_A DDR

| Bit   | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24    | 23    | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|-------|-----|-----|-----|-----|-----|-----|-----|-------|-------|-----|-----|-----|-----|-----|-----|-----|
| Name  |     |     |     |     |     |     | Jl  | JMP_T | O_ADD | R   |     |     |     |     | ,   |     |
| 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   |
| Bit   | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8     | 7     | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| Name  |     |     |     |     |     |     | Jl  | JMP_T | O_ADD | R   |     |     |     |     |     |     |
| 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   |

JUMP\_TO\_ADDR The starting address of the next DMA buffer; when a jump takes place in VLC DMA address counter, the address will jump from the ending address of the current DMA buffer, which is JUMP\_FROM\_ADDR, to the starting address of the next DMA buffer, which is JUMP\_TO\_ADDR; note that the address counter will not jump until done with the content in memory with address as JUMP\_FROM\_ADDR. So the memory content with address JUMP\_FROM\_ADDR will be executed by hardware.

#### 6.17.2.6 Software Decode Mode

29

28

30

## MP4+0400h Software Decode Mode Command Register

MP4\_SVLD\_CO MD

19 18 17 16
- STOP STAR T
WO WO
3 2 1 0

| . ,    |         |         |        |         |         |        |           |           |           |         |         |         |        |           |           |           |
|--------|---------|---------|--------|---------|---------|--------|-----------|-----------|-----------|---------|---------|---------|--------|-----------|-----------|-----------|
| Bit    | 15      | 14      | 13     | 12      | 11      | 10     | 9         | 8         | 7         | 6       | 5       | 4       | 3      | 2         | 1         | 0         |
| Name   | •       | -       | -      | -       | -       | -      | CODE      | MCBP<br>C | QUAN<br>T | DCT     | AC      | СВРҮ    | MV     | DMAR<br>K | MMAR<br>K | FLUS<br>H |
| Type   |         |         |        |         |         |        | WO        | WO        | WO        | WO      | WO      | WO      | WO     | WO        | WO        | WO        |
| For SW | V decod | le mode | the fo | llowing | control | hits m | ust be so | ent to F  | IW for    | hlock-h | ased de | ecoding | The se | equence   | r (or he  | ader      |

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

Name Type

MMARKMotion MarkerDMARKDC MarkerMVMotion Vector

**CBPY** cbpy

AC ac\_pred\_flag
DCT dct\_coefficient

QUANTdquant MCBPC mcbpc

CODED not\_coded
START Block Decode Start



STOP Block Decode Stop

## MP4+0404h Software Decode Mode Bit Count Register

MP4\_SVLD\_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 | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  |     |     | BITCNT |     |     |
| Type |    |    |    |    |    |    |    |    |    |    |    | R/W | R/W | 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 | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | <u> </u> | -  | -  | -  | -         |
| Type |    |    |    |    |    |    |    |    |    |    |    |          |    |    |    |           |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4        | 3  | 2  | 1  | 0         |
| Name | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  |    | -        | -  | DC | MV | RESY<br>N |
| Type |    |    |    |    |    |    |    |    |    |    |    |          |    | RO | RO | RO        |

RESYN Resync Marker

MV Motion Marker

DC DC Marker

## MP4+040Ch Software Decode Mode VLD Code Word Register

MP4\_SVLD\_CO

DE

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

**CODE** Current Code Word in VLD Stream, MSB Aligned

#### 6.17.2.6.1 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 |
|------|----|----|----|-----|----|----|----|----|----|------|--------|--------|----|----|----|----|
| Name | -  | -  | -  | - ( | -  | -  |    |    |    | - IN | ITRA_N | /IB_NU | M  |    |    |    |
| Type |    |    |    |     |    |    | RO | 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 |    |    | 4  |     |    |    |    | SA | DY |      |        |        |    |    |    |    |
| Type | RO | RO | RO | RO  | RO | RO | RO | RO | RO | RO   | RO     | RO     | RO | RO | RO | 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 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |    |    | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | _  |



RO

RO

RO

RO

RO

| MEDIATEK |    |    |    |    |    |    |   |    |    |   |   |   |   |   |
|----------|----|----|----|----|----|----|---|----|----|---|---|---|---|---|
| Type     |    |    |    |    |    |    |   |    |    |   |   |   |   |   |
| Bit      | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8  | 7  | 6 | 5 | 4 | 3 | 2 |
| Name     |    |    |    |    |    |    |   | SA | DU |   |   |   |   |   |

RO

#### 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 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  | -  |    | -  | -  |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name |    |    |    |    |    |    |    | SA | DV |    |    |    | 4. |    |    |    |
| Type | RO |

RO

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

6.17.2.6.2 **Resync Marker** 

RO

RO

Type

RO

RO

RO

#### MP4 CORE RE **MPEG4 Core Resync Marker Configuration 0 Register** MP4+0600h SYNC\_CONF0

| Bit   | 31  | 30   | 29  | 28  | 27  | 26  | 25  | 24    | 23    | 22     | 21  | 20  | 19  | 18  | 17  | 16  |
|-------|-----|------|-----|-----|-----|-----|-----|-------|-------|--------|-----|-----|-----|-----|-----|-----|
| Name  | EN  | MODE |     |     |     |     |     |       | PERIO | D_BITS |     |     |     |     |     |     |
| 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    | 1   | 1   | 1   | 1   | 1   | 1.0   |       | 1      | 1   | 1   | 1   | 1   | 1   | 1   |
| Bit   | 15  | 14   | 13  | 12  | 11  | 10  | 9   | 87    | 7     | 6      | 5   | 4   | 3   | 2   | 1   | 0   |
| Name  |     |      |     |     |     |     |     | PERIO | BITS  |        |     |     |     |     |     |     |
| 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   | 10  | 1     | 1     | 1      | 1   | 1   | 1   | 1   | 1   | 1   |

**EN** Resync marker insertion enable

- Disable resync marker insertion
- 1 Enable resync marker insertion

**MODE** Resync Marker insertion mode selection

- resync marker is inserted based on number of bits
- resync marker is inserted based on number of macroblocks

**PERIOD BITS** Period in number of bits to insert resync marker; only effective when MODE is set to 0; hardware will insert resync marker at the next macroblock boundary once the bit length of a video packet exceeds this value.

#### MP4+0604h **MPEG4 Core Resync Marker Configuration 1 Register**

## MP4 CORE RE SYNC CONF1

| Bit   | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24           | 23   | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|-------|-----|-----|-----|-----|-----|-----|-----|--------------|------|-----|-----|-----|-----|-----|-----|-----|
| Name  | -   |     |     | -   | -   | -   | -   | -            | -    | -   | -   | -   | -   | -   | -   | HEC |
| Type  | 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>PERIO</b> | D_MB |     |     |     |     |     |     |     |



| Туре  | R/W |
|-------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Reset | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   | 1   |

HEC Header Extension Code; indicates the value of header\_extension\_code in MPEG4 standard (ISO/IEC 14496-2).

- header\_extension\_code is 0.
- 1 header extension code is 1.

**PERIOD\_MB** Period in number of macroblocks (MB) to insert resync marker; only effective when MODE is set to 1; hardware will insert resync marker at the next macroblock boundary once the number of macroblock in current video packet exceeds this value.

### MP4+060Ch MPEG4 Core Local Time Base Register

MP4\_CORE\_TIM E BASE

| Bit   | 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24    | 23           | 22     | 21     | 20  | 19  | 18  | 17  | 16  |
|-------|-----|-----|-----|-----|-----|-----|-----|-------|--------------|--------|--------|-----|-----|-----|-----|-----|
| Name  | -   | -   | -   | -   | -   | -   | -   |       | <b>IODUL</b> | O_TIMI | E_BASI |     | 7   | B   | W   |     |
| Type  | 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      | 47  | 3   | 2   | 1   | 0   |
| Name  |     |     |     |     |     |     | VOP | TIME_ | NCRE         | MENT   | 7      | 7   |     |     |     |     |
| Туре  | 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   |

**MODULO TIME BASE** Represent the value of modulo\_time\_base; value ranges from 0 to 31.

Bit width of vop\_time\_increment. The real bit-width of vop\_time\_increment is (BW + 1), ranging from 1 to 16.

**VOP\_TIME\_INCREMENT** Carries the value of vop\_time\_increment defined in MPEG4 standard (ISO/IEC 14496-2); the meaningful bit width of vop\_time\_increment is signaled by BW field.

## 6.18 TV Controller

## 6.18.1 General Description

MT6228 supports NTSC/PAL interlaced TV format. The display function includes two components: a TV controller and a TV encoder. The main functions of the TV controller are as follows:

- 1. Fetch the TV frame buffer.
  - <u>In video playback mode</u>, the source is from the video codec buffer in YUV420 format. In this mode, the TV controller and MPEG4 decoder can also communicate to achieve the best performance.
  - <u>In image playback mode</u>, the source is in RGB565 format. In this mode, still images can be displayed. The LCM controller can direct the image path to the TV controller. When the LCM controller sends frames to the frame buffer as it does for the LCD display, the TV controller retrieves the frames for display.
- 2. Scale the frame size to fit the TV size. MT6228 adopts bilinear interpolation in both horizontal and vertical dimension to scale up the frame. The user can adjust both the location and the size to achieve a suitable appearance.

In NTSC mode, the ideal display area is  $720(W) \times 480(H)$ , but the actual display area depends on the TV set. Some boundary area may be invisible. In PAL mode, the ideal display area is  $720(W) \times 576(H)$ ; the actual display area also depends on the TV set.



TV frame updates consume a lot of bandwidth. For interlaced system, one frame contains 2 fields. In NTSC mode, the field update rate is 59.94 frames per second (fps); the field update rate in PAL mode is 50 fps. Performance is bound by the size of the source image. The larger the image size, the higher the bandwidth required to support the TV display.

The controller supports an arbitrary image size up to 640 pixels in height and 480 pixels in width.

Figure 36 depicts the block diagram of the TV controller.



Figure 36 Block Diagram of the TV Encoder

## **6.18.2 Register Definitions**

#### TVC+0000h TVC enable register

TVC ENA

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

The register is double buffer. At the start of each frame, the enable bit is latched into the active buffer and takes effect.

**TSEN** TV control test signal enable.

- O Disable the test signal display.
- 1 Enable the test signal display.

**TVEN** TV controller enable,

- O Disable the TV frame update and display.
- 1 Enable the TV frame update and display.

#### TVC+0004h TVC reset control register

TVC\_RST

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



The register is used to reset both the TV controller and the TV encoder. This control bit is write-only.

**RST** Reset control bit.

#### TVC+0008h TVC control register

TVC CON

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25        | 24        | 23 | 22 | 21        | 20        | 19         | 18   | _17 | 16   |
|-------|----|----|----|----|----|----|-----------|-----------|----|----|-----------|-----------|------------|------|-----|------|
| Name  |    |    |    |    |    |    |           |           |    |    |           |           |            |      | 7   |      |
| Type  |    |    |    |    |    |    |           |           |    |    |           |           |            |      |     |      |
| Reset |    |    |    |    |    |    |           |           |    |    |           |           |            |      |     |      |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9         | 8         | 7  | 6  | 5         | 4         | 3          | 2    | 1   | 0    |
| Name  |    |    |    |    |    |    | AB_W<br>R | AB_R<br>D |    |    | BURS<br>T | DPBU<br>F | BLKO<br>UT | NOIP |     | YUV_ |
| 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 contains double buffer control, burst-mode control, buffer configuration, vertical interpolation control, and color-space control.

**AB\_WR** Double buffer access control. Only five active buffers can be directly programmed through setting AB\_WR: TVC\_YADR\_SRC, TVC\_SRCWIDTH, TVC\_TARWIDTH, TVC\_HCOEFX, TVC\_HCOEFY.

- **0** Write write-buffer.
- 1 Write both write-buffer and active-buffer.

**AB** RD Double buffer access control.

- Read write-buffer.
- 1 Read active-buffer.

**BURST** Enable memory burst mode access. TVC supports 4-beat burst mode access to memory. Double buffer.

- O Disable burst mode access.
- 1 Enable burst mode access.

**DPBUF** Enable deeper buffer for better performance. Double buffer.

- O Disable deeper buffer.
- 1 Enable deeper buffer.

**BLACKOUT** Fill the unfilled line buffer area with black pixels. Double buffer.

- O Do not fill with black pixels.
- 1 Fill with black pixels.

**NOIP** Bypass vertical interpolation. Enabling this bit reduces the average data access bandwidth by 2. Double buffer.

- Enable vertical interpolation.
- 1 Bypass vertical interpolation.

YUV\_M Enable YUV mode. Double buffer.

- **0** RGB565 mode. For LCD dump buffer.
- 1 YUV420 mode. For MPEG buffer.

## TVC+000Ch TVC Y data source address

TVC\_YADR\_SR

C

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



Reset

This register is a double buffer. At the start of each frame, the enable bit is latched into the active buffer and takes effect. In YUV mode, the register represents the Y source address. In RGB mode, the register represents the RGB source address.

0

#### TVC+0010h TVC U data source address

TVC\_UADR\_SR

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

This register is double buffer. At the start of each frame, the enable bit is latched into the active buffer and takes effect. In YUV mode, the register represents the U source address. In RGB mode, this register has no function.

#### TVC+0014h TVC V data source address

TVC\_VADR\_SR

.. C

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

This register is double buffer. At the start of each frame, the enable bit is latched into the active buffer and takes effect. In YUV mode, the register represents the V source address. In RGB mode, this register has no function.

## TVC+0018h TVC horizontal scaling coefficient X

TVC HCOEFX

| Bit   | 15 | 14 | 13 | 12 | 11 | 10     |             | <u>_9</u> | 8 | 7 | 6 | 5   | 4          | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|--------|-------------|-----------|---|---|---|-----|------------|---|---|---|---|
| Name  |    |    |    |    |    |        | $\subseteq$ |           |   |   |   | COI | <b>EFX</b> |   |   |   |   |
| Type  |    |    |    |    |    | $\Box$ |             |           |   |   |   | R/  | W          |   |   |   |   |
| Reset |    |    |    |    |    |        |             |           |   |   |   | (   | )          |   |   |   |   |

This register is double buffer. At the start of each frame, the enable bit is latched into the active buffer and takes effect. The scaling coefficients should follow the formula:

$$\frac{Ws (source width) - 1}{Wt (t \operatorname{arg} et width) - 1} = \frac{X + \frac{Y}{Wt - 1}}{256}$$

where X, Y are positive integers, and  $0 < Y < W_t - 1$ .

For example, if the user needs to scale the image width from 640 pixels to 720 pixels, the formula is:

$$\frac{639}{719} = \frac{227 + \frac{371}{719}}{256}$$

giving values X=227 and Y=371.



### TVC+001Ch TVC horizontal scaling coefficient Y

#### TVC HCOEFY

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

This register is double buffer. At the start of each frame, the enable bit is latched into the active buffer and takes effect.

### TVC+0020h TVC vertical scaling coefficient X

## TVC VCOEFX

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

This register is double buffer. At the start of each frame, the enable bit is latched into the active buffer and takes effect. The scaling coefficients should follow the formula:

$$\frac{Hs (source \ height) - 1}{Ht (t \ arg \ etn \ height) - 1} = \frac{X + \frac{Y}{Ht - 1}}{256}, X, Y \in positive \ in \ teger$$

## TVC+0024h TVC vertical scaling coefficient Y

#### TVC VCOEFY

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

This register is double buffer. At the start of each frame, the enable bit is latched into the active buffer and takes effect.

## TVC+0028h TVC frame source width control register

#### TVC SRCWIDTH

|       |    |    |    |    |    |    |   |   | _ |   |   |      |       |   |   |   |   |
|-------|----|----|----|----|----|----|---|---|---|---|---|------|-------|---|---|---|---|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | M | 7 | 6 | 5    | 4     | 3 | 2 | 1 | 0 |
| Name  |    |    |    |    |    |    |   |   |   |   |   | SRCV | VIDTH |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   |   | R/   | W     |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   |   | (    | )     |   |   |   | l |

This register is double buffer. At the start of each frame, the enable bit is latched into the active buffer and takes effect. In YUV mode, the source width is a multiple of 16; in RGB mode, the source width is a multiple of 2.

## TVC+002C TVC frame source height control register

#### TVC SRCHEIGH

т

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

This register is double buffer. At the start of each frame, the enable bit is latched into the active buffer and takes effect.

## TVC+0030 TVC frame target width control register

#### TVC TARWIDTH

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



This register is double buffer. At the start of each frame, the enable bit is latched into the active buffer and takes effect.

## TVC+0034 TVC frame target height control register

TVC\_TARHEIGH

т.

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

This register is double buffer. At the start of each frame, the enable bit is latched into the active buffer and takes effect.

### TVC+0038h TVC start point control register

TVC\_START\_PO INT

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

This register is double buffer. At the start of each frame, the enable bit is latched into the active buffer and takes effect. This register is used to control the position of frame displayed on TV. Setting START\_PXL to 0 and START\_LINE to 21(NTSC) or 22(PAL) aligns the frame to the top-left corner of display.

**START\_PXL** Starting pixel position in a line.

**START LINE** Starting line of display.

#### TVC+003Ch TVC register update control register

TVC REG RDY

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

This register indicates that the double buffer register data is ready to be latched into active buffer.

At the start of each frame, the hardware monitors the bit. If the bit is set to 1 by the software, the double buffer register is latched into active buffer synchronously, and the REG\_RDY bit is automatically cleared.

**REG\_RDY** Double buffer control bit.

## TVC+0040h Test signal region start line number control register 1 TVC PTRN1

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



The register specifies the starting line of the 1<sup>st</sup> and 2<sup>nd</sup> regions of the test signal to display. While the running line number falls in the 1<sup>st</sup> region, the TV iteratively displays the 1<sup>st</sup> line buffer. While it falls in the 2<sup>nd</sup> region, the TV iteratively displays the 2<sup>nd</sup> line buffer. The data in the line buffers is pre-filled by the user. The line length is 720 pixels.

**SLINE1** The starting line of the 2<sup>nd</sup> region.

**SLINEO** The starting line of the 1<sup>st</sup> region.

#### TVC+0044h Test signal region start line number control register 2

TVC PTRN2

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21  | 20  | 19       | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|-----|-----|----------|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    | SLI | NE3 | 4.       |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    | R/  | W   | _3/2     |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    | (   | )   |          |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5   | 4   | 3        | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    | SLI | NE2 |          |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    | R/  | W   | <i>5</i> |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    | (   |     |          |    | •  |    |

The register specifies the starting line of the  $3^{rd}$  and  $4^{th}$  regions of the test signal to display. While the running line number falls in the  $3^{rd}$  region, the TV iteratively displays the  $3^{rd}$  line buffer. While it falls in the  $4^{th}$  region, the TV iteratively displays the  $4^{th}$  line buffer. The data in the line buffers is pre-filled by the user. The line length is 720 pixels.

**SLINE3** The starting line of the 4<sup>th</sup> region.

**SLINE2**The starting line of the 3<sup>rd</sup> region.

## TVC+0048h Line buffer load control register

TVC\_LINELOAD

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7 | 6 | 5 | 4 | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|---|------|---|---|---|---|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    |   | BUSY |   |   |   |   | LL3 | LL2 | LL1 | LL0 |
| Type  |    |    |    |    |    |    |   | RO   |   |   |   |   | WO  | WO  | WO  | WO  |
| Reset |    |    |    |    |    |    |   | 507  |   |   |   |   | 0   | 0   | 0   | 0   |

The register controls the data loading of the line buffer. Turn off TVEN and TSEN when performing the line loading operation. The BUSY flag is asserted until the line loading operation is completed.

**BUSY** Line loading busy.

**LL3** Writing one starts loading line buffer 3.

**LL2** Writing one starts loading line buffer 2.

**LL1** Writing one starts loading line buffer 1.

#### 6.18.2.1 LL0 Writing one starts loading line buffer 0.

# 6.19 TV encoder

## 6.19.1 General Description

TV encoder receives a YCbCr stream from the video scaler and encodes the stream into NTSC/PAL signal.

shows the block diagram of the TV encoder.





Figure 37 Block Diagram of TV Encoder

# 6.19.2 Register Definitions

### TVE+0000h Encoder mode control

TVE MODE

| Bit   | 31        | 30        | 29        | 28  | 27  | 26   | 25  | 24  | 23   | 22        | 21        | 20         | 19  | 18        | 17   | 16        |
|-------|-----------|-----------|-----------|-----|-----|------|-----|-----|------|-----------|-----------|------------|-----|-----------|------|-----------|
| Name  |           |           |           |     |     |      |     |     |      |           |           |            |     |           | TVT  | YPE       |
| 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         |
| Reset | 0         | 0         | 0         | 0   | 0   | 0    | 0   | 0   | 0    | 0         | 0         | 0          | 0   | 0         | (    | )         |
| Bit   | 15        | 14        | 13        | 12  | 11  | 10   | 9   | 87  | 7    | 6         | 5         | 4          | 3   | 2         | 1    | 0         |
| Name  | UVSW<br>P | BLKE<br>R | SLOF<br>F |     |     | SYDE | YD  | EL  | CUPO | YLPO<br>N | CLPO<br>N | CLPS<br>EL |     | SETU<br>P | CBON | ENCO<br>N |
| Туре  | 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         |

**TVTYPE** TV type.

**00** NTSC (525 lines, no phase alternation line)

**01** PAL-M (525 lines, with phase alternation line)

**10** PAL-C (625 lines, with phase alternation line)

11 PAL (625 lines, with phase alternation line)

**UVSWP** U/V swap.

**BLKER** Blacker than black mode on.

**SLOFF** Slew at the beginning and at the end of the horizontal active area off.

**SYDEL** Delay of Y (half sample resolution).

**YDEL** Delay of Y (one sample resolution). (Recommended setting is 2.)

**CUPOF** Chrominance (chroma) of component up-sample off.

YLPON Luminance (luma) low-pass filter on. (Recommended setting is 1.)

**CLPON** Chroma low-pass filter on. (Recommended setting is 1.)

**CLPSEL** Chroma low-pass filter coefficient selection.

**SETUP** 7.5IRE setup enable. (M) NTSC and (M, N) PAL have a blanking pedestal.



CBON

Enable the color bar.

**ENCON** 

Enable the TV encoder.

### TVE+0004h Scale control

TVE CSCALE

| Bit   | 31 | 30 | 29 | 28   | 27   | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19      | 18 | 17       | 16 |  |
|-------|----|----|----|------|------|----|----|----|----|----|----|------|---------|----|----------|----|--|
| Name  |    |    |    |      |      |    |    |    |    |    |    |      |         |    | ANK      |    |  |
| Type  |    |    |    |      |      |    |    |    |    |    |    |      |         | R  | /W       |    |  |
| Reset |    |    |    |      |      |    |    |    |    |    |    |      | 0x4     |    |          |    |  |
| Bit   | 15 | 14 | 13 | 12   | 11   | 10 | 9  | 8  | 7  | 6  | 5  | 4    | 3 2 1 ( |    |          |    |  |
| Name  |    |    |    | VSC  | ALE  |    |    |    |    |    |    | USC  | ALE     |    | <b>—</b> |    |  |
| Type  |    |    |    | R/   | W    |    |    |    |    |    |    | R/   | W       | 67 |          |    |  |
| Reset |    | •  | •  | 0x5A | (90) |    | •  | •  |    | •  |    | 0x5A | (90)    |    | •        |    |  |

**USCALE** Scale of U (USCALE/128).

**VSCALE** Scale of V (VSCALE/128).

**BLANK**Luma data at this level (BLANKx4) is presented as blank.

### TVE+0008h DAC control

TVE DACTRL

| Bit   | 31  | 30  | 29  | 28  | 27                   | 26   | 25   | 24                  | 23  | 22                            | 21                  | 20           | 19                | 18           | 17                | 16         |
|-------|-----|-----|-----|-----|----------------------|------|------|---------------------|-----|-------------------------------|---------------------|--------------|-------------------|--------------|-------------------|------------|
| Name  |     |     |     |     |                      |      |      |                     |     |                               |                     | TRIMS<br>ET  |                   | TF           | RIM               |            |
| 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                |            |
| Reset | 0   | 0   | 0   | 0   | 0                    | 0    | 0    | 0                   | 0   | 0                             | 0                   | 0            | 3 2 1             |              |                   |            |
| Bit   | 15  | 14  | 13  | 12  | 11                   | 10   | 9    | 8                   | 7   | $\overline{}$ 6 $\overline{}$ | 5                   | 4            | 3                 | 2            | 1                 | 0          |
| Name  |     |     |     |     | TEST<br>_COM<br>P_EN | VPLU | GREF | PLUG<br>_DET<br>_EN |     |                               | PDN_<br>HAIBI<br>AS | PDN_<br>DAC2 | PDN_<br>DAC1      | PDN_<br>DAC0 | PDN_<br>BGRE<br>F | DAC_<br>EN |
| 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        |
| Reset | 0   | 0   | 0   | 0   | 0                    | (    | )    | 0                   | 0_  | 0                             | 0                   | 0            | R/W R/W R/W 0 0 0 |              |                   | 1          |

506/616

**TRIMSET** Enable software trimming code setting.

O Disable.

1 Enable.

**TRIM** Trimming code for BGVref.

**TEST\_COMP\_EN** Comparator test enable.

O Disable.

1 Enable.

**VPLUGREF** Plug-in detect threshold selection.

PLUG\_DET\_EN Plug-in detect enable.

O Disable.

1 Enable.

PDN\_HAIBIAS Half bias current power down mode.

O Power up.

1 Power down.

**PDN\_DAC2** DAC power down control.

O Power up.

Power down.

PDN\_DAC1 3/4 DAC power down control.

O Power up.



1 Power down.

**PDN\_DAC0** 1/2 DAC power down control.

Power up.Power down.

**PDN\_BGREF** BGVref power down control.

Power up.Power down.

**DAC\_EN** DAC enable.

### TVE+000Ch Burst level control

TVE\_BURST

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

**UPQINI** Phase offset of the color burst.

**BRSTLVL** Color burst level.

### TVE+0010h Color frequency control

TVE\_FREQ

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24    | 23 | 22      | 21  | 20       | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|-------|----|---------|-----|----------|----|----|----|----|
| Name  |    |    |    |    |    |    |    |       |    | BFP2    |     |          |    |    |    |    |
| Type  |    |    |    |    |    |    |    |       |    | R/W     |     |          |    |    |    |    |
| Reset |    |    |    |    |    |    |    |       | 0x | dd0 (35 | 36) |          |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8     | 7  | 6       | 5   | 4        | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    | 5. 7/ |    |         |     | BFP1     |    |    |    |    |
| Type  |    |    |    |    |    |    |    |       |    |         |     | R/W      |    |    |    |    |
| Reset |    |    |    |    |    |    |    |       |    |         | 0>  | (10f (27 | 1) |    |    |    |

Burst frequency control.

$$Burst\ frequency = 27MHz \times \frac{BFP2 + \frac{X}{625}}{2048}$$

where H is the pixel clock cycle number per line.

Use the following table to get BFP1 and BFP2 (in decimal).

| TV type | H    | X  | BFP1 | BFP2 |
|---------|------|----|------|------|
| NTSC    | 1716 | 0  | 271  | 3536 |
| PAL     | 1728 | 67 | 336  | 2061 |

**BFP2** Color burst frequency synthesis value 2.

**BFP1** Color burst frequency synthesis value 1.

### TVE+0014h Slew control

**TVE SLEW** 

| Direction of the second | 7  |    | 07 |    |    |    |    |    | 0.1 |    |    |    |    |    |
|-------------------------|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|
| Bit 31 30               | 20 | 28 | 97 | 26 | 25 | 2/ | 23 | 22 | 21  | 20 | 10 | 18 | 17 | 16 |
| DIL 31 30               | 23 | 20 |    |    | 20 |    | 20 |    |     |    | 10 | 10 | 17 | 10 |



### MT6228 GSM/GPRS Baseband Processor Data Sheet Revision 1.0

| Name          |    |    |    |    |    |              |   |   |   |   | 5    | SLEWUI   | •  |   |   |   |  |  |
|---------------|----|----|----|----|----|--------------|---|---|---|---|------|----------|----|---|---|---|--|--|
| Type<br>Reset |    |    |    |    |    |              |   |   |   |   |      | R/W      |    |   |   |   |  |  |
| Reset         |    |    |    |    |    |              |   |   |   |   | 0    | xc8 (200 | 0) |   |   |   |  |  |
| Bit           | 15 | 14 | 13 | 12 | 11 | 10           | 9 | 8 | 7 | 6 | 5    | 4        | 3  | 2 | 1 | 0 |  |  |
| Name          |    |    |    |    |    |              |   |   |   | S | LEWD | N        |    |   | 4 |   |  |  |
| Type<br>Reset |    |    |    |    |    |              |   |   |   |   | R/W  |          |    |   |   |   |  |  |
| Reset         | •  |    |    |    |    | 0x6A4 (1700) |   |   |   |   |      |          |    |   |   |   |  |  |

**SLEWUP** Begin cycle of valid pixel with slew rate control.

**SLEWDN** End cycle of valid pixel with slew rate control.

### TVE+0028h Luma low-pass filter coefficients 10-11

TVE YLPFC

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

YLPF11 Luma low-pass filter coefficient 11. Signed integer.

**YLPF10** Luma low-pass filter coefficient 10. Signed integer.

### TVE+002Ch Luma low-pass filter coefficients 12-15

**TVE YLPFD** 

| Bit   | 31 | 30                | 29      | 28 | 27     | 26     | 25 | 24               | 23 | 22 | 21 | 20 | 19     | 18    | 17 | 16 |
|-------|----|-------------------|---------|----|--------|--------|----|------------------|----|----|----|----|--------|-------|----|----|
| Name  |    |                   |         | ,  | YLPF15 | 5      |    |                  |    |    |    | ,  | YLPF14 | ,     |    |    |
| Type  |    |                   |         |    | R/W    |        |    |                  |    |    |    |    | R/W    |       |    |    |
| Reset |    | 0x2 (2) 0x1e (30) |         |    |        |        |    |                  |    |    |    |    |        |       |    |    |
| Bit   | 15 | 14                | 13      | 12 | 11     | 10     | 9  | 8                | 7  | 6  | 5  | 4  | 3      | 2     | 1  | 0  |
| Name  |    |                   |         |    | YLP    | F13    |    | <del>7</del> .7/ |    |    |    |    | YLP    | F12   |    |    |
| Type  |    |                   | R/W R/W |    |        |        |    |                  |    |    |    |    |        |       |    |    |
| Reset |    |                   |         |    | 0X3c   | d (-3) |    |                  |    |    |    | •  | 0X25   | (-27) | •  |    |

**YLPF15** Luma low-pass filter coefficient 15. Signed integer.

YLPF14 Luma low-pass filter coefficient 14. Signed integer.

**YLPF13** Luma low-pass filter coefficient 13. Signed integer.

**YLPF12** Luma low-pass filter coefficient 12. Signed integer.

# TVE+0030h Luma low-pass filter coefficients 16-19

**TVE YLPFE** 

| Bit   | 31 | 30 | 29 | 28   | 27    | 26 | 25 | 24 | 23 | 22 | 21 | 20   | 19    | 18 | 17 | 16 |
|-------|----|----|----|------|-------|----|----|----|----|----|----|------|-------|----|----|----|
| Name  |    |    |    | YLP  | F19   |    |    |    |    |    |    | YLF  | F18   |    |    |    |
| Type  |    |    |    | R/   | W     |    |    |    |    |    |    | R/   | W     |    |    |    |
| Reset |    |    |    | 0x90 | (144) |    |    |    |    |    |    | 0xb4 | (180) |    |    |    |
| Bit   | 15 | 14 | 13 | 12   | 11    | 10 | 9  | 8  | 7  | 6  | 5  | 4    | 3     | 2  | 1  | 0  |
| Name  |    |    |    | YLP  | F17   |    |    |    |    |    |    | YLF  | PF16  |    |    |    |
| Type  |    |    |    | R/   | W     |    |    |    |    |    |    | R/   | W     |    |    |    |
| Reset |    |    | 4  | 0Xff | (-1)  |    |    |    |    |    |    | 0Xc7 | (-57) |    |    |    |

YLPF19 Luma low-pass filter coefficient 19. Must be unsigned. Hardware extends to 9 bits.
YLPF18 Luma low-pass filter coefficient 18. Must be unsigned. Hardware extends to 9 bits.

**YLPF17** Luma low-pass filter coefficient 17. Signed integer.

**YLPF16** Luma low-pass filter coefficient 16. Signed integer.



### TVE+0034h Chrominance low-pass filter coefficients 0-3

### TVE CLPFA

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

**CLPF3** Chrominance low-pass filter coefficient 3.

**CLPF2** Chrominance low-pass filter coefficient 2.

**CLPF1** Chrominance low-pass filter coefficient 1.

**CLPF0** Chrominance low-pass filter coefficient 0.

# TVE+0038h Chrominance low-pass filter coefficients 4-7

### TVE CLPFB

| Bit   | 31 | 30 | 29 | 28 | 27  | 26  | 25 | 24 | 23 | 22 | 21       | 20 | 19  | 18  | 17 | 16 |
|-------|----|----|----|----|-----|-----|----|----|----|----|----------|----|-----|-----|----|----|
| Name  |    |    |    |    | CLI | PF7 |    |    |    |    | <u> </u> | 7  | CL  | PF6 |    |    |
| Type  |    |    |    |    | R/  | W   |    |    |    |    |          |    | R/  | /W  |    |    |
| Reset |    |    |    |    | 0x  | 25  |    |    |    |    |          |    | 0x  | 34  |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11  | 10  | 9  | 8  | 7  | 6  | 5        | 4  | 3   | 2   | 1  | 0  |
| Name  |    |    |    |    | CLI | PF5 |    |    |    |    |          |    | CLI | PF4 |    |    |
| Type  |    |    |    |    | R/  | W   |    |    |    |    |          |    | R/  | /W  |    |    |
| Reset |    |    |    |    | 0x  | 20  |    |    |    |    |          |    | 0x  | :21 |    |    |

**CLPF7** Chrominance low-pass filter coefficient 7.

**CLPF6** Chrominance low-pass filter coefficient 6.

**CLPF5** Chrominance low-pass filter coefficient 5.

**CLPF4** Chrominance low-pass filter coefficient 4.

# TVE+003Ch Chrominance low-pass filter coefficients 8-9

### **TVE CLPFC**

| 31 | 30 | 29 | 28 | 27  | 26                | 25 | 24                                  | 23                                | 22                                 | 21                                    | 20                                     | 19                                       | 18                                                | 17                                                  | 16                                                   |
|----|----|----|----|-----|-------------------|----|-------------------------------------|-----------------------------------|------------------------------------|---------------------------------------|----------------------------------------|------------------------------------------|---------------------------------------------------|-----------------------------------------------------|------------------------------------------------------|
|    |    |    |    |     |                   |    |                                     |                                   |                                    |                                       |                                        |                                          |                                                   |                                                     |                                                      |
|    |    |    |    |     |                   |    |                                     |                                   |                                    |                                       |                                        |                                          |                                                   |                                                     |                                                      |
|    |    |    |    |     |                   |    |                                     |                                   |                                    |                                       |                                        |                                          |                                                   |                                                     |                                                      |
| 15 | 14 | 13 | 12 | 11  | 10                | 9  | 8                                   | 7                                 | 6                                  | 5                                     | 4                                      | 3                                        | 2                                                 | 1                                                   | 0                                                    |
|    |    |    |    | CLI | PF9               |    |                                     |                                   |                                    |                                       |                                        | CLI                                      | PF8                                               |                                                     |                                                      |
|    |    |    |    | R/  | W                 |    |                                     |                                   |                                    |                                       |                                        | R/                                       | W                                                 |                                                     |                                                      |
|    |    |    | •  | 0x  | 27                | •  |                                     |                                   |                                    |                                       | •                                      | 0x                                       | 3c                                                |                                                     |                                                      |
|    |    |    |    |     | 15 14 13 12 11 CL |    | 15 14 13 12 11 10 9<br>CLPF9<br>R/W | 15 14 13 12 11 10 9 8  CLPF9  R/W | 15 14 13 12 11 10 9 8 7  CLPF9  RW | 15 14 13 12 11 10 9 8 7 6  CLPF9  R/W | 15 14 13 12 11 10 9 8 7 6 5  CLPF9 R/W | 15 14 13 12 11 10 9 8 7 6 5 4  CLPF9 R/W | 15 14 13 12 11 10 9 8 7 6 5 4 3  CLPF9 CLI R/W R/ | 15 14 13 12 11 10 9 8 7 6 5 4 3 2  CLPF9 CLPF8  R/W | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1  CLPF9  R/W  R/W |

**CLPF9** Chrominance low-pass filter coefficient 9.

**CLPF8** Chrominance low-pass filter coefficient 8.

# TVE+0040h Gamma correction coefficient 0

### TVE GAMMAA

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



GAMMA0~GAMMA8 indicate the turning points of a piecewise linear approximation for a gamma curve. By default, the values form a perfect linear equation with no gamma correction.

Gamma correction is performed on Luma only.



**GAMMA0** Gamma correction coefficient 0.

### TVE+0044h Gamma correction coefficients 1-2

TVE\_GAMMAB

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22  | 21   | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|-----|----|-----|------|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    | 4   |    | GAN | IMA2 |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |     |    | R   | W    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | (0) |    | 0x: | 314  |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7  | 6   | 5    | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    | 4  |     |    | GAN | IMA1 |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |     |    | R   | W    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |     |    | 0x  | 18a  |    | •  | •  | •  | •  |

**GAMMA2** Gamma correction coefficient 2.

**GAMMA1** Gamma correction coefficient 1.

# TVE+0048h Gamma correction coefficients 3-4

**TVE GAMMAC** 

| Bit   | 31 | 30 | 29 | 28 | 27              | 26      | 25 | 24 | 23 | 22  | 21   | 20 | 19 | 18 | 17 | 16 |  |  |
|-------|----|----|----|----|-----------------|---------|----|----|----|-----|------|----|----|----|----|----|--|--|
| Name  |    |    |    |    |                 | <u></u> |    |    |    | GAN | IMA4 |    |    |    |    |    |  |  |
| Type  |    |    |    |    |                 | R/W     |    |    |    |     |      |    |    |    |    |    |  |  |
| Reset |    |    |    |    |                 | 0x629   |    |    |    |     |      |    |    |    |    |    |  |  |
| Bit   | 15 | 14 | 13 | 12 | $\Box$ 1 $\Box$ | 10      | 9  | 8  | 7  | 6   | 5    | 4  | 3  | 2  | 1  | 0  |  |  |
| Name  |    |    |    |    |                 |         |    |    |    | GAN | IMA3 |    |    |    |    |    |  |  |
| Туре  |    |    |    |    |                 |         |    |    |    | R/  | W    |    |    |    |    |    |  |  |
| Reset |    |    |    |    |                 |         |    |    |    | 0x4 | 19e  |    |    |    |    |    |  |  |

**GAMMA4** Gamma correction coefficient 4.

**GAMMA3** Gamma correction coefficient 3.

### TVE+004Ch Gamma correction coefficients 5-6

**TVE GAMMAD** 

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



### MT6228 GSM/GPRS Baseband Processor Data Sheet Revision 1.0

| Name          |    |    |    |    |    |    |   |   |   | GAM | MA6             |   |   |   |   |   |
|---------------|----|----|----|----|----|----|---|---|---|-----|-----------------|---|---|---|---|---|
| Type          |    |    |    |    |    |    |   |   |   | R/  | W               |   |   |   |   |   |
| Reset         |    |    |    |    |    |    |   |   |   | 0x9 | 93d             |   |   |   |   |   |
| Bit           | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6   | 5               | 4 | 3 | 2 | 1 | 0 |
| Name          |    |    |    |    |    |    |   |   |   | GAM | MA5             |   |   |   | 4 |   |
| Type<br>Reset |    |    |    |    |    |    |   |   |   | R/  |                 |   |   |   |   |   |
| Reset         |    |    |    |    |    |    |   |   |   | 0x7 | <sup>7</sup> b3 |   |   |   |   |   |

GAMMA6 Gamma correction coefficient 6.GAMMA5 Gamma correction coefficient 5.

### TVE+0050h Gamma correction coefficients 7-8

TVE GAMMAE

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

**GAMMA7** Gamma correction coefficient 8. Gamma correction coefficient 7.

### TVE+0060h Software reset control

TVE SWRST

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    | _  |           |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|
| 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  |    |    |    |    |    |    |    | N  |    |    |    |    |    |    |    | SWRS<br>T |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | WO        |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0         |

Writing a 1 invokes a software reset.

# TVE+0070h Plug-in detection

TVE PLUG

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

The TV encoder can detect cable plug-in by sensing the output impedance. To enable plug-in detection, set the TVE\_DACTRL register PLUG\_DETECT\_EN bit. If PLUG\_DETECT\_EN is enabled, when the cable is plugged in, the PLUG bit is set to 1. The user can use polling or interrupt schemes (refer to TVE\_INTREN and TVE\_INTR) for plug-in detection.

**PLUG** Plug-in detection.

- O Cable not plugged in.
- 1 Cable plugged in.



# 7 Audio Front-End

# 7.1 General Description

The audio front-end essentially consists of voice and audio data paths. **Figure 38** shows the block diagram of the audio front-end. All voice band data paths comply with the GSM 03.50 specification. Mono hands-free audio or external FM radio playback paths are also provided. The audio stereo path facilitates CD-quality playback, external FM radio, and voice playback through a headset.



Figure 38 Block diagram of audio front-end

**Figure 39** 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 filter block performs filter operations for voice band and audio band signal processing. The Digital Audio Interface (DAI) block communicates with the System Simulator for FTA or external Bluetooth modules.





Figure 39 Block diagram of digital circuits of the audio front-end

To communicate with the external Bluetooth module, the master-mode PCM interface and master-mode I2S/EIAJ interface are supported. The clock of PCM interface is 256 KHz, and the frame sync is 8 KHz. Both long sync and short sync interfaces are supported. The PCM interface can transmit 16-bit stereo or 32-bit mono 8KHz sampling rate voice signal. **Figure 40** shows the timing diagram of the PCM interface. Note that the serial data changes when the clock is rising and is latched when the clock is falling.



Figure 40 Timing diagram of Bluetooth application

I2S/EIAJ interface is designed to transmit high quality audio data. **Figure 40** and **Figure 41** illustrate the timing diagram of the two types of interfaces. I2S/EIAJ can support 32KHz, 44.1KHz, and 48KHz sampling rate audio signals. The



clock frequency of I2S/EIAJ can be  $32\times$ (sampling frequency), or  $64\times$ (sampling frequency). For example, to transmit a 44.1KHz CD-quality music, the clock frequency should be  $32\times44.1$ KHz = 1.4112MHz or  $64\times44.1$ KHz = 2.8224MHz.

I2S/EIAJ interface is not only used for Bluetooth module, but also for external DAC components. Audio data can easily be sent to the external DAC through the I2S/EIAJ interface.

In this document, the I2S/EIAJ interface is referred to as EDI (External DAC Interface).



**Figure 41** EDI Format 1: EIAJ (FMT = 0).



**Figure 42** EDI Format 2:  $I^2S$  (FMT = 1).

# 7.1.1 DAI, PCM and EDI Pin Sharing

DAI, PCM, and EDI interfaces share the same pins. The pin mapping is listed in Table 59.

| PIN NAME         | DAI     | PCM      | EDI     |  |
|------------------|---------|----------|---------|--|
|                  |         |          |         |  |
| DAI_CLK (OUTPUT) | DAI_CLK | PCM_CLK  | EDI_CLK |  |
|                  |         |          |         |  |
| DAI_TX (OUTPUT)  | DAI_TX  | IPCM_OUT | EDI_DAT |  |
|                  |         |          |         |  |
| DAI_RX (INPUT)   | DAI_RX  | PCM_IN   |         |  |
|                  |         |          |         |  |
| BT_SYNC (OUTPUT) | -       | PCM SYNC | EDI WS  |  |
|                  |         |          | _       |  |

Table 59 Pin mapping of DAI, PCM, and EDI interfaces.

Beside the shared pins, the EDI interface can also use other dedicated pins. With the dedicated pins, PCM and EDI interfaces can operate at the same time.





Figure 43 DAI, PCM, EDI interfaces

# 7.2 Register Definitions

MCU APB bus registers in audio front-end are listed as follows.

### AFE+0000h AFE Voice MCU Control Register

AFE\_VMCU\_CO N0

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

MCU sets this register to start AFE voice operation. A synchronous reset signal is issued, then periodical interrupts of 8-KHz frequency are issued. Clearing this register stops the interrupt generation.

**VAFEON** Turn on audio front-end operations.

# AFE+000Ch AFE Voice Analog-Circuit Control Register 1

AFE\_VMCU\_CO

**N**1

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

Set this register for consistency of analog circuit setting. Suggested value is 80h.

**VRSDON** Turn on the voice-band redundant signed digit function.

0: 1-bit 2-level mode

1: 2-bit 3-level mode



### AFE+0014h AFE Voice DAI Bluetooth Control Register

AFE VDB CON

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6         | 5          | 4         | 3           | 2 | 1      | 0 |
|-------|----|----|----|----|----|----|---|---|---|-----------|------------|-----------|-------------|---|--------|---|
| Name  |    |    |    |    |    |    |   |   |   | EDIO<br>N | VDAI<br>ON | PCMO<br>N | VBTS<br>YNC | ١ | /BTSLE | N |
| Type  |    |    |    |    |    |    |   |   |   | RW        | R/W        | R/W       | R/W         |   | R/W    |   |
| Reset |    |    |    |    |    |    |   |   |   | 0         | 0          | 0         | 0           |   | 000    |   |

Set this register for DAI test mode and Bluetooth application.

**EDION** EDI signals are selected as the output of DAI, PCM, EDI shared interface.

- **O** EDI is not selected. A dedicated EDI interface can be enabled by programming the GPIO selection. Please refer to GPIO section for details.
- 1 EDI is selected. VDAION and VBTON are not set.

**VDAION** Turn on the DAI function.

**VBTON** Turn on the Bluetooth PCM function.

**VBTSYNC**Bluetooth PCM frame sync type

0: short

**1**: long

**VBTSLEN** Bluetooth PCM long 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           |
|-------|----|----|----|----|----|----|---|------------|---|---|---|---|-------------|--------------|-------------|-------------|
|       |    |    |    |    |    |    |   |            |   | , |   |   | <b>VBYP</b> | <b>VDAPI</b> | VINTI       | <b>VDEC</b> |
| Name  |    |    |    |    |    |    |   |            |   |   |   |   | ASSII       | NMOD         | <b>NMOD</b> | <b>INMO</b> |
|       |    |    |    |    |    |    |   |            |   |   |   |   | R           | E            | E           | DE          |
| Type  |    |    |    |    |    |    |   | <b>T</b> 9 |   |   |   |   | R/W         | R/W          | R/W         | R/W         |
| Reset |    | •  |    |    |    |    |   |            |   |   |   |   | 0           | 0            | 0           | 0           |

Set this register for AFE voice digital circuit configuration control. Several loop back modes are 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 | 1/    | 13 | 12 | 11  | 10 | a | Ω | 7 | 6 | 5 | 1 | વ | 2 | 1 | n |
|-----|----|-------|----|----|-----|----|---|---|---|---|---|---|---|---|---|---|
| Dit | 13 | V 1-2 | 10 | 12 | 1.1 | 10 | 9 | U | , | U | J |   | J |   | ı | U |

516/616



| Name  |  |  |  |  |  |  |  | AAFE<br>ON |
|-------|--|--|--|--|--|--|--|------------|
| Type  |  |  |  |  |  |  |  | R/W        |
| Reset |  |  |  |  |  |  |  | 0          |

MCU sets this register to start AFE audio operation. A synchronous reset signal is issued, then periodical interrupts of 1/6 sampling frequency are issued. Clearing this register stops the interrupt generation.

### AFE+0024h

### **AFE Audio Control Register 1**

**AFE AMCU** 

| Bit   | 15 | 14 | 13 | 12 | 11  | 10  | 9 | 8           | 7     | 6    | 5  | 4     | 3          | 2          | 1 |
|-------|----|----|----|----|-----|-----|---|-------------|-------|------|----|-------|------------|------------|---|
| Name  |    |    |    |    | ВҮР | ASS |   | ADITH<br>ON | ADITI | HVAL | AR | AMPSP | AMUTE<br>R | AMUTE<br>L | 4 |
| Type  |    |    |    |    | R'  | W   |   | R/W         | R/    | W    |    | R/W   | R/W        | R/W        | F |
| Reset |    |    |    |    | 0   | 0   |   | 0           | 0     | 0    |    | 00    | 0          | 0          |   |

MCU sets this register to inform hardware of the sampling frequency of audio being played back.

**BYPASS** To bypass part of the audio hardware path.

- **00** No bypass. The input data rate is 1/4 sampling frequency. For example, if the sampling frequency is 32KHz, then the input data rate is 8KHz.
- **01** Bypass the first stage of interpolation. The input data rate is 1/2 the sampling frequency.
- **10** Bypass two stages of interpolation. The input data rate is the same as the sampling frequency.
- 11 Bypass two stages of interpolation and EQ filter. The input data rate is the same as the sampling frequency.



Figure 44 Block diagram of the audio path.

**ADITHON** Turn on the audio dither function.

**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 the audio R-channel, with a soft ramp up/down.

**AMUTEL** Mute the audio L-channel, with a soft ramp up/down.

**AFS** Sampling frequency setting.

**00** 32-KHz

**01** 44.1-KHz

**10** 48-KHz

11 reserved

### AFE+0028h AFE EDI Control Register

AFE\_EDI\_CON

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

This register is used to control the EDI

**EN** Enable EDI. When EDI is disabled, EDI\_DAT and EDI\_WS hold low.

0 disable EDI

1 enable EDI

**FMT** EDI format

O EIAJ

1 I2S

**WCYCLE** Clock cycle count in a word. Cycle count = WCYCLE + 1, and WCYCLE can be 15 or 31 only. Any other values result in an unpredictable error.

15 Cycle count is 16.

**31** Cycle count is 32.



**Figure 45** Cycle count is 16 for I2S format.



Figure 46 Cycle count is 32 for I2S format.



# AFE+0040h~00 AFE Audio Equalizer Filter Coefficient Register

AFE EQCO

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | $\Box$ 0 $\Box$ |
|------|----|----|----|----|----|----|---|-----|---|---|---|---|---|---|---|-----------------|
| Name |    |    |    |    |    |    |   | - / | 4 |   |   |   |   |   |   |                 |
| Type |    |    |    |    |    |    |   | W   | O |   |   |   |   |   |   |                 |

Audio front-end provides a 45-tap equalizer filter. The filter is shown below.

 $DO = (A44 \times DI44 + A43 \times DI43 \dots + A1 \times DI1 + A0 \times DI0)/32768.$ 

DIn is the input data, and An is the coefficient of the filter, which is a 16-bit 2's complement signed integer. input data.

The coefficient cannot be programmed when the audio path is enabled, or unpredictable noise may be generated. If coefficient programming is necessary while the audio path is enabled, the audio path must be muted during programming. After programming is complete, the audio path is not to be resumed (unmated) for 100 sampling periods.

Coefficient of the filter.

### 7.3 **Programming Guide**

Several cases - including speech call, voice memo record, voice memo playback, melody playback and DAI tests - requires that partial or the whole audio front-end be turned on.

The following are the recommended voice band path programming procedures to turn on audio front-end:

- 1. 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. Refer also to the analog chip interface specification.
- 2. MCU clears the VAFE bit of the PDN\_CON2 register to ungate the clock for the voice band path. Refer to the software power down control specification.
- 3. MCU sets AFE VMCU CON to start operation of the voice band path.

The following are the recommended voice band path programming procedures to turn off audio front-end:

- 1. MCU programs AFE\_VAPDN\_CON to power down the voice band path analog blocks.
- 2. MCU clears AFE VMCU CON to stop operation of the voice band path.
- 3. MCU sets VAFE bit of PDN\_CON2 register to gate the clock for the 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)

The MS then waits for DAIRST# signaling from the SS. Recognizing this, DSP starts to transmit to and/or receive from the DSP. For further details, refer to the GSM 11.10 specification.

519/616



The following are the recommended audio band path programming procedures to turn on audio front-end:

- 1. MCU programs the AFE\_MCU\_CON1, AFE\_AAG\_CON, AFE\_AAC\_CON, and AFE\_AAPDN\_CON registers for specific configurations. Refer also to the analog chip interface specification.
- 2. MCU clears the AAFE bit of the PDN\_CON2 register to ungate the clock for the audio band path. Refer to the software power down control specification.
- 3. MCU sets AFE\_AMCU\_CON0 to start operation of the audio band path.

The following are the recommended audio band path programming procedures to turn off audio front-end:

- 1. MCU programs the AFE\_AAPDN\_CON to power down the audio band path analog blocks. Refer also to the analog block specification for further details.
- 2. MCU clears AFE\_AMCU\_CON0 to stop operation of the audio band path.
- 3. MCU sets the AAFE bit of the PDN\_CON2 register to gate the clock for the audio band path.



# 8 Radio Interface Control

This chapter details the MT6228 interface control with the radio part of a GSM terminal. Providing a comprehensive control scheme, the MT6228 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 Baseband Serial Interface

The Baseband Serial Interface controls external radio components. A 3-wire serial bus transfers 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 a 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. Each data control register identifies which events (signaled by TDMA\_BSISTRn, generated by the TDMA timer) trigger the download process of the word in register BSI\_Dn\_DAT. The word and its length (in bits) is downloaded via the serial bus. A special event is triggered when the IMOD flag is set to 1: it provides immediate download process without software 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 is downloaded first, followed by the next lowest and so on.

The total download time depends on the word length, the number of words to download, and the clock rates. The programmer must space the successive event to provide enough time. If the download process of the previous event is not complete before a new event arrives, the latter is suppressed.

The unit has 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 2 external components. BSI\_CS1 is multiplexed with another function. Please refer to GPIO table for more detail.

In order to support bi-directional read and write operations of the RF chip, software can directly write values to BSI\_CLK, BSI\_DATA and BSI\_CS by programming the BSI\_DOUT register. Data from the RF chip can be read by software via the register BSI\_DIN. If the RF chip interface is a 3-wire interface, then BSI\_DATA is bi-directional. Before software can program the 3-wire behavior, the BSI\_IO\_CON register must be set. An additional signal path from GPIO accommodates RF chips with a 4-wire interface.

The block diagram of the BSI unit is as depicted in Figure 47.







Figure 47 Block diagram of BSI unit.



Figure 48 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<br>NV | EN1_<br>POL | EN1_<br>LEN | EN0_<br>POL | ENO_<br>LEN | IMOD | CLK | SPD | CLK_<br>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           |

This register is the control register for the BSI unit. The register controls the signal type of the 3-wire interface.

**CLK\_POL** Controls the polarity of BSI\_CLK. Refer to **Figure 48.** 

- O True clock polarity
- 1 Inverted clock polarity

**CLK\_SPD** 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

Enables immediate mode. If the user writes 1 to the flag, the download is triggered immediately without waiting for the timer events. The words for which the register event ID equals 1Fh are downloaded following this signal. This flag is write-only. The immediate write is exercised only once: the programmer must write the flag again to invoke another immediate download. Setting the flag does not disable the other events from the timer; the programmer can disable all events by setting BSI ENA to all zeros.

**ENX LEN** Controls the type of signals BSI CS0 and BSI CS1. Refer to **Figure 47.** 

- **0** Long enable pulse
- 1 Short enable pulse

**ENX\_POL** Controls the polarity of signals BSI\_CS0 and BSI\_CS1.

- **0** True enable pulse polarity
- 1 Inverted enable pulse polarity

**SETENV** Enables the write operation of the active buffer.

- O The user writes to the write buffer. The data is then latched in the active buffer after TDMA\_EVTVAL is pulsed.
- 1 The user writes data directly to the active buffer.

### BSI+0004h Control part of data register 0

BSI DO CON

| Bit  | 15  | 14 | 13 | 12 | 11 | 10  | 9 | 8 | 7_ | $\begin{bmatrix} 6 \end{bmatrix}$ | 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. The register determines the required length of the download data word, the event to trigger the download process of the word, and the targeted device.

**Table 61** lists the 27 data registers of this type. Multiple data control registers may contain the same event ID: the data words of all registers with the same event ID are downloaded when the event occurs.

**EVT\_ID** Stores the event ID for which the data word awaits to be downloaded.

**00000~01111** Synchronous download of the word with the selected EVT\_ID event. The relationship between this field and the event is listed as **Table 60.** 

| 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 60 The relationship between the value of EVT\_ID field in the BSI control registers and the TDMA\_BSISTR events.

10000~11110Reserved

11111 Immediate download

LEN Stores the length of the data word. The actual length is defined as LEN + 1 (in 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 DO DAT** 

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

This register is the data part of the data register 0. The legal length of the data is up to 32 bits. The actual number of bits to be transmitted is specified in LEN field in the BSI\_D0\_CON register.

**DAT** The field signifies the data part of the data register.

**Table 61** lists the address mapping and function of the 27 pairs of data registers.

| Register Address | Register Function               | Acronym     |
|------------------|---------------------------------|-------------|
| BSI +0004h       | Control part of data register 0 | BSI_D0_CON  |
| BSI +0008h       | Data part of data register 0    | BSI_D0_DAT  |
| BSI +000Ch       | Control part of data register 1 | BSI_D1_CON  |
| BSI +0010h       | Data part of data register 1    | BSI_D1_ DAT |
| BSI +0014h       | Control part of data register 2 | BSI_D2_CON  |
| BSI +0018h       | Data part of data register 2    | BSI_D2_ DAT |
| BSI +001Ch       | Control part of data register 3 | BSI_D3_CON  |
| BSI +0020h       | Data part of data register 3    | BSI_D3_ DAT |
| BSI +0024h       | Control part of data register 4 | BSI_D4_CON  |
| BSI +0028h       | Data part of data register 4    | BSI_D4_ DAT |
| BSI +002Ch       | Control part of data register 5 | BSI_D5_CON  |
| BSI +0030h       | Data part of data register 5    | BSI_D5_ DAT |
| BSI +0034h       | Control part of data register 6 | BSI_D6_CON  |
| BSI +0038h       | Data part of data register 6    | BSI_D6_ DAT |



| •••        |                                  |              |
|------------|----------------------------------|--------------|
| BSI +003Ch | Control part of data register 7  | BSI_D7_CON   |
| BSI +0040h | Data part of data register 7     | BSI_D7_ DAT  |
| BSI +0044h | Control part of data register 8  | BSI_D8_CON   |
| BSI +0048h | Data part of data register 8     | BSI_D8_ DAT  |
| BSI +004Ch | Control part of data register 9  | BSI_D9_CON   |
| BSI +0050h | Data part of data register 9     | BSI_D9_ DAT  |
| BSI +0054h | Control part of data register 10 | BSI_D10_CON  |
| BSI +0058h | Data part of data register 10    | BSI_D10_DATA |
| BSI +005Ch | Control part of data register 11 | BSI_D11_CON  |
| BSI +0060h | Data part of data register 11    | BSI_D11_ DAT |
| BSI +0064h | Control part of data register 12 | BSI_D12_CON  |
| BSI +0068h | Data part of data register 12    | BSI_D12_DAT  |
| BSI +006Ch | Control part of data register 13 | BSI_D13_CON  |
| BSI +0070h | Data part of data register 13    | BSI_D13_ DAT |
| BSI +0074h | Control part of data register 14 | BSI_D14_CON  |
| BSI +0078h | Data part of data register 14    | BSI_D14_ DAT |
| BSI +007Ch | Control part of data register 15 | BSI_D15_CON  |
| BSI +0080h | Data part of data register 15    | BSI_D15_ DAT |
| BSI +0084h | Control part of data register 16 | BSI_D16_CON  |
| BSI +0088h | Data part of data register 16    | BSI_D16_ DAT |
| BSI +008Ch | Control part of data register 17 | BSI_D17_CON  |
| BSI +0090h | Data part of data register 17    | BSI_D17_ DAT |
| BSI +0094h | Control part of data register 18 | BSI_D18_CON  |
| BSI +0098h | Data part of data register 18    | BSI_D18_ DAT |
| BSI +009Ch | Control part of data register 19 | BSI_D19_CON  |
| BSI +00A0h | Data part of data register 19    | BSI_D19_ DAT |
| BSI +00A4h | Control part of data register 20 | BSI_D20_CON  |
| BSI +00A8h | Data part of data register 20    | BSI_D20_ DAT |
| BSI +00ACh | Control part of data register 21 | BSI_D21_CON  |
| BSI +00B0h | Data part of data register 21    | BSI_D21_ DAT |
| BSI +00B4h | Control part of data register 22 | BSI_D22_CON  |
| BSI +00B8h | Data part of data register 22    | BSI_D22_ DAT |
| BSI +00BCh | Control part of data register 23 | BSI_D23_CON  |
| BSI +00C0h | Data part of data register 23    | BSI_D23_ DAT |
| BSI +00C4h | Control part of data register 24 | BSI_D24_CON  |
| BSI +00C8h | Data part of data register 24    | BSI_D24_ DAT |
| BSI +00CCh | Control part of data register 25 | BSI_D25_CON  |
| BSI +00D0h | Data part of data register 25    | BSI_D25_ DAT |
| BSI +00D4h | Control part of data register 26 | BSI_D26_CON  |
|            |                                  |              |



| BSI +00D8h | Data part of data register 26 | BSI_D26_ DAT |
|------------|-------------------------------|--------------|
|------------|-------------------------------|--------------|

Table 61 **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  |
| Reset | 1     | 1     | 1     | 1     | 1     | 1     | 1    | 1    | 1    | 1    | 1    | 1    | 1    |      | 1    | 1    |

This register enables an event by setting the corresponding bit. After a hardware reset, all bits are initialized to 1. These bits are also set to 1 after TDMA\_EVTVAL pulse.

**BSIx** Enables downloading of the words corresponding to the events signaled by TMDA BSI.

- **0** The event is not enabled.
- 1 The event is enabled.

### BSI +0194h BSI IO mode control register

**BSI IO CON** 

| Bit   | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3           | 2          | 1           | 0    |
|-------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-------------|------------|-------------|------|
| Name  |     |     |     |     |     |     |     |     |     |     | U   |     | SEL_<br>CS1 | 4_WIR<br>E | DAT_<br>DIR | MODE |
| Type  | R/W         | R/W        | R/W         | R/W  |
| Reset | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 07_ | 0   | 0   | 0           | 0          | 1           | 0    |

**MODE** Defines the source of BSI signal.

- **0** BSI signal is generated by the hardware.
- 1 BSI signal is generated by the software. In this mode, the BSI clock depends on the value of the field DOUT.CLK. BSI\_CS depends on the value of the field DOUT.CS and BSI\_DATA depends on the value of the field DOUT.DATA.

**DAT\_DIR** Defines the direction of BSI\_DATA.

- **0** BSI \_DATA is configured as input. The 3-wire interface is used and BSI\_DATA is bi-directional.
- 1 BSI\_DATA is configured as output.

**4\_WIRE** Defines the BSI\_DIN source.

- **0** The 3-wire interface is used and BSI\_DATA is bi-directional. BSI\_DIN comes from the same pin as BSI\_DATA.
- 1 The 4-wire interface is used. Another pin (GPIO) is used as BSI\_DIN.

**SEL\_CS1** Defines which of the BSI\_CSx (BSI\_CS0 or BSI\_CS1) is written by the software.

- **0** BSI CS0 is selected.
- 1 BSI\_CS1 is selected.

### BSI +0198h Software-programmed data out

**BSI DOUT** 

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

526/616

**CLK** Signifies the BSI\_CLK signal.

CS Signifies the BSI\_CS signal.

**DATA** Signifies the BSI\_DATA signal.



### BSI +019ch Input data from RF chip

**BSI DIN** 

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

**DIN** Registers the input value of BSI\_DATA from the RF chip.

### 8.2 Baseband Parallel Interface

## 8.2.1 General Description

The Baseband Parallel Interface features 10 control pins, which are used for timing-critical external circuits. These pins typically control front-end components which must be turned on or off at specific times during GSM operation, such as transmit-enable, band switching, TR-switch, etc.



- The driving capability is configurable.

Figure 49 Block

### diagram of BPI interface

The user can program 22 sets of 10-bit registers to set the output value of BPI\_BUS0~BPI\_BUS9. The data is stored in the write buffers. The write buffers are then forwarded to the active buffers when the TDMA\_EVTVAL signal is pulsed, usually once per frame. Each of the 22 write buffers corresponds to an active buffer, as well as to a TDMA event.

Each TDMA\_BPISTR event triggers the transfer of 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 is not pulsed, and the value on the BPI bus remains unchanged.

For applications in which BPI signals serve as the switch, current-driving components are typically added to enhance driving capability. Four configurable output pins provide current up to 8 mA, and help reduce the number of 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

BPI\_CON

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4     | 3     | 2     | 1     | 0         |
|-------|----|----|----|----|----|----|---|---|---|---|---|-------|-------|-------|-------|-----------|
| Name  |    |    |    |    |    |    |   |   |   |   |   | PINM3 | PINM2 | PINM1 | PINM0 | PETE<br>V |
| Type  |    |    |    |    |    |    |   |   |   |   |   | WO    | WO    | WO    | WO    | R/W       |
| Reset |    |    |    |    |    |    |   |   | · | · |   | 0     |       | 0     | 0     | 0         |

This register is the control register of the BPI unit. The register controls the direct access mode of the active buffer and the current driving capability for the output pins.

The driving capabilities of BPI\_BUS0, BPI\_BUS1, BPI\_BUS2, and BPI\_BUS3 can be 2 mA or 8 mA, determined by the value of PINM0, PINM1, PINM2, and PINM3, respectively. These output pins provide a higher driving capability and save on external current-driving components. In addition to the configurable pins, pins BPI\_BUS4 to BPI\_BUS9 provide a driving capability of 2 mA (fixed).

**PETEV** Enables direct access to the active buffer.

- 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.

**PINMO** Controls the driving capability of BPI\_BUSO.

- **0** The output driving capability is 2mA.
- 1 The output driving capability is 8mA.

**PINM1** Controls the driving capability of BPI\_BUS1.

- The output driving capability is 2mA.
- 1 The output driving capability is 8mA.

**PINM2** Controls the driving capability of BPI\_BUS2.

- The output driving capability is 2mA.
- 1 The output driving capability is 8mA.

**PINM3** Controls the driving capability of BPI\_BUS3.

- O The output driving capability is 2mA.
- 1 The output driving capability is 8mA.

### BPI +0004h BPI data register 0

**BPI BUF0** 

| Bit  | 15 | 14 | 13 | 12 | 可归 | 10 | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|------|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name |    |    |    |    |    |    | PO9 | PO8 | PO7 | P06 | PO5 | PO4 | PO3 | PO2 | PO1 | PO0 |
| Type |    |    |    |    |    |    | R/W |

This register defines the BPI signals that are associated with the event TDMA BPI0.

Table 62 lists 22 registers of the same structure, each of which is associated with one specific event signal from the TDMA timer. The data registers are all double-buffered. When PETEV is set to 0, the data register links to the write buffer. When PETEV is set to 1, the data register links to the active buffer.



One register, BPI\_BUFI, is dedicated for use in immediate mode. Writing a value to that register effects an immediate change in the corresponding BPI signal and bus.

**POx** This flag defines the corresponding signals for BPIx after the TDMA event 0 takes place. The overall data register definition is listed in **Table 62.** 

| Register Address | Register Function                  | Acronym   |
|------------------|------------------------------------|-----------|
| BPI +0004h       | BPI pin data for event TDMA_BPI 0  | BPI_BUF0  |
| BPI +0008h       | BPI pin data for event TDMA_BPI 1  | BPI_BUF1  |
| BPI +000Ch       | BPI pin data for event TDMA_BPI 2  | BPI_BUF2  |
| BPI +0010h       | BPI pin data for event TDMA_BPI 3  | BPI_BUF3  |
| BPI +0014h       | BPI pin data for event TDMA_BPI 4  | BPI_BUF4  |
| BPI +0018h       | BPI pin data for event TDMA_BPI 5  | BPI_BUF5  |
| BPI +001Ch       | BPI pin data for event TDMA_BPI 6  | BPI_BUF6  |
| BPI +0020h       | BPI pin data for event TDMA_BPI 7  | BPI_BUF7  |
| BPI +0024h       | BPI pin data for event TDMA_BPI 8  | BPI_BUF8  |
| BPI +0028h       | BPI pin data for event TDMA_BPI 9  | BPI_BUF9  |
| BPI +002Ch       | BPI pin data for event TDMA_BPI 10 | BPI_BUF10 |
| BPI +0030h       | BPI pin data for event TDMA_BPI 11 | BPI_BUF11 |
| BPI +0034h       | BPI pin data for event TDMA_BPI 12 | BPI_BUF12 |
| BPI +0038h       | BPI pin data for event TDMA_BPI 13 | BPI_BUF13 |
| BPI +003Ch       | BPI pin data for event TDMA_BPI 14 | BPI_BUF14 |
| BPI +0040h       | BPI pin data for event TDMA_BPI 15 | BPI_BUF15 |
| BPI +0044h       | BPI pin data for event TDMA_BPI 16 | BPI_BUF16 |
| BPI +0048h       | BPI pin data for event TDMA_BPI 17 | BPI_BUF17 |
| BPI +004Ch       | BPI pin data for event TDMA_BPI 18 | BPI_BUF18 |
| BPI +0050h       | BPI pin data for event TDMA_BPI 19 | BPI_BUF19 |
| BPI +0054h       | BPI pin data for event TDMA_BPI 20 | BPI_BUF20 |
| BPI +0058h       | BPI pin data for event TDMA_BPI 21 | BPI_BUF21 |
| BPI +005Ch       | BPI pin data for immediate mode    | BPI_BUFI  |

Table 62 **BPI Data Registers.** 

### BPI +0060h BPI event enable register 0

| _ |   | _ |    | _ | $\hat{}$ |
|---|---|---|----|---|----------|
| ĸ | ш | _ | NI | ^ |          |
| ப |   | _ | IV | ~ | u        |

| Bit   | 15        | 14        | 13          | 12        | 71        | 10        | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-------|-----------|-----------|-------------|-----------|-----------|-----------|------|------|------|------|------|------|------|------|------|------|
| Name  | BEN1<br>5 | BEN1<br>4 | BEN1<br>3   | BEN1<br>2 | BEN1<br>1 | BEN1<br>0 | BEN9 | BEN8 | BEN7 | BEN6 | BEN5 | BEN4 | BEN3 | BEN2 | BEN1 | BEN0 |
| 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         | <u> 4</u> 1 | 1         | 1         | 1         | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    | 1    |

This register enables the events that are signaled by the TDMA timer: by clearing a register bit, the corresponding event signal is ignored. After a hardware reset, all the enable bits default to 1 (enabled). Upon receiving a TDMA\_EVTVAL pulse, all register bits are also set to 1 (enabled).

**BENn** This flag indicates whether event n signals are heeded or ignored.



- Event n is disabled (ignored).
- 1 Event n is enabled.

### BPI+0064h BPI event enable register 1

**BPI ENA**1

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5    | 4    | 3    | 2    | 1    | _ 0  |
|-------|----|----|----|----|----|----|---|---|---|---|------|------|------|------|------|------|
| Name  |    |    |    |    |    |    |   |   |   |   | BEN2 | BEN2 | BEN1 | BEN1 | BEN1 | BEN1 |
| Туре  |    |    |    |    |    |    |   |   |   |   | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |
| Reset |    |    |    |    |    |    |   |   |   |   | 0    | 0    | 0    | 0    | 0    | 0    |

This register enables the events that are signaled by the TDMA timing generator: by clearing a register bit, the corresponding event signal is ignored. After a hardware reset, all the enable bits default to 1 (enabled). Upon receiving the TDMA\_EVTVAL pulse, all register bits are also set to 1 (enabled).

**BENn** This flag indicates whether event n signals are heeded or ignored.

- **0** Event n is disabled (ignored).
- 1 Event n is enabled.

# 8.3 Automatic Power Control (APC) Unit

# 8.3.1 General Description

The Automatic Power Control (APC) unit controls the Power Amplifier (PA) module. Through APC unit, the proper transmit power level of the handset can be set to ensure that 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 are adjustable for different conditions.

The entries from one bank of the ramp profile are partitioned into two parts, with 8 values in each half. In normal operation, the entries in the left half are multiplied by a 10-bit left scaling factor, and the entries in the right half are multiplied by a 10-bit right scaling factor. The 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 50**.

The APB bus interface is 32 bits wide. Four write accesses are required to program each bank of ramp profile. The detailed register allocations are listed in **Table 63.** 







50 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 |    |    |    | EN | T3         |    |    |    |    |    |    | EN | IT2 |    |    |    |
| Type |    |    |    | R/ | W          |    |    |    |    |    |    | R/ | W   |    |    |    |
| Bit  | 15 | 14 | 13 | 12 | 11         | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3   | 2  | 1  | 0  |
| Name |    |    |    | EN | <b>T</b> 1 |    |    |    |    |    |    | EN | IT0 |    |    |    |
| 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 entry in the second byte [15:8], the third entry in the third byte [23:16], and the fourth in the most significant byte [31:24]. Since this register provides no hardware reset, the programmer must 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 63**.

| 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 63 APC ramp profile registers

### APC +0010h APC 1st ramp profile left scaling factor

**APC SCALOL** 

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

The register stores the left scaling factor of the  $1^{st}$  ramp profile. This factor multiplies the first 8 entries of the  $1^{st}$  ramp profile to provide the scaled profile, which is then interpolated to control the D/A converter.

After a hardware reset, the initial value of the register is 256. In this case, no scaling is done (each entry of the ramp profile is multiplied by 1), because the 8 least significant bits are truncated after multiplication.

The overall scaling factor register definition is listed in Table 64.

**SF** Scaling factor. After a hardware reset, the value is 256.

# APC +0014h APC 1st ramp profile right scaling factor

APC SCALOR

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

The register stores the right scaling factor of the  $1^{st}$  ramp profile. This factor multiplies the last 8 entries of the  $1^{st}$  ramp profile to provide the scaled profile, which is then interpolated to control the D/A converter.



After a hardware reset, the initial value of the register is 256. In this case, no scaling is done (each entry of the ramp profile is multiplied by 1), because the 8 least significant bits are truncated after multiplication.

The overall scaling factor register definition is listed in **Table 64**.

**SF** Scaling factor. After a 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  |    |    |    |    |    |    |   |   |   |   | OFF | SET |   |   |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   | R/  | W   |   |   |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   | (   | )   |   |   |   |   |

There are 7 offset values for the corresponding ramp profile.

The 1<sup>st</sup> offset value also serves as the pedestal value. The value is 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, to provide the initial control voltage for 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; its valid range is 0~127 quarter-bits of time after the baseband D/A converter is powered up.

**OFFSET** Offset value for the corresponding ramp profile. After a hardware reset, the default value is 0. The overall offset register definition is listed in **Table 64.** 

| 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 64 APC scaling factor and offset value registers



| APC   | FUUE | אכ | APC | contr | oı re | gister |   |   |   |   |   |   |   |   | APC_ | CON |
|-------|------|----|-----|-------|-------|--------|---|---|---|---|---|---|---|---|------|-----|
| Bit   | 15   | 14 | 13  | 12    | 11    | 10     | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1    |     |
| Name  |      |    |     |       |       |        |   |   |   |   |   |   |   |   | GSM  | FPU |
| Type  |      |    |     |       |       |        |   |   |   |   |   |   |   |   | R/W  | R/W |
| Reset |      |    |     |       |       |        |   |   |   |   |   |   |   |   | 1    | 0   |

GSM Defines the operation mode of the APC module. In GSM mode, each frame has only one slot, thus only one scaling factor and one offset value must be configured. If the GSM bit is set, the programmer needs only to configure APC\_SCALOL and APC\_OFFSETO. 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** Forces the APC D/A converter to power up. Test only.

- The APC D/A converter is not forced to power up. The converter is only powered on when the transmission window is opened. Default value.
- 1 The APC D/A converter is forced to power up.

# 8.3.3 Ramp Profile Programming

The first value of the first normalized ramp profile must be written in the least significant byte of the APC\_PFA0 register. The second value must be written in the second least significant byte of the APC\_PFA0, and so on.

Each ramp profile can be programmed to form an arbitrary shape.

The start of ramping is triggered by one of the TDMA\_APCSTR signals. The timing relationship between TDMA\_APCSTR and TDMA slots is depicted in **Figure 51** for 4 consecutive time slots case. The power ramping profile must comply with the timing mask defined in GSM SPEC 05.05. The timing offset values for 7 ramp profiles are stored in the TDMA timer register from TDMA\_APC0 to TDMA\_APC6.



Figure 51 Timing diagram of TDMA\_APCSTR.

Because the APC unit provides more than 5 ramp profiles, up to 4 consecutive transmission slots can accommodated. The 2 additional ramp profiles are useful particularly when the timing between the last 2 transmission time slots and CTIRQ is uncertain; software can begin writing the ramp profiles for the succeeding frame during the current frame, alleviating the risk of not writing the succeeding frame's profile data in time.

In GPRS mode, to fit the intermediate ramp profile between different power levels, a simple scaling scheme is used to synthesize the ramp profile. \_\_The equation is as follows:



$$\begin{split} & \mathrm{DA}_{0} = \mathrm{OFF} + \mathrm{S}_{0} \cdot \frac{\mathrm{DN}_{15,pre} + \ \mathrm{DN}_{0}}{2} \\ & \mathrm{DA}_{2k} = \mathrm{OFF} + \mathrm{S}_{l} \cdot \frac{\mathrm{DN}_{k-1} + \ \mathrm{DN}_{k}}{2}, k = 1, ..., 15 \\ & \mathrm{DA}_{2k+1} = \mathrm{OFF} + \mathrm{S}_{l} \cdot \mathrm{DN}_{k}, k = 0, 1, ..., 15 \\ & l = \begin{cases} 0, & \text{if } 8 > k \geq 0 \\ 1, & \text{if } 15 \geq k \geq 8 \end{cases} \end{split}$$

where  $\mathbf{D}\mathbf{A}$  = the data to present to the D/A converter,

**DN** = the normalized data which is stored in the register  $APC_PFn$ ,

 $S_0$  = the left scaling factor stored in register APC\_SCALnL,

 $S_1$  = the right scaling factor stored in register APC\_SCALnR, and

 $OFF = the offset value stored in the register APC_OFFSET_n$ .

The subscript n denotes the index of the ramp profile.

The ramp calculation before interpolation is as depicted in **Figure 52**.

During each ramp process, each word of the normalized profile is first multiplied by 10-bit scaling factors and added to an offset value to form a bank of 18-bit words. The first 8 words (in the left half part as in **Figure 52**) are multiplied by the left scaling factor  $S_0$  and the last 8 words (in the right half part as in **Figure 52**) are multiplied by the right scaling factor  $S_1$ . The lowest 8 bits of each word are then truncated to get a 10-bit result. The scaling factor is 0x100, which represents no scaling on reset. A value smaller than 0x100 scales the ramp profile down, and a value larger than 100 scales the ramp profile up.



Figure 52 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.0833 MHz, that is, at quarter-bit rate. The timing diagram is shown in **Figure 53** and the final value is retained on the output until the next event occurs.





Figure 53 Timing diagram of the APC ramping.

The APC unit is only powered up when the APC window is open. The APC window is controlled by configuring the TDMA registers TDMA\_BULCON1 and TDMA\_BULCON2. Please refer to the 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 is critical. The programmer must be restricted from writing to the data buffer during the ramping process, otherwise the ramp profile may be incorrect and lead to a malfunction.

# 8.4 Automatic Frequency Control (AFC) Unit

# 8.4.1 General Description

The Automatic Frequency Control (AFC) unit provides the direct control of the oscillator for frequency offset and Doppler shift compensation. The block diagram is of the AFC unit depicted in **Figure 54**. The module utilizes a 13-bit D/A converter to achieve high-resolution control. Two modes of operation provide flexibility when controlling the oscillator; they are described as follows.





Figure 54 Block Diagram of the AFC Controller

In timer-triggered mode, the TDMA timer controls the AFC enabling events. Each TDMA frame can pulse at most four events. Double buffer architecture is supported. AFC values can be written to the write buffers. When the signal TDMA\_EVTVAL is received, the values in the write buffers are latched into the active buffers. However, AFC values can also be written to the active buffers directly. Each event is associated with an active buffer sharing the same index. When a TDMA event is triggered by TDMA\_AFC, the value in the corresponding active buffer takes effect. **Figure 55** shows a timing diagram of AFC events with respect to TX/RX/MX windows. In this mode, the D/A converter can stay powered on or be powered on for a programmable duration (256 quarter-bits, by default). The latter option is for power saving.



Figure 55 Timing Diagram for the AFC Controller

In immediate mode, the MCU can directly control the AFC value without event-triggering. The value written by the MCU takes effect immediately. In this mode, the D/A converter must be powered on continuously. When transitioning from immediate mode into timer-triggered mode (by setting flag I\_MODE in the register AFC\_CON to be 0), the D/A converter is kept powered on for a programmable duration (256 quarter-bits by default) if a TDMA\_AFC is not been pulsed. The duration is prolonged upon receiving events.

# 8.4.2 Register Definitions

### AFC+0000h AFC control register AFC CON Bit 15 14 13 12 9 8 6 5 2 3 **RDAC** MO I MO Name DE NV DE т 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.



**RDACT** The flag enables the direct read operation from the active buffer. Note that the control flag is only applicable to the four data buffers AFC\_DAT0, AFC\_DAT1, AFC\_DAT2, and AFC\_DAT3.

- O 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 that the control flag is only applicable to the four data buffers AFC\_DAT0, AFC\_DAT1, AFC\_DAT2, and AFC\_DAT3.

- **O** 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 immediate mode. To enable immediate mode, force power up mode must also be enabled.

- **0** Immediate mode is not enabled.
- 1 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 the RDACT or FETENV bit (of the AFC\_CON register) is set, the data transfer operates on the active buffer. When neither flag is set, the data transfer operates on the write buffer.

**AFCD** The AFC sample for the D/A converter.

Four registers (AFC\_DAT0, AFC\_DAT1, AFC\_DAT2, AFC\_DAT3) of the same type correspond to the event triggered by the TDMA timer. The four registers are summarized in **Table 65**.

| Register Address | Register Function   | Acronym  |
|------------------|---------------------|----------|
| AFC +0004h       | AFC control value 0 | AFC_DAT0 |
| AFC +0008h       | AFC control value 1 | AFC_DAT1 |
| AFC +000Ch       | AFC control value 2 | AFC_DAT2 |
| AFC +0010h       | AFC control value 3 | AFC_DAT3 |

### Table 65 AFC Data Registers

Immediate mode can only use AFC\_DATO. In this mode, only the control value in the AFC\_DATO write buffer is used to control the D/A converter. Unlike timer-triggered mode, the control value in AFC\_DATO write buffer can bypass the active buffer stage and be directly coupled to the output buffer in immediate mode. To use immediate mode, program the AFC\_DATO in advance and then enable immediate mode by setting the I\_MODE flag in the AFC\_CON register.

The registers AFC\_DATA0, AFC\_DAT1, AFC\_DAT2, and AFC\_DAT3 have no initial values, thus the register must be programmed before any AFC event takes place. The AFC value for the D/A converter, i.e., the output buffer value, is initially 0 after power up before any event occurs.



### 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  |    |    |    | PU_PER |     |    |   |   |   |    |   |   |   |   |    |   |
| Type  |    |    |    |        | R/W |    |   |   |   |    |   |   |   |   |    |   |
| Reset |    |    |    |        | •   |    |   |   |   | ff |   |   |   |   | 1- |   |

This register stores the AFC power up period, which is 13 bits wide. The value ranges from 0 to 8191. If the I\_MODE or F\_MODE flag is set, this register has no effect since the D/A converter is powered up continuously. If neither flag is set, the register controls the power up duration of the D/A converter. During that period, the signal nPDN\_DAC in **Figure 54** is set to 1(power up).

**PU\_PER** Stores the AFC power up period. After hardware power up, the field is initialized to 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 56**). 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 56** illustrates interconnection around Baseband Front End. In the figure the shadowed blocks compose 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 of uplink and downlink paths is active at one moment. 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 56 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 interfaces with DSP in serial manner. It 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 completely be different from that in normal function mode. The special mode is for testing purpose. Please see the subsequent section of Downlink Path for details.

TX and RX windows are under control of TDMA timer. Please refer to functional specification of TDMA timer for the details how to open/close a TX/RX window. Opening/Closing of TX/RX windows has two major effects on Baseband Front End. They are 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. Lets denote as RX enable window the interval that RX mixed-signal module is powered on and denote as RX dump window 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. Notes 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'. It 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 control of TX/RX dump window. Note that if TX/RX dump window is not integer multiplies of bit-time it will be extended to be integer multiplies of bit-time. For example, if TX/RX dump window has interval of 156.25 bit-times then it will be extended as 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  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | BCIE<br>N |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | R/W       |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0         |

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 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 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    |    |    |    |    |    |    |   |   |   |   |   |   | BULF | BULE | <b>BDLF</b> | <b>BDLE</b> |
| Ivallie |    |    |    |    |    |    |   |   |   |   |   |   | S    | N    | S           | N           |
| Type    |    |    |    |    |    |    |   |   |   |   |   |   | RO   | RO   | RO          | RO          |
| Reset   |    |    |    |    |    |    |   |   |   |   |   |   | 0    | 0    | 0           | 0           |

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.

- O Disabled
- 1 Enabled

**BDLFS** Indicate if Baseband Serial Ports for downlink path is enabled.

- O Disabled
- Enabled

**BULEN** Indicate if uplink path is enabled.

- O Disabled
- 1 Enabled

**BULFS** Indicate if Baseband Serial Ports for uplink path is enabled.

- O Disabled
- 1 Enabled

# 9.2 Downlink Path (RX Path)

## 9.2.1 General Description

On 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 57**.

While RX enable windows are opened, 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 57**. 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 of 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 details. The mode is for measurement of performance of A/D converters in RX mixed-signal module.





Figure 57 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  |    | LP | DN |    |    |    |   |   |   |   |   |   |   |   | BYPF<br>LTR | SWA<br>P |
| Type  |    | R/ | W  |    |    |    |   |   |   |   |   |   |   |   | R/W         | R/W      |
| Reset |    | 00 | 00 |    |    |    |   |   |   |   |   |   |   |   | 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** The register bit is for control of whether I/Q channel signals need swap before they are input to Baseband Front End. It provides flexibility of 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 are 11-bit resolution and at 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.

O Not bypass RX FIR filter

Bypass RX FIR filter

**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  |    |    |    |    |    |    |   |   |   |   |          |   |   |   | BLPE | N[1:0] |
| Type  |    |    |    |    |    |    |   |   |   |   |          |   |   |   | R/   | W      |
| Reset |    |    |    |    |    |    |   |   |   |   | <b>9</b> |   |   |   | C    | )      |

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  |    |    |    |    |    |    | D9  | D8  | <b>D7</b> | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| 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   |

The 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 58**.





Figure 58 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 |    |    |    |    | $\Box \bot$ |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

The 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  | <b>D</b> 7 | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| 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   |



The 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   | R/W | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | _ 0 _ | 0   | 0   |

The 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   |

The 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  | <b>D</b> 1 | D0  |
| Type  |    |    |    |    |    |    | R/W        | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0          | 0   |

The 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  | <b>D7</b> | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| 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   |

The 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 | 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   |

The 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 |



### MT6228 GSM/GPRS Baseband Processor Data Sheet Revision 1.0

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

The 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  | <b>D</b> 1 | D0  |
| Type  |    |    |    |    |    |    | R/W        | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0          | 0   |

The 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\_COEF1

0

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7   | 6   | 5         | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|-----|-----|-----|-----|-----------|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    | D9  | D8  | D7  | D6  | <b>D5</b> | D4  | D3  | D2  | D1  | D0  |
| 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   |

The 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\_COEF1

1

| 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   |

The 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\_COEF1

2

| 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  |    |    |    |    | KJ |    | R/W |
| Reset |    |    |    |    |    |    | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

The 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 COEF1

3

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8   | 7         | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|-----|-----|-----------|-----|-----|-----|-----|-----|-----|-----|
| Name  |    |    |    |    |    |    | D9  | D8  | <b>D7</b> | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
| 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   |



The 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   |

The 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   |

The 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 59**. On 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 input 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 59 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 has it drive valid outputs to RF module. However, uplink parts of Baseband Serial Ports still don't sink data from DSP through the serial interface between Baseband Serial Ports and DSP until now. Uplink parts of Baseband Serial Ports will not sink data from 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<br>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.

- O 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. Note that when the bit is set to '0', the interval between the moment at which TX enable window is activated and the moment at which TX dump window is activated must be multiples of one bit time.
- 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<br>CEN | IQSW<br>P |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W         | R/W       |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0           | 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.
- O Dectivate 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  |    |    |    |    | OFF | 2[5:0] |   |   | 7 |   |   |   | OFF | [5:0] |   |   |
| Type  |    |    |    |    | R/  | W      |   |   |   |   |   |   | R/  | W     |   |   |
| Reset |    |    |    |    | 000 | 000    |   |   |   | • |   |   | 000 | 000   | • | • |

The 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





# 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 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 60 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 61 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 APC [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 62 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

U

| 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 |   |   |   | CTIRQ<br>2 | CTIRQ<br>1 | DTIR<br>Q |
| 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***n* Enable TDMA\_CTIRQ*n* 

**AFC***n* Enable TDMA\_AFC*n* 

**BDL***n* Enable TDMA\_BDLON*n* and TDMA\_BDLOFF*n* 

For all these bits,

- function is disabled
- 1 function is enabled

# TDMA+0154h Event Enable Register 1

**TDMA EVTENA** 

1

|     |       | <u></u> |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----|-------|---------|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit | 15    | 14      | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|     | _ ` 、 |         |    |    |    |    |   |   |   | _ | _ |   | _ |   |   | _ |



### MT6228 GSM/GPRS Baseband Processor Data Sheet Revision 1.0

| Name  | <b>GPRS</b> |  | BUL3 | BUL <sub>2</sub> | BUL1 | BUL <sub>0</sub> | 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    |

**APC***n* Enable TDMA\_APC*n* 

**BUL***n* Enable TDMA\_BULON*n* and TDMA\_BULOFF*n* 

TDMA +0158h Event Enable Register 2

For all these bits,

• function is disabled

1 function is enabled

## **TDMA EVTENA**

2

| Bit   | 15           | 14    | 13    | 12    | 11    | 10                | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-------|--------------|-------|-------|-------|-------|-------------------|------|------|------|------|------|------|------|------|------|------|
| Name  | <b>BSI15</b> | BSI14 | BSI13 | BSI12 | BSI11 | BSI <sub>10</sub> | 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    |

**BSI** BSI event enable control

O Disable TDMA BSIn

1 Enable TDMA\_BSI*n* 

### **TDMA EVTENA**

3

| Bit   | 15           | 14    | 13           | 12    | 11    | 10    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-------|--------------|-------|--------------|-------|-------|-------|------|------|------|------|------|------|------|------|------|------|
| Name  | <b>BPI15</b> | BPI14 | <b>BPI13</b> | 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 +015Ch Event Enable Register 3

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 | <b>BPI16</b> |
| Type  |    |    |    |    |    |    |   |   |   |   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W          |
| Reset |    |    |    |    |    |    |   |   |   |   | 0     | 0     | 0     | 0     | 0     | 0            |

**BPI** BPI event enable control

Disable TDMA\_BPIn

1 Enable TDMA\_BPI*n* 

### **TDMA EVTENA**

5

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

**AUX** Auxiliary ADC event enable control

O Disable Auxiliary ADC event

TDMA+0164h Event Enable Register 5

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  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | TOI[1:0] |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | R/W      |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0        |

Tol 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\_REGBIA

S

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

**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 |     | <u>6</u> | 5 | 4 | 3    | 2    | 1    | 0    |
|------|----|----|----|----|----|----|---|---|---|-----|----------|---|---|------|------|------|------|
| Name |    |    |    |    |    |    |   |   |   |     |          |   |   | DTX3 | DTX2 | DTX1 | DTX0 |
| Type |    |    |    |    |    |    |   |   |   | 7 ( |          |   |   | R/W  | R/W  | R/W  | R/W  |

**DTX** DTX flag is used to disable the associated transmit signals

- 0 BULONO, BULOFFO, APC\_EVO & APC\_EV1 are controlled by TDMA\_EVTENA1 register
- 1 BULONO, BULOFFO, APC\_EVO & 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 | MOD <sub>5</sub> | MOD4 | MOD3 | MOD2 | MOD1 | MOD0 |    |   |   | · | RXINTO | NT[9:0 |   |   |   |   |
| Type | R/W              | R/W  | R/W  | R/W  | R/W  | R/W  | 01 |   |   |   | R/     | W      |   |   |   |   |

**RXINTCNT** TDMA\_RXWIN interrupt generation interval in quarter bit unit

**MOD***n* Mode of Receive Interrupts

- O 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 |    |    |    | ADC_ON |    |   |   |   |   |   |   | ADC | OFF |   |   |
| Type |    |    |    | R/W    |    |   |   |   |   |   |   | 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

| Bit  | 15 | 14 | 13 | 12  | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2   | 1 | $\Box$ 0 $\Box$ |
|------|----|----|----|-----|----|----|---|---|---|---|---|---|-----|-----|---|-----------------|
| Name |    |    |    | DAC | ON |    |   |   |   |   |   |   | DAC | OFF |   |                 |
| Type |    |    |    | R/  | W  |    |   |   |   |   |   |   | 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.

| +0000h R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Address | Type | Width  | Reset Value | Name         | Description                                          |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------|--------|-------------|--------------|------------------------------------------------------|
| +0008h R/W   13:0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | +0000h  | R    | [13:0] | _           | TDMA_TQCNT   | Read quarter bit counter                             |
| +000Ch   R/W   [13:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | +0004h  | R/W  | [13:0] | 0x1387      | TDMA_WRAP    | Latched Qbit counter reset position                  |
| +0010h R/W [13:0] — TDMA_DTIRQ DSP software control   +0014h R/W [13:0] — TDMA_CTIRQ1 MCU software control   +0018h R/W [13:0] — TDMA_AFC0 The 1st AFC control   +0020h R/W [13:0] — TDMA_AFC1 The 2nd AFC control   +0024h R/W [13:0] — TDMA_AFC2 The 3nd AFC control   +0028h R/W [13:0] — TDMA_AFC2 The 3nd AFC control   +0028h R/W [13:0] — TDMA_AFC3 The 4nd AFC control   +0030h R/W [13:0] — TDMA_BDLON0   +0034h R/W [13:0] — TDMA_BDLON0   +0034h R/W [13:0] — TDMA_BDLOFF0   +0038h R/W [13:0] — TDMA_BDLOFF0   +0038h R/W [13:0] — TDMA_BDLOFF1   +0040h R/W [13:0] — TDMA_BDLOFF1   +0040h R/W [13:0] — TDMA_BDLOFF2   +0044h R/W [13:0] — TDMA_BDLOFF2   +0048h R/W [13:0] — TDMA_BDLOFF3   +0044Ch R/W [13:0] — TDMA_BDLOFF3   +0054Ch R/W [13:0] — TDMA_BDLOFF3   +0055Ch R/W [13:0] — TDMA_BDLOFF5   +0050Ch R/W [13:0] — TDMA_BDLOFF5   +0050Ch R/W [13:0] — TDMA_BDLOFF5   +0050Ch R/W [13:0] — TDMA_BDLOFF5   +0060Ch R/W [13:0] — TDMA_BDLOFF0   +0060Ch R/W [13:0] — TDMA_BULOFF0   +0060Ch R/W [13:0] — TDMA_BULOFF0   +0060Ch R/W [13:0] — TDMA_BULOFF0   +0060Ch R/W [13:0] — TDMA_BULOFF1   +0070M R/W [13:0] — TDMA_BULOFF2   +0074M R/W [13:0] — TDMA_BULOFF3   +0075M R/W [13:0] — TDMA_BULOFF3   +0076M R/W [13 | +0008h  | R/W  | [13:0] | 0x1387      | TDMA_WRAPIMD | Direct Qbit counter reset position                   |
| +0014h R/W   13:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | +000Ch  | R/W  | [13:0] | 0x0000      | TDMA_EVTVAL  | Event latch position                                 |
| +0018h R/W   13:0  — TDMA_CTIRQ2   MCU software control 2     +0020h R/W   13:0  — TDMA_AFC0   The 1st AFC control     +0024h R/W   13:0  — TDMA_AFC1   The 2st AFC control     +0028h R/W   13:0  — TDMA_AFC2   The 3st AFC control     +0020h R/W   13:0  — TDMA_AFC3   The 4st AFC control     +0020h R/W   13:0  — TDMA_BDLON0     +0030h R/W   13:0  — TDMA_BDLOFF0   Data serialization of the 1st RX block     +0034h R/W   13:0  — TDMA_BDLOFF1   Data serialization of the 2st RX block     +0038h R/W   13:0  — TDMA_BDLOFF1   Data serialization of the 2st RX block     +0040h R/W   13:0  — TDMA_BDLOFF2   Data serialization of the 3st RX block     +0040h R/W   13:0  — TDMA_BDLOFF2   Data serialization of the 4st RX block     +0040h R/W   13:0  — TDMA_BDLOFF3   Data serialization of the 4st RX block     +0040h R/W   13:0  — TDMA_BDLOFF3   Data serialization of the 5st RX block     +0050h R/W   13:0  — TDMA_BDLOFF4   Data serialization of the 5st RX block     +0050h R/W   13:0  — TDMA_BDLOFF5   Data serialization of the 6st RX block     +0050h R/W   13:0  — TDMA_BDLOFF5   Data serialization of the 1st TX slot     +0060h R/W   13:0  — TDMA_BULOFF0   Data serialization of the 2st TX slot     +0060h R/W   13:0  — TDMA_BULOFF0   Data serialization of the 2st TX slot     +0060h R/W   13:0  — TDMA_BULOFF1   Data serialization of the 3st TX slot     +0070h R/W   13:0  — TDMA_BULOFF2   Data serialization of the 3st TX slot     +0070h R/W   13:0  — TDMA_BULOFF2   Data serialization of the 4st TX slot     +0070h R/W   13:0  — TDMA_BULOFF2   Data serialization of the 4st TX slot     +0070h R/W   13:0  — TDMA_BULOFF2   Data serialization of the 4st TX slot     +0070h R/W   13:0  — TDMA_BULOFF2   Data serialization of the 4st TX slot     +0070h R/W   13:0  — TDMA_BULOFF3   Data serialization of the 4st TX slot     +0070h R/W   13:0  — TDMA_BULOFF3   Data serialization of the 4st TX slot     +0070h R/W   13:0  — TDMA_BULOFF3   Data serialization of the 4st TX slot     +0070h R/W   13:0  — TDMA_BULOFF3   Data serialization of the 4st TX s   | +0010h  | R/W  | [13:0] | _           | TDMA_DTIRQ   | DSP software control                                 |
| +0020h R/W   [13:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | +0014h  | R/W  | [13:0] | _           | TDMA_CTIRQ1  | MCU software control 1                               |
| +0024h         R/W         [13:0]         —         TDMA_AFC1         The 2nd AFC control           +0028h         R/W         [13:0]         —         TDMA_AFC2         The 3rd AFC control           +002Ch         R/W         [13:0]         —         TDMA_BDLON0         —           +0030h         R/W         [13:0]         —         TDMA_BDLON0         —           +0034h         R/W         [13:0]         —         TDMA_BDLON1         —           +0038h         R/W         [13:0]         —         TDMA_BDLON1         —           +003Ch         R/W         [13:0]         —         TDMA_BDLOFF1         —           +0040h         R/W         [13:0]         —         TDMA_BDLOFF2         —         Data serialization of the 2nd RX block           +0044h         R/W         [13:0]         —         TDMA_BDLOFF2         —         Data serialization of the 3rd RX block           +0048h         R/W         [13:0]         —         TDMA_BDLOFF3         —         Data serialization of the 4th RX block           +0050h         R/W         [13:0]         —         TDMA_BDLOFF4         —         Data serialization of the 5th RX block           +0058h         R/W         [13:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | +0018h  | R/W  | [13:0] | _           | TDMA_CTIRQ2  | MCU software control 2                               |
| +0028h         R/W         [13:0]         —         TDMA_AFC3         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         Data serialization of the 2 <sup>nd</sup> RX block           +0038h         R/W         [13:0]         —         TDMA_BDLOFF1         Data serialization of the 2 <sup>nd</sup> RX block           +003Ch         R/W         [13:0]         —         TDMA_BDLOFF1         Data serialization of the 3 <sup>rd</sup> RX block           +0040h         R/W         [13:0]         —         TDMA_BDLON2         Data serialization of the 3 <sup>rd</sup> RX block           +0044h         R/W         [13:0]         —         TDMA_BDLOFF3         Data serialization of the 4 <sup>th</sup> RX block           +004Ch         R/W         [13:0]         —         TDMA_BDLOFF4         Data serialization of the 5 <sup>th</sup> RX block           +005h         R/W         [13:0]         —         TDMA_BDLON5         Data serialization of the 6 <sup>th</sup> RX block           +005h         R/W         [13:0]         —         TDMA_BULOFF5         Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | +0020h  | R/W  | [13:0] | _           | TDMA_AFC0    | The 1 <sup>st</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         Data serialization of the 2 <sup>nd</sup> RX block           +0038h         R/W         [13:0]         —         TDMA_BDLON1         Data serialization of the 2 <sup>nd</sup> RX block           +0040h         R/W         [13:0]         —         TDMA_BDLON2         Data serialization of the 3 <sup>rd</sup> RX block           +0044h         R/W         [13:0]         —         TDMA_BDLON3         Data serialization of the 4 <sup>th</sup> RX block           +004Ch         R/W         [13:0]         —         TDMA_BDLOFF3         Data serialization of the 5 <sup>th</sup> RX block           +0050h         R/W         [13:0]         —         TDMA_BDLOFF4         Data serialization of the 5 <sup>th</sup> RX block           +005h         R/W         [13:0]         —         TDMA_BDLOFF5         Data serialization of the 6 <sup>th</sup> RX block           +005h         R/W         [13:0]         —         TDMA_BULOFF5         Data serialization of the 1 <sup>st</sup> TX slot           +005h         R/W         [13:0]         —         TDMA_BULOFF1 <td>+0024h</td> <td>R/W</td> <td>[13:0]</td> <td>_</td> <td>TDMA_AFC1</td> <td></td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | +0024h  | R/W  | [13:0] | _           | TDMA_AFC1    |                                                      |
| +0030h         R/W         [13:0]         —         TDMA_BDLONO         Data serialization of the 1st RX block           +0034h         R/W         [13:0]         —         TDMA_BDLOFF0         Data serialization of the 1st RX block           +0038h         R/W         [13:0]         —         TDMA_BDLON1         Data serialization of the 2nd RX block           +003Ch         R/W         [13:0]         —         TDMA_BDLON2         Data serialization of the 3nd RX block           +0040h         R/W         [13:0]         —         TDMA_BDLON2         Data serialization of the 3nd RX block           +0044h         R/W         [13:0]         —         TDMA_BDLON3         Data serialization of the 4nd RX block           +0048h         R/W         [13:0]         —         TDMA_BDLON4         Data serialization of the 5nd RX block           +0050h         R/W         [13:0]         —         TDMA_BDLON5         Data serialization of the 5nd RX block           +005ch         R/W         [13:0]         —         TDMA_BDLON5         Data serialization of the 6nd RX block           +005ch         R/W         [13:0]         —         TDMA_BULON0         Data serialization of the 1st TX slot           +006h         R/W         [13:0]         —         TDMA_BULOFF0 <td>+0028h</td> <td>R/W</td> <td>[13:0]</td> <td>_</td> <td>TDMA_AFC2</td> <td></td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | +0028h  | R/W  | [13:0] | _           | TDMA_AFC2    |                                                      |
| +0034h         R/W         [13:0]         —         TDMA_BDLOFF0           +0038h         R/W         [13:0]         —         TDMA_BDLON1           +003Ch         R/W         [13:0]         —         TDMA_BDLOFF1           +0040h         R/W         [13:0]         —         TDMA_BDLON2           +0044h         R/W         [13:0]         —         TDMA_BDLON2           +0048h         R/W         [13:0]         —         TDMA_BDLON3           +004Ch         R/W         [13:0]         —         TDMA_BDLON3           +0050h         R/W         [13:0]         —         TDMA_BDLOFF3           +0050h         R/W         [13:0]         —         TDMA_BDLOFF3           +0050h         R/W         [13:0]         —         TDMA_BDLOFF4           +0058h         R/W         [13:0]         —         TDMA_BDLOFF5           +0060h         R/W         [13:0]         —         TDMA_BULON0           +0068h         R/W         [13:0]         —         TDMA_BULON1           +0060h         R/W         [13:0]         —         TDMA_BULOFF1           +0070h         R/W         [13:0]         —         TDMA_BULOFF2 </td <td>+002Ch</td> <td>R/W</td> <td>[13:0]</td> <td>_</td> <td>TDMA_AFC3</td> <td>The 4<sup>th</sup> AFC control</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | +002Ch  | R/W  | [13:0] | _           | TDMA_AFC3    | The 4 <sup>th</sup> AFC control                      |
| +0034h R/W [13:0] — TDMA_BDLOFF0 +0038h R/W [13:0] — TDMA_BDLOFF1 +0040h R/W [13:0] — TDMA_BDLOFF2 +0044h R/W [13:0] — TDMA_BDLOFF2 +0048h R/W [13:0] — TDMA_BDLOFF3 +0040ch R/W [13:0] — TDMA_BDLOFF3 +0040ch R/W [13:0] — TDMA_BDLOFF3 +0050h R/W [13:0] — TDMA_BDLOFF4 +0058h R/W [13:0] — TDMA_BDLOFF4 +0058h R/W [13:0] — TDMA_BDLOFF5 +0060h R/W [13:0] — TDMA_BULON0 +0064h R/W [13:0] — TDMA_BULOFF0 +0068h R/W [13:0] — TDMA_BULOFF0 +0060ch R/W [13:0] — TDMA_BULOFF1 +0070h R/W [13:0] — TDMA_BULOFF1 +0070h R/W [13:0] — TDMA_BULOFF1 +0070h R/W [13:0] — TDMA_BULOFF2 +0078h R/W [13:0] — TDMA_BULOFF2 +0078h R/W [13:0] — TDMA_BULOFF3 -Data serialization of the 3 <sup>rd</sup> TX slot -Data serialization of the 4 <sup>th</sup> TX slot                                                                                                                                                                                                                                                         | +0030h  | R/W  | [13:0] | _           | TDMA_BDLON0  | Data socialization of the 1 <sup>st</sup> DV block   |
| +003Ch         R/W         [13:0]         —         TDMA_BDLOFF1         Data serialization of the 2 <sup>rd</sup> RX block           +0040h         R/W         [13:0]         —         TDMA_BDLON2         —         Data serialization of the 3 <sup>rd</sup> RX block           +0044h         R/W         [13:0]         —         TDMA_BDLON3         —         Data serialization of the 4 <sup>th</sup> RX block           +004Ch         R/W         [13:0]         —         TDMA_BDLOFF3         —         Data serialization of the 5 <sup>th</sup> RX block           +0050h         R/W         [13:0]         —         TDMA_BDLOFF4         —         Data serialization of the 5 <sup>th</sup> RX block           +0050h         R/W         [13:0]         —         TDMA_BDLOFF4         —         Data serialization of the 5 <sup>th</sup> RX block           +0050h         R/W         [13:0]         —         TDMA_BDLOFF5         —         Data serialization of the 6 <sup>th</sup> RX block           +005Ch         R/W         [13:0]         —         TDMA_BULON0         —         Data serialization of the 1 <sup>st</sup> TX slot           +006h         R/W         [13:0]         —         TDMA_BULOFF1         —         Data serialization of the 2 <sup>nd</sup> TX slot           +006ch         R/W         [13:0]         —         TDMA_BULOFF2         — <td>+0034h</td> <td>R/W</td> <td>[13:0]</td> <td>_</td> <td>TDMA_BDLOFF0</td> <td>— Data serialization of the 1 KA block</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | +0034h  | R/W  | [13:0] | _           | TDMA_BDLOFF0 | — Data serialization of the 1 KA block               |
| +003Ch R/W [13:0] — TDMA_BDLOFF1 +0040h R/W [13:0] — TDMA_BDLON2 +0044h R/W [13:0] — TDMA_BDLOFF2 +0048h R/W [13:0] — TDMA_BDLON3 +004Ch R/W [13:0] — TDMA_BDLOFF3 +0050h R/W [13:0] — TDMA_BDLON4 +0054h R/W [13:0] — TDMA_BDLOFF4 +0058h R/W [13:0] — TDMA_BDLON5 +005Ch R/W [13:0] — TDMA_BDLOFF5 +0060h R/W [13:0] — TDMA_BDLOFF5 +0060h R/W [13:0] — TDMA_BULON0 +0064h R/W [13:0] — TDMA_BULOFF0 +0068h R/W [13:0] — TDMA_BULOFF0 +006Ch R/W [13:0] — TDMA_BULOFF1 +0070h R/W [13:0] — TDMA_BULOFF1 +0070h R/W [13:0] — TDMA_BULOFF1 +0070h R/W [13:0] — TDMA_BULOFF2 +0078h R/W [13:0] — TDMA_BULOFF2 +0078h R/W [13:0] — TDMA_BULOFF3 Data serialization of the 2 <sup>nd</sup> TX slot  Data serialization of the 3 <sup>rd</sup> TX slot  Data serialization of the 4 <sup>th</sup> TX slot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | +0038h  | R/W  | [13:0] | _           | TDMA_BDLON1  | Dete socialization of the 2 <sup>nd</sup> BV block   |
| +0044h         R/W         [13:0]         —         TDMA_BDLOFF2         Data serialization of the 3° RX block           +0048h         R/W         [13:0]         —         TDMA_BDLON3         —         Data serialization of the 4th RX block           +004Ch         R/W         [13:0]         —         TDMA_BDLOFF3         —         Data serialization of the 5th RX block           +0050h         R/W         [13:0]         —         TDMA_BDLOFF4         —         Data serialization of the 5th RX block           +0050h         R/W         [13:0]         —         TDMA_BDLOFF5         —         Data serialization of the 6th RX block           +005Ch         R/W         [13:0]         —         TDMA_BULON0         —         Data serialization of the 6th RX block           +0060h         R/W         [13:0]         —         TDMA_BULON0         —         Data serialization of the 1st TX slot           +0064h         R/W         [13:0]         —         TDMA_BULOFF0         —         Data serialization of the 2nd TX slot           +0066h         R/W         [13:0]         —         TDMA_BULOFF1         —         Data serialization of the 3rd TX slot           +0070h         R/W         [13:0]         —         TDMA_BULOFF2         —         Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | +003Ch  | R/W  | [13:0] | _           | TDMA_BDLOFF1 | — Data serialization of the 2 KA 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_BDLON4         Data serialization of the 5 <sup>th</sup> RX block           +0050h         R/W         [13:0]         —         TDMA_BDLON5         Data serialization of the 6 <sup>th</sup> RX block           +0058h         R/W         [13:0]         —         TDMA_BDLON5         Data serialization of the 6 <sup>th</sup> RX block           +005Ch         R/W         [13:0]         —         TDMA_BULON0         Data serialization of the 1 <sup>st</sup> TX slot           +0064h         R/W         [13:0]         —         TDMA_BULOFF0         Data serialization of the 2 <sup>nd</sup> TX slot           +0068h         R/W         [13:0]         —         TDMA_BULOFF1         Data serialization of the 2 <sup>nd</sup> TX slot           +0070h         R/W         [13:0]         —         TDMA_BULOFF2         Data serialization of the 3 <sup>rd</sup> TX slot           +0078h         R/W         [13:0]         —         TDMA_BULOFF3         Data serialization of the 4 <sup>th</sup> TX slot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | +0040h  | R/W  | [13:0] | _           | TDMA_BDLON2  | Data sarialization of the 2 <sup>rd</sup> DV block   |
| +004Ch         R/W         [13:0]         —         TDMA_BDLOFF3         Data serialization of the 4 RX block           +0050h         R/W         [13:0]         —         TDMA_BDLON4         —         Data serialization of the 5 <sup>th</sup> RX block           +0054h         R/W         [13:0]         —         TDMA_BDLON5         —         Data serialization of the 6 <sup>th</sup> RX block           +005Ch         R/W         [13:0]         —         TDMA_BDLON5         —         Data serialization of the 6 <sup>th</sup> RX block           +0060h         R/W         [13:0]         —         TDMA_BULON0         —         Data serialization of the 1 <sup>st</sup> TX slot           +0064h         R/W         [13:0]         —         TDMA_BULOFF0         —         Data serialization of the 2 <sup>nd</sup> TX slot           +006Ch         R/W         [13:0]         —         TDMA_BULOFF1         —         Data serialization of the 3 <sup>rd</sup> TX slot           +0074h         R/W         [13:0]         —         TDMA_BULOFF2         —         Data serialization of the 4 <sup>th</sup> TX slot           +007Ch         R/W         [13:0]         —         TDMA_BULOFF3         —         Data serialization of the 4 <sup>th</sup> TX slot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | +0044h  | R/W  | [13:0] |             | TDMA_BDLOFF2 | — Data serialization of the 3 KA block               |
| +004Ch R/W [13:0] — TDMA_BDLOFF3  +0050h R/W [13:0] — TDMA_BDLOFF4  +0054h R/W [13:0] — TDMA_BDLOFF4  +0058h R/W [13:0] — TDMA_BDLOFF5  +0060h R/W [13:0] — TDMA_BDLOFF5  +0064h R/W [13:0] — TDMA_BULON0  +0064h R/W [13:0] — TDMA_BULOFF0  +006Ch R/W [13:0] — TDMA_BULON1  +006Ch R/W [13:0] — TDMA_BULOFF1  +0070h R/W [13:0] — TDMA_BULOFF1  +0070h R/W [13:0] — TDMA_BULOFF2  +0078h R/W [13:0] — TDMA_BULOFF3  +007Ch R/W [13:0] — TDMA_BULOFF3  Data serialization of the 2 <sup>nd</sup> TX slot  Data serialization of the 3 <sup>rd</sup> TX slot  Data serialization of the 3 <sup>rd</sup> TX slot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | +0048h  | R/W  | [13:0] |             | TDMA_BDLON3  | Data socialization of the 4th DV block               |
| +0054h R/W [13:0] — TDMA_BDLOFF4 +0058h R/W [13:0] — TDMA_BDLON5 +005Ch R/W [13:0] — TDMA_BDLOFF5 +0060h R/W [13:0] — TDMA_BULON0 +0064h R/W [13:0] — TDMA_BULOFF0 +0068h R/W [13:0] — TDMA_BULON1 +006Ch R/W [13:0] — TDMA_BULOFF1 +0070h R/W [13:0] — TDMA_BULOFF1 +0074h R/W [13:0] — TDMA_BULOFF2 +0078h R/W [13:0] — TDMA_BULOFF2 +0078h R/W [13:0] — TDMA_BULON3 +007Ch R/W [13:0] — TDMA_BULOFF3  Data serialization of the 5 <sup>th</sup> RX block  Data serialization of the 6 <sup>th</sup> RX block  Data serialization of the 1 <sup>st</sup> TX slot  Data serialization of the 2 <sup>nd</sup> TX slot  Data serialization of the 2 <sup>nd</sup> TX slot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | +004Ch  | R/W  | [13:0] | _           | TDMA_BDLOFF3 | Data serialization of the 4 KA block                 |
| +0054h R/W [13:0] — TDMA_BDLOFF4  +0058h R/W [13:0] — TDMA_BDLOFF5  +0060h R/W [13:0] — TDMA_BULON0  +0064h R/W [13:0] — TDMA_BULOFF0  +0068h R/W [13:0] — TDMA_BULON1  +006Ch R/W [13:0] — TDMA_BULOFF1  +0070h R/W [13:0] — TDMA_BULON2  +0074h R/W [13:0] — TDMA_BULOFF2  +0078h R/W [13:0] — TDMA_BULOFF3  Data serialization of the 1 <sup>st</sup> TX slot  Data serialization of the 2 <sup>nd</sup> TX slot  Data serialization of the 3 <sup>rd</sup> TX slot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | +0050h  | R/W  | [13:0] | -           | TDMA_BDLON4  | Dete socialization of the 5th DV block               |
| +005Ch R/W [13:0] — TDMA_BDLOFF5  +0060h R/W [13:0] — TDMA_BULON0  +0064h R/W [13:0] — TDMA_BULOFF0  +0068h R/W [13:0] — TDMA_BULON1  +006Ch R/W [13:0] — TDMA_BULOFF1  +0070h R/W [13:0] — TDMA_BULON2  +0074h R/W [13:0] — TDMA_BULOFF2  +0078h R/W [13:0] — TDMA_BULON3  +007Ch R/W [13:0] — TDMA_BULOFF3  Data serialization of the 6"RX block  RX block  Data serialization of the 1st TX slot  Data serialization of the 2st TX slot  Data serialization of the 2st TX slot  Data serialization of the 4st TX slot  Data serialization of the 4st TX slot  Data serialization of the 4st TX slot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | +0054h  | R/W  | [13:0] | - (         | TDMA_BDLOFF4 | — Data serialization of the 3 KA block               |
| +005Ch         R/W         [13:0]         —         TDMA_BDLOFFS           +0060h         R/W         [13:0]         —         TDMA_BULON0           +0064h         R/W         [13:0]         —         TDMA_BULOFF0           +0068h         R/W         [13:0]         —         TDMA_BULON1           +006Ch         R/W         [13:0]         —         TDMA_BULOFF1           +0070h         R/W         [13:0]         —         TDMA_BULON2           +0074h         R/W         [13:0]         —         TDMA_BULOFF2           +0078h         R/W         [13:0]         —         TDMA_BULON3           +007Ch         R/W         [13:0]         —         TDMA_BULOFF3    Data serialization of the 4 <sup>th</sup> TX slot  Data serialization of the 4 <sup>th</sup> TX slot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | +0058h  | R/W  | [13:0] |             | TDMA_BDLON5  | — Data socialization of the 6 <sup>th</sup> DV block |
| +0064h         R/W         [13:0]         TDMA_BULOFF0         Data serialization of the 1" TX slot           +0068h         R/W         [13:0]         —         TDMA_BULON1         Data serialization of the 2" TX slot           +006Ch         R/W         [13:0]         —         TDMA_BULOFF1         Data serialization of the 3" TX slot           +0070h         R/W         [13:0]         —         TDMA_BULOFF2         Data serialization of the 3" TX slot           +0078h         R/W         [13:0]         —         TDMA_BULON3         Data serialization of the 4" TX slot           +007Ch         R/W         [13:0]         —         TDMA_BULOFF3         Data serialization of the 4" TX slot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | +005Ch  | R/W  | [13:0] |             | TDMA_BDLOFF5 | Data serialization of the 0 KA block                 |
| +0064h R/W [13:0] — TDMA_BULOFF0  +0068h R/W [13:0] — TDMA_BULON1  +006Ch R/W [13:0] — TDMA_BULOFF1  +0070h R/W [13:0] — TDMA_BULON2  +0074h R/W [13:0] — TDMA_BULOFF2  +0078h R/W [13:0] — TDMA_BULON3  +007Ch R/W [13:0] — TDMA_BULOFF3  Data serialization of the 3 <sup>rd</sup> TX slot  Data serialization of the 4 <sup>th</sup> TX slot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | +0060h  | R/W  | [13:0] |             | TDMA_BULON0  | — Dete carialization of the 1 <sup>st</sup> TV slot  |
| +006Ch         R/W         [13:0]         —         TDMA_BULOFF1           +0070h         R/W         [13:0]         —         TDMA_BULON2           +0074h         R/W         [13:0]         —         TDMA_BULOFF2           +0078h         R/W         [13:0]         —         TDMA_BULON3           +007Ch         R/W         [13:0]         —         TDMA_BULOFF3   Data serialization of the 2 <sup>th</sup> TX slot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | +0064h  | R/W  | [13:0] |             | TDMA_BULOFF0 | — Data serialization of the 1 17 slot                |
| +006Ch         R/W         [13:0]         —         TDMA_BULOFF1           +0070h         R/W         [13:0]         —         TDMA_BULON2           +0074h         R/W         [13:0]         —         TDMA_BULOFF2           +0078h         R/W         [13:0]         —         TDMA_BULON3           +007Ch         R/W         [13:0]         —         TDMA_BULOFF3   Data serialization of the 4 <sup>th</sup> TX slot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | +0068h  | R/W  | [13:0] | _           | TDMA_BULON1  | — Data sarialization of the 2 <sup>nd</sup> TV slot  |
| +0074h R/W [13:0] — TDMA_BULOFF2<br>+0078h R/W [13:0] — TDMA_BULON3<br>+007Ch R/W [13:0] — TDMA_BULOFF3  Data serialization of the 3 <sup>th</sup> TX slot  TDMA_BULOFF2  Data serialization of the 4 <sup>th</sup> TX slot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | +006Ch  | R/W  | [13:0] | _           | TDMA_BULOFF1 | — Data serialization of the 2 TA slot                |
| +0074h R/W [13:0] — TDMA_BULOFF2<br>+0078h R/W [13:0] — TDMA_BULON3<br>+007Ch R/W [13:0] — TDMA_BULOFF3  Data serialization of the 4 <sup>th</sup> TX slot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | +0070h  | R/W  | [13:0] |             | TDMA_BULON2  | — Data serialization of the 2 <sup>rd</sup> TV slot  |
| +007Ch R/W [13:0] — TDMA_BULOFF3 Data serialization of the 4" 1X slot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | +0074h  | R/W  | [13:0] |             | TDMA_BULOFF2 | Data Scriditzation of the 5 TA Slot                  |
| +007Ch R/W [13:0] — TDMA_BULOFF3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | +0078h  | R/W  | [13:0] |             | TDMA_BULON3  | Data socialization of the 4 <sup>th</sup> TV slot    |
| +0090h R/W [13:0] — TDMA_APC0 The 1 <sup>st</sup> APC control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | +007Ch  | R/W  | [13:0] |             | TDMA_BULOFF3 | — Data serialization of the 4 TA slot                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | +0090h  | R/W  | [13:0] | _           | TDMA_APC0    | The 1 <sup>st</sup> APC control                      |



| MEDIATEK          |     |                  |              |              |                                 |
|-------------------|-----|------------------|--------------|--------------|---------------------------------|
| +0094h            | R/W | [13:0]           | _            | TDMA_APC1    | The 2 <sup>nd</sup> APC control |
| +0098h            | R/W | [13:0]           | _            | TDMA_APC2    | The 3 <sup>rd</sup> APC control |
| +009Ch            | R/W | [13:0]           | _            | TDMA_APC3    | The 4 <sup>th</sup> APC control |
| +00A0h            | R/W | [13:0]           | _            | TDMA_APC4    | The 5 <sup>th</sup> APC control |
| +00A4h            | R/W | [13:0]           | _            | TDMA_APC5    | The 6 <sup>th</sup> APC control |
| +00A8h            | R/W | [13:0]           | _            | TDMA_APC6    | 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                     |
| +00CCh            | 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                     |
| +00D4h            | R/W | [13:0]           |              | TDMA_BSI10   | BSI event 10                    |
| +00D6h            | R/W | [13:0]           | <del>_</del> | TDMA_BSI11   | BSI event 11                    |
| +00E0h            | R/W |                  | <u> </u>     | TDMA_BSI12   | BSI event 12                    |
| +00E0II<br>+00E4h | R/W | [13:0]<br>[13:0] | <u> </u>     | TDMA_BSI12   | BSI event 13                    |
|                   | R/W |                  | <del>_</del> |              | BSI event 14                    |
| +00E8h            | R/W | [13:0]           | <u> </u>     | TDMA_BSI14   | BSI event 15                    |
| +00ECh            |     | [13:0]           | <del>_</del> | TDMA_BSI15   |                                 |
| +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          |
|                   |     |                  |              | <del>-</del> |                                 |



| +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 66 TDMA Timer Register Map

# 10.2 Slow Clocking Unit



Figure 63 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 63, 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

SM CON

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1               | 0            |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----------------|--------------|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | PAUSE_STA<br>RT | FM_STAR<br>T |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   | W               | W            |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   | 0               | 0            |

**FM\_START** Initiate the frequency measurement procedure

PAUSE\_STARTInitiate 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               |
|------|----------------|-----------|-----------|----------------|-----|----|--------|-----------------|
| Name |                |           |           |                |     | 6  |        | PAUSE_ABO<br>RT |
| Type |                |           |           |                |     |    |        | R               |
| Bit  | 7              | 6         | 5         | 4              | 3   | 2  | 1      | 0               |
| Name | SETTLE_CP<br>L | PAUSE_CPL | PAUSE_INT | PAUSE_RQS<br>T | - 9 |    | 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 completedSETTLE 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   |
|-------|----|----|----|----|----|----|---|---|---|---|------|-----|------|-----|-----|-----|
| Name  |    |    |    |    |    |    |   |   |   |   | MSDC | RTC | EINT | KP  | SM  | FM  |
| Type  |    |    |    |    |    |    |   |   |   |   | R/W  | R/W | R/W  | R/W | R/W | R/W |
| Reset |    |    |    |    |    |    |   |   |   |   | 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

### TDMA +0300h Power-down indication of DSP ROM

**DSPROMPD** 

|      |    | _  |    |    |       |       |      |      |      |      |      |      |      |      |      |      |
|------|----|----|----|----|-------|-------|------|------|------|------|------|------|------|------|------|------|
| Bit  | 15 | 14 | 13 | 12 | 11    | 10    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| Name |    |    |    |    | PD_11 | PD_10 | PD_9 | PD_8 | PD_7 | PD_6 | PD_5 | PD_4 | PD_3 | PD_2 | PD_1 | PD_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  |



| MEDIA | IEK |  |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-------|-----|--|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Res   | et  |  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 7 |

- **PD** X Power-down indication of page X of DSP CM ROM, X = 5:0
  - o power down disabled
  - 1 power down enabled
- PD\_X Power-down indication of page X of DSP PM ROM, X = 11:6
  - o power down disabled
  - 1 power down enabled

This register is for controlling the VIA-ROM, which requires a reset signal whenever the ROM is wakened up from power-down mode. It means that as long as MCU plans to interrupt DSP from slow idle, the register should be programmed in advance by 15us, otherwise the read data would be unknown. Total of 12 pages are programmable and is to be reserveed for future usage, by which the MCU can dynamically wake-up only the pages that needs to be accessed. However, for now, MCU can just simply program the register to all one's or all zero's. In view of the hardware, the 12 bits are ANDED as a power-down indication. As the indication turns from high to low, a counter will be triggered to count the 15-us interval according to the MCU clock, then a negative pulse will be generated as the ROM reset.

| 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                   |
| . 022011 | 20.1 | [         | 0.10000     | 511_51 (5        | 21.1 40111120111101111011111111111111111111 |

# 10.2.2 Frequency Measurement



Figure 64 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.

$$Measured\_frequency = \frac{2 \times (SM\_FM\_DURATION + 1) \times 13 \times 10^6}{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 of 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:

$$\begin{aligned} Nb\_quarter\_bit &= Kqbit \times (SM\_FINAL\_PAUSE + SM\_CLK\_SETTLE) - \Delta qbit \\ \Delta qbit &= TQ\_WRAP - SM\_QBIT\_START \\ Kqbit &= \frac{32k\_period\_duration}{quarter\_bit\_duration} = \frac{SM\_FM\_RESULT}{24 \times (SM\_FM\_DURATION + I)} \end{aligned}$$



# 11 Power, Clocks and Reset

This chapter describes the power, clock and reset management functions provided by MT6228. Together with Power Management IC (PMIC), MT6228 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 MT6228 as well as main power states provided by the PMIC are shown in **Figure 65**.



Figure 65 Major Phone Power States and Operating Modes for MT6228 based terminal

## 11.1 **B2PSI**

# 11.1.1 General Description

MT6228 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 waits 3 clock cycles for the PMIC B2PSI state machine to decode the operation for the next 8 data bits. The state machine should count 16 clocks to complete the data transfer.





Figure 66 B2PSI bus timing

## 11.1.2 Register Definitions

## B2PSI+0000h B2PSI data register

**B2PSI DATA** 

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

**B2PSI** DATA The B2PSI DATA format contains 4 bit register + 3 bit do not care + write / read bit + 8 bit data.

- 0 Read operation
- 1 Write operation

To prevent a writing error, B2PSI\_DATA must be set to 8216h before the actual data write.

## B2PSI +0008h B2PSI baud rate divider register

**B2PSI DIV** 

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | $\sqrt{9}$ | 8      | 7        | 6  | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|------------|--------|----------|----|---|---|---|---|---|---|
| Name  |    |    |    |    |    |    | B          | 2PSI_[ | DIV [15: | 0] |   |   |   |   |   |   |
| Type  |    |    |    |    |    | u  |            | R/     | W        |    |   |   |   |   |   |   |
| Reset |    |    |    |    |    |    |            | (      | )        |    |   |   |   |   |   |   |

**B2PSI\_DIV** B2PSI clock rate divisor. B2PSICK = system clock rate / div.

## B2PSI+0010h B2PSI status register

**B2PSI STAT** 

| Bit   | 15 | 14 | 13 | 12 | <u> </u> | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                         | 0                  |
|-------|----|----|----|----|----------|----|---|---|---|---|---|---|---|---|---------------------------|--------------------|
| Name  |    |    |    |    |          |    |   |   |   |   |   |   |   |   | WRIT<br>E_SU<br>CCES<br>S | READ<br>_REA<br>DT |
| Type  |    |    |    |    |          |    |   |   |   |   |   |   |   |   | RC                        | RC                 |
| Reset |    |    |    |    |          |    |   |   |   |   |   |   |   |   | 0                         | 0                  |

**READY** Read data ready.

- O Read data is not ready yet.
- 1 Read data is ready. The bit is cleared by reading B2PSI\_STAT register or if B2PSI initializes a new transmit.



**WRITE\_SUCCESS** B2PSI write successfully.

- O B2PSI write is not finished yet.
- 1 B2PSI write has finished. The bit is 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  |    |    |    |    |    |    |   |   |   |   |   |   |   | <b>B</b> 2 | PSI_TII | ΝE |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |            | R/W     |    |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |            | 0       |    |

**B2PSI\_TIME** The time interval that first B2PSICK is started after the B2PSICS is active low. Time interval = 1/system clock \* B2PSI\_time.

## 11.2 Clocks

There are two major time bases in MT6228. The faster one is the 13 MHz clock originating from an off-chip temperature-compensated voltage controlled oscillator (TCVCXO) that can be either 13 MHz or 26 MHz. 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 67** shows the clock sources as well as their utilizations inside the chip.



Figure 67 Clock distributions inside the MT6228.



### 11.2.1 32.768 KHz Time Base

The 32768 Hz clock is always running. It is mainly used as the time base of the Real Time Clock (RTC) module, which maintains time and date with counters. Therefore, the 32768 Hz oscillator and the RTC module are powered by separate voltage supplies that are not be powered down when the other power supplies are.

In low power mode, the 13 MHz time base is turned off, so the 32768 Hz clock is employed to update 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

A 1/2-divider, for MCU Clock, exists to allow usage of either 26 or 13 MHz TCVCXO as clock input

Three phase-locked loops (MDPLL, TPLL and UPLL) are used to generate four primary clocks, MCU\_CLOCK, DSP\_CLOCK, USB\_CLOCK and TV\_CLOCK, and to clock modules in the MCU Clock Domain and DSP Clock Domain, USB and TV Encoder, 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 takes care of the PLL lock time while changing the clock selections. The PLLs and their usages are listed below.

MDPLL provides the MCU system clock (MCU\_CLOCK) and DSP system clock (DSP\_CLOCK. DPLL).

MCU\_CLOCK clocks the MCU core, MCU memory system and MCU peripherals as well.

DSP\_CLOCK clocks DSP core and DSP-related modules. MDPLL can be programmed to provide

1X to 8X output of 13 MHz reference. However, because of the employment of DCM (dynamic clock manager), the output of MDPLL are set as 104 MHz. The clock rates of MCU system and DSP system can only be changed by programming the clock rate setting of MCU DCM and DSP DCM.

UPLL provides the USB clock, USB\_CLOCK. The UPLL input is a 4 MHz clock, which comes from 104 MHz clock generated by MDPLL and then divided by 26. UPLL pumps the input clock source 12 times to generate 48 MHz for USB module.

**TPLL** provides the TV encoder clock, TV\_CLOCK. The TPLL input is a 3 MHz clock, which comes from the 48 MHz clock generated by UPLL and then divided by 16. TPLL pumps the input clock source 9 times to generate 27 MHz for TV encoder.

Note that PLLs need some time to become stable after being powered up. The software takes 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 go back to sleep automatically after all "hreqs" de-assert. Therefore, any transactions can still take place as usual during AHB sleep mode, and power is saved when there are no transactions. The penalty associated with this is that the system loses some efficiency due to the switching on and off of the bus clock, but this impact is small.



# 11.2.3 Dynamic Clock Switch of MCU Clock

Dynamic Clock Manager is implemented to allow MCU and DSP switching clock dynamically without any jitter, and enabling signal drift, and system can operate stably during any clock rate switch.

Please note that MDPLL must be enabled and the frequency is set as 104 MHz. Before switching to the 104 MHz clock rate, the clock from MD DIV2 feeds through dynamic clock manager (DCM) directly. That means if MD DIV2 is enabled, the internal clock rate is the half of SYSCLK. Contrarily, the internal clock rate is identical to SYSCLK.

However, the settings of some hardware modules are required to change before or after clock rate change. Software has the responsibility of changing them at the proper timing. The following table is a list of hardware modules that need to change their settings during a clock rate change.

| Module Name | Programming Sequence                                                                                                                                                                                                                                                                                                     |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EMI         | Wait state is changed before clock rate change if the clock rate changes from low to high, and after the clock rate change if the clock rate changes from high to low. The new wait state does not take effect until the current EMI access is complete. Software should insert a period of time before switching clock. |
| NAND        | Wait state is changed before clock rate change if the clock rate changes from low to high, and after clock rate change if the clock rate changes from high to low. New wait state will not take effect until current EMI access is complete. Software should insert a period of time before switching clock.             |
| LCD         | Change wait state while LCD in IDLE state.                                                                                                                                                                                                                                                                               |
|             |                                                                                                                                                                                                                                                                                                                          |

**Table 67** Programming sequence during clock switch

# 11.2.4 Register Definitions

## CONFG+0100h MDPLL Frequency Register

**MDPLL** 

| 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 Selects the Output Clock Rate for MDPLL.

Note: The output of MDPLL is a 104 MHz clock for normal function. The clock rate of MCU system and DSP system is adjusted by programming MCU DCM and DSP DCM.

**000** power down

**001** 13MHz x 2

**010** 13MHz x 3

**011** 13MHz x 4

000 13MHz x 5

**101** 13MHz x 6

**110** 13MHz x 7

**111** 13MHz x 8

**RST** Resets Control of MDPLL

Normal Operation



Reset the MDPLL

**CALI** Calibration Control for MDPLL

## **CONFG+108h UPLL Frequency register**

UPLL

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

**RST** Resets Control of UPLL

0 Normal Operation

1 Reset the UPLL

**CALI** Calibration Control for UPLL

## **CONFG+10Ch TPLL Frequency register**

**TPLL** 

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

**RST** Reset Control of TPLL

0 Normal Operation

1 Reset the TPLL

**CALI** Calibration Control for TPLL

## **CONFG+110h** Clock Control Register

**CLK CON** 

| Bit   | 15           | 14                | 13                | 12 | 11 | 10 | 9 | 8                           | 7           | 6                 | 5 | 4                 | 3           | 2 | 1         | 0 |
|-------|--------------|-------------------|-------------------|----|----|----|---|-----------------------------|-------------|-------------------|---|-------------------|-------------|---|-----------|---|
| Name  | TV_E<br>XTCK | USB_<br>EXTC<br>K | DSP_<br>EXTC<br>K |    |    |    |   | TPLL_<br>TMA                | UPLL<br>TMA | MDPL<br>L_TM<br>A |   | CLKS<br>Q_PL<br>D | MD_D<br>IV2 |   | MDPL<br>L |   |
| Type  | R/W          | R/W               | R/W               |    |    |    |   | R/W                         | R/W         | R/W               |   | R/W               | R/W         |   | R/W       |   |
| Reset | 0            | 0                 | 0                 |    |    |    |   | <sup>™</sup> 0 <sup>™</sup> | 0           | 0                 |   | 0                 | 0           |   | 0         |   |

568/616

MDPLL Selects MCU and DSP clock source

0 MDPLL bypassed

1 Using MDPLL Clock

MD\_DIV2 Control the x2 clock divider for MDPLL reference clock input.

O Divider bypassed

Divider not bypassed

CLKSQ PLD Pull Down Control

O Disable

1 Enables

MDPLL\_TMA MDPLL test mode

0 Disable

1 Enable

**UPLL TMA**UPLL test mode

0 Disable

1 Enable

TPLL\_TMA TPLL test mode



- 0 Disable
- 1 Enable
- DSP\_EXTCK DSP external clock. When enabled, an external clock source from PIN EINTO is used instead of DSP clock from MDPLL output.
  - 0 Disable
  - 1 Enable
- **USB\_EXTCK** USB external clock. When enabled, an external clock source from EINT1 is used instead of UPLL output.
  - O Disable
  - 1 Enable
- TV\_EXTCK TV external clock. When enabled, an external clock source from EINT3 is used instead of TPLL output.
  - O Disable
  - 1 Enable

## **CONFG+114h** Sleep Control Register

**SLEEP CON** 

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4     | 3 | 2   | 1   | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|-----|-------|---|-----|-----|-----|
| Name  |    |    |    |    |    |    |   |   |   |   |     | (D) — |   | DSP | AHB | MCU |
| Type  |    |    |    |    |    |    |   |   |   |   | 702 |       |   | WO  | WO  | WO  |
| Reset |    |    |    |    |    |    |   |   |   |   |     |       |   | 0   | 0   | 0   |

- MCU Stops the MCU Clock to force MCU Processor to enter sleep mode. MCU clock resumes as long as there is an interrupt request or system is reset.
  - 0 MCU Clock is running
  - 1 MCU Clock is stopped
- AHB Stops the AHB Bus Clock to force the entire bus to enter sleep mode. AHB clock resumes 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** Stops the DSP Clock.
  - O DSP Bus Clock is running
  - 1 DSP Bus Clock is stopped

### CONFG+0118h MCU Clock Control Register

MCUCLK CON

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

MCU\_FSELMCU clock frequency selection. This control register is used to control the output clock frequency of MCU Dynamic Clock Manager. The clock frequency is from 13MHz to 52MHz. The waveforms of the output clock are shown below.

Note that the clock period of 39MHz is not uniform. The shortest period of 39MHz clock is the same as the period of 52MHz. As a result, the wait states of external interfaces, such as EMI, NAND, and so on, have to be configured based on 52MHz timing. Therefore, the MCU performance executing in external memory at 39MHz may be worse than at 26MHz.

Also note that the maximum latency of clock switch is 8 104MHz-clock periods. Software provides at least 8T locking time after clock switch command.





Figure 68 Output of Dynamic Clock Manager

0 13MHz

1 26MHz

2 39MHz

3 52MHz

Others reserved

ARM\_FSELARM clock frequency selection. This control register is used to control the output clock frequency of ARM Dynamic Clock Manager. The clock frequency is from 13MHz to 104MHz. 39MHz is not a uniform period clock.

0 13MHz

1 26MHz

2 39MHz

**3** 52MHz

4 reserved

5 reserved

6 reserved

**7** 104MHz

Others reserved

## CONFG+011C

h

## **DSP Clock Control Register**

DSPCLK\_CON

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

DSP\_FSEL DSP clock frequency selection. This control register is used to control the output clock frequency of DSP Dynamic Clock Manager. The clock frequency is from 13MHz to 104MHz. 39MHz, 65MHz, 78MHz, and 91MHz are not a uniform period clock rate.

0 13MHz

1 26MHz

2 39MHz

**3** 52MHz

4 65MHz

5 78MHz

6 91MHz

7 104MHz



Others reserved

# 11.3 Reset Generation Unit (RGU)

**Figure 69** shows the reset scheme used in MT6228. MT6228 provides three kinds of resets: hardware reset, watchdog reset, and software reset.



Figure 69 Reset Scheme Used in MT6228

## 11.3.1 General Description

### 11.3.1.1 Hardware Reset

This reset is input through the SYSRST# pin, which is driven low during power-on. The hardware reset has a global effect on the chip: all digital and analog circuits are initialized, except the Real Time Clock module. The initial states of the MT6228 sub-blocks are as follows:.

- All analog circuits are turned off.
- All PLLs are turned off and bypassed. The 13 MHz 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: 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, and
- External components (trigged by software).



#### 11.3.1.3 Software Resets

Software resets are local reset signals that initialize specific hardware components. For example, if hardware failures are detected, the MCU or DSP software may write to software reset trigger registers to reset those specific hardware modules to their initial states.

The following modules have software resets.

- DSP Core
- DSP Coprocessors

## 11.3.2 Register Definitions

### RGU +0000h Watchdog Timer Control Register

**WDT MODE** 

| Bit   | 15 | 14 | 13 | 12  | 11    | 10 | 9 | 8 | 7 | 6 | 5 | 4                    | 3   | 2         | 1          | 0          |
|-------|----|----|----|-----|-------|----|---|---|---|---|---|----------------------|-----|-----------|------------|------------|
| Name  |    |    |    | KEY | [7:0] |    |   |   |   |   | 9 | AUTO<br>-REST<br>ART | IRQ | EXTE<br>N | EXTP<br>OL | ENAB<br>LE |
| Type  |    |    |    |     |       |    |   |   |   |   |   | R/W                  | R/W | R/W       | R/W        | R/W        |
| Reset |    | ·  | •  |     | ·     |    |   | • |   |   |   | 0                    | 0   | 0         | 0          | 1          |

**ENABLE** Enables the Watchdog Timer.

**0** Disables the Watchdog Timer.

1 Enables the Watchdog Timer.

**EXTPOL** Defines the polarity of the external watchdog pin.

O Active low.

1 Active high.

**EXTEN** Specifies whether or not to generate an external watchdog reset signal.

- The watchdog does not generate an external watchdog reset signal.
- 1 If the watchdog counter reaches zero, an external watchdog signal is generated.

IRQ Issues an interrupt instead of a Watchdog Timer reset. For debug purposes, RGU issues an interrupt to the MCU instead of resetting the system.

- O Disable.
- 1 Enable.

**AUTO-RESTART** Restarts the Watchdog Timer counter with the value of WDT\_LENGTH while task ID is written into Software Debug Unit.

- **0** Disable. The counter restarts by writing KEY into the WDT\_RESTART register.
  - 1 Enable. The counter restarts by writing KEY into the WDT\_RESTART register or by writing task ID into the 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 |
|-------|----|----|----|----|------|--------|------|---|----------|---|---|---|---|---|---|---|
| Name  |    |    | 7= |    | TIMI |        |      | k | (EY[4:0] |   |   |   |   |   |   |   |
| Type  |    |    |    |    |      |        |      |   |          |   |   |   |   |   |   |   |
| Reset |    |    |    |    | 111_ | 1111_1 | 111b |   |          |   |   |   |   |   |   |   |

**KEY** Write access is allowed if KEY=08h.



**TIMEOUT** The counter is restarted with {TIMEOUT [10:0],  $1_{1111}1111b$ }. Thus the Watchdog Timer time-out period is a multiple of  $512*T_{32k}=15.6$ 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 |
|-------|----|----|----|----|----|----|---|------|-------|---|---|---|---|---|-----|
| 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_W<br>DT |    |    |    |    |   |   |   |   |   | (7) | 7 |   |   |   |
| Type  | RO  | RO         |    |    |    |    |   |   |   |   |   |     |   |   |   |   |
| Reset | 0   | 0          |    |    |    |    |   |   |   |   |   |     |   |   |   |   |

**WDT** Indicates the cause of the watchdog reset.

**0** Reset not due to Watchdog Timer.

**1**Reset because the Watchdog Timer time-out period expired.

**SW\_WDT** Indicates if the watchdog was triggered by software.

**0** Reset not due to software-triggered Watchdog Timer.

1 Reset due to software-triggered Watchdog Timer.

**NOTE**: A system reset does not affect this register. This bit is cleared when the WTU\_MODE register ENABLE bit is written.

# RGU +0010h CPU Peripheral Software Reset Register

SW\_PERIPH\_RS

ΤN

| Bit   | 15 | 14         | 13         | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4  | 3  | 2 | 1 | 0 |
|-------|----|------------|------------|----|----|----|---|---|---|---|---|----|----|---|---|---|
| Name  |    | DAMR<br>ST | USBR<br>ST |    |    |    | K |   |   |   |   | KI | ΞY |   |   |   |
| Type  |    | R/W        | R/W        |    |    |    |   | 1 |   |   |   |    |    |   |   |   |
| Reset |    | 0          | 0          |    |    |    |   |   |   |   |   |    |    |   |   |   |

**KEY** Write access is allowed if KEY=37h

**DMARST** Reset the DMA peripheral.

O No reset.

1 Invoke a reset.

**USBRST** Reset the USB.

O No reset.

1 Invoke a reset.

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



- No reset.
- 1 Invoke a reset.

## RGU +0018h Watchdog Timer Reset Signal Duration Register

WDT\_RSTINTRE

| 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 |    |    |    |    |    |               | • | • |   | FF | Fh | • |   |   |   |   |  |  |  |

**LENGTH** This register indicates the reset duration when Watchdog Timer times out. However, if the WDT\_MODE register IRQ bit is set to 1, an interrupt is issued 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 | 7.7 | 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 the WDT\_MODE register IRQ bit is set to 1, an interrupt is issued instead of a reset.

**KEY** 1209h

## 11.4 Software Power Down Control

In addition to the Pause Mode capability while in the Standby State, the software program can also put each peripheral independently into Power Down Mode while in the Active State by gating off their clock. The typical logic implementation is depicted in **Figure 70**. For all configuration bits, 1 signifies that the function is in Power Down Mode, and 0 means the function is in the Active Mode.



Figure 70 Power Down Control at Block Level

# 11.4.1 Register Definitions

## CONFG+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 |    | MDPL<br>L |    | CLK_<br>DIV2 | CLKS<br>Q | UPLL | TPLL |   |   |   | PPP | CHE | WAVE<br>TABL<br>E | GCU | USB | DMA |
| Type |    | 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 1 1 1 1 1 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.

**WAVETALBE** Controls the DSP WaveTable DMA Power Down.

**CHE** Controls the CHE Power Down.

PPP Controls the PPP Framer Power Down.

TPLL Controls the TPLL Power Down.

UPLL Controls the UPLL Power Down.

CLKSQ Controls the Clock squarer Power Down.

CLK\_DIV2 Controls the Input Clock DIV2 Power Down.

MDPLL Controls the MCU and DSP PLL Power Down.

## CONFG +304h Power Down Control 1 Register

### PDN CON1

| Bit   | 15   | 14        | 13    | 12  | 11   | 10        | 9    | 8         | 7   | 6         | 5    | 4   | 3         | 2    | 1   | 0   |
|-------|------|-----------|-------|-----|------|-----------|------|-----------|-----|-----------|------|-----|-----------|------|-----|-----|
| Name  | IRDA | UART<br>3 | B2PSI | NFI | PWM2 | SWDB<br>G | MSDC | UART<br>2 | LCD | ALTE<br>B | PWM1 | SIM | UART<br>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   | _10       |      | 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.

**PWM1** Controls the PWM1 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.

**SWDBG** Controls the MCU/DSP Software Debug 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.

## CONFG +308h Power Down Control 2 Register

### PDN\_CON2

| 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<br>D | 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    |

575/616

**TDMA** Controls the TDMA Power Down.

RTC Controls the RTC Power Down.



#### MT6228 GSM/GPRS Baseband Processor Data Sheet Revision 1.0

Controls the BSI Power Down. This control is not be updated until both tdma\_evtval and qbit\_en are asserted.

BPI Controls the BPI Power Down. This control is not be updated until both tdma\_evtval and qbit\_en are asserted.

AFC Controls the AFC Power Down. This control is not be updated until both tdma evtval and qbit en are asserted.

APC Controls the APC Power Down. This control is not be updated until both tdma\_evtval and qbit\_en are asserted.

FCS Controls the FCS Power Down. This control is not be updated until both tulna\_evtval and qbit\_cir are asset.

AUX ADC Ontrols 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.

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.

## CONFG +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  | DRZ | IMGD<br>MA | DCT | ISP | PRZ | JPEG | MP4 | G2D | GCMQ | GIF  | PNG | IPP | TV  | CRZ | RESZ<br>LB | ICE |
| 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   |

**ICE** Enables the debug feature of the ARM7EJS core. Controls the DBGEN pin of the ICEBreaker.

**RESZ** LB Controls the Post Resizer Power Down.

TV Controls the TV Encoder Power Down.

**CRZ** Controls the Capture Resizer Power Down.

IPP Controls the Image Processor Power Down.

PNG Controls the PNG Decoder 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.

**REZ** 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.

**DRZ** Controls the Drop Resizer Power Down.

### CONFG +330h Power Down Control 4 Register

### PDN CON4

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4   | 3   | 2   | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|-----|-----|-----|-----|---|---|
| Name  |    |    |    |    |    |    |   |   |   |   | APC | AFC | BPI | BSI |   |   |
| Type  |    |    |    |    |    |    |   |   |   |   | WO  | WO  | WO  | WO  |   |   |
| Reset |    |    |    |    |    |    |   |   |   |   | 1   | 1   | 1   | 1   |   |   |

576/616

BSI Controls the BSI Power Down. This control is updated immediately.

**BPI** Controls the BPI Power Down. This control is updated immediately.





AFC Controls the AFC Power Down. This control is updated immediately.

Controls the APC Power Down. This control is updated immediately.

### CONFG+0310h Power Down Set 0 Register

### PDN\_SET0

| Bit  | 15 | 14        | 13 | 12           | 11        | 10   | 9    | 8 | 7 | 6 | 5   | 4   | 3                 | 2   |     | 0   |
|------|----|-----------|----|--------------|-----------|------|------|---|---|---|-----|-----|-------------------|-----|-----|-----|
| Name |    | MDPL<br>L |    | CLK_<br>DIV2 | CLKS<br>Q | UPLL | TPLL |   |   |   | PPP |     | WAVE<br>TABL<br>E | GCU | USB | DMA |
| Type |    | W1S       |    | W1S          | W1S       | W1S  | W1S  |   |   |   | W1S | W1S | W1S               | W1S | W1S | W1S |

### CONFG+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 | IRDA | UART<br>3 | B2PSI | NFI | TRC | PWM2 | MSDC | UART<br>2 | LCD | ALTE<br>R | PWM1 | SIM | UART<br>1 | GPIO | KP  | GPT |
| Type | W1S  | W1S       | W1S   | W1S | W1S | W1S  | W1S  | W1S       | W1S | W1S       | W1S  | W1S | W1S       | W1S  | W1S | W1S |

### CONFG+0318h Power Down Set 2 Register

### PDN\_SET2

| Bit  | 15   | 14   | 13   | 12   | 11  | 10  | 9   | 8    | 7         | 6   | 5   | 0 4 | 3   | 2   | 1   | 0    |
|------|------|------|------|------|-----|-----|-----|------|-----------|-----|-----|-----|-----|-----|-----|------|
| Name | GMSK | BBRX | SCCB | AAFE | DIV | GCC | BFE | VAFE | AUXA<br>D | FCS | APC | AFC | BPI | BSI | RTC | TDMA |
| Type | W1S  | W1S  | W1S  | W1S  | W1S | W1S | W1S | W1S  | W1S       | W1S | W1S | W1S | W1S | W1S | W1S | W1S  |

#### CONFG+031C

h

## **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 |     | IVIA |     |     |     |     |      |     |     |     |     |     |     | CITZ | LB  | ICL |
| Type | W1S | W1S  | W1S | W1S | W1S | W1S | W1S. | W15 | W1S | W1S | W1S | W1S | W1S | W1S  | W1S | W1S |

### CONFG+0334h Power Down Set 4 Register

#### PDN SET4

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4   | 3   | 2   | 1 | 0 |
|------|----|----|----|----|----|----|---|---|---|---|-----|-----|-----|-----|---|---|
| Name |    |    |    |    |    |    |   |   |   |   | APC | AFC | BPI | BSI |   |   |
| Type |    |    |    |    |    |    |   |   |   |   | W1S | W1S | W1S | W1S |   |   |

These registers are used to set power down control bit individually. Only bits set to 1 are in effect. Setting the bits to 1 sets the corresponding power down control bits to 1. Otherwise, the bits retain their original value.

**EACH BIT** Set the Associated Power Down Control Bit to 1.

- O No effect.
- 1 Set corresponding bit to 1.

### CONFG+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 |    | MDPL<br>L |    | CLK_<br>DIV2 | CLKS<br>Q | UPLL | TPLL |   |   |   | PPP | CHE | WAVE<br>TABL<br>E | GCU | USB | DMA |
| Type |    | W1C       |    | W1C          | W1C       | W1C  | W1C  |   |   |   | W1C | W1C | W1C               | W1C | W1C | W1C |



### CONFG+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<br>3 | B2PSI | NFI | TRC | PWM2 | MSDC | UART<br>2 | LCD | ALTE<br>R | PWM1 | SIM | UART<br>1 | GPIO | KP  | GPT |
| Type | W1C  | W1C       | W1C   | W1C | W1C | W1C  | W1C  | W1C       | W1C | W1C       | W1C  | W1C | W1C       | W1C  | W1C | W1C |

### CONFG+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<br>D | FCS | APC | AFC | BPI | BSI | RTC | TDMA |
| Туре | W1C  | W1C  | W1C  | W1C  | W1C | W1C | W1C | W1C  | W1C       | W1C | W1C | W1C | Wic | W1C | W1C | W1C  |

#### CONFG+032C

h

### **Power Down Clear 3 Register**

### PDN\_CLR3

| Bit  | 15  | 14         | 13  | 12  | 11  | 10   | 9   | 8   | 7    | 6   | 5   | 4)  | 3   | 2   | 1          | 0   |
|------|-----|------------|-----|-----|-----|------|-----|-----|------|-----|-----|-----|-----|-----|------------|-----|
| Name | DRZ | IMGD<br>MA | DCT | ISP | REZ | JPEG | MP4 | G2D | GCMQ | GIF | PNG | IPP | TV  | CRZ | RESZ<br>LB | ICE |
| Type | W1C | W1C        | W1C | W1C | W1C | W1C  | W1C | W1C | W1C  | W1C | W1C | W1C | W1C | W1C | W1C        | W1C |

### CONFG+0338h Power Down Clear 4 Register

### PDN\_CLR4

| Bit  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 1 6 | 6 | 5   | 4   | 3   | 2   | 1 | 0 |
|------|----|----|----|----|----|----|---|---|---|-----|---|-----|-----|-----|-----|---|---|
| Name |    |    |    |    |    |    |   |   |   | T   |   | APC | AFC | BPI | BSI |   |   |
| Type |    |    |    |    |    |    |   |   |   |     |   | W1C | W1C | W1C | W1C |   |   |

These registers are used to clear power down control bits individually. Only the bits set to 1 are in effect. Setting the bits to 1 sets the corresponding power down control bits to 0. Otherwise, the bits retain 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 & Analog Blocks

## 12.1 General Description

To communicate with analog blocks, 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. The Analog Blocks includes the following analog function for complete GSM/GPRS base-band signal processing:

- 1. Base-band RX: For I/Q channels base-band A/D conversion
- 2. Base-band TX: For I/Q channels base-band D/A conversion and smoothing filtering, DC level shifting
- 3. *RF Control*: Two DACs for automatic power control (APC) and automatic frequency control (AFC) are included. Their outputs are provided to external RF power amplifier and VCXO), respectively.
- 4. Auxiliary ADC: Providing an ADC for battery and other auxiliary analog function monitoring
- 5. *Audio mixed-signal blocks:* It provides complete analog voice signal processing including microphone amplification, A/D conversion, D/A conversion, earphone driver, and etc. Besides, dedicated stereo D/A conversion and amplification for audio signals are included).
- 6. *Clock Generation*: A clock squarer for shaping system clock, and three PLLs that provide clock signals to DSP, MCU, and USB units are included
- 7. XOSC32: It is a 32-KHz crystal oscillator circuit for RTC application Analog Block Descriptions

#### 12.1.1 BBRX

#### 12.1.1.1 Block Descriptions

The receiver (RX) performs base-band I/Q channels downlink analog-to-digital conversion:

- 1. Analog input multiplexer: For each channel, a 4-input multiplexer that supports offset and gain calibration is included.
- 2. A/D converter: Two 14-bit sigma-delta ADCs perform I/Q digitization for further digital signal processing.

#### 12.1.1.2 Functional Specifications

The functional specifications of the base-band downlink receiver are listed in the following table.

| Symbol | Parameter                 | Min | Typical  | Max | Unit |
|--------|---------------------------|-----|----------|-----|------|
| N      | Resolution                |     | 14       |     | Bit  |
| FC     | Clock Rate                |     | 26       |     | MHz  |
| FS     | Output Sampling Rate      |     | 13/12    |     | MSPS |
|        | Input Swing When GAIN='0' |     | 0.8*AVDD |     | Vpk  |
|        |                           |     | 0.4*AVDD |     | Vpk  |



|       | When GAIN='1'                                                                                                               |          |        |            |                                                                                    |
|-------|-----------------------------------------------------------------------------------------------------------------------------|----------|--------|------------|------------------------------------------------------------------------------------|
| OE    | Offset Error                                                                                                                |          | +/- 10 |            | mV                                                                                 |
| FSE   | Full Swing Error                                                                                                            |          | +/- 30 |            | mV                                                                                 |
|       | I/Q Gain Mismatch                                                                                                           |          |        | 0.5        | dB                                                                                 |
| SINAD | Signal to Noise and Distortion Ratio - 45kHz sine wave in [0:90] kHz bandwidth - 145kHz sine wave in [10:190] kHz bandwidth | 65<br>65 |        | 4          | dB<br>dB                                                                           |
| ICN   | Idle channel noise - [0:90] kHz bandwidth - [10:190] kHz bandwidth                                                          |          |        | -74<br>-70 | dB<br>dB                                                                           |
| DR    | Dynamic Range - [0:90] kHz bandwidth - [10:190] kHz bandwidth                                                               | 74<br>70 |        | 3          | dB<br>dB                                                                           |
| RIN   | Input Resistance                                                                                                            | 75       |        |            | kΩ                                                                                 |
| DVDD  | Digital Power Supply                                                                                                        | 1.6      | 1.8    | 2.0        | V                                                                                  |
| AVDD  | Analog Power Supply                                                                                                         | 2.5      | 2.8    | 3.1        | V                                                                                  |
| Т     | Operating Temperature                                                                                                       | -20      |        | 80         | $^{\circ}\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!$ |
|       | Current Consumption Power-up Power-Down                                                                                     | 2        | 5      |            | mA<br>μA                                                                           |

Table 68 Base-band Downlink Specifications

#### 12.1.2 BBTX

#### 12.1.2.1 Block Descriptions

The transmitter (TX) performs base-band I/Q channels up-link digital-to-analog conversion. Each channel includes:

- 1. 10-Bits D/A Converter: It converts digital GMSK modulated signals to analog domain. The input to the DAC is sampled at 4.33-MHz rate with 10-bits resolution.
- 2. *Smoothing Filter:* The low-pass filter performs smoothing function for DAC output signals with a 350-kHz 2nd-order Butterworth frequency response.

### 12.1.2.2 Function Specifications

The functional specifications of the base-band uplink transmitter are listed in the following table.

| Symbol | Parameter                            | Min       | Typical  | Max       | Unit |
|--------|--------------------------------------|-----------|----------|-----------|------|
| N      | Resolution                           |           | 10       |           | Bit  |
| FS     | Sampling Rate                        |           | 4.33     |           | MSPS |
| SINAD  | Signal to Noise and Distortion Ratio | 57        | 60       |           | dB   |
|        | Output Swing                         | 0.18*AVDD |          | 0.89*AVDD | V    |
| VOCM   | Output CM Voltage                    | 0.34*AVDD | 0.5*AVDD | 0.62*AVDD | V    |

580/616



|      | Output Capacitance                                      |                    |                    | 20                 | PF                     |
|------|---------------------------------------------------------|--------------------|--------------------|--------------------|------------------------|
|      | Output Resistance                                       | 10                 |                    |                    | ΚΩ                     |
| DNL  | Differential Nonlinearity                               |                    | +/- 0.5            |                    | LSB                    |
| INL  | Integral Nonlinearity                                   |                    | +/- 1.0            |                    | LSB                    |
| OE   | Offset Error                                            |                    | +/- 15             |                    | mV                     |
| FSE  | Full Swing Error                                        |                    | +/- 30             |                    | mV                     |
| FCUT | Filter –3dB Cutoff Frequency                            | 300                | 350                | 400                | KHz                    |
| ATT  | Filter Attenuation at<br>100-KHz<br>270-KHz<br>4.33-MHz | 0.1<br>2.2<br>46.4 | 0.0<br>1.3<br>43.7 | 0.0<br>0.8<br>41.4 | dB<br>dB<br>dB         |
|      | I/Q Gain Mismatch                                       |                    | +/- 0.5            | 71                 | dB                     |
|      | I/Q Gain Mismatch Correction Range                      | -1.18              |                    | +1.18              | dB                     |
| DVDD | Digital Power Supply                                    | 1.6                | 1.8                | 2.0                | V                      |
| AVDD | Analog Power Supply                                     | 2.5                | 2.8                | 3.1                | V                      |
| Т    | Operating Temperature                                   | -20                | (7)                | 80                 | $^{\circ}\!\mathbb{C}$ |
|      | Current Consumption Power-up Power-Down                 | 0                  | 5                  |                    | mA<br>μA               |

Table 69 Base-band Uplink Transmitter Specifications

### 12.1.3 AFC-DAC

### 12.1.3.1 Block Descriptions

As shown in the following figure, together with a 2<sup>nd</sup>-oder digital sigma-delta modulator, AFC-DAC is designed to produce a single-ended output signal at AFC pin. AFC pin should be connected to an external 1<sup>st</sup>-order R-C low pass filter to meet the 13-bits resolution (DNL) requirement<sup>2</sup>.

The AFC\_BYP pin is the mid-tap of a resistor divider inside the chip to offer the AFC output common-mode level. Nominal value of this common-mode voltage is half the analog power supply, and typical value of output impedance of AFC\_BYP pin is about  $21k\Omega$ . To suppress the noise on common mode level, it is suggested to add an external capacitance between AFC\_BYP pin and ground. The value of the bypass capacitor should be chosen as large as possible but still meet the settling time requirement set by overall AFC algorithm<sup>3</sup>.

<sup>&</sup>lt;sup>2</sup> DNL performance depends on external output RC filter bandwidth: the narrower the bandwidth, the better the DNL. Thus, there exists a tradeoff between output setting speed and DNL performance

<sup>&</sup>lt;sup>3</sup> AFC\_BYP output impedance and bypass capacitance determine the common-mode settling RC time constant. Insufficient common-mode settling will affect the INL performance. A typical value of 1nF is suggested.





Figure 71 Block diagram of AFC-DAC

### 12.1.3.2 Functional Specifications

The following table gives the electrical specification of AFC-DAC.

| Symbol | Parameter                                     | Min  | Typical   | Max | Unit                   |
|--------|-----------------------------------------------|------|-----------|-----|------------------------|
| N      | Resolution                                    |      | 13        |     | Bit                    |
| FS     | Sampling Rate                                 |      | 6500      |     | KHz                    |
| DVDD   | Digital Power Supply                          | 1.6  | 1.8       | 2.0 | V                      |
| AVDD   | Analog Power Supply                           | 2.6  | 2.8       | 3.1 | V                      |
| T      | Operating Temperature                         | -20  |           | 80  | $^{\circ}\!\mathbb{C}$ |
|        | Current Consumption Power-up Power-Down       |      | 1.2       | 1   | mA<br>μA               |
|        | Output Swing                                  | 4,10 | 0.75*AVDD |     | V                      |
|        | Output Resistor<br>(in AFC output RC network) | 1    |           |     | ΚΩ                     |
| DNL    | Differential Nonlinearity                     |      | +1/-1     |     | LSB                    |
| INL    | Integral Nonlinearity                         |      | +4.0/-4.0 |     | LSB                    |

Table 70 Functional specification of AFC-DAC

#### 12.1.4 APC-DAC

### 12.1.4.1 Block Descriptions

The APC-DAC is a 10-bits DAC with output buffer aimed for automatic power control. Here blow are its analog pin assignment and functional specification tables.

### 12.1.4.2 Function Specifications

| Symbol | Parameter                            | Min | Typical | Max    | Unit |
|--------|--------------------------------------|-----|---------|--------|------|
| N      | Resolution                           |     | 10      |        | Bit  |
| FS     | Sampling Rate                        |     |         | 1.0833 | MSPS |
| SINAD  | Signal to Noise and Distortion Ratio |     | 50      |        | dB   |

582/616



|      | (10-KHz Sine with 1.0V Swing & 100-KHz BW)            |     |         |          |                        |
|------|-------------------------------------------------------|-----|---------|----------|------------------------|
|      | 99% Settling Time (Full Swing on Maximal Capacitance) |     |         | 5        | μS                     |
|      | Output Swing                                          |     |         | AVDD-0.2 | V                      |
|      | Output Capacitance                                    |     |         | 200      | pF                     |
|      | Output Resistance                                     | 10  |         |          | ΚΩ                     |
| DNL  | Differential Nonlinearity                             |     | +/- 0.5 |          | LSB                    |
| INL  | Integral Nonlinearity                                 |     | +/- 1.0 |          | LSB                    |
| OE   | Offset Error                                          |     | +/- 10  |          | mV                     |
| FSE  | Full Swing Error                                      |     | +/- 10  |          | mV                     |
| DVDD | Digital Power Supply                                  | 1.6 | 1.8     | 2.0      | V                      |
| AVDD | Analog Power Supply                                   | 2.5 | 2.8     | 3.1      | V                      |
| T    | Operating Temperature                                 | -20 |         | 80       | $^{\circ}\!\mathbb{C}$ |
|      | Current Consumption                                   |     | 600     |          | μΑ                     |
|      | Power-up                                              |     | 1       |          | μΑ                     |
|      | Power-Down                                            |     | U       |          |                        |

Table 71 APC-DAC Specifications

## 12.1.5 Auxiliary ADC

### 12.1.5.1 Block Descriptions

The auxiliary ADC includes the following functional blocks:

- 1. Analog Multiplexer: The analog multiplexer selects signal from one of the seven auxiliary input pins. Real word message to be monitored, like temperature, should be transferred to the voltage domain.
- 2. 10 bits A/D Converter: The ADC converts the multiplexed input signal to 10-bit digital data.

### 12.1.5.2 Function Specifications

The functional specifications of the auxiliary ADC are listed in the following table.

| Symbol | Parameter                                                  | Min       | Typical | Max       | Unit     |
|--------|------------------------------------------------------------|-----------|---------|-----------|----------|
| N      | Resolution                                                 |           | 10      |           | Bit      |
| FC     | Clock Rate                                                 | 0.1       | 1.0833  | 5         | MHz      |
| FS     | Sampling Rate @ N-Bit                                      |           |         | 5/(N+1)   | MSPS     |
|        | Input Swing                                                | 1.0       |         | AVDD      | V        |
| VREFP  | Positive Reference Voltage (Defined by AUX_REF pin)        | 1.0       |         | AVDD      | V        |
| CIN    | Input Capacitance Unselected Channel Selected Channel      |           |         | 50<br>1.2 | fF<br>pF |
| RIN    | Input Resistance<br>Unselected Channel<br>Selected Channel | 10<br>1.8 |         |           | ΜΩ<br>ΜΩ |



| RS    | Resistor String Between AUX_REF pin & ground                                       | 35  | 50        | 65  | ΚΩ<br>ΜΩ               |
|-------|------------------------------------------------------------------------------------|-----|-----------|-----|------------------------|
|       | Power Up<br>Power Down                                                             | 10  |           |     | 10122                  |
|       | Clock Latency                                                                      |     | 11        |     | 1/FC                   |
| DNL   | Differential Nonlinearity                                                          |     | +0.5/-0.5 |     | LSB                    |
| INL   | Integral Nonlinearity                                                              |     | +1.0/-1.0 |     | LSB                    |
| OE    | Offset Error                                                                       |     | +/- 10    |     | mV                     |
| FSE   | Full Swing Error                                                                   |     | +/- 10    |     | mV                     |
| SINAD | Signal to Noise and Distortion Ratio (10-KHz Full Swing Input & 13-MHz Clock Rate) |     | 50        | 10  | dB                     |
| DVDD  | Digital Power Supply                                                               | 1.6 | 1.8       | 2.0 | V                      |
| AVDD  | Analog Power Supply                                                                | 2.5 | 2.8       | 3.1 | V                      |
| Т     | Operating Temperature                                                              | -20 |           | 80  | $^{\circ}\!\mathbb{C}$ |
|       | Current Consumption                                                                |     | 300       |     | μΑ                     |
|       | Power-up                                                                           |     | 1         |     | μΑ                     |
|       | Power-Down                                                                         |     |           |     |                        |

Table 72 The Functional specification of Auxiliary ADC

## 12.1.6 Audio mixed-signal blocks

### 12.1.6.1 Block Descriptions

Audio mixed-signal blocks (AMB) integrate complete voice uplink/downlink and audio playback functions. As shown in the following figure, it includes mainly three parts. The first consists of stereo audio DACs and speaker amplifiers for audio playback. The second is the voice downlink path, including voice-band DACs and amplifiers, which produces voice signal to earphone or other auxiliary output device. Amplifiers in these two blocks are equipped with multiplexers to accept signals from internal audio/voice or external radio sources. The last is the voice uplink path, which is the interface between microphone (or other auxiliary input device) input and MT6228 DSP. A set of bias voltage is provided for external electret microphone..





Figure 72 Block diagram of audio mixed-signal blocks.

## 12.1.6.2 Functional Specifications

The following table gives functional specifications of voice-band uplink/downlink blocks.

| Symbol | Parameter                                         | Min | Typical | Max | Unit                   |
|--------|---------------------------------------------------|-----|---------|-----|------------------------|
| FS     | Sampling Rate                                     |     | 4096    |     | KHz                    |
| CREF   | Decoupling Cap Between AU_VREF_P<br>And AU_VREF_N |     | 47      |     | NF                     |
| DVDD   | Digital Power Supply                              | 1.6 | 1.8     | 2.0 | V                      |
| AVDD   | Analog Power Supply                               | 2.5 | 2.8     | 3.1 | V                      |
| T      | Operating Temperature                             | -20 |         | 80  | $^{\circ}\!\mathbb{C}$ |
| IDC    | Current Consumption                               |     | 5       |     | mA                     |
| VMIC   | Microphone Biasing Voltage                        |     | 1.9     |     | V                      |



| IMIC      | Current Draw From Microphone Bias<br>Pins                                            |    |    | 2   | mA       |
|-----------|--------------------------------------------------------------------------------------|----|----|-----|----------|
| Uplink Pa | th <sup>4</sup>                                                                      |    |    |     |          |
| SINAD     | Signal to Noise and Distortion Ratio<br>Input Level: -40 dbm0<br>Input Level: 0 dbm0 | 29 | 69 |     | dB<br>dB |
| RIN       | Input Impedance (Differential)                                                       | 13 | 20 | 27  | ΚΩ       |
| ICN       | Idle Channel Noise                                                                   |    |    | -67 | dBm0     |
| XT        | Crosstalk Level                                                                      |    |    | -66 | dBm0     |
| Downlink  | Path <sup>5</sup>                                                                    |    |    |     |          |
| SINAD     | Signal to Noise and Distortion Ratio<br>Input Level: -40 dBm0<br>Input Level: 0 dBm0 | 29 | 69 | 7)  | dB<br>dB |
| RLOAD     | Output Resistor Load (Differential)                                                  | 28 |    |     | Ω        |
| CLOAD     | Output Capacitor Load                                                                |    |    | 200 | pF       |
| ICN       | Idle Channel Noise of Transmit Path                                                  |    |    | -67 | dBm0     |
| XT        | Crosstalk Level on Transmit Path                                                     |    |    | -66 | dBm0     |

**Table 73** Functional specifications of analog voice blocks

Functional specifications of the audio blocks are described in the following.

| Symbol | Parameter                          | Min | Typical | Max        | Unit         |
|--------|------------------------------------|-----|---------|------------|--------------|
| FCK    | Clock Frequency                    |     | Fs*128  |            | KHz          |
| Fs     | Sampling Rate                      | 32  | 44.1    | 48         | KHz          |
| AVDD   | Power Supply                       | 2.6 | 2.8     | 3.1        | V            |
| Т      | Operating Temperature              | -20 |         | 80         | $^{\circ}$ C |
| IDC    | Current Consumption                |     | 5       |            | mA           |
| PSNR   | Peak Signal to Noise Ratio         |     | 80      |            | dB           |
| DR     | Dynamic Range                      |     | 80      |            | dB           |
| VOUT   | Output Swing for OdBFS Input Level |     | 0.85    |            | Vrms         |
| THD    | Total Harmonic Distortion          |     |         | -40<br>-60 | dB           |

<sup>&</sup>lt;sup>4</sup> For uplink-path, not all gain setting of VUPG meets the specification listed on table, especially for the several highest gains. The maximum gain that meets the specification is to be determined.

<sup>&</sup>lt;sup>5</sup> For downlink-path, not all gain setting of VDPG meets the specification listed on table, especially for the several lowest gains. The minimum gain that meets the specification is to be determined.



|       | 45mW at 16 Ω Load<br>22mW at 32 Ω Load |    |     | dB |
|-------|----------------------------------------|----|-----|----|
| RLOAD | Output Resistor Load (Single-Ended)    | 16 |     | Ω  |
| CLOAD | Output Capacitor Load                  |    | 200 | pF |
| XT    | L-R Channel Cross Talk                 |    | TBD | dB |

Table 74 Functional specifications of the analog audio blocks

## 12.1.7 Clock Squarer

### 12.1.7.1 Block Descriptions

For most VCXO, the output clock waveform is sinusoidal with too small amplitude (about several hundred mV) to make MT6228 digital circuits function well. Clock squarer is designed to convert such a small signal to a rail-to-rail clock signal with excellent duty-cycle. It provides also a pull-down function when the circuit is powered-down.

### 12.1.7.2 Function Specifications

The functional specification of clock squarer is shown in Table 75.

| Symbol  | Parameter                 | Min      | Typical | Max      | Unit                   |
|---------|---------------------------|----------|---------|----------|------------------------|
| Fin     | Input Clock Frequency     |          | 13      |          | MHz                    |
| Fout    | Output Clock Frequency    |          | 13      |          | MHz                    |
| Vin     | Input Signal Amplitude    |          | 500     | AVDD     | mVpp                   |
| DcycIN  | Input Signal Duty Cycle   |          | 50      |          | %                      |
| DcycOUT | Output Signal Duty Cycle  | DcycIN-5 |         | DcycIN+5 | %                      |
| TR      | Rise Time on Pin CLKSQOUT |          |         | 5        | ns/pF                  |
| TF      | Fall Time on Pin CLKSQOUT |          |         | 5        | ns/pF                  |
| DVDD    | Digital Power Supply      | 1.3      | 1.5     | 1.7      | V                      |
| AVDD    | Analog Power Supply       | 2.5      | 2.8     | 3.1      | V                      |
| T       | Operating Temperature     | -20      |         | 80       | $^{\circ}\!\mathbb{C}$ |
|         | Current Consumption       |          | TBD     |          | MA                     |

Table 75 The Functional Specification of Clock Squarer

## 12.1.7.3 Application Notes

Here below in the figure is an equivalent circuit of the clock squarer. Please be noted that the clock squarer is designed to accept a sinusoidal input signal. If the input signal is not sinusoidal, its harmonic distortion should be low enough to not produce a wrong clock output. As an reference, for a 13MHz sinusoidal signal input with amplitude of 0.2V the harmonic distortion should be smaller than 0.02V.





Figure 73 Equivalent circuit of Clock Squarer.

### 12.1.8 Phase Locked Loop

### 12.1.8.1 Block Descriptions

MT6228 includes three PLLs: DSP PLL, MCU PLL, and USB PLL. DSP PLL and MCU PLL are identical and programmable to provide either 52MHz or 78 MHz output clock while accepts 13MHz signal. USB PLL is designed to accept 4MHz input clock signal and provides 48MHz output clock.

### 12.1.8.2 Function Specifications

The functional specification of DSP/MCU PLL is shown in the following table.

| Symbol | Parameter               | Min | Typical | Max | Unit                   |
|--------|-------------------------|-----|---------|-----|------------------------|
| Fin    | Input Clock Frequency   |     | 13      |     | MHz                    |
| Fout   | Output Clock Frequency  | 52  |         | 78  | MHz                    |
|        | Lock-in Time            | 9   | TBD     |     | Ms                     |
|        | Output Clock Duty Cycle | 40  | 50      | 60  | %                      |
|        | Output Clock Jitter     |     | 650     |     | ps                     |
| DVDD   | Digital Power Supply    | 1.6 | 1.8     | 2.0 | V                      |
| AVDD   | Analog Power Supply     | 2.5 | 2.8     | 3.1 | V                      |
| T      | Operating Temperature   | -20 |         | 80  | $^{\circ}\!\mathbb{C}$ |
|        | Current Consumption     |     | TBD     |     | μΑ                     |

Table 76 The Functional Specification of DSP/MCU PLL

The functional specification of USB PLL is shown below.

| Symbol | Parameter               | Min | Typical | Max | Unit |
|--------|-------------------------|-----|---------|-----|------|
| Fin    | Input Clock Frequency   |     | 4       |     | MHz  |
| Fout   | Output Clock Frequency  |     | 48      |     | MHz  |
|        | Lock-in Time            |     | TBD     |     | μs   |
|        | Output Clock Duty Cycle | 40  | 50      | 60  | %    |
|        | Output Clock Jitter     |     | 650     |     | ps   |



| DVDD | Digital Power Supply  | 1.3 | 1.5 | 1.7 | V          |
|------|-----------------------|-----|-----|-----|------------|
| AVDD | Analog Power Supply   | 2.5 | 2.8 | 3.1 | V          |
| T    | Operating Temperature | -20 |     | 80  | $^{\circ}$ |
|      | Current Consumption   |     | TBD |     | μΑ         |

Table 77 The Functional Specification of USB PLL

## 12.1.9 32-KHz Crystal Oscillator

### 12.1.9.1 Block Descriptions

The low-power 32-KHz crystal oscillator XOSC32 is designed to work with an external piezoelectric 32.768kHz crystal and a load composed of two functional capacitors, as shown in the following figure.



Figure 74 Block diagram of XOSC32

### 12.1.9.2 Functional specifications

The functional specification of XOSC32 is shown in the following table.

| Symbol  | Parameter             | Min  | Typical | Max  | Unit                   |
|---------|-----------------------|------|---------|------|------------------------|
| AVDDRTC | Analog power supply   | 1.08 | 1.2     | 1.65 | V                      |
| Tosc    | Start-up time         |      |         | 5    | sec                    |
| Dcyc    | Duty cycle            |      | 50      |      | %                      |
| TR      | Rise time on XOSCOUT  |      | TBD     |      | ns/pF                  |
| TF      | Fall time on XOSCOUT  |      | TBD     |      | ns/pF                  |
|         | Current consumption   |      |         | 5    | μΑ                     |
|         | Leakage current       |      | 1       |      | μΑ                     |
| T       | Operating temperature | -20  |         | 80   | $^{\circ}\!\mathbb{C}$ |

 Table 78 Functional Specification of XOSC32

Here below are a few recommendations for the crystal parameters for use with XOSC32.

| Symbol | Parameter       | Min | Typical | Max | Unit |
|--------|-----------------|-----|---------|-----|------|
| F      | Frequency range |     | 32768   |     | Hz   |



| GL              | Drive level         |   |        | 5    | uW  |
|-----------------|---------------------|---|--------|------|-----|
| Δf/f            | Frequency tolerance |   | +/- 20 |      | Ppm |
| ESR             | Series resistance   |   |        | 50   | ΚΩ  |
| C0              | Static capacitance  |   |        | 1.6  | pF  |
| CL <sup>6</sup> | Load capacitance    | 6 |        | 12.5 | pF  |

Table 79 Recommended Parameters of the 32kHz crystal

## 12.2 MCU Register Definitions

#### 12.2.1 BBRX

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  |    |    |    |    | QS | EL | IS | EL | RSV | PDNC<br>HP | GAIN |       | ( | CALBIA | S |   |
| Туре  |    |    |    |    | R/ | W  | R/ | W  | R/W | R/W        | Ř/W  |       |   | R/W    |   |   |
| Reset | 00 |    |    | 0  | 0  | 0  | 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.

- O 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.

- O 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

590/616

<sup>&</sup>lt;sup>6</sup> CL is the parallel combination of C1 and C2 in the block diagram.



- **01** Loopback TX analog Q
- 10 Loopback TX analog I
- 11 Select the grounded input

#### 12.2.2 BBTX

MCU APB bus registers for BBTX DAC are listed as followings.

### MIXED+0400h BBTX DAC Analog-Circuit Control Register 0

BBTX\_AC\_CON

| Bit   | 15                | 14  | 13 | 12   | 11 | 10  | 9     | 8  | 7    | 6  | 5   | 4 | 3           | 2  | 1    | 0 |
|-------|-------------------|-----|----|------|----|-----|-------|----|------|----|-----|---|-------------|----|------|---|
| Name  | CALR<br>CDON<br>E |     |    | GAIN |    | CA  | ALRCS | EL |      | TR | IMI |   | <b>&gt;</b> | TF | RIMQ |   |
| Type  | R                 | R/W |    | R/W  |    | R/W |       |    | R/W  |    |     |   | 5 —         | F  | 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  | CA       | ALRCO | UT | FLOA<br>T |    | CALR | CCNT |   |   | C | ALBIA | S |        | 1   | CMV |   |
| Type  | pe R     |       |    | R/W       |    | R/   | W    |   |   |   | R/W   |   |        |     | R/W |   |
| Reset | eset - 0 |       |    | 0         |    | 00   | 00   |   |   |   | 00000 |   | $\Box$ | 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.3 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  |    |    |    |    |    |      |   | TE | ST | PDN_<br>CHPU<br>MP |   |   | CALI |   |   |
| Type  |    |    |    |    |    |      |   | R/ | W  | R/W                |   |   | R/W  |   |   |
| Reset |    |    |    |    |    |      |   | (  | )  | 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.4 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    | 7 - |   |

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.5 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  |    |    |    |    |    |    |   |   |   |   | 7 |   |   | 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.6 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  |    |    |    |    |    | <b>VUPG</b> |     | <b>—</b>    |   | VDI | PG0 |          |   | VDI | PG1 |   |
| Type  |    |    |    |    |    | R/W         |     | <b>&gt;</b> |   | R/  | W   |          |   | R/  | W   |   |
| Reset |    |    |    |    |    | 0000        | 7/1 |             |   | 00  | 00  | <u> </u> |   | 00  | 00  |   |

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  |

593/616





#### Table 80 Uplink PGA gain setting (VUPG [4:0])

**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 |

Table 81 Downlink power amplifier gain setting

#### 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  |    |    |    |    |    |             | VC | FG |   | VDS | END |   | 7) | <b>VCALI</b> |   |   |
| Type  |    |    |    |    |    |             | R/ | W  |   | R/  | W   |   |    | R/W          |   |   |
| Reset |    |    |    |    |    | R/W<br>0000 |    |    |   | 0   | 0   |   |    | 00000        |   |   |

Set this register for analog circuit configuration controls.

VCFG[3] microphone biasing control

0 differential biasing

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  |    |    |    | VE | G_CT | RL | VPDN<br>_CHP<br>UMP | VFLO<br>AT | VRSD<br>ON |     | VBUF<br>0SEL | V | BUF1SI | EL | VADC<br>INMO<br>DE |     |
| Type  |    |    |    |    |      |    | 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 output010: external FM radio input100: 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  |    |    |    |    |    |    |   |   |   |   | VPDN<br>_BIAS |     |     | VPDN | VPDN<br>_OUT<br>1 | VPDN<br>_OUT<br>0 |
| 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

Ν

| Bit   | 15 | 14 | 13          | 12 11           |             | 10 | 9           | 8     | 7     | 6    | 5     | 4     | 3     | 2   | 1            | 0         |
|-------|----|----|-------------|-----------------|-------------|----|-------------|-------|-------|------|-------|-------|-------|-----|--------------|-----------|
| Name  |    |    | AGCT<br>EST | RELNOIDU<br>SEL | RELNOIDUR I |    | OILEV<br>EL | FRELO | CKSEL | SREL | CKSEL | ATTTH | IDCAL |     | HYST<br>EREN | AGCE<br>N |
| Type  |    |    | R/W         | R/W             |             |    | W           | R/    | W     | R    | W     | R/    | W     | R/W | R/W          | R/W       |
| Reset |    |    | 0           | 00              |             |    | 0           | 0     | 0     | C    | 0     | 0     | 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

**HYSTEREN** AGC hysteresis function enable

ATTCKSEL attack clock selection

**0**: 16 KHz **1**: 32 KHz

ATTTHDCAL attack threshold calibration release slow clock selection

00: 1000/512 Hz01: 1000/256 Hz10: 1000/128 Hz11: 1000/64 Hz

**FRELCKSEL** release fast clock selection

00: 1000/64 Hz01: 1000/32 Hz10: 1000/16 Hz11: 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.7 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  |    |    |    |    |    |    | AMUT<br>ER | AMUT<br>EL |   | AP | GR |   |   | AP | GL |   |
| Type  |    |    | 4  |    |    |    | R/W        | R/W        |   | R/ | W  |   |   | R/ | W  |   |
| Reset |    |    |    |    |    |    | 0          | 0          |   | 00 | 00 | • |   | 00 | 00 |   |

Set this register for analog PGA gains.

**AMUTER** audio PGA L-channel mute control **AMUTEL** audio PGA R-channel mute control



MEDIATEK \_

APGR audio PGA R-channel gain control audio PGA L-channel gain control

### 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  |    |    |    |    | ARCO<br>N | AE | BUFSE | LR | AE | BUFSE | LL |   |   | ACALI |     |
| 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

L-channel OUT buffer block

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  |    |    |    |    |    | C  |     | AC  | NR  |   |   | APDN<br>_BIAS | DAC |     | APDN<br>_OUT<br>R | APDN<br>_OUT<br>L |
| Type  |    |    |    |    |    |    | R/W |     |     |   |   |               | R/W | R/W | R/W               | R/W               |
| Reset |    |    |    |    |    |    |     | 000 | 000 |   |   | 0             | 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 OUTL** 

APDN\_DACR
APDN\_DACL
APDN\_OUTR

R-channel DAC block
L-channel DAC block
R-channel OUT buffer block



#### 12.2.8 Reserved

Some registers are reserved for further extensions.

### MIXED+0800h Reserved 0 Analog Circuit Control Register 0

RESO\_AC\_CON

0

| 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   |

### MIXED+0804h Reserved 0 Analog Circuit Control Register 1

RESO\_AC\_CON

4

| 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   |

## MIXED+0900h Reserved 1 Analog Circuit Control Register 0

RES1\_AC\_CON

n

| 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   |

### MIXED+0904h Reserved 1 Analog Circuit Control Register 1

RES1\_AC\_CON

.

| D: .  | 4-  | 4.4 | 40  | 40  | 4.4 | 4.0 | 0.4 |     |     | _   |     |     | _   | _   | 4   |     |
|-------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Bit   | 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | /   | 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   |

### MIXED+0A00h Reserved 2 Analog Circuit Control Register 0

RES2\_AC\_CON

0

| 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   |

## MIXED+0A04h Reserved 2 Analog Circuit Control Register 1

**RES2 AC CON** 

1

| 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   |



### MIXED+0B00h Reserved 3 Analog Circuit Control Register 0

RES3 AC CON

| Bit  | 15    | 14    | 13    | 12    | 11    | 10  | 9   | 8   | 7   | 6   | 5   | 4     | 3       | 2    | 1_  | 0   |
|------|-------|-------|-------|-------|-------|-----|-----|-----|-----|-----|-----|-------|---------|------|-----|-----|
| Name |       |       |       |       |       |     |     |     |     |     |     |       |         |      |     |     |
| -    | D 444 | D 447 | D 444 | D 444 | D 447 |     |     |     |     |     |     | D 447 | 5 4 4 7 | 5000 |     |     |
| 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 |

## MIXED+0B04h Reserved 3 Analog Circuit Control Register 1

**RES3 AC CON** 

| 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   |

# MIXED+0C00h Reserved 4 Analog Circuit Control Register Q

RES4\_AC\_CON

| 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   |

## MIXED+0C04h Reserved 4 Analog Circuit Control Register 1 RES4\_AC\_CON1

| 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,7 | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

### MIXED+0D00h Reserved 5 Analog Circuit Control Register 0 RES5\_AC\_CON0

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

### MIXED+0D04h Reserved 5 Analog Circuit Control Register 1 RES5\_AC\_CON1

| Bit   | 15  | 14  | 13  | 12  | _11_     | 10  | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|-----|-----|-----|-----|----------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| 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   | $\Box_0$ | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

### MIXED+0E00h Reserved 6 Analog Circuit Control Register 0

RES6\_AC\_CON0

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

600/616



### MIXED+0E04h Reserved 6 Analog Circuit Control Register 1

### **RES6 AC CON1**

| 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   |

#### MIXED+0F00h Reserved 7 Analog Circuit Control Register 0

#### **RES7 AC CON0**

| 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   |

### MIXED+0F04h Reserved 7 Analog Circuit Control Register 1

#### **RES7 AC CON1**

| 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 5 | 0   | 0   | 0   | 0   | 0   |

## 12.3 Programming Guide

### 12.3.1 BBRX Register Setup

The register used to control analog base-band receiver is BBRX\_AC\_CON.

### 12.3.1.1 Programmable Biasing Current

To maximize the yield in modern digital process, the receiver features providing 5-bit 32-level programmable current to bias internal analog blocks. The 5-bits registers **CALBIAS** [4:0] is coded with 2's complement format.

#### 12.3.1.2 Offset / Gain Calibration

The base-band downlink receiver (RX), together with the base-band uplink transmitter (TX) introduced in the next section, provides necessary analog hardware for DSP algorithm to correct the mismatch and offset error. The connection for measurement of both RX/TX mismatch and gain error is shown in **Figure** 75, and the corresponding calibration procedure is described below.





Figure 75 Base-band A/D and D/A Offset and Gain Calibration

#### 12.3.1.3 Downlink RX Offset Error Calibration

The RX offset measurement is achieved by selecting grounded input to A/D converter (set ISEL [1:0] ='11' and QSEL [1:0] ='11' to select channel 3 of the analog input multiplexer, as shown in **Figure** 76. The output of the ADC is sent to DSP for further offset cancellation. The offset cancellation accuracy depends on the number of samples being converted. That is, more accurate measurement can be obtained by collecting more samples followed by averaging algorithm.



Figure 76 Downlink ADC Offset Error Measurement

#### 12.3.1.4 Downlink RX and Uplink TX Gain Error Calibration

To measure the gain mismatch error, both I/Q uplink TXs should be programmed to produce full-scale pure sinusoidal waves output. Such signals are then fed to downlink RX for A/D conversion, in the following two steps.



- A. The uplink I-channel output are connected to the downlink I-channel input, and the uplink Q-channel output are connected to the downlink Q-channel input. This can be achieved by setting ISEL [1:0] = '01' and QSEL [1:0] = '01' (shown in **Figure** 77 (A))...
- B. The uplink I-channel output are then connected to the downlink Q-channel input, and the uplink Q-channel output are connected to the downlink I-channel input. This can be achieved by setting ISEL [1:0] = '10' and QSEL [1:0] = '10' (shown in **Figure** 77 (B)).



**Figure** 77 Downlink RX and Up-link TX Gain Mismatch Measurement (A) I/Q TX connect to I/Q RX (B) I/Q TX connect to Q/I RX

Once above successive procedures are completed, RX/TX gain mismatch could be easily obtained because the amplitude mismatch on RX digitized result in step A and B is the sum and difference of RX and TX gain mismatch, respectively.

The gain error of the downlink RX can be corrected in the DSP section and the uplink TX gain error can be corrected by the gain trimming facility that TX block provide.

#### 12.3.1.5 Uplink TX Offset Error Calibration

Once the offset of the downlink RX is known and corrected, the offset of the uplink TX alone could be easily estimated. The offset error of TX should be corrected in the digital domain by means of the programmable feature of the digital GMSK modulator.

Finally, it is important that above three calibration procedures should be exercised in order, that is, correct the RX offset first, then RX/TX gain mismatch, and finally TX offset. This is owing to that analog gain calibration in TX will affect its offset, while the digital offset correction has no effect on gain.

## 12.3.2 BBTX Register Setup

The register used to control analog base-band transmitter is BBTX\_AC\_CON0 and BBTX\_AC\_CON1.



#### 12.3.2.1 Output Gain Control

The output swing of the uplink transmitter is controlled by register GAIN [2:0] coded in 2's complement with about 2dB step. When TRIMI [3:0] / TRIMQ [3:0] = 0 the swing is listed in **Table** 82, defined to be the difference between positive and negative output signal.

| GAIN [2:0] | Output Swing          | For AVDD=2.8 (V) |
|------------|-----------------------|------------------|
| +3 (011)   | AVDD*0.900 (+6.02 dB) | 2.52             |
| +2 (010)   | AVDD*0.720 (+4.08 dB) | 2.02             |
| +1 (001)   | AVDD*0.576 (+2.14 dB) | 1.61             |
| +0 (000)   | AVDD*0.450 (+0.00 dB) | 1.26             |
| -1 (111)   | AVDD*0.360 (-1.94 dB) | 1                |
| -2 (110)   | AVDD*0.288 (-3.88 dB) | 0.81             |
| -3 (101)   | AVDD*0.225 (-6.02 dB) | 0.63             |
| -4 (100)   | AVDD*0.180 (-7.95 dB) | 0.5              |

**Table** 82 Output Swing Control Table

### 12.3.2.2 Output Gain Trimming

I/Q channels can also be trimmed separately to compensate gain mismatch in the base-band transmitter or the whole transmission path including RF module. The gain trimming is adjusted in 16 steps spread from –1.18dB to +1.18dB (**Table** 83), compared to the full-scale range set by GAIN [2:0].

| TRIMI [3:0] / TRIMQ [3:0] | Gain Step (dB) |
|---------------------------|----------------|
| +7 (0111)                 | 1.18           |
| +6 (0110)                 | 1.00           |
| +5 (0101)                 | 0.83           |
| +4 (0100)                 | 0.66           |
| +3 (0011)                 | 0.49           |
| +2 (0010)                 | 0.32           |
| +1 (0001)                 | 0.16           |
| +0 (0000)                 | 0.00           |
| -1 (1111)                 | -0.16          |
| -2 (1110)                 | -0.31          |
| -3 (1101)                 | -0.46          |
| -4 (1100)                 | -0.61          |
| -5 (1011)                 | -0.75          |
| -6 (1010)                 | -0.90          |
| -7 (1001)                 | -1.04          |



| -8 (1000) | -1.18 |
|-----------|-------|

Table 83 Gain Trimming Control Table

### 12.3.2.3 Output Common-Mode Voltage

The output common-mode voltage is controlled by CMV [2:0] with about 0.08\*AVDD step, as listed in the following table.

| CMV [2:0] | Common-Mode Voltage |
|-----------|---------------------|
| +3 (011)  | AVDD*0.62           |
| +2 (010)  | AVDD*0.58           |
| +1 (001)  | AVDD*0.54           |
| +0 (000)  | AVDD*0.50           |
| -1 (111)  | AVDD*0.46           |
| -2 (110)  | AVDD*0.42           |
| -3 (101)  | AVDD*0.38           |
| -4 (100)  | AVDD*0.34           |

Table 84 Output Common-Mode Voltage Control Table

### 12.3.2.4 Programmable Biasing Current

The transmitter features providing 5-bit 32-level programmable current to bias internal analog blocks. The 5-bits registers CALBIAS [4:0] is coded with 2's complement format.

### 12.3.2.5 Smoothing Filter Characteristic

The 2<sup>nd</sup> –order Butterworth smoothing filter is used to suppress the image at DAC output: it provides more than 40dB attenuation at the 4.44MHz sampling frequency. To tackle with the digital process component variation, programmable cutoff frequency control bits CALRCSEL [2:0] are included. User can directly change the filter cut-off frequency by different CALRCSEL value (coded with 2's complement format and with a default value 0). In addition, an internal calibration process is provided, by setting START CALRC to high and CALRCCNT to an appropriate value (default is 11). After the calibration process, the filter cut-off frequency is calibrated to 350kHz +/- 50 kHz and a new CALRCOUT value is stored in the register. During the calibration process, the output of the cell is high-impedance.

### 12.3.3 AFC-DAC Register Setup

The register used to control the APC DAC is AFC\_AC\_CON, which providing 5-bit 32-level programmable current to bias internal analog blocks. The 5-bits registers CALI [4:0] is coded with 2's complement format.

## 12.3.4 APC-DAC Register Setup

The register used to control the APC DAC is AFC\_AC\_CON, which providing 5-bit 32-level programmable current to bias internal analog blocks. The 5-bits registers CALI [4:0] is coded with 2's complement format.

## 12.3.5 Auxiliary A/D Conversion Register Setup

The register used to control the Aux-ADC is AUX\_AC\_CON. For this register, which providing 5-bit 32-level



programmable current to bias internal analog blocks. The 5-bits registers CALI [4:0] is coded with 2's complement format.

### 12.3.6 Voice-band Blocks Register Setup

The registers used to control AMB are AFE\_VAG\_CON, AFE\_VAC\_CON0, AFE\_VAC\_CON1, and AFE\_VAPDN\_CON For these registers, please refer to chapter "Analog Chip Interface"

#### 12.3.6.1 Reference Circuit

The voice-band blocks include internal bias circuits, a differential bandgap voltage reference circuit and a differential microphone bias circuit. Internal bias current could be calibrated by varying VCALI[4:0] (coded with 2's complement format).

The differential bandgap circuit generates a low temperature dependent voltage for internal use. For proper operation, there should be an external 47nF capacitor connected between differential output pins AU\_VREFP and AU\_VREFN. The bandgap voltage (~1.24V<sup>7</sup>, typical) also defines the dBm0 reference level through out the audio mixed-signal blocks. The following table illustrates typical 0dBm0 voltage when uplink/downlink programmable gains are unity. For other gain setting, 0dBm0 reference level should be scaled accordingly.

| Symbol                             | Parameter                                                                                                                | Min | Typical | Max | Unit  |
|------------------------------------|--------------------------------------------------------------------------------------------------------------------------|-----|---------|-----|-------|
| V <sub>0dBm0</sub> , <sub>UP</sub> | 0dBm0 Voltage for Uplink Path, Applied<br>Differentially Between Positive and<br>Negative Microphone Input Pins          |     | 0.2V    |     | V-rms |
| $V_{0dBm0,Dn}$                     | 0dBm0 voltage for Downlink Path,<br>Appeared Differentially Between Positive<br>and Negative Power Amplifier Output Pins |     | 0.6V    |     | V-rms |

Table 85 0dBm0 reference level for unity uplink/downlink gain

The microphone bias circuit generates a differential output voltage between AU\_MICBIAS\_P and AU\_MICBIAS\_N for external electret type microphone. Typical output voltage is 1.9 V. In singled-ended mode, by set VCFG[3] =1, AU\_MICBIAS\_N is pull down while output voltage is present on AU\_MICBIAS\_P, respect to ground. The max current supplied by microphone bias circuit is 2mA.

#### 12.3.6.2 Uplink Path

Uplink path of voice-band blocks includes an uplink programmable gain amplifier and a sigma-delta modulator.

#### 12.3.6.2.1 Uplink Programmable Gain Amplifier

Input to the PGA is a multiplexer controlled by VCFG [3:0], as described in the following table. In normal operation, both input AC and DC coupling are feasible for attenuation the input signal (gain <= 0dB). However, only AC coupling is suggested if amplification of input signal is desired (gain>=0dB).

| Cont | rol | Function | Descriptions |
|------|-----|----------|--------------|

<sup>&</sup>lt;sup>7</sup> The bandgap voltage could be calibrated by adjusting control signal VBG\_CTRL[1:0]. Its default value is [00]. VBG\_CTRL not only adjust the bandgap voltage but also vary its temperature dependence. Optimal value of VBG\_CTRL is to be determined.



| Signal   |                       |                                                                                                                        |
|----------|-----------------------|------------------------------------------------------------------------------------------------------------------------|
| VCFG [0] | Input Selector        | 0: Input 0 (From AU_VIN0_P / AU_VIN0_N) Is Selected                                                                    |
|          |                       | 1: Input 1 (From AU_VIN1_P / AU_VIN1_N) Is Selected                                                                    |
| VCFG [1] | Coupling Mode         | 0: AC Coupling                                                                                                         |
|          |                       | 1: DC Coupling                                                                                                         |
| VCFG [2] | Gain Mode             | 0: Amplification Mode (gain >= 0 dB)                                                                                   |
|          |                       | 1: Attenuation Mode (gain <= 0dB)                                                                                      |
| VCFG [3] | Microphone<br>Biasing | 0: Differential Biasing (Take Bias Voltage Between AU_MICBIAS_P and AU_MICBIAS_N)                                      |
|          |                       | 1: Signal-Ended Biasing (Take Bias Voltage From AU_MICBIAS_P Respected to Ground. AU_MICBIAS_N Is Connected to Ground) |

Table 86 Uplink PGA input configuration setting

The PGA itself provides programmable gain (through VUPG [3:0]) with step of 3dB, as listed in the following table.

| VCFG [2] ='0' |      | VCFG [2] ='1' |       |
|---------------|------|---------------|-------|
| VUPG [3:0]    | Gain | VUPG [3:0]    | Gain  |
| 1111          | NA   | X111          | -21dB |
| 1110          | 42dB | X110          | -18dB |
| 1101          | 39dB | X101          | -15dB |
| 1100          | 36dB | X100          | -12dB |
| 1011          | 33dB | X011          | -9dB  |
| 1010          | 30dB | X010          | -6dB  |
| 1001          | 27dB | X001          | -3dB  |
| 1000          | 24dB | X000          | 0dB   |
| 0111          | 21dB |               |       |
| 0110          | 18dB |               |       |
| 0101          | 15dB |               |       |
| 0100          | 12dB |               |       |
| 0011          | 9dB  |               |       |
| 0010          | 6dB  |               |       |
| 0001          | 3dB  |               |       |
| 0000          | 0dB  |               |       |

Table 87 Uplink PGA gain setting (VUPG [3:0])

The following table illustrates typically the 0dBm0 voltage applied at the microphone inputs, differentially, for several gain settings.

| VCFG [2] ='0' |               | VCFG [2] ='1' |               |  |  |
|---------------|---------------|---------------|---------------|--|--|
| VUPG [3:0]    | 0dBm0 (V-rms) | VUPG [3:0]    | 0dBm0 (V-rms) |  |  |
| 1100          | 3.17mV        | X110          | 1.59V         |  |  |
| 1000          | 12.6mV        | X100          | 0.8V          |  |  |



| 0100 | 50.2mV | X010 | 0.4V |
|------|--------|------|------|
| 0000 | 0.2V   | X000 | 0.2V |

**Table 88** 0dBm0 voltage at microphone input pins

#### 12.3.6.2.2 Sigma-Delta Modulator

Analog-to-digital conversion in uplink path is made with a second-order sigma-delta modulator (SDM) whose sampling rate is 4096kHz. Output signals are coded in either one-bit or RSD format, optionally controlled by VRSDON register.

For test purpose, one can set VADCINMODE to HI to form a look-back path from downlink DAC output to SDM input. The default value of VADCINMODE is zero.

#### 12.3.6.3 Downlink Path

Downlink path of voice-band blocks includes a digital to analog converter (DAC) and two programmable output power amplifiers.

#### 12.3.6.3.1 Digital to Analog Converter

The DAC converts input bit-stream to analog signal by sampling rate of 4096kHz. Besides, it performs a  $2^{nd}$ -order 40kHz butterworth filtering. The DAC receives input signals from MT6228 DSP by set VDACINMODE = 0. It can also take inputs from SDM output by setting VDACINMODE = 1.

#### 12.3.6.3.2 Downlink Programmable Power Amplifier

Voice-band analog blocks include two identical output power amplifiers with programmable gain. Amplifier 0 and amplifier 1 can be configured to either differential or single-ended mode by adjusting VDSEND [0] and VDSEND [1], respectively. In single-ended mode, when VDSEND[0] =1, output signal is present at AU\_VOUT0\_P pin respect to ground. Same as VDSEND[1] for AU\_VOUT1\_P pin.

For the amplifier itself, programmable gain setting is described in the following table.

| 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 |

Table 89 Downlink power amplifier gain setting

Control signal VFLOAT, when set to 'HI', is used to make output nodes totally floating in power down mode. If VFLOAT is set to 'LOW" in power down mode, there will be a resistor of 50k ohm (typical) between AU\_VOUTO\_P and AU\_VOUTO\_N, as well as between AU\_VOUTO\_P and AU\_VOUTO\_N.

The amplifiers deliver signal power to drive external earphone. The minimum resistive load is 28 ohm and the upper limit of the output current is 50mA. On the basis that 3.14dBm0 digital input signal into downlink path produces DAC output differential voltage of 0.87V-rms (typical), the following table illustrates the power amplifier output signal level (in V-rms) and signal power for an external 32 ohm resistive load.

| VDPG | Output Signal<br>Level (V-rms) | Output Signal Power (mW / dBm) |
|------|--------------------------------|--------------------------------|
| 0010 | 0.11                           | 0.37/-4.3                      |
| 0110 | 0.27                           | 2.28/3.6                       |
| 1010 | 0.69                           | 14.8/11.7                      |
| 1110 | 1.74                           | 94.6/19.8                      |

**Table 90** Output signal level/power for 3.14dBm0 input. External resistive load = 32 ohm

The following table illustrates the output signal level and power for different resistive load when VDPG =1110.

| RLOAD |      | Output Signal Power (mW / dBm) |
|-------|------|--------------------------------|
| 30    | 1.74 | 101/20                         |
| 100   | 1.74 | 30.3/14.8                      |
| 600   | 1.74 | 5/7                            |

**Table 91** Output signal level/power for 3.14dBm0 input, VDPG =1110

#### 12.3.6.4 Power Down Control

Each block inside audio mixed-signal blocks features dedicated power-down control, as illustrated in the following table.

| Control<br>Signal | Descriptions                                 |
|-------------------|----------------------------------------------|
| VPDN_BIAS         | Power Down Reference Circuits (Active Low)   |
| VPDN_LNA          | Power Down Uplink PGA (Active Low)           |
| VPDN_ADC          | Power Down Uplink SDM (Active Low)           |
| VPDN_DAC          | Power Down DAC (Active Low)                  |
| VPDN_OUT0         | Power Down Downlink Power Amp 0 (Active Low) |
| VPDN_OUT1         | Power Down Downlink Power Amp 1 (Active Low) |



Table 92 Voice-band blocks power down control

### 12.3.7 Audio-band Blocks Register Setup

The registers used to control audio blocks are AFE\_AAG\_CON, AFE\_AAC\_CON, and AFE\_AAPDN\_CON. For these registers, please refer to chapter "Analog Chip Interface"

#### 12.3.7.1 Output Gain Control

Audio blocks include stereo audio DACs and programmable output power amplifiers. The DACs convert input bit-stream to analog signal by sampling rate of Fs\*128 where Fs could be 32kHz, 44.1kHz, or 48kHz. Besides, it performs a 2<sup>nd</sup>-order butterworth filtering. The two identical output power amplifiers with programmable gain are designed to driving external AC-coupled single-end speaker. The minimum resistor load is 16 ohm and the maximum driving current is 50mA. The programmable gain setting, controlled by APGR[] and APGL[], is the same as that of the voice-band amplifiers.

Unlike voice signals, 0dBFS defines the full-scale audio signals amplitude. Based on bandgap reference voltage again, the following table illustrates the power amplifier output signal level (in V-rms) and signal power for an external 16 ohm resistive load.

| APGR[]/<br>APGL[] | Output Signal<br>Level (V-rms) | Output Signal Power (mW / dBm) |
|-------------------|--------------------------------|--------------------------------|
| 0010              | 0.055                          | 0.19/-7.2                      |
| 0110              | 0.135                          | 1.14/0.6                       |
| 1010              | 0.345                          | 7.44/8.7                       |
| 1110              | 0.87                           | 47.3/16.7                      |

Table 93 Output signal level/power for 0dBFS input. External resistive load = 16 ohm

#### 12.3.7.2 Mute Function and Power Down Control

By setting AMUTER (AMUTEL) to high, right (Left) channel output will be muted.

Each block inside audio mixed-signal blocks features dedicated power-down control, as illustrated in the following table.

| Control Signal | Descriptions                                      |
|----------------|---------------------------------------------------|
| APDN_BIAS      | Power Down Reference Circuits (Active Low)        |
| APDN_DACL      | Power Down L-Channel DAC (Active Low)             |
| APDN_DACR      | Power Down R-Channel DAC (Active Low)             |
| APDN_OUTL      | Power Down L-Channel Audio Amplifier (Active Low) |
| APDN_OUTR      | Power Down R-Channel Audio Amplifier (Active Low) |

Table 94 Audio-band blocks power down control

### 12.3.8 Multiplexers for Audio and Voice Amplifiers

The audio/voice amplifiers feature accepting signals from various signal sources including AU\_FMINR/AU\_FMINL pins, that aimed to receive stereo AM/FM signal from external radio chip:

1) Voice-band amplifier 0 accepts signals from voice DAC output only.



- 2) Voice-band amplifier 1 accepts signal from either voice DAC, audio DAC, or AM/FM radio input pins (controlled by register VBUF1SEL[]). For the last two cases, left and right channel signals will be summed together to form a mono signal first.
- 3) Audio left/right channel amplifiers receive signals from either voice DAC, audio DAC, or AM/FM radio input pins (controlled by registers ABUFSELL[] and ABUFSELR[]), too. Left and right channel amplifiers will produce identical output waveforms when receiving mono signals from voice DAC.

### 12.3.9 Clock Squarer Register Setup

The register used to control clock squarer is CLK CON. For this register, please refer to chapter "Clocks"

CLKSQ\_PLD is used to bypass the clock squarer.

### 12.3.10 Phase-Locked Loop Register Setup

For registers control the PLL, please refer to chapter "Clocks" and "Software Power Down Control"

#### 12.3.10.1 Frequency Setup

The DSP/MCU PLL itself could be programmable to output either 52MHz or 78MHz clocks. Accompanied with additional digital dividers, 13/26/39/52/65/78 MHz clock outputs are supported.

### 12.3.10.2 Programmable Biasing Current

The PLLs feature providing 5-bit 32-level programmable current to bias internal analog blocks. The 5-bits registers CALI [4:0] is coded with 2's complement format.

### 12.3.11 32-khz Crystal Oscillator Register Setup

For registers that control the oscillator, please refer to chapter "Real Time Clock" and "Software Power Down Control".

XOSCCALI[4:0] is the calibration control registers of the bias current, and is coded with 2's complement format.

<sup>1</sup> CL is the parallel combination of C1 and C2 in the block diagram.





# 13 Digital Pin Electrical Characteristics

- Based on I/O power supply (VDD33) = 3.3 V
- Vil (max) = 0.8 V
- Vih (min) = 2.0 V

| Ball  | Name         | Dir | Driving Iol &  | Vol at Iol Max | Voh at Ioh Min | PU/PD I  | Resistor | ~        | Pull     | Cin      |
|-------|--------------|-----|----------------|----------------|----------------|----------|----------|----------|----------|----------|
| 13x13 |              |     | Ioh Typ (mA)   | (V)            | (V)            | Min      | Тур      | Max      |          | (pF)     |
|       |              |     | JTAG Port      |                |                |          |          | W -      |          |          |
| E4    | JTRST#       | I   |                |                |                | 40K      | 75K      | 190K     | PD       | 2        |
| F5    | JTCK         | I   |                |                |                | 40K      | 75K      | 190K     | PU       | 2        |
| F4    | JTDI         | I   |                |                |                | 40K      | 75K      | 190K     | PU       | 2        |
| F3    | JTMS         | I   |                |                |                | 40K      | 75K      | 190K     | PU       | 2        |
| F2    | JTDO         | О   | 4              | 0.4            | 2.4            |          |          |          |          |          |
| F1    | JRTCK        | О   | 4              | 0.4            | 2.4            |          |          |          |          |          |
|       |              |     | RF Parallel Co | ntrol Unit     |                | 7        | 7        |          |          |          |
| G5    | BPI_BUS0     | О   | 2/8            | 0.4            | 2.4            |          |          |          |          |          |
| G4    | BPI_BUS1     | О   | 2/8            | 0.4            | 2.4            |          |          |          |          |          |
| G3    | BPI_BUS2     | О   | 2/8            | 0.4            | 2.4            |          |          |          |          |          |
| G1    | BPI_BUS3     | О   | 2/8            | 0.4            | 2.4            |          |          |          |          |          |
| J6    | BPI_BUS4     | О   | 2              | 0.4            | 2.4            |          |          |          |          |          |
| H5    | BPI_BUS5     | О   | 2              | 0.4            | 2.4            |          |          |          |          |          |
| H4    | BPI_BUS6     | IO  | 2              | 0.4            | 2.4            | 40K      | 75K      | 190K     | PD       | 2        |
| НЗ    | BPI_BUS7     | IO  | 2              | 0.4            | 2.4            | 40K      | 75K      | 190K     | PD       | 2        |
| H2    | BPI_BUS8     | IO  | 2              | 0.4            | 2.4            | 40K      | 75K      | 190K     | PD       | 2        |
| J5    | BPI_BUS9     | IO  | 2              | 0.4            | 2.4            | 40K      | 75K      | 190K     | PD       | 2        |
|       | <del>!</del> |     | RF Serial Cont | rol Unit       |                | <u>.</u> |          | -        | -        | -        |
| J4    | BSI_CS0      | О   | 2              | 0.4            | 2.4            |          |          |          |          |          |
| J3    | BSI_DATA     | О   | 2              | 0.4            | 2.4            |          |          |          |          |          |
| J2    | BSI_CLK      | О   | 2              | 0.4            | 2.4            |          |          |          |          |          |
|       | <del>'</del> |     | PWM Interface  | e              | -              | <u> </u> | •        | <u> </u> | <u> </u> | <u> </u> |
| R4    | PWM1         | IO  | 2              | 0.4            | 2.4            | 40K      | 75K      | 190K     | PD       | 2        |
| R3    | PWM2         | IO  | 2              | 0.4            | 2.4            | 40K      | 75K      | 190K     | PD       | 2        |
| R2    | ALERTER      | IO  | 2              | 0.4            | 2.4            | 40K      | 75K      | 190K     | PD       | 2        |
|       |              |     | Serial LCD/PM  | I IC Interface |                |          |          |          |          |          |
| J1    | LSCK         | IO  | 2/4/6/8        | 0.4            | 2.4            | 40K      | 75K      | 190K     | PU       | 2        |
| K5    | LSA0         | IO  | 2/4/6/8        | 0.4            | 2.4            | 40K      | 75K      | 190K     | PU       | 2        |
| K4    | LSDA         | IO  | 2/4/6/8        | 0.4            | 2.4            | 40K      | 75K      | 190K     | PU       | 2        |
| K3    | LSCE0#       | IO  | 2/4/6/8        | 0.4            | 2.4            | 40K      | 75K      | 190K     | PU       | 2        |
| K2    | LSCE1#       | IO  | 2/4/6/8        | 0.4            | 2.4            | 40K      | 75K      | 190K     | PU       | 2        |
|       |              | 4   | Parallel LCD/N |                |                |          |          |          | 1- 0     | <u> </u> |
|       |              |     | Interface      | THE PROPERTY   |                |          |          |          |          |          |
| K6    | LPCE1#       | IO  | 2/4/6/8        | 0.4            | 2.4            | 40K      | 75K      | 190K     | PU       | 2        |
| L5    | LPCE0#       | O   | 2/4/6/8        |                |                |          |          |          |          |          |
| L4    | LRST#        | 0   | 2/4/6/8        |                |                |          |          |          |          |          |
| L3    | LRD#         | O   | 2/4/6/8        |                |                |          |          |          |          |          |



| MEDIATE    | <u> </u>  |    |                |                  |     |              |            |              |          |    |
|------------|-----------|----|----------------|------------------|-----|--------------|------------|--------------|----------|----|
| L2         | LPA0      | О  | 2/4/6/8        |                  |     |              |            |              |          |    |
| L1         | LWR#      | 0  | 2/4/6/8        |                  |     |              |            |              |          |    |
| G7         | NLD17     | Ю  | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| J9         | NLD16     | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| K9         | NLD15     | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| J10        | NLD14     | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| L9         | NDL13     | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| K10        | NLD12     | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| J11        | NLD11     | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| L10        | NLD10     | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| K11        | NLD9      | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| L11        | NLD8      | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| L6         | NLD7      | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| M5         | NLD6      | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| M4         | NLD5      | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| M3         | NLD4      | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| N5         | NLD3      | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| N4         | NLD2      | Ю  | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| N3         | NLD1      | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| N2         | NLD0      | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| N1         | NRNB      | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PU       | 2  |
| P5         | NCLE      | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| P4         | NALE      | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| P3         | NWE#      | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PU       | 2  |
| P2         | NRE#      | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PU       | 2  |
| P1         | NCE#      | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PU       | 2  |
|            | <u> </u>  | _  | SIM Card Inter | ·face            |     |              |            |              | <u>L</u> |    |
| M19        | SIMRST    | О  | 2              | 0.4              | 2.4 |              |            |              |          |    |
| L16        | SIMCLK    | 0  | 2              | 0.4              | 2.4 |              |            |              |          |    |
| L17        | SIMVCC    | 0  | 2              | 0.4              | 2.4 |              |            |              |          |    |
| L18        | SIMSEL    | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| L19        | SIMDATA   | IO | 2              | 0.4              | 2.4 | +01 <b>X</b> | 73IX       | 1701         | I D      | 2  |
| L1)        | SIMDAIA   | 10 | Dedicated GPIO |                  | 2.7 |              |            |              |          |    |
| 112        | CDIO      | 10 |                | , <del>-</del> - | 2.4 | 4017         | 75 V       | 1001/        | DD       | 12 |
| U3         | GPIO0     | IO | 2              | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |
| U1         | GPIO1     | IO | 2              | 0.4              | 2.4 | 40K          | 75K<br>75K | 190K         | PD<br>PU | 2  |
| D17        | GPIO2     | IO | 2 2            | 0.4              | 2.4 | 40K          |            | 190K<br>190K | _        | 2  |
| C19<br>C18 | GPIO3     | IO | 2/4/6/8        | 0.4              | 2.4 | 40K          | 75K        | 190K         | PU       | 2  |
|            | GPIO4     | IO |                |                  |     |              |            |              |          |    |
| C17        | GPIO5     | IO | 2/4/6/8        | 0.4              | 2.4 |              |            |              |          | 2  |
| A19        | GPIO6     | IO | 2/4/6/8        | 0.4              | 2.4 |              |            |              |          | 2  |
| B18        | GPIO7     | IO | 2/4/6/8        | 0.4              | 2.4 |              |            |              |          | 2  |
| A18        | GPIO8     | IO | 4              | 0.4              | 2.4 |              |            |              |          | 2  |
| A17        | GPIO9     | IO | 4              | 0.4              | 2.4 |              |            |              |          | 2  |
|            |           |    | Miscellaneous  |                  |     |              |            |              |          |    |
| T2         | SYSRST#   | I  |                |                  |     |              |            |              |          | 2  |
| R16        | WATCHDOG# | 0  | 4              | 0.4              | 2.4 |              |            |              |          |    |
| T1         | SRCLKENAN | О  | 2              | 0.4              | 2.4 |              |            |              |          |    |
| T4         | SRCLKENA  | О  | 2              | 0.4              | 2.4 |              |            |              |          |    |
| T3         | SRCLKENAI | IO | 2              | 0.4              | 2.4 | 40K          | 75K        | 190K         | PD       | 2  |





| MEDIATE |          |    |                 | 1              | 1        |     |     |      |    | _ |
|---------|----------|----|-----------------|----------------|----------|-----|-----|------|----|---|
| E5      | TESTMODE | I  |                 |                |          | 40K | 75K | 190K | PD | 2 |
| D15     | ESDM_CK  | О  |                 |                |          |     |     |      |    |   |
|         |          |    | Keypad Interfa  | ice            |          |     |     |      |    |   |
| H17     | KCOL6    | I  | 2               |                |          | 40K | 75K | 190K | PU | 2 |
| H18     | KCOL5    | I  | 2               |                |          | 40K | 75K | 190K | PU | 2 |
| H19     | KCOL4    | I  | 2               |                |          | 40K | 75K | 190K | PU | 2 |
| G15     | KCOL3    | I  | 2               |                |          | 40K | 75K | 190K | PU | 2 |
| G16     | KCOL2    | I  | 2               |                |          | 40K | 75K | 190K | PU | 2 |
| G17     | KCOL1    | I  | 2               |                |          | 40K | 75K | 190K | PU | 2 |
| G18     | KCOL0    | I  | 2               |                |          | 40K | 75K | 190K | PU | 2 |
| G19     | KROW5    | О  | 2/8             | 0.4            | 2.4      |     |     |      |    |   |
| F15     | KROW4    | О  | 2/8             | 0.4            | 2.4      |     |     |      |    |   |
| F16     | KROW3    | О  | 2/8             | 0.4            | 2.4      |     |     |      |    |   |
| F17     | KROW2    | О  | 2/8             | 0.4            | 2.4      |     |     |      |    |   |
| E16     | KROW1    | О  | 2               | 0.4            | 2.4      |     |     |      |    |   |
| E17     | KROW0    | 0  | 2               | 0.4            | 2.4      |     |     |      |    |   |
|         |          |    | External Intern | rupt Interface |          |     |     |      |    |   |
| U2      | EINT0    | I  |                 |                |          | 40K | 75K | 190K | PU | 2 |
| V1      | EINT1    | I  |                 |                |          | 40K | 75K | 190K | PU | 2 |
| W1      | EINT2    | I  |                 |                |          | 40K | 75K | 190K | PU | 2 |
| V2      | EINT3    | I  |                 |                |          | 40K | 75K | 190K | PU | 2 |
| U4      | MIRQ     | I  | 4               | 0.4            | 2.4      | 40K | 75K | 190K | PU | 2 |
| B17     | MFIQ     | I  | 2/4/6/8         | 0.4            | 2.4      | 40K | 75K | 190K | PU | 2 |
|         |          |    | External Memo   | ory Interface  |          |     |     |      |    |   |
| R15     | ED0      | IO | 2~32            | 0.4            | 2.4      |     |     |      |    | 2 |
| T19     | ED1      | IO | 2~32            | 0.4            | 2.4      |     |     |      |    | 2 |
| T18     | ED2      | IO | 2~32            | 0.4            | 2.4      |     |     |      |    | 2 |
| U19     | ED3      | IO | 2~32            | 0.4            | 2.4      |     |     |      |    | 2 |
| U18     | ED4      | IO | 2~32            | 0.4            | 2.4      |     |     |      |    | 2 |
| V19     | ED5      | IO | 2~32            | 0.4            | 2.4      |     |     |      |    | 2 |
| W19     | ED6      | IO | 2~32            | 0.4            | 2.4      |     |     |      |    | 2 |
| W18     | ED7      | IO | 2~32            | 0.4            | 2.4      |     |     |      |    | 2 |
| U17     | ED8      | IO | 2~32            | 0.4            | 2.4      |     |     |      |    | 2 |
| W17     | ED9      | IO | 2~32            | 0.4            | 2.4      |     |     |      |    | 2 |
| T16     | ED10     | IO | 2~32            | 0.4            | 2.4      |     |     |      |    | 2 |
| U16     | ED11     | IO | 2~32            | 0.4            | 2.4      |     |     |      |    | 2 |
| V16     | ED12     | IO | 2~32            | 0.4            | 2.4      |     |     |      |    | 2 |
| T15     | ED13     | IO | 2~32            | 0.4            | 2.4      |     |     |      |    | 2 |
| U15     | ED14     | IO | 2~32            | 0.4            | 2.4      |     |     |      |    | 2 |
| W15     | ED15     | IO | 2~32            | 0.4            | 2.4      |     |     |      |    | 2 |
| P12     | ERD#     | 0  | 2~32            | 0.4            | 2.4      |     |     |      |    |   |
| T12     | EWR#     | О  | 2~32            | 0.4            | 2.4      |     |     |      |    |   |
| U12     | ECS0#    | О  | 2~32            | 0.4            | 2.4      |     |     |      |    |   |
| V12     | ECS1#    | О  | 2~32            | 0.4            | 2.4      |     |     |      |    |   |
| P11     | ECS2#    | 0  | 2~32            | 0.4            | 2.4      |     |     |      |    |   |
| R11     | ECS3#    | 0  | 2~32            | 0.4            | 2.4      |     |     |      |    |   |
| R14     | EWAIT    | 0  | 2~32            |                |          | 40K | 75K | 190K | PU |   |
| T14     | ECAS#    | 0  | 2~32            | 0.4            | 2.4      |     |     |      |    |   |
| W14     | ERAS#    | 0  | 2~32            | 0.4            | 2.4      |     |     |      |    |   |
|         |          | 1  | 1               | 1              | <u> </u> |     | 1   | 1    | 1  | 1 |



| MEDIATE | <b>.</b> |    |              |         |                |      |           |       |       |    |
|---------|----------|----|--------------|---------|----------------|------|-----------|-------|-------|----|
| R13     | ECKE     | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| T13     | EDCLK    | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       | 76 |
| V13     | ELB#     | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| W13     | EUB#     | 0  | 2~32         | 0.4     | 2.4            |      |           |       | A (   |    |
| T11     | EPDN#    | 0  | 10           | 0.4     | 2.4            |      |           |       |       |    |
| W11     | EADV#    | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| V11     | ECLK     | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| P10     | EA0      | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| T10     | EA1      | 0  | 2~32         | 0.4     | 2.4            |      |           | 4     |       |    |
| U10     | EA2      | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| W10     | EA3      | 0  | 2~32         | 0.4     | 2.4            |      | 4         |       |       |    |
| R9      | EA4      | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| T9      | EA5      | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| U9      | EA6      | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| V9      | EA7      | О  | 2~32         | 0.4     | 2.4            |      | V         |       |       |    |
| R8      | EA8      | О  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| T8      | EA9      | О  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| W8      | EA10     | 0  | 2~32         | 0.4     | 2.4            | 70   | 7         |       |       |    |
| P8      | EA11     | О  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| R7      | EA12     | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| U7      | EA13     | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| V7      | EA14     | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| W7      | EA15     | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| Т6      | EA16     | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| U6      | EA17     | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| W6      | EA18     | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| R5      | EA19     | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| T5      | EA20     | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| U5      | EA21     | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| V5      | EA22     | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| W4      | EA23     | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| V4      | EA24     | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
| W3      | EA25     | 0  | 2~32         | 0.4     | 2.4            |      |           |       |       |    |
|         |          |    |              |         |                |      |           |       |       |    |
| P17     | MCCM0    | IO | 2/4/6/8      | 0.4     | 2.4            | 40K  | 75K       | 190K  | PU/PD | 2  |
| P18     | MCDA0    | IO | 2/4/6/8      | 0.4     | 2.4            | 40K  | 75K       | 190K  | PU/PD | 2  |
| P19     | MCDA1    | IO | 2/4/6/8      | 0.4     | 2.4            | 40K  | 75K       | 190K  | PU/PD | 2  |
| N17     | MCDA2    | IO | 2/4/6/8      | 0.4     | 2.4            | 40K  | 75K       | 190K  | PU/PD | 2  |
| N18     | MCDA3    | IO | 2/4/6/8      | 0.4     | 2.4            | 40K  | 75K       | 190K  | PU/PD | 2  |
| M18     | MCCK     | О  | 2/4/6/8      | 0.4     | 2.4            |      |           |       |       |    |
| N19     | MCPWRON  | 0  | 2            | 0.4     | 2.4            |      |           |       |       |    |
| M16     | MCWP     | I  | 2            |         |                | 40K  | 75K       | 190K  | PU/PD | 2  |
| M17     | MCINS    | I  | 2            |         |                | 40K  | 75K       | 190K  | PU/PD | 2  |
|         | 4        | -  | UART/IrDA In | terface | <u> </u>       |      |           | -     | -     |    |
| K15     | URXD1    | I  | 2/4/6/8      |         |                | 40K  | 75K       | 190K  | PU    | 2  |
| K16     | UTXD1    | O  | 2/4/6/8      | 0.4     | 2.4            |      | ,,,,,,    | 1,011 |       | _  |
| K17     | UCTS1    | I  | 2/4/6/8      |         |                | 40K  | 75K       | 190K  | PU    | 2  |
| K17     | URTS1    | 0  | 2/4/6/8      | 0.4     | 2.4            | 1011 | /311      | 1701  |       |    |
| K19     | URXD2    | Ю  | 2/4/6/8      | 0.4     | 2.4            | 40K  | 75K       | 190K  | PU    | 2  |
| 13.17   | OIMID2   | 10 | 2171010      | U.T     | _ <del> </del> | 1017 | / / / / / | 1701  | 110   | -  |



| M        |
|----------|
| MEDIATEK |

| III.LDIAT.LI | •         |    |                         |     |     |     |     |      |    |   |
|--------------|-----------|----|-------------------------|-----|-----|-----|-----|------|----|---|
| J15          | UTXD2     | IO | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PU | 2 |
| J16          | URXD3     | IO | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PU | 2 |
| J17          | UTXD3     | IO | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PU | 2 |
| J19          | IRDA_RXD  | IO | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PU | 2 |
| H15          | IRDA_TXD  | IO | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PU | 2 |
| H16          | IRDA_PDN  | IO | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PU | 2 |
|              |           |    | Digital Audio Interface |     |     |     |     |      |    |   |
| E18          | DAICLK    | IO | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PU | 2 |
| E19          | DAIPCMOUT | IO | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PD | 2 |
| D16          | DAIPCMIN  | IO | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PU | 2 |
| D19          | DAIRST    | IO | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PU | 2 |
| D18          | DAISYNC   | IO | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PU | 2 |
|              | •         | -  | CMOS Sensor             |     | -   | •   | •   | •    | ÷  | ÷ |
| J12          | CMRST     | IO | 2                       | 0.4 | 2.4 | 40K | 75K | 190K | PD | 2 |
| K12          | CMPDN     | IO | 2                       | 0.4 | 2.4 | 40K | 75K | 190K | PD | 2 |
| H12          | CMVREF    | I  | 2                       |     |     | 40K | 75K | 190K | PD | 2 |
| H11          | CMHREF    | I  | 2                       |     |     | 40K | 75K | 190K | PD | 2 |
| Н9           | CMPCLK    | I  | 2                       |     |     | 40K | 75K | 190K | PD | 2 |
| H10          | CMMCLK    | О  | 2/4/6/8                 | 0.4 | 2.4 | 771 |     |      |    |   |
| H8           | CMDAT9    | I  | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PD | 2 |
| Ј8           | CMDAT8    | I  | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PD | 2 |
| K8           | CMDAT7    | I  | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PD | 2 |
| L8           | CMDAT6    | I  | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PD | 2 |
| M8           | CMDAT5    | I  | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PD | 2 |
| M9           | CMDAT4    | I  | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PD | 2 |
| M10          | CMDAT3    | I  | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PD | 2 |
| M11          | CMDAT2    | I  | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PD | 2 |
| M12          | CMDAT1    | IO | 2/4/6/8                 | 0.4 | 2.4 | 40K | 75K | 190K | PD | 2 |
| L12          | CMDAT0    | IO | 2/4/6/8                 | 0.4 | 2,4 | 40K | 75K | 190K | PD | 2 |