



OV5647

## datasheet

### PRODUCT SPECIFICATION

1/4" color CMOS QSXGA (5 megapixel) image sensor  
with OmniBSI™ technology



**Copyright © 2012 OmniVision Technologies, Inc. All rights reserved.**

This document is provided "as is" with no warranties whatsoever, including any warranty of merchantability, non-infringement, fitness for any particular purpose, or any warranty otherwise arising out of any proposal, specification, or sample.

OmniVision Technologies, Inc. and all its affiliates disclaim all liability, including liability for infringement of any proprietary rights, relating to the use of information in this document. No license, expressed or implied, by estoppel or otherwise, to any intellectual property rights is granted herein.

The information contained in this document is considered proprietary to OmniVision Technologies, Inc. and all its affiliates. This information may be distributed to individuals or organizations authorized by OmniVision Technologies, Inc. to receive said information. Individuals and/or organizations are not allowed to re-distribute said information.

**Trademark Information**

OmniVision and the OmniVision logo are registered trademarks of OmniVision Technologies, Inc. OmniBSI is a trademark of OmniVision Technologies, Inc.

All other trademarks used herein are the property of their respective owners.

**color CMOS QSXGA (5 megapixel) image sensor with OmniBSI™ technology**

datasheet (COB)  
PRODUCT SPECIFICATION

version 2.1  
march 2012

To learn more about OmniVision Technologies, visit [www.ovt.com](http://www.ovt.com).

OmniVision Technologies is publicly traded on NASDAQ under the symbol OVTI.

## applications

- cellular phones
- toys
- PC multimedia
- digital still cameras

## ordering information

- **OV05647-G04A** (color, chip probing, 200 µm backgrinding, reconstructed wafer)

## features

- 1.4 µm x 1.4 µm pixel with OmniBSI technology for high performance (high sensitivity, low crosstalk, low noise)
- optical size of 1/4"
- automatic image control functions: automatic exposure control (AEC), automatic gain control (AGC), automatic white balance (AWB), automatic band filter (ABF), automatic 50/60 Hz luminance detection, and automatic black level calibration (ABLC)
- programmable controls for frame rate, AEC/AGC 16-zone size/position/weight control, mirror and flip, cropping, windowing, and panning
- image quality controls: lens correction, defective pixel canceling
- support for output formats: 8-/10-bit raw RGB data
- support for video or snapshot operations
- support for LED and flash strobe mode
- support for internal and external frame synchronization for frame exposure mode
- support for horizontal and vertical sub-sampling
- standard serial SCCB interface
- digital video port (DVP) parallel output interface
- MIPI interface (two lanes)
- 32 bytes of embedded one-time programmable (OTP) memory
- on-chip phase lock loop (PLL)
- embedded 1.5V regulator for core power
- programmable I/O drive capability, I/O tri-state configurability
- support for black sun cancellation

## key specifications (typical)

- **active array size:** 2592 x 1944
- **power supply:**  
core: 1.5V ± 5% (with embedded 1.5V regulator)  
analog: 2.6 ~ 3.0V (2.8V typical)  
I/O: 1.7V ~ 3.0V
- **power requirements:**  
active: 96 mA  
standby: 20 µA
- **temperature range:**  
operating: -30°C to 70°C junction temperature (see **table 8-2**)  
stable image: 0°C to 50°C junction temperature (see **table 8-2**)
- **output formats:** 8-/10-bit RGB RAW output
- **lens size:** 1/4"
- **lens chief ray angle:** 24° (see **figure 10-2**)
- **input clock frequency:** 6~27 MHz
- **max S/N ratio:** 34 dB
- **dynamic range:** 67 dB @ 8x gain
- **maximum image transfer rate:**  
QSXGA (2592 x 1944): 15 fps  
1080p: 30 fps  
960p: 45 fps  
720p: 60 fps  
VGA (640 x 480): 90 fps
- **sensitivity:** 600mV/Lux-sec
- **shutter:** rolling shutter
- **maximum exposure interval:** 1968 x t<sub>ROW</sub>
- **pixel size:** 1.4 µm x 1.4 µm
- **dark current:** 8 mV/s @ 50°C junction temperature
- **image area:** 3673.6 µm x 2738.4 µm
- **die dimensions:** 5520 µm x 4700 µm

**OV5647**

color CMOS QSXGA (5 megapixel) image sensor with OmniBSI™ technology

Confidential for  
Zhongxindian



proprietary to OmniVision Technologies

PRODUCT SPECIFICATION

version 2.1

## table of contents

|                                                |            |
|------------------------------------------------|------------|
| <b>1 signal descriptions</b>                   | <b>1-1</b> |
| <b>2 system level description</b>              | <b>2-1</b> |
| 2.1 overview                                   | 2-1        |
| 2.2 architecture                               | 2-1        |
| 2.3 format and frame rate                      | 2-3        |
| 2.4 I/O control                                | 2-3        |
| 2.4.1 system clock control                     | 2-3        |
| 2.5 power up sequence                          | 2-3        |
| 2.5.1 power up with internal DVDD              | 2-3        |
| 2.5.2 power up with external DVDD source       | 2-4        |
| 2.6 reset                                      | 2-5        |
| 2.7 hardware and software standby              | 2-5        |
| 2.8 serial camera control bus (SCCB) interface | 2-6        |
| 2.8.1 data transfer protocol                   | 2-6        |
| 2.8.2 message format                           | 2-6        |
| 2.8.3 read / write operation                   | 2-6        |
| 2.8.4 SCCB timing                              | 2-9        |
| 2.8.5 group write                              | 2-10       |
| <b>3 block level description</b>               | <b>3-1</b> |
| 3.1 pixel array structure                      | 3-1        |
| 3.2 subsampling                                | 3-2        |
| 3.3 analog amplifier                           | 3-2        |
| 3.4 10-bit A/D converters                      | 3-2        |
| <b>4 image sensor core digital functions</b>   | <b>4-1</b> |
| 4.1 mirror and flip                            | 4-1        |
| 4.2 image windowing                            | 4-2        |
| 4.3 test pattern                               | 4-3        |
| 4.3.1 color bar                                | 4-3        |
| 4.3.2 square                                   | 4-3        |
| 4.3.3 random data                              | 4-4        |
| 4.3.4 transparent effect                       | 4-4        |

|                                                |      |
|------------------------------------------------|------|
| 4.3.5 rolling bar effect                       | 4-4  |
| 4.4 50/60Hz detection                          | 4-6  |
| 4.5 AEC and AGC algorithms                     | 4-7  |
| 4.5.1 overview                                 | 4-7  |
| 4.5.2 average-based algorithm                  | 4-8  |
| 4.5.3 average luminance (YAVG)                 | 4-10 |
| 4.6 AEC/AGC steps                              | 4-12 |
| 4.6.1 auto exposure control (AEC)              | 4-12 |
| 4.6.2 night mode                               | 4-12 |
| 4.6.3 banding mode ON with AEC                 | 4-12 |
| 4.6.4 banding mode OFF with AEC                | 4-12 |
| 4.6.5 manual exposure control                  | 4-12 |
| 4.6.6 auto gain control (AGC)                  | 4-12 |
| 4.6.7 manual gain control                      | 4-13 |
| 4.6.8 integration time between 1-16 rows       | 4-13 |
| 4.6.9 gain insertion between AEC banding steps | 4-13 |
| 4.6.10 gain insertion between night mode steps | 4-13 |
| 4.6.11 when AEC reaches maximum                | 4-13 |
| 4.7 black level calibration (BLC)              | 4-15 |
| 4.8 strobe flash and frame exposure            | 4-16 |
| 4.8.1 strobe flash control                     | 4-16 |
| 4.9 xenon flash control                        | 4-16 |
| 4.9.1 LED1 & 2 mode                            | 4-17 |
| 4.9.2 LED 3 mode                               | 4-18 |
| 4.10 frame exposure (FREX) mode                | 4-19 |
| 4.10.1 FREX control                            | 4-19 |
| 4.10.2 STROBE control in FREX mode             | 4-22 |
| 4.11 FREX strobe flash control                 | 4-23 |
| 4.12 one-time programmable (OTP) memory        | 4-24 |
| 4.12.1 OTP program                             | 4-26 |
| 4.12.2 OTP read                                | 4-26 |

|                                                                 |            |
|-----------------------------------------------------------------|------------|
| <b>5 image sensor processor digital functions</b>               | <b>5-1</b> |
| 5.1 ISP general controls                                        | 5-1        |
| 5.2 lens correction (LENC)                                      | 5-3        |
| 5.3 defect pixel cancellation (DPC)                             | 5-5        |
| 5.4 auto white balance (AWB)                                    | 5-5        |
| 5.5 post binning filter                                         | 5-7        |
| <b>6 image sensor output interface digital functions</b>        | <b>6-1</b> |
| 6.1 system control                                              | 6-1        |
| 6.2 SCCB                                                        | 6-5        |
| 6.3 group register write                                        | 6-5        |
| 6.4 timing control                                              | 6-6        |
| 6.5 frame control (FC)                                          | 6-8        |
| 6.6 digital video port (DVP)                                    | 6-8        |
| 6.6.1 DVP timing                                                | 6-10       |
| 6.7 mobile industry processor interface (MIPI)                  | 6-12       |
| <b>7 register tables</b>                                        | <b>7-1</b> |
| 7.1 system control [0x3000 - 0x3209]                            | 7-1        |
| 7.2 group hold control [0x3200 - 0x3208]                        | 7-6        |
| 7.3 AEC/AGC [0x3500 - 0x373A, 0x3A00 - 0x3A21, 0x5680 - 0x5A41] | 7-7        |
| 7.4 timing control [0x3800 - 0x3834]                            | 7-12       |
| 7.5 strobe/frame exposure [0x3B00 - 0x3B0C]                     | 7-14       |
| 7.6 50/60 Hz detection [0x3C00 - 0x3C1E]                        | 7-15       |
| 7.7 OTP control [0x3D00 - 0x3D21]                               | 7-16       |
| 7.8 BLC control [0x4000 - 0x4067]                               | 7-18       |
| 7.9 frame control [0x4200 - 0x4202]                             | 7-19       |
| 7.10 DVP control [0x4700 - 0x470C]                              | 7-19       |
| 7.11 MIPI control [0x4800 - 0x4843]                             | 7-21       |
| 7.12 ISP control [0x5000 - 0x5059]                              | 7-26       |
| 7.13 AWB control [0x5180 - 0x51DF]                              | 7-32       |
| 7.14 LENC control [0x5800 - 0x5849]                             | 7-34       |
| 7.15 ISP output windows [0x5980 - 0x5988]                       | 7-36       |

|                                              |             |
|----------------------------------------------|-------------|
| <b>8 operating specifications</b>            | <b>8-1</b>  |
| 8.1 absolute maximum ratings                 | 8-1         |
| 8.2 functional temperature                   | 8-1         |
| 8.3 DC characteristics                       | 8-2         |
| 8.4 AC characteristics                       | 8-4         |
| <b>9 mechanical specifications</b>           | <b>9-1</b>  |
| 9.1 physical specifications                  | 9-1         |
| <b>10 optical specifications</b>             | <b>10-1</b> |
| 10.1 sensor array center                     | 10-1        |
| 10.2 lens chief ray angle (CRA)              | 10-2        |
| <b>appendix A handling of RW devices</b>     | <b>A-1</b>  |
| A.1 ESD /EOS prevention                      | A-1         |
| A.2 particles and cleanliness of environment | A-1         |
| A.3 other requirements                       | A-1         |

## list of figures

|             |                                                                               |      |
|-------------|-------------------------------------------------------------------------------|------|
| figure 1-1  | pad diagram                                                                   | 1-4  |
| figure 2-1  | OV5647 block diagram                                                          | 2-1  |
| figure 2-2  | reference design schematic                                                    | 2-2  |
| figure 2-3  | power up timing with internal DVDD                                            | 2-4  |
| figure 2-4  | power up timing with external DVDD source                                     | 2-5  |
| figure 2-5  | message type                                                                  | 2-6  |
| figure 2-6  | SCCB single read from random location                                         | 2-7  |
| figure 2-7  | SCCB single read from current location                                        | 2-7  |
| figure 2-8  | SCCB sequential read from random location                                     | 2-7  |
| figure 2-9  | SCCB sequential read from current location                                    | 2-8  |
| figure 2-10 | SCCB single write to random location                                          | 2-8  |
| figure 2-11 | SCCB sequential write to random location                                      | 2-8  |
| figure 2-12 | SCCB interface timing                                                         | 2-9  |
| figure 3-1  | sensor array region color filter layout                                       | 3-1  |
| figure 3-2  | example of 2x2 binning                                                        | 3-2  |
| figure 4-1  | mirror and flip samples                                                       | 4-1  |
| figure 4-2  | image windowing                                                               | 4-2  |
| figure 4-3  | color bar types                                                               | 4-3  |
| figure 4-4  | color, black and white square bars                                            | 4-3  |
| figure 4-5  | transparent effect                                                            | 4-4  |
| figure 4-6  | rolling bar effect                                                            | 4-4  |
| figure 4-7  | desired convergence                                                           | 4-8  |
| figure 4-8  | average-based window definition                                               | 4-10 |
| figure 4-9  | xenon flash mode                                                              | 4-16 |
| figure 4-10 | LED 1 & 2 mode - one pulse output                                             | 4-17 |
| figure 4-11 | LED 1 & 2 mode - multiple pulse output                                        | 4-18 |
| figure 4-12 | LED 3 mode                                                                    | 4-18 |
| figure 4-13 | FREX modes                                                                    | 4-19 |
| figure 4-14 | FREX mode 1 timing diagram                                                    | 4-19 |
| figure 4-15 | FREX mode 2 timing diagram (when shutter delay is longer than exposure time)  | 4-21 |
| figure 4-16 | FREX mode 2 timing diagram (when shutter delay is shorter than exposure time) | 4-21 |
| figure 4-17 | STROBE control in FREX mode                                                   | 4-22 |

|             |                       |      |
|-------------|-----------------------|------|
| figure 6-1  | DVP timing diagram    | 6-10 |
| figure 9-1  | die specifications    | 9-1  |
| figure 10-1 | sensor array center   | 10-1 |
| figure 10-2 | chief ray angle (CRA) | 10-2 |

Confidential for  
Zhongxindian

## list of tables

|            |                                              |      |
|------------|----------------------------------------------|------|
| table 1-1  | signal descriptions                          | 1-1  |
| table 1-2  | pad configuration under various conditions   | 1-3  |
| table 2-1  | format and frame rate                        | 2-3  |
| table 2-2  | SCCB interface timing specifications         | 2-9  |
| table 2-3  | SCCB interface register                      | 2-10 |
| table 2-4  | group hold registers                         | 2-10 |
| table 3-1  | horizontal and vertical binning registers    | 3-2  |
| table 4-1  | mirror flip control registers                | 4-1  |
| table 4-2  | image windowing registers                    | 4-2  |
| table 4-3  | test pattern registers                       | 4-5  |
| table 4-4  | 50/60 Hz detection control registers         | 4-6  |
| table 4-5  | AEC/AGC control function registers           | 4-7  |
| table 4-6  | average based control function registers     | 4-9  |
| table 4-7  | average luminance control function registers | 4-10 |
| table 4-8  | AEC/AGC registers                            | 4-13 |
| table 4-9  | BLC control functions                        | 4-15 |
| table 4-10 | flashlight modes                             | 4-16 |
| table 4-11 | FREX mode 2 timing point description         | 4-20 |
| table 4-12 | FREX strobe control functions                | 4-23 |
| table 4-13 | OTP control function registers               | 4-24 |
| table 5-1  | ISP general control registers                | 5-1  |
| table 5-2  | LENC control registers                       | 5-3  |
| table 5-3  | defect pixel cancellation registers          | 5-5  |
| table 5-4  | AWB control registers                        | 5-5  |
| table 5-5  | post binning control registers               | 5-7  |
| table 6-1  | system control registers                     | 6-1  |
| table 6-2  | system control registers                     | 6-5  |
| table 6-3  | group hold control registers                 | 6-5  |
| table 6-4  | timing control registers                     | 6-6  |
| table 6-5  | frame control registers                      | 6-8  |
| table 6-6  | DVP registers                                | 6-8  |
| table 6-7  | DVP timing specifications                    | 6-10 |

|                                                   |      |
|---------------------------------------------------|------|
| table 6-8 MIPI transmitter registers              | 6-12 |
| table 7-1 system control registers                | 7-1  |
| table 7-2 group hold control registers            | 7-6  |
| table 7-3 AEC/AGC registers                       | 7-7  |
| table 7-4 system timing registers                 | 7-12 |
| table 7-5 strobe/frame exposure control registers | 7-14 |
| table 7-6 50/60 Hz detection registers            | 7-15 |
| table 7-7 OTP control registers                   | 7-16 |
| table 7-8 BLC registers                           | 7-18 |
| table 7-9 frame control registers                 | 7-19 |
| table 7-10 DVP registers                          | 7-19 |
| table 7-11 MIPI registers                         | 7-21 |
| table 7-12 ISP control registers                  | 7-26 |
| table 7-13 AWB registers                          | 7-32 |
| table 7-14 LENC registers                         | 7-34 |
| table 7-15 ISP output windows registers           | 7-36 |
| table 8-1 absolute maximum ratings                | 8-1  |
| table 8-2 functional temperature                  | 8-1  |
| table 8-3 DC characteristics (-30°C < TJ < 70°C)  | 8-2  |
| table 8-4 timing characteristics                  | 8-4  |
| table 9-1 pad location coordinates                | 9-1  |
| table 10-1 CRA versus image height plot           | 10-2 |

# 1 signal descriptions

**table 1-1** lists the signal descriptions and their corresponding pad numbers for the OV5647 image sensor. The die information is shown in **section 9**.

**table 1-1** signal descriptions (sheet 1 of 3)

| pad number | signal name        | pad type  | description                                                                     | default status |
|------------|--------------------|-----------|---------------------------------------------------------------------------------|----------------|
| 01         | AVDD               | power     | power for analog circuit, 2.8V                                                  |                |
| 02         | AGND               | ground    | ground for analog circuit                                                       |                |
| 03         | DOGND              | ground    | ground for digital I/O                                                          |                |
| 04         | SCL                | input     | SCCB clock input                                                                |                |
| 05         | SDA                | I/O       | SCCB data I/O                                                                   | input          |
| 06         | DVDD               | power     | power for digital core circuit, 1.5V<br>(connect to ground via 0.1µF capacitor) |                |
| 07         | SGND               | ground    | ground for pixel array                                                          |                |
| 08         | GPIO1 <sup>a</sup> | I/O       | general purpose I/O port 1                                                      | input          |
| 09         | GPIO0 <sup>a</sup> | I/O       | general purpose I/O port 2                                                      | input          |
| 10         | STROBE             | I/O       | strobe                                                                          | input          |
| 11         | FREX               | I/O       | frame exposure control                                                          | input          |
| 12         | DOVDD              | power     | power for digital I/O, 1.7 ~ 3.0V                                               |                |
| 13         | VREF2              | reference | reference for analog circuit<br>(connect to ground via 1µF capacitor)           |                |
| 14         | VREF1              | reference | reference for analog circuit<br>(connect to ground via 0.1µF capacitor)         |                |
| 15         | PWDN               | input     | power down control<br>(active high with internal pull down resistor)            |                |
| 16         | DVDD               | power     | power for digital core circuit, 1.5V<br>(connect to ground via 0.1µF capacitor) |                |
| 17         | RESETB             | input     | hardware reset (active low with internal pull up resistor)                      |                |
| 18         | AVDD               | power     | power for analog circuit, 2.8V                                                  |                |
| 19         | AGND               | ground    | ground for analog circuit                                                       |                |
| 20         | TM                 | input     | test mode<br>(active high with internal pull down resistor)                     |                |
| 21         | DOGND              | ground    | ground for digital I/O                                                          |                |

**table 1-1** signal descriptions (sheet 2 of 3)

| pad number | signal name | pad type | description                                                                     | default status |
|------------|-------------|----------|---------------------------------------------------------------------------------|----------------|
| 22         | DVDD        | power    | power for digital core circuit, 1.5V<br>(connect to ground via 0.1µF capacitor) |                |
| 23         | DVDD        | power    | power for digital core circuit, 1.5V<br>(connect to ground via 0.1µF capacitor) |                |
| 24         | DOVDD       | power    | power for digital I/O, 1.7 ~ 3.0V                                               |                |
| 25         | DOGND       | ground   | ground for digital I/O                                                          |                |
| 26         | AVDD        | power    | power for analog circuit, 2.8V                                                  |                |
| 27         | HREF        | I/O      | DVP HREF output                                                                 | input          |
| 28         | PCLK        | I/O      | DVP PCLK output                                                                 | input          |
| 29         | VSYNC       | I/O      | DVP VSYNC output                                                                | input          |
| 30         | DOVDD       | power    | power for digital I/O, 1.7 ~ 3.0V                                               |                |
| 31         | D0          | I/O      | DVP data bit 0                                                                  | input          |
| 32         | D1          | I/O      | DVP data bit 1                                                                  | input          |
| 33         | D2          | I/O      | DVP data bit 2                                                                  | input          |
| 34         | D3          | I/O      | DVP data bit 3                                                                  | input          |
| 35         | D9/MDN0     | I/O      | DVP data bit 9 / MIPI data lane0 negative output                                | input          |
| 36         | D8/MDP0     | I/O      | DVP data bit 8 / MIPI data lane0 positive output                                | input          |
| 37         | EVDD        | power    | power for MIPI circuit, 1.5V (connect to DVDD)                                  |                |
| 38         | D7/MCN      | I/O      | DVP data bit 7 / MIPI clock negative output                                     | input          |
| 39         | D6/MCP      | I/O      | DVP data bit 6 / MIPI clock positive output                                     | input          |
| 40         | EGND        | ground   | ground for MIPI TX circuit                                                      |                |
| 41         | D5/MDN1     | I/O      | DVP data bit 5 / MIPI data lane1 negative output                                | input          |
| 42         | D4/MDP1     | I/O      | DVP data bit 4 / MIPI data lane1 positive output                                | input          |
| 43         | EGND        | ground   | ground for MIPI TX circuit                                                      |                |
| 44         | PVDD        | power    | power for PLL circuit, 2.8V (connect to AVDD)                                   |                |
| 45         | XCLK        | input    | system input clock                                                              |                |
| 46         | DOVDD       | power    | power for digital I/O, 1.7 ~ 3.0V                                               |                |

**table 1-1** signal descriptions (sheet 3 of 3)

| pad number | signal name | pad type | description                                                                     | default status |
|------------|-------------|----------|---------------------------------------------------------------------------------|----------------|
| 47         | DVDD        | power    | power for digital core circuit, 1.5V<br>(connect to ground via 0.1µF capacitor) |                |
| 48         | DOGND       | ground   | ground for digital I/O                                                          |                |
| 49         | AVDD        | power    | power for analog circuit, 2.8V                                                  |                |
| 50         | AGND        | ground   | ground for analog circuit                                                       |                |

a. GPIO pins' pad design is IO pad, but there are no registers in the sensor to read their input values and they can only serve as general output pins

**table 1-2** pad configuration under various conditions

| signal | RESET <sup>a</sup> | RESET <sup>b</sup> | post-RESET                         | software sleep                      | hardware standby<br>(power down pin = 1) |
|--------|--------------------|--------------------|------------------------------------|-------------------------------------|------------------------------------------|
| VSYNC  | high-z             | high-z             | input by default<br>(configurable) | high-z by default<br>(configurable) | high-z by default<br>(configurable)      |
| FREX   | high-z             | high-z             | input by default<br>(configurable) | high-z by default<br>(configurable) | high-z by default<br>(configurable)      |
| STROBE | high-z             | high-z             | input by default<br>(configurable) | high-z by default<br>(configurable) | high-z by default<br>(configurable)      |
| GPIO0  | high-z             | high-z             | input by default<br>(configurable) | high-z by default<br>(configurable) | high-z by default<br>(configurable)      |
| GPIO1  | high-z             | high-z             | input by default<br>(configurable) | high-z by default<br>(configurable) | high-z by default<br>(configurable)      |
| XCLK   | high-z             | input              | input                              | input                               | high-z                                   |
| SDA    | open drain         | I/O                | I/O                                | I/O                                 | open drain                               |
| SCL    | high-z             | input              | input                              | input                               | high-z                                   |

a. PWDN pin = 1 when chip power up

b. PWDN pin = 0 when chip power up

figure 1-1 pad diagram



Confidential  
Zhongxindian

## 2 system level description

### 2.1 overview

The OV5647 is a low voltage, high performance, 5 megapixel CMOS image sensor that provides 2592x1944 video output using OmniBSI™ technology. It provides multiple resolution raw images via the control of the serial camera control bus.

The OV5647 has an image array capable of operating up to 15 fps in 2592x1944 resolution with user control of image quality, data transfer and camera functions through the SCCB interface. The OV5647 uses OmniBSI technology to improve sensor performance without any physical or optical trade-offs.

The OV5647 includes a one-time programmable (OTP) memory.

### 2.2 architecture

The OV5647 sensor core generates streaming pixel data at a constant frame rate, indicated by HREF and VSYNC.

**figure 2-1** shows the functional block of the OV5647 image sensor. **figure 2-2** shows an example application of the OV5647 sensor.

**figure 2-1** OV5647 block diagram



figure 2-2 reference design schematic



**note 1** connect FREX to GND if not used.

**note 2** GND is system ground (power ground -- GND).  
AGND and DGND are sensor analog and digital ground.  
connect different ground plans to a single point.

5647\_COB\_DS\_2\_2

## 2.3 format and frame rate

**table 2-1** format and frame rate

| format   | resolution | frame rate | methodology                    | pixel clock |
|----------|------------|------------|--------------------------------|-------------|
| 5 Mpixel | 2592x1944  | 15 fps     | full resolution                | 96 MHz      |
| 1080p    | 1920x1080  | 30 fps     | cropping                       | 96 MHz      |
| 960p     | 1280x960   | 45 fps     | cropping, subsampling/ binning | 96 MHz      |
| 720p     | 1280x720   | 60 fps     | cropping, subsampling/ binning | 96 MHz      |
| VGA      | 640x480    | 90 fps     | cropping, subsampling/ binning | 48 MHz      |

## 2.4 I/O control

### 2.4.1 system clock control

The OV5647 has an on-chip PLL which generates a default 96 MHz clock from a 6~27 MHz input clock. A built-in programmable clock divider is used to generate different frame rate timing.

## 2.5 power up sequence

Based on the system power configuration (1.8V or 2.8V for I/O power), using external DVDD or internal DVDD, the power up sequence will differ. If 1.8V is used for I/O power, using the internal DVDD is preferred. If 2.8V is used for I/O power, due to a high voltage drop at the internal DVDD regulator, there is a potential heat issue. Hence, for a 2.8V power system, OmniVision recommends using an external DVDD source. Due to the higher power down current when using an external DVDD source, OmniVision strongly recommends cutting off all power supplies, including the external DVDD, when the sensor is not in use in the case of 2.8V I/O and external DVDD.

### 2.5.1 power up with internal DVDD

For powering up with the internal DVDD and SCCB access during the power ON period, the following conditions must occur:

1. when DOVDD and AVDD are turned ON, make sure DOVDD becomes stable before AVDD becomes stable
2. PWDN is active high with an asynchronous design (does not need clock)
3. PWDN must be high during the power up period
4. for PWDN to go low, power must first become stable (AVDD to PWDN  $\geq$  5 ms)
5. RESETB is active low with an asynchronous design
6. state of RESETB does not matter during power up period once DOVDD is up
7. master clock XCLK should be provided at least 1 ms before host accesses sensor's registers
8. host can access SCCB bus (if shared) during entire period. 20 ms after PWDN goes low or 20 ms after RESETB goes high if reset is inserted after PWDN goes low, host can access sensor's registers to initialize sensor

**figure 2-3 power up timing with internal DVDD****DOVDD first, then AVDD, and rising time is less than 5 ms**

**note**  $T0 \geq 0$  ms: delay from DOVDD stable to AVDD stable  
 $T2 \geq 5$  ms: delay from AVDD stable to sensor power up stable

5647\_DS\_2\_3

### 2.5.2 power up with external DVDD source

For powering up with an external DVDD source and SCCB access during the power ON period, the following conditions must occur:

1. when DOVDD and AVDD are turned ON, make sure DOVDD becomes stable before AVDD becomes stable
2. when AVDD and DVDD are turned ON, make sure AVDD becomes stable before DVDD becomes stable
3. PWDN is active high with an asynchronous design (does not need clock)
4. for PWDN to go low, power must first become stable ( $DVDD \text{ to } PWDN} \geq 5 \text{ ms}$ )
5. all power supplies are cut off when the camera is not in use (power down mode is not recommended)
6. RESETB is active low with an asynchronous design
7. state of RESETB does not matter during power up period once DOVDD is up
8. master clock XVCLK should be provided at least 1 ms before host accesses sensor's registers
9. host can access SCCB bus (if shared) during entire period. 20 ms after PWDN goes low or 20 ms after RESETB goes high if reset is inserted after PWDN goes high, host can access sensor's registers to initialize sensor

Confidential  
Zhongxindianzi

**figure 2-4 power up timing with external DVDD source**



**note**  $T_0 \geq 0$  ms: delay from DOVDD stable to AVDD stable  
 $T_1 \geq 0$  ms: delay from AVDD stable to DVDD stable  
 $T_2 \geq 5$  ms: delay from DVDD stable to sensor power up stable

5647\_DS\_2\_4

## 2.6 reset

Two reset modes are available for the OV5647:

- hardware reset
- SCCB software reset

The OV5647 sensor includes a RESETB pad that forces a complete hardware reset when it is pulled low (GND). The OV5647 clears all registers and resets them to their default values when a hardware reset occurs. A reset can also be initiated through the SCCB interface by setting register 0x0103[0] to high.

The whole chip will be reset during power up. Manually applying a hard reset upon power up is recommended even though the on-chip power up reset is included. The hard reset is active low with an asynchronous design. The reset pulse width should be greater than or equal to 1 ms.

## 2.7 hardware and software standby

Two suspend modes are available for the OV5647:

- hardware standby
- software standby

To initiate hardware standby mode, the PWDN pad must be tied to high while in MIPI mode. Set register 0x3018[4:3] to 2'b11 before the PWDN pin is set to high. When this occurs, the OV5647 internal device clock is halted and all internal counters are reset and registers are maintained.

Executing a software standby (0x0100[0]) through the SCCB interface suspends internal circuit activity but does not halt the device clock. All register content is maintained in both modes.

## 2.8 serial camera control bus (SCCB) interface

The Serial Camera Control Bus (SCCB) interface controls the image sensor operation. Refer to the OmniVision Technologies Serial Camera Control Bus (SCCB) Specification for detailed usage of the serial control port.

### 2.8.1 data transfer protocol

The data transfer of the OV5647 follows the SCCB protocol.

### 2.8.2 message format

The OV5647 supports the message format shown in [figure 2-5](#). The 7-bit address of the OV5647 is 0x36 by default but can be programmed using register 0x3002[7:1]. The repeated START (Sr) condition is not shown in [figure 2-6](#), but is shown in [figure 2-7](#) and [figure 2-8](#).

**figure 2-5** message type

message type: 16-bit sub-address, 8-bit data, and 7-bit slave address



### 2.8.3 read / write operation

The OV5647 supports four different read operations and two different write operations:

- a single read from random locations
- a sequential read from random locations
- a single read from current location
- a sequential read from current location
- single write to random locations
- sequential write starting from random location

The sub-address in the sensor automatically increases by one after each read/write operation.

In a single read from random locations, the master does a dummy write operation to desired sub-address, issues a repeated start condition and then addresses the camera again with a read operation. After acknowledging its slave address, the camera starts to output data onto the SDA line as shown in [figure 2-6](#). The master terminates the read operation by setting a negative acknowledge and stop condition.

**figure 2-6 SCCB single read from random location**



If the host addresses the camera with read operation directly without the dummy write operation, the camera responds by setting the data from last used sub-address to the SDA line as shown in [figure 2-7](#). The master terminates the read operation by setting a negative acknowledge and stop condition.

**figure 2-7 SCCB single read from current location**



The sequential read from a random location is illustrated in [figure 2-8](#). The master does a dummy write to the desired sub-address, issues a repeated start condition after acknowledge from slave and addresses the slave again with read operation. If a master issues an acknowledge after receiving data, it acts as a signal to the slave that the read operation shall continue from the next sub-address. When master has read the last data byte, it issues a negative acknowledge and stop condition.

**figure 2-8 SCCB sequential read from random location**



The sequential read from current location is similar to a sequential read from a random location. The only exception is that there is no dummy write operation, as shown in [figure 2-9](#). The master terminates the read operation by setting a negative acknowledge and stop condition.

[figure 2-9](#) SCCB sequential read from current location



5647\_DS\_2\_9

The write operation to a random location is illustrated in [figure 2-10](#). The master issues a write operation to the slave, sets the sub-address and data correspondingly after the slave has acknowledged. The write operation is terminated with a stop condition from the master.

[figure 2-10](#) SCCB single write to random location



5647\_DS\_2\_10

The sequential write is illustrated in [figure 2-11](#). The slave automatically increments the sub-address after each data byte. The sequential write operation is terminated with stop condition from the master.

[figure 2-11](#) SCCB sequential write to random location



5647\_DS\_2\_11

## 2.8.4 SCCB timing

**figure 2-12** SCCB interface timing



**table 2-2** SCCB interface timing specifications<sup>ab</sup>

| symbol       | parameter                      | min  | typ | max | unit    |
|--------------|--------------------------------|------|-----|-----|---------|
| $f_{SCL}$    | clock frequency                |      |     | 400 | KHz     |
| $t_{LOW}$    | clock low period               | 1.3  |     |     | $\mu s$ |
| $t_{HIGH}$   | clock high period              | 0.6  |     |     | $\mu s$ |
| $t_{AA}$     | SCL low to data out valid      | 0.1  | 0.9 |     | $\mu s$ |
| $t_{BUF}$    | bus free time before new start | 1.3  |     |     | $\mu s$ |
| $t_{HD:STA}$ | start condition hold time      | 0.6  |     |     | $\mu s$ |
| $t_{SU:STA}$ | start condition setup time     | 0.6  |     |     | $\mu s$ |
| $t_{HD:DAT}$ | data in hold time              | 0    |     |     | $\mu s$ |
| $t_{SU:DAT}$ | data in setup time             | 0.1  |     |     | $\mu s$ |
| $t_{SU:STO}$ | stop condition setup time      | 0.6  |     |     | $\mu s$ |
| $t_R, t_F$   | SCCB rise/fall times           |      | 0.3 |     | $\mu s$ |
| $t_{DH}$     | data out hold time             | 0.05 |     |     | $\mu s$ |

a. SCCB timing is based on 400KHz mode

b. timing measurement shown at the beginning of the rising edge or/and of the falling edge signifies 10%, timing measurement shown in the middle of the rising/falling edge signifies 50%, timing measurement shown at the beginning of the rising edge or/and of the falling edge signifies 90%

### 2.8.5 group write

Group write is supported in order to update a group of registers in the same frame. These registers are guaranteed to be written prior to the internal latch at the frame boundary.

The OV5647 supports up to four groups. These groups share 512 B RAM and the size of each group is programmable by adjusting the start address.

**table 2-3** SCCB interface register

| address | register name | default value | R/W | description                                                                                                                                                                                                                          |
|---------|---------------|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3104  | SCCB_PLL      | 0x20          | RW  | Bit[6]: sda_vblank<br>Bit[5]: r_sys_sel (sclk)<br>0: pll2_daclk<br>1: pll1_sclk<br>Bit[4]: r_dac_sel (ser_clk)<br>0: pll2_daclk<br>1: pll1_sclk<br>Bit[3]: r_daclk (dacclk)<br>0: pll2_daclk<br>1: pll1_sclk<br>Bit[2:0]: Debug mode |

**table 2-4** group hold registers

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|---------------|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3208  | GROUP ACCESS  | -             | W   | Group Access<br>Bit[7:4]: group_ctrl<br>0000: Group hold start<br>0001: Group hold end<br>1010: Group launch<br>others: Reserved<br>Bit[3:0]: group_id<br>0000: Group bank 0, default start from address 0x00<br>0001: Group bank 1, default start from address 0x40<br>0010: Group bank 2, default start from address 0x80<br>0011: Group bank 3, default start from address 0xB0<br>others: Reserved |
| 0x3209  | GRP0_PERIOD   | 0x00          | RW  | Frames For Staying in Group 0                                                                                                                                                                                                                                                                                                                                                                          |
| 0x320A  | GRP1_PERIOD   | 0x00          | RW  | Frames For Staying in Group 1                                                                                                                                                                                                                                                                                                                                                                          |
| 0x320B  | GRP_SWCTRL    | 0x01          | RW  | Bit[3]: group_switch_repeat<br>Bit[2]: context_en<br>Bit[1:0]: Second group selection                                                                                                                                                                                                                                                                                                                  |

## 3 block level description

### 3.1 pixel array structure

The OV5647 sensor has an image array of 2624 columns by 1956 rows (5,132,544 pixels). **figure 3-1** shows a cross-section of the image sensor array.

The color filters are arranged in a Bayer pattern. The primary color BG/GR array is arranged in line-alternating fashion. Of the 5,132,544 pixels, 5,038,848 (2592x1944) are active pixels and can be output. The other pixels are used for black level calibration and interpolation. The center 2592x1944 is suggested to be output from the whole active pixel array. The backend processor can use the boundary pixels for additional processing.

The sensor array design is based on a field integration read-out system with line-by-line transfer and an electronic shutter with a synchronous pixel read-out scheme.

**figure 3-1** sensor array region color filter layout



### 3.2 subsampling

There are two subsampling modes in the OV5647: binning and skipping. Both are acceptable methods of reducing output resolution while maintaining the field of view. Binning is usually preferred as it increases the pixel's signal-to-noise ratio. When the binning function is ON, voltage levels of adjacent pixels are averaged. In skipping mode (binning function is OFF), alternate pixels, which are not output, are merely skipped. The OV5647 supports 2x2 binning. **figure 3-2** illustrates 2x2 binning, where the voltage levels of two horizontal (2x1) adjacent same-color pixels are averaged before entering the ADC. See **table 3-1** for horizontal and vertical binning registers.

**table 3-1** horizontal and vertical binning registers

| address | register name   | default value | R/W | description                                           |  |
|---------|-----------------|---------------|-----|-------------------------------------------------------|--|
| 0x3820  | TIMING_TC_REG20 | 0x40          | RW  | Bit[0]: Vertical binning<br>0: Disable<br>1: Enable   |  |
| 0x3821  | TIMING_TC_REG21 | 0x00          | RW  | Bit[0]: Horizontal binning<br>0: Disable<br>1: Enable |  |

Sensor timing adjustment is necessary after applying binning. Please consult your local OmniVision FAE for details.

**figure 3-2** example of 2x2 binning



### 3.3 analog amplifier

When the column sample/hold circuit has sampled one row of pixels, the pixel data will shift out one-by-one into an analog amplifier.

### 3.4 10-bit A/D converters

The balanced signal is then digitized by the on-chip 10-bit ADC. The actual conversion rate is determined by the frame rate and resolution.

## 4 image sensor core digital functions

### 4.1 mirror and flip

The OV5647 provides mirror and flip read-out modes, which respectively reverse the sensor data read-out order horizontally and vertically (see [figure 4-1](#)). In flip mode, the OV5647 does not need additional settings because the ISP block will auto-detect whether the pixel is in the red line or blue line and make the necessary adjustments.

[figure 4-1](#) mirror and flip samples



5647\_05\_4\_1

[table 4-1](#) mirror flip control registers

| address | register name   | default value | R/W | description                                                                 |
|---------|-----------------|---------------|-----|-----------------------------------------------------------------------------|
| 0x3820  | TIMING_TC_REG20 | 0x40          | RW  | Timing Control<br>Bit[2]: ISP vertical flip<br>Bit[1]: Sensor vertical flip |
| 0x3821  | TIMING_TC_REG21 | 0x00          | RW  | Timing Control<br>Bit[2]: ISP mirror<br>Bit[1]: Sensor mirror               |

## 4.2 image windowing

An image windowing area is defined by four parameters, x\_addr\_start, x\_addr\_end, y\_addr\_start, y\_addr\_end. By properly setting the parameters, any portion or size within the sensor array can be defined as a visible area. Windowing is achieved by simply masking off the pixels outside the defined window; thus, the original timing is not affected.

**figure 4-2** image windowing



**table 4-2** image windowing registers

| address | register name       | default value | R/W | description                  |
|---------|---------------------|---------------|-----|------------------------------|
| 0x3800  | TIMING_X_ADDR_START | 0x00          | RW  | Bit[3:0]: x_addr_start[11:8] |
| 0x3801  | TIMING_X_ADDR_START | 0x0C          | RW  | Bit[7:0]: x_addr_start[7:0]  |
| 0x3802  | TIMING_Y_ADDR_START | 0x00          | RW  | Bit[3:0]: y_addr_start[11:8] |
| 0x3803  | TIMING_Y_ADDR_START | 0x04          | RW  | Bit[7:0]: y_addr_start[7:0]  |
| 0x3804  | TIMING_X_ADDR_END   | 0x0A          | RW  | Bit[3:0]: x_addr_end[11:8]   |
| 0x3805  | TIMING_X_ADDR_END   | 0x33          | RW  | Bit[7:0]: x_addr_end[7:0]    |
| 0x3806  | TIMING_Y_ADDR_END   | 0x07          | RW  | Bit[3:0]: y_addr_end[11:8]   |
| 0x3807  | TIMING_Y_ADDR_END   | 0xA3          | RW  | Bit[7:0]: y_addr_end[7:0]    |

## 4.3 test pattern

For testing purposes, the OV5647 offers three types of test patterns, color bar, square and random data. The OV5647 also offers two effects: transparent effect and rolling bar effect. The output type of test pattern is controlled by register 0x503D[1:0] (test\_pattern\_type).

### 4.3.1 color bar

There are four types of color bars shown in **figure 4-3**. The output type of color the color bar can be selected by bar style register 0x503D[3:2].

**figure 4-3** color bar types



### 4.3.2 square

There are two types of square patterns: color square and black-white square. Register 0x503D[4] (squ\_bw) determines which type of square will be output.

**figure 4-4** color, black and white square bars



#### 4.3.3 random data

There are two types of random data test patterns: frame-changing and frame-fixed random data. The output type of random data is determined by register 0x503E[4] (rnd\_same). The random seed is set by register 0x503E[3:0] (rnd\_seed).

#### 4.3.4 transparent effect

The transparent effect is enabled by register 0x503D[5] (transparent\_mode). If this register is set, the transparent test pattern will be used. **figure 4-5** is an example which shows a transparent color bar image.

**figure 4-5** transparent effect



5647\_DS\_4\_5

#### 4.3.5 rolling bar effect

The rolling bar is set by register 0x503D[6] (rolling\_bar). If it is set, an inverted-color rolling bar will roll up and down.

**figure 4-6** is an example which shows a rolling bar on a color bar image.

**figure 4-6** rolling bar effect



5647\_DS\_4\_6

**table 4-3** test pattern registers

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|---------------|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x503D  | ISP CTRL3D    | 0x00          | RW  | <p>Bit[7]: test_pattern_en<br/>0: Disable<br/>1: Enable</p> <p>Bit[6]: rolling_bar<br/>0: Disable rolling bar<br/>1: Enable rolling bar</p> <p>Bit[5]: transparent_mode<br/>0: Disable<br/>1: Enable</p> <p>Bit[4]: squ_bw_mode<br/>0: Output square is color square<br/>1: Output square is black-white square</p> <p>Bit[3:2]: bar_style<br/>When set to different value, the different type color bar will be output</p> <p>Bit[1:0]: test_pattern_type<br/>00: Color bar<br/>01: Square<br/>10: Random data<br/>11: Input data</p> |
| 0x503E  | ISP CTRL3E    | 0x00          | RW  | <p>Bit[6]: win_cut_en</p> <p>Bit[5]: isp_test<br/>0: Two lowest bits are 1<br/>1: Two lowest bits are 0</p> <p>Bit[4]: rnd_same<br/>0: Frame changing random data pattern<br/>1: Frame-fixed random data pattern</p> <p>Bit[3:0]: rnd_seed<br/>Initial seed for random data pattern</p>                                                                                                                                                                                                                                                |

#### 4.4 50/60Hz detection

When the integration time is not an integer multiple of the period of light intensity, the image will flicker. The function of the detector is to detect whether the sensor is under a 50 Hz or 60 Hz light source so that the basic step of integration time can be determined. Contact your local OmniVision FAE for auto detection settings.

**table 4-4** 50/60 Hz detection control registers

| address       | register name             | default value | R/W | description                                                                                                                                                                                                                                                                                                                        |
|---------------|---------------------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3C00        | 50/60 HZ DETECTION CTRL00 | 0x00          | RW  | <p>Bit[5:3]: 50/60 Hz detection control<br/>Contact your local OmniVision FAE for the correct settings</p> <p>Bit[2]: band_def<br/>Band50 default value<br/>0: 60 Hz as default value<br/>1: 50 Hz as default value</p> <p>Bit[1:0]: 50/60 Hz detection control<br/>Contact your local OmniVision FAE for the correct settings</p> |
| 0x3C01        | 50/60 HZ DETECTION CTRL01 | 0x00          | RW  | <p>Bit[7]: band_man_en<br/>Band detection manual mode<br/>0: Manual mode disable<br/>1: Manual mode enable</p> <p>Bit[6:0]: 50/60 Hz detection control<br/>Contact your local OmniVision FAE for the correct settings</p>                                                                                                          |
| 0x3C02~0x3C0B | 50/60 HZ DETECTION CTRL02 | 0x00          | RW  | Bit[7:0]: 50/60 Hz detection control<br>Contact your local OmniVision FAE for the correct settings                                                                                                                                                                                                                                 |
| 0x3C0C        | 50/60 HZ DETECTION CTRL0C | -             | R   | Bit[0]: band50<br>0: Detection result is 60 Hz<br>1: Detection result is 50 Hz                                                                                                                                                                                                                                                     |

## 4.5 AEC and AGC algorithms

### 4.5.1 overview

The Auto Exposure Control (AEC) and Auto Gain Control (AGC) allows the image sensor to adjust the image brightness to a desired range by setting the proper exposure time and gain applied to the image. Besides automatic control, exposure time and gain can be set manually from external control. The related registers are listed in **table 4-5**

**table 4-5** AEC/AGC control function registers

| address | register name | default value | R/W | description                                                                                                                                                                                                                                         |
|---------|---------------|---------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3500  | EXPOSURE      | 0x00          | RW  | Bit[3:0]: Exposure[19:16]<br>Exposure in units of 1/16 line                                                                                                                                                                                         |
| 0x3501  | EXPOSURE      | 0x02          | RW  | Bit[7:0]: Exposure[15:8]<br>Exposure in units of 1/16 line                                                                                                                                                                                          |
| 0x3502  | EXPOSURE      | 0x00          | RW  | Bit[7:0]: Exposure[7:0]<br>Exposure in units of 1/16 line;<br>lower four bits are a fraction of a<br>line; they should be 0 since<br>OV5647 does not support fraction<br>line exposure                                                              |
| 0x3503  | MANUAL CTRL   | 0x00          | RW  | Bit[5:4]: Gain latch timing delay<br>x0: Gain has no latch delay<br>01: Gain delay of 1 frame<br>11: Gain delay of 2 frames<br>Bit[1]: AGC manual<br>0: Auto enable<br>1: Manual enable<br>Bit[0]: AEC manual<br>0: Auto enable<br>1: Manual enable |
| 0x350A  | AGC           | 0x00          | RW  | Bit[1:0]: Gain[9:8]<br>AGC real gain output high byte<br>Gain = {0x350A[1:0],<br>0x350B[7:0]}/16                                                                                                                                                    |
| 0x350B  | AGC           | 0x10          | RW  | Bit[7:0]: Gain[7:0]<br>AGC real gain output low byte                                                                                                                                                                                                |

#### 4.5.2 average-based algorithm

The average-based AEC controls image luminance using registers **WPT** (0x3A0F), **BPT** (0x3A10), **WPT2** (0x3A1B), and **BPT2** (0x3A1E). In average-based mode, the value of register **WPT** (0x3A0F) indicates the high threshold value for image change from unstable to stable state, and the value of register **BPT** (0x3A10) indicates the low threshold value for image change from unstable to stable state. The value of register **WPT2** (0x3A1B) indicates the high threshold value for image change from stable state to unstable state and the value of register **BPT2** (0x3A1E) indicates the low threshold value for image change from stable state to unstable state. When the target image luminance average value AVG (0x5693) is within the range specified by registers **WPT2** (0x3A1B) and **BPT2** (0x3A1E), the AEC keeps the image exposure and gain. When register AVG (0x5693) is greater than the value in register **WPT2** (0x3A1B), the AEC will decrease the image exposure and gain until it falls into the range of {0x3A10, 0x3A0F}. When register AVG (0x5693) is less than the value in register **BPT2** (0x3A1E), the AEC will increase the image exposure and gain until it falls into the range of {0x3A10, 0x3A0F}. Accordingly, the value in register **WPT** (0x3A0F) should be greater than the value in register **BPT** (0x3A10). The value of register **WPT2** should be no less than the value of register **WPT** (0x3A0F), and the value of register **BPT2** (0x3A1E) should be no greater than the value of **BPT** (0x3A10).

The AEC function supports both manual and auto speed selections in order to bring the image exposure into the range set by the values in registers **WPT** (0x3A0F) and **BPT** (0x3A10). For manual speed mode, the step is fixed and supports both normal and fast modes. Setting the AEC to normal mode will allow for the slowest step increment or decrement in image exposure to maintain the specified range. Setting the AEC to fast mode will provide for an approximate ten-step increment or decrement in image exposure to maintain the specified range. For auto speed mode, the step will automatically be adjusted according to the difference between the target and present values. The auto ratio of steps can be set by register bits AEC CTRL05[4:0](0x3A05).

Register HIGH VPT (0x3A11) and register LOW VPT (0x3A1F) controls the fast AEC range in manual speed mode. If the target image AVG (0x5693) is greater than HIGH VPT (0x3A11), AEC will decrease by half. If register AVG (0x5693) is less than LOW VPT (0x3A1F), AEC will double, as shown in [figure 4-7](#). These registers have no effect in auto speed mode.

[figure 4-7](#) desired convergence



**table 4-6** average based control function registers

| address | register name | default value | R/W | description                                                                        |
|---------|---------------|---------------|-----|------------------------------------------------------------------------------------|
| 0x3A0F  | WPT           | 0x78          | RW  | Bit[7:0]: WPT<br>Stable range high limit (from unstable state to stable state)     |
| 0x3A10  | BPT           | 0x68          | RW  | Bit[7:0]: BPT<br>Stable range low limit (from unstable state to stable state)      |
| 0x3A11  | HIGH VPT      | 0xD0          | RW  | Bit[7:0]: vpt_high<br>Fast zone high limit (when step ratio auto mode is disabled) |
| 0x3A1B  | WPT2          | 0x78          | RW  | Bit[7:0]: wpt2<br>Stable range high limit (from stable state to unstable state)    |
| 0x3A1E  | BPT2          | 0x68          | RW  | Bit[7:0]: bpt2<br>Stable range low limit (from stable state to unstable state)     |
| 0x3A1F  | LOW VPT       | 0x40          | RW  | Bit[7:0]: vpt_low<br>Fast zone low limit (when step ratio auto mode is disabled)   |

For the average-based AEC/AGC algorithm, the measured window is horizontally and vertically adjustable and divided by sixteen (4x4) zones (see **figure 4-8**). Each zone (or block) is 1/16th of the image and has a 4-bit weight in calculating the average luminance (YAVG). The final YAVG is the weighted average of the sixteen zones. The 4-bit weight could be n/16 where n is from 0 to 15.

Confidential  
Zhongxindian

### 4.5.3 average luminance (YAVG)

Auto exposure time calculation is based on a frame brightness average value. By properly setting x\_start, x\_window, y\_start, and y\_window as shown in [figure 4-8](#), a 4x4 grid average window is defined. It will automatically divide each zone into 4x4 zones. The average value is the weighted average of the 16 sections. [table 4-7](#) lists the corresponding registers.

[figure 4-8](#) average-based window definition



[table 4-7](#) average luminance control function registers (sheet 1 of 2)

| address | register name | default value | R/W | description                                                                       |
|---------|---------------|---------------|-----|-----------------------------------------------------------------------------------|
| 0x5680  | XSTART        | 0x00          | RW  | Bit[3:0]: x_start[11:8]<br>Horizontal start position for average window high byte |
| 0x5681  | XSTART        | 0x00          | RW  | Bit[7:0]: x_start[7:0]<br>Horizontal start position for average window low byte   |
| 0x5682  | YSTART        | 0x00          | RW  | Bit[3:0]: y_start[11:8]<br>Vertical start position for average window high byte   |
| 0x5683  | YSTART        | 0x00          | RW  | Bit[7:0]: y_start[7:0]<br>Vertical start position for average window low byte     |

**table 4-7** average luminance control function registers (sheet 2 of 2)

| address | register name | default value | R/W | description                                                                              |
|---------|---------------|---------------|-----|------------------------------------------------------------------------------------------|
| 0x5684  | X WINDOW      | 0x0A          | RW  | Bit[4:0]: x_window[12:8]<br>Window X in manual average window mode high byte             |
| 0x5685  | X WINDOW      | 0x20          | RW  | Bit[7:0]: x_window[7:0]<br>Window X in manual average window mode low byte               |
| 0x5686  | Y WINDOW      | 0x07          | RW  | Bit[3:0]: y_window[11:8]<br>Window Y in manual average window mode high byte             |
| 0x5687  | Y WINDOW      | 0x98          | RW  | Bit[7:0]: y_window[7:0]<br>Window Y in manual average window mode low byte               |
| 0x5688  | WEIGHT00      | 0x11          | RW  | Bit[7:4]: Window1 weight<br>Bit[3:0]: Window0 weight                                     |
| 0x5689  | WEIGHT01      | 0x11          | RW  | Bit[7:4]: Window3 weight<br>Bit[3:0]: Window2 weight                                     |
| 0x568A  | WEIGHT02      | 0x11          | RW  | Bit[7:4]: Window5 weight<br>Bit[3:0]: Window4 weight                                     |
| 0x568B  | WEIGHT03      | 0x11          | RW  | Bit[7:4]: Window7 weight<br>Bit[3:0]: Window6 weight                                     |
| 0x568C  | WEIGHT04      | 0x11          | RW  | Bit[7:4]: Window9 weight<br>Bit[3:0]: Window8 weight                                     |
| 0x568D  | WEIGHT05      | 0x11          | RW  | Bit[7:4]: Window11 weight<br>Bit[3:0]: Window10 weight                                   |
| 0x568E  | WEIGHT06      | 0x11          | RW  | Bit[7:4]: Window13 weight<br>Bit[3:0]: Window12 weight                                   |
| 0x568F  | WEIGHT07      | 0x11          | RW  | Bit[7:4]: Window15 weight<br>Bit[3:0]: Window14 weight                                   |
| 0x5690  | AVG CTRL10    | 0x02          | RW  | Bit[1]: avg_opt<br>Bit[0]: avg_man<br>0: Auto average window<br>1: Manual average window |
| 0x5693  | AVG READOUT   | -             | R   | Bit[7:0]: Avg value                                                                      |

## 4.6 AEC/AGC steps

The AEC and AGC work together to achieve optimal exposure and gain based on the environmental illumination. In order to achieve the best signal-to-noise ratio (SNR), extending the exposure time is always preferred to raising the analog gain when the illumination level is decreasing. Similarly, with increasing illumination, decreasing the gain prior to shortening the exposure time is preferred.

### 4.6.1 auto exposure control (AEC)

The function of the AEC is to calculate the necessary integration time of the next frame and send the information to the timing control block. Based on the statistics of previous frames, the AEC is able to determine whether the integration time should increase, decrease, fast increase, fast decrease, or remain the same.

To avoid image flickering under a periodic light source, the integration time can be adjusted in steps of integer multiples of the period of the light source. This new AEC step system is called the banding filter, suggesting that the exposure time is not continuous but falls in some steps.

### 4.6.2 night mode

The OV5647 supports long integration time larger than one frame in dark conditions. This is achieved by slowing down the original frame rate and waiting for exposure. Night mode ceiling can be set in register {0x3A14[15:8], 0x3A15[7:0]} and {0x3A02[15:8], 0x3A03[7:0]} for 50/60 Hz lighting, respectively. Night mode can be disabled by setting register bit 0x3A00[2] to 0. Also, when in night mode, the increase and decrease step can be based on either band or frames, depending on register 0x3A05[6]. The minimum increase/decrease step can be one band.

### 4.6.3 banding mode ON with AEC

In Banding ON mode, the exposure time will fall in steps of integer multiples of the period of light intensity. This design is to reject image flickering when the light source is not steady but periodical.

For a given light flickering frequency, the band step can be expressed in units of row period.

Band Step = period of light intensity × frame rate × rows per frame.

The band steps for 50Hz and 60Hz light sources can be set in registers {0x3A08[1:0], 0x3A09[7:0]} and {0x3A0A[1:0], 0x3A0B[7:0]}, respectively. Banding mode can be enabled by setting register 0x3A00[5].

### 4.6.4 banding mode OFF with AEC

When banding mode is OFF, integration time increases/decreases as normal. It is not necessarily multiples of band steps.

### 4.6.5 manual exposure control

To manually change exposure value, you must first set register 0x3503[0] to enable manual exposure control. The exposure value in registers 0x3500 ~ 0x3502 is in units of 1/16 line.

### 4.6.6 auto gain control (AGC)

Unlike prolonging integration time, increasing gain will amplify both signal and noise. Thus, AGC usually starts after AEC is full. However, in cases where adjacent AEC step changes are too large (>1/16), AGC steps should be inserted in between. Otherwise, the integration time will keep switching between two adjacent steps and the image flickers.

#### 4.6.7 manual gain control

To manually change gain, first set register bit 0x3503[1]to enable manual control, then change the values in {0x350A[1:0], 0x350B[7:0]} for the manual gain.

$$\text{Gain} = \{0x350A[1:0], 0x350B[7:0]\} / 16$$

#### 4.6.8 integration time between 1-16 rows

When integration time is less than 16 rows, the changes between adjacent AEC steps are larger than 1/16, which may possibly make the image oscillate between two AEC levels. Thus, some AGC steps are added in between.

#### 4.6.9 gain insertion between AEC banding steps

When banding mode is ON, the integration time changes in step of the period of light intensity. For the first 16 band steps, since the exposure time change between adjacent steps is larger than 1/16, AGC steps are inserted to ensure image stability.

#### 4.6.10 gain insertion between night mode steps

Between night mode steps (e.g., integration time = 1 frame and 2 frames), AGC steps are inserted to ensure no adjacent step change is larger than 1/16.

#### 4.6.11 when AEC reaches maximum

When AEC reaches its maximum while the image is still too dark, the gain starts to increase until the new frame average falls into the stable range or AGC reaches its maximum. The AGC ceiling can be set in {0x3A18[9:8], 0x3A19[7:0]}.

$$\text{Gain Ceiling} = \{0x3A18[1:0], 0x3A19[7:0]\} / 16$$

**table 4-8 AEC/AGC registers (sheet 1 of 2)**

| address | register name | default value | R/W | description                                                                                             |
|---------|---------------|---------------|-----|---------------------------------------------------------------------------------------------------------|
| 0x3A00  | AEC CTRL00    | 0x78          | RW  | Bit[5]: Band function<br>Bit[2]: Night mode                                                             |
| 0x3A02  | MAX EXPO 60   | 0x3D          | RW  | Bit[7:0]: Max expo[15:8]<br>Night mode ceiling of 60Hz                                                  |
| 0x3A03  | MAX EXPO 60   | 0x80          | RW  | Bit[7:0]: Max expo[7:0]<br>Night mode ceiling of 60Hz                                                   |
| 0x3A05  | AEC CTRL05    | 0x30          | RW  | Bit[6]: frame_insert<br>0: In night mode, insert frame disable<br>1: In night mode, insert frame enable |
| 0x3A08  | B50 STEP      | 0x01          | RW  | Bit[1:0]: b50_step[9:8]<br>Band step size of 50Hz                                                       |
| 0x3A09  | B50 STEP      | 0x27          | RW  | Bit[7:0]: b50_step[7:0]<br>Band step size of 50Hz                                                       |

**table 4-8** AEC/AGC registers (sheet 2 of 2)

| address | register name        | default value | R/W | description                                                                                |
|---------|----------------------|---------------|-----|--------------------------------------------------------------------------------------------|
| 0x3A0A  | B60 STEP             | 0x00          | RW  | Bit[1:0]: b60_step[9:8]<br>Band step size of 60Hz                                          |
| 0x3A0B  | B60 STEP             | 0xF6          | RW  | Bit[7:0]: b60_step[7:0]<br>Band step size of 60Hz                                          |
| 0x3A0D  | B60 MAX              | 0x08          | RW  | Bit[5:0]: b60_max<br>Max band step number of 60Hz                                          |
| 0x3A0E  | B50 MAX              | 0x06          | RW  | Bit[5:0]: b50_max<br>Max band step number of 50Hz                                          |
| 0x3A14  | MAX EXPO 50          | 0xE           | RW  | Bit[7:0]: max_expo[15:8]<br>Night mode ceiling of 50Hz                                     |
| 0x3A15  | MAX EXPO 50          | 0x40          | RW  | Bit[7:0]: max_expo[7:0]<br>Night mode ceiling of 50Hz                                      |
| 0x3A17  | NIGHT MODE GAIN BASE | 0x01          | RW  | Bit[1:0]: gnight_thre<br>Night mode gain threshold<br>00: 1x<br>01: 2x<br>10: 4x<br>11: 8x |
| 0x3A18  | AEC GAIN CEILING     | 0x00          | RW  | Bit[1:0]: gain_ceiling[9:8]<br>Gain ceiling = {0x3A18[1:0],<br>0x3A19[7:0]} /16            |
| 0x3A19  | AEC GAIN CEILING     | 0x7C          | RW  | Bit[7:0]: gain_ceiling[7:0]                                                                |

Confidential  
Zhongxindian

## 4.7 black level calibration (BLC)

The pixel array contains several optically shielded (black) lines. These lines are used as reference for black level calibration. There are three main functions of the BLC:

- combining two ADC data paths into one data path
- adjusting all normal pixel values based on the values of the black levels
- applying multiplication to all pixel values based on digital gain

The target of BLC level can be set by register 0x4009.

**table 4-9** BLC control functions

| address | register name      | default value | R/W | description                                                                                                                         |
|---------|--------------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------|
| 0x4000  | BLC CTRL00         | 0x89          | RW  | BLC Control<br>Bit[0]: BLC enable<br>0: Disable<br>1: Enable                                                                        |
| 0x4003  | BLC CTRL03         | 0x08          | RW  | Bit[7]: blc_redo_en<br>Writing 1 to this bit will trigger a BLC redo N frames begin<br>Bit[6]: Freeze<br>Bit[5:0]: manual_frame_num |
| 0x4005  | BLC CTRL05         | 0x18          | RW  | Bit[1]: blc_always_up_en<br>0: Normal freeze<br>1: BLC always update                                                                |
| 0x4009  | BLACK LEVEL TARGET | 0x10          | RW  | Bit[7:0]: BLC black level target                                                                                                    |

## 4.8 strobe flash and frame exposure

### 4.8.1 strobe flash control

The strobe signal is programmable. It supports both LED and Xenon modes. The polarity of the pulse can be changed. The strobe signal is enabled (turned high/low depending on the pulse's polarity) by requesting the signal via the SCCB interface. Flash modules are triggered by the rising edge by default or by the falling edge if the signal polarity is changed. The OV5647 supports the following flashlight modes (see **table 4-10**).

**table 4-10**      flashlight modes

| mode  | output     | AEC / AGC | AWB |
|-------|------------|-----------|-----|
| xenon | one-pulse  | no        | no  |
| LED 1 | pulse      | no        | no  |
| LED 2 | pulse      | no        | yes |
| LED 3 | continuous | yes       | yes |

## 4.9 xenon flash control

After a strobe request is submitted, the strobe pulse will be activated at the beginning of the third frame (see **figure 4-9**). The third frame will be correctly exposed. The pulse width can be changed in Xenon mode between 1H and 4H, depending on register 0x3B00[3:2], where H is one row period.

**figure 4-9**      xenon flash mode



#### 4.9.1 LED1 & 2 mode

Two frames after the strobe request is submitted, the third frame is correctly exposed. The strobe pulse will be activated only one time if the strobe end request is set correctly (see [figure 4-10](#)). If end request is not sent, the strobe signal is activated intermittently until the strobe end request is set (see [figure 4-11](#)). The number of skipped frames is programmable using registers {0x3A1C, 0x3A1D}.

**figure 4-10** LED 1 & 2 mode - one pulse output



Com  
Zhongxindian

**figure 4-11** LED 1 & 2 mode - multiple pulse output

#### 4.9.2 LED 3 mode

In LED 3 mode, the strobe signal stays active until the strobe end request is sent (see **figure 4-12**).

**figure 4-12** LED 3 mode

## 4.10 frame exposure (FREX) mode

### 4.10.1 FREX control

The OV5647 supports two modes of FREX (see [figure 4-13](#)). In FREX mode, all pixels in the frame start integration at the same time, rather than integrating row by row. After a user-defined exposure time (either by external control in mode 1 or registers {0x3B01, 0x3B04, 0x3B05} in mode 2), the mechanical shutter should be closed, preventing further integration, and then the image begins to read out. After the readout finishes, the shutter opens again and the sensor resumes normal mode, waiting for the next FREX request. In mode 1, the FREX pin is configured as an input while it is configured as an output in mode 2. In both mode 1 and mode 2, the strobe output is irrelevant with the rolling strobe function. The strobe function of rolling shutter mode and FREX/shutter mode do not work at the same time.

**figure 4-13** FREX modes



**note** After frame exposure mode, the first output frame is invalid because of improper exposure during the readout time of the frame exposure image. From the second output frame, the images become normal.

Mode 1 (see [figure 4-14](#)) frame exposure and shutter control requests come from the external system via the FREX pin. The sensor will send a strobe output signal to control the flash light.

**figure 4-14** FREX mode 1 timing diagram



Example setting:

|             |                            |
|-------------|----------------------------|
| 6C 3002 EF; | FREX mode selection: input |
| 6C 3B06 14; | STROBE width: fixed        |
| 6C 3B07 18; | FREX mode 1 selection      |
| 6C 3B0A 24; | STROBE output enable       |
| 6C 3011 00; | enable FREX pin            |

Mode 2 (see [figure 4-15](#) and [figure 4-16](#)) frame exposure request comes from the external system via the SCCB register 0x3B08[0]. The sensor outputs two signals, shutter control signal through the FREX pin and strobe signal through the STROBE pin. When the sensor is in FREX mode 2, by default the FREX output signal maintains a high status until the signal is triggered. After trigger the FREX pin outputs a low control signal. The polarity of the FREX output signal can be changed by setting 0x3B07[2]to 1'b1.

Frame exposure time is defined by {0x3B01[7:0], 0x3B04[7:0], 0x3B05[7:0]} with one step equal to 128tp/bit. If OV5647 works at 96MHz, each step is equal to 1.33μs and the minimum exposure time is 1.33μs with 0x3811 = 0x00, 0x3B04 = 0x00 and 0x3B05 = 0x01; the maximum exposure time is 22.37s with 0x3811 = 0xFF, 0x3B04 = 0xFF and 0x3B05 = 0xFF.

A shutter delay time is defined by {0x3B02[4:0], 0x3B03[7:0]} to compensate for the mechanical shutter delay. One step is equal to 128tp/bit. The minimum shutter delay time is 0 with 0x3B02 = 0x00 and 0x3B03 = 0x00. With PCLK = 96MHz, each step is equal to 1.33μs and the maximum shutter delay is 10.92ms with 0x3B02 = 0x1F and 0x3B03 = 0xFF.

In [figure 4-15](#) and [figure 4-16](#) control of the relationship between shutter delay and the exposure time is realized by the following timing control. For FREXOUT signal,  $T_4 - T_2 = T_{exp} + T_{pchg}$ ; For FTX signal,  $T_4 - T_1 = T_{delay}$

**table 4-11** FREX mode 2 timing point description

| timing point | description                                 |
|--------------|---------------------------------------------|
| $T_0$        | end of SCCB request                         |
| $T_1$        | beginning of FREX output                    |
| $T_2$        | beginning of global reset                   |
| $T_3$        | end of global reset (beginning of exposure) |
| $T_4$        | external shutter close (end of exposure)    |

$T_1$  may be in front of or behind  $T_2$  based on whether the  $T_{delay}$  is longer than  $T_{pchg} + T_{exp}$  ( $T_1 > T_2$  see [figure 4-15](#)) or  $T_{delay}$  is shorter than  $T_{pchg} + T_{exp}$  ( $T_1 < T_2$  see [figure 4-16](#)).

**figure 4-15** FREX mode 2 timing diagram (when shutter delay is longer than exposure time)



**note:** Tdelay: shutter delay time  
Texp: exposure time  
Trst: global reset time

5647\_DS\_4\_15

**figure 4-16** FREX mode 2 timing diagram (when shutter delay is shorter than exposure time)



**note:** Tdelay: shutter delay time  
Texp: exposure time  
Trst: global reset time

5647\_DS\_4\_16

Example setting (see **figure 4-15**):

```

6C 3B06 14;
6C 3B07 1D;          FREX mode 2 selection and FREX polarity selection
6C 3002 FF;          FREX mode selection: output
6C 3B01 00;
6C 3B04 04;
6C 3B05 00;          with PCLK = 96MHz, exposure time = 1.37ms
6C 3B02 08;
6C 3B03 00;          with PCLK = 96MHz, shutter delay = 2.72ms
6C 3B08 01;          SCCB FREX trigger

```

#### 4.10.2 STROBE control in FREX mode

In FREX mode, two modes of STROBE control are provided in OV5647 (see **figure 4-17**). The first mode provides controllable STROBE output high signal (0x3B06[4]to 1'b0) from 1 to 16 tp (0x3B06[3:0]). The second mode provides STROBE output high signal (0x3B06[4]to 1'b1) during whole exposure period.

**figure 4-17** STROBE control in FREX mode



## 4.11 FREX strobe flash control

See **table 4-12** for FREX strobe control functions.

**table 4-12** FREX strobe control functions

| address | register name          | default value | R/W | description                                                                                                                                                                                                                                                                                                                  |
|---------|------------------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3B00  | STROBE CTRL            | 0x00          | RW  | <p>Strobe Control</p> <p>Bit[7]: Strobe request ON/OFF<br/>0: OFF<br/>1: ON</p> <p>Bit[6]: Strobe pulse reverse</p> <p>Bit[3:2]: width_in_xenon<br/>00: 1 row period<br/>01: 2 row period<br/>10: 3 row period<br/>11: 4 row period</p> <p>Bit[1:0]: Strobe mode<br/>00: Xenon<br/>01: LED 1<br/>10: LED 2<br/>11: LED 3</p> |
| 0x3B01  | STROBE_FREX_EXP_H2     | 0x00          | RW  | Bit[7:0]: frex_exp[23:16]                                                                                                                                                                                                                                                                                                    |
| 0x3B02  | STROBE_SHUTTER_DLY     | 0x08          | RW  | Bit[4:0]: shutter_dly[12:8]                                                                                                                                                                                                                                                                                                  |
| 0x3B03  | STROBE_SHUTTER_DLY     | 0x00          | RW  | Bit[7:0]: shutter_dly[7:0]                                                                                                                                                                                                                                                                                                   |
| 0x3B04  | STROBE_FREX_EXP_H      | 0x04          | RW  | Bit[7:0]: frex_exp[15:8]                                                                                                                                                                                                                                                                                                     |
| 0x3B05  | STROBE_FREX_EXP_L      | 0x00          | RW  | Bit[7:0]: frex_exp[7:0]                                                                                                                                                                                                                                                                                                      |
| 0x3B06  | FREX CTRL              | 0x04          | RW  | <p>FREX Control</p> <p>Bit[7:6]: frex_pchg_width</p> <p>Bit[5:4]: frex_strobe_option</p> <p>Bit[3:0]: frex_strobe_width[3:0]</p>                                                                                                                                                                                             |
| 0x3B07  | STROBE_FREX_MODE_SEL   | 0x08          | RW  | <p>Bit[3]: fx1_fm_en</p> <p>Bit[2]: frex_inv</p> <p>Bit[1:0]: FREX mode select<br/>00: frex_strobe mode1<br/>01: frex_strobe mode2<br/>1x: Rolling strobe</p>                                                                                                                                                                |
| 0x3B08  | STROBE_FREX_EXP_REQ    | 0x00          | RW  | Bit[0]: frex_exp_req                                                                                                                                                                                                                                                                                                         |
| 0x3B09  | FREX_SHUTTER_DELAY     | 0x00          | RW  | Bit[2:0]: frex end option                                                                                                                                                                                                                                                                                                    |
| 0x3B0A  | STROBE_FREX_RST_LENGTH | 0x04          | RW  | Bit[2:0]: frex_RST_length[2:0]                                                                                                                                                                                                                                                                                               |
| 0x3B0B  | STROBE_WIDTH           | 0x00          | RW  | Bit[7:0]: frex_strobe_width[19:12]                                                                                                                                                                                                                                                                                           |
| 0x3B0C  | STROBE_WIDTH           | 0x3D          | RW  | Bit[7:0]: frex_strobe_width[11:4]                                                                                                                                                                                                                                                                                            |

## 4.12 one-time programmable (OTP) memory

The OV5647 has a total of 256 bits (32 bytes) of embedded one time programmable (OTP) memory. It can be programmed through a normal SCCB write and read back through a normal SCCB read. The AVDD voltage range during OTP programming is  $2.5V \pm 5\%$  and during OTP read, there is no such restriction.

The first 5 bytes (0x3D00~0x3D04) are reserved for OmniVision FAE use and the remaining 27 bytes (0x3D05~0x3D1F) can be used by users including module vendors.

**table 4-13     OTP control function registers (sheet 1 of 2)**

| address             | register name | default value | R/W | description   |
|---------------------|---------------|---------------|-----|---------------|
| 0x3D00 <sup>a</sup> | OTP_DATA_0    | 0x00          | RW  | OTP Buffer 0  |
| 0x3D01 <sup>a</sup> | OTP_DATA_1    | 0x00          | RW  | OTP Buffer 1  |
| 0x3D02 <sup>a</sup> | OTP_DATA_2    | 0x00          | RW  | OTP Buffer 2  |
| 0x3D03 <sup>a</sup> | OTP_DATA_3    | 0x00          | RW  | OTP Buffer 3  |
| 0x3D04 <sup>a</sup> | OTP_DATA_4    | 0x00          | RW  | OTP Buffer 4  |
| 0x3D05              | OTP_DATA_5    | 0x00          | RW  | OTP Buffer 5  |
| 0x3D06              | OTP_DATA_6    | 0x00          | RW  | OTP Buffer 6  |
| 0x3D07              | OTP_DATA_7    | 0x00          | RW  | OTP Buffer 7  |
| 0x3D08              | OTP_DATA_8    | 0x00          | RW  | OTP Buffer 8  |
| 0x3D09              | OTP_DATA_9    | 0x00          | RW  | OTP Buffer 9  |
| 0x3D0A              | OTP_DATA_A    | 0x00          | RW  | OTP Buffer A  |
| 0x3D0B              | OTP_DATA_B    | 0x00          | RW  | OTP Buffer B  |
| 0x3D0C              | OTP_DATA_C    | 0x00          | RW  | OTP Buffer C  |
| 0x3D0D              | OTP_DATA_D    | 0x00          | RW  | OTP Buffer D  |
| 0x3D0E              | OTP_DATA_E    | 0x00          | RW  | OTP Buffer E  |
| 0x3D0F              | OTP_DATA_F    | 0x00          | RW  | OTP Buffer F  |
| 0x3D10              | OTP_DATA_16   | 0x00          | RW  | OTP Buffer 10 |
| 0x3D11              | OTP_DATA_17   | 0x00          | RW  | OTP Buffer 11 |
| 0x3D12              | OTP_DATA_18   | 0x00          | RW  | OTP Buffer 12 |
| 0x3D13              | OTP_DATA_19   | 0x00          | RW  | OTP Buffer 13 |
| 0x3D14              | OTP_DATA_20   | 0x00          | RW  | OTP Buffer 14 |
| 0x3D15              | OTP_DATA_21   | 0x00          | RW  | OTP Buffer 15 |

**table 4-13** OTP control function registers (sheet 2 of 2)

| address             | register name    | default value | R/W | description                                                                                                                                                                                                               |
|---------------------|------------------|---------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3D16              | OTP_DATA_22      | 0x00          | RW  | OTP Buffer 16                                                                                                                                                                                                             |
| 0x3D17              | OTP_DATA_23      | 0x00          | RW  | OTP Buffer 17                                                                                                                                                                                                             |
| 0x3D18              | OTP_DATA_24      | 0x00          | RW  | OTP Buffer 18                                                                                                                                                                                                             |
| 0x3D19              | OTP_DATA_25      | 0x00          | RW  | OTP Buffer 19                                                                                                                                                                                                             |
| 0x3D1A              | OTP_DATA_26      | 0x00          | RW  | OTP Buffer 1A                                                                                                                                                                                                             |
| 0x3D1B              | OTP_DATA_27      | 0x00          | RW  | OTP Buffer 1B                                                                                                                                                                                                             |
| 0x3D1C              | OTP_DATA_28      | 0x00          | RW  | OTP Buffer 1C                                                                                                                                                                                                             |
| 0x3D1D              | OTP_DATA_29      | 0x00          | RW  | OTP Buffer 1D                                                                                                                                                                                                             |
| 0x3D1E              | OTP_DATA_30      | 0x00          | RW  | OTP Buffer 1E                                                                                                                                                                                                             |
| 0x3D1F              | OTP_DATA_31      | 0x00          | RW  | OTP Buffer 1F                                                                                                                                                                                                             |
| 0x3D20 <sup>b</sup> | OTP_PROGRAM_CTRL | 0x00          | RW  | <p>Bit[7]: OTP_wr_busy<br/>           Bit[1]: OTP_program_speed<br/>           0: Fast<br/>           1: Slow<br/>           Bit[0]: OTP_program_enable<br/>           Changing from 0 to 1 initiates OTP programming</p> |
| 0x3D21              | OTP_LOAD_CTRL    | 0x00          | RW  | <p>Bit[7]: OTP_rd_busy<br/>           Bit[1]: OTP speed<br/>           0: Fast<br/>           1: Slow<br/>           Bit[0]: OTP_load_enable<br/>           Changing from 0 to 1 initiates OTP read</p>                   |

- a. 0x3D00~0x3D04 is reserved for OmniVision internal use.
- b. AVDD must be  $2.5V \pm 5\%$  when writing/programming OTP; otherwise, there will be reliability issues. There is no such limitation when reading OTP under normal operating conditions.

The following sections provide instructions on how to program the OTP (can only be done once) and how to read back the OTP (can be done multiple times). Before read/write, make sure all sensor powers are properly provided and the sensor is up and running. The OTP module is at default enabled state, 0x301C[0] is 0 and 0x301C[4] is 1.

#### 4.12.1 OTP program

An example of programming OTP addresses 0x3D0C~0x3D0F is shown below. Make sure non-programmable addresses 0x3D00~0x3D0B and 0x3D10~0x3D1F are at default value of 0 to avoid accidental programming to other OTP addresses.

```
6C 3D20 00  
6C 3D21 00  
6C 3D0C 20  
6C 3D0D 41  
6C 3D0E 41  
6C 3D0F 11  
  
6C 3D20 01 // program the above 4 byte data  
#delay 10ms  
6C 3D20 00
```

Note that the procedure shown above can only be performed once for each sensor.

#### 4.12.2 OTP read

After programming and at any time after the sensor is powered on, use the procedure shown below to read back the OTP values. Before each read, the user can clear 0x3D00~0x3D1F registers first if just finished write.

```
//OTP Read  
6C 3D20 00  
6C 3D21 00  
6C 3D21 01 //Load data to registers  
#delay 1ms  
6C 3D0C ; read back OTP data  
6C 3D0D ; read back OTP data  
6C 3D0E ; read back OTP data  
6C 3D0F ; read back OTP data  
  
#delay 10ms  
6C 3D21 00
```

## 5 image sensor processor digital functions

### 5.1 ISP general controls

The ISP module provides image processor functions, including lens correction and defect pixel correction.

**table 5-1** ISP general control registers (sheet 1 of 2)

| address | register name | default value | R/W | description                                                                                                                                                                                                                                |
|---------|---------------|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x5000  | ISP CTRL00    | 0xFF          | RW  | ISP Control 00 (0: disable; 1: enable)<br>Bit[7]: Lens shading correction<br>Bit[2]: Black pixel correction<br>Bit[1]: White pixel correction                                                                                              |
| 0x5001  | ISP CTRL01    | 0x01          | RW  | ISP Control 01<br>Bit[0]: AWB<br>0: Disable<br>1: Enable                                                                                                                                                                                   |
| 0x5002  | ISP CTRL02    | 0x41          | RW  | ISP Control 02 (0: disable; 1: enable)<br>Bit[6]: win_en<br>Bit[1]: otp_en<br>Bit[0]: AWB gain                                                                                                                                             |
| 0x5003  | ISP CTRL03    | 0xA           | RW  | ISP Control 03 (0: disable; 1: enable)<br>Bit[3]: buf_en<br>Bit[2]: bin_man_set<br>Bit[1]: bin_auto_en                                                                                                                                     |
| 0x5005  | ISP CTRL05    | 0x14          | RW  | ISP Control 05 (0: disable; 1: enable)<br>Bit[5]: awb_bias_on<br>Bit[2]: lenc_bias_on                                                                                                                                                      |
| 0x501F  | ISP CTRL1F    | 0x03          | RW  | Bit[5]: enable_opt<br>0: Not latched by VSYNC<br>1: Enable latched by VSYNC<br>Bit[4]: cal_sel<br>0: DPC cal_start using SOF<br>1: DPC cal_start using VSYNC<br>Bit[2:0]: fmt_sel<br>011: ISP output data<br>Others: ISP input data bypass |
| 0x5025  | ISP CTRL25    | 0x00          | RW  | Bit[1:0]: avg_sel<br>00: Inputs of AVG module are from LENC output<br>01: Inputs of AVG module are from AWB gain output<br>10: Inputs of AVG module are from DPC output<br>11: Inputs of AVG module are from binning output                |

**table 5-1** ISP general control registers (sheet 2 of 2)

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|---------------|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x503D  | ISP CTRL3D    | 0x00          | RW  | <p>Bit[7]: test_pattern_en<br/>0: Disable<br/>1: Enable</p> <p>Bit[6]: rolling_bar<br/>0: Disable rolling bar<br/>1: Enable rolling bar</p> <p>Bit[5]: transparent_mode<br/>0: Disable<br/>1: Enable</p> <p>Bit[4]: squ_bw_mode<br/>0: Output square is color square<br/>1: Output square is black-white square</p> <p>Bit[3:2]: bar_style<br/>When set to a different value, a different type of color bar is output</p> <p>Bit[1:0]: test_pattern_type<br/>00: Color bar<br/>01: Square<br/>10: Random data<br/>11: Input data</p> |
| 0x503E  | ISP CTRL3E    | 0x00          | RW  | <p>Bit[6]: win_cut_en</p> <p>Bit[5]: isp_test<br/>0: Two lowest bits are 1<br/>1: Two lowest bits are 0</p> <p>Bit[4]: rnd_same<br/>0: Frame-changing random data pattern<br/>1: Frame-fixed random data pattern</p> <p>Bit[3:0]: rnd_seed<br/>Initial seed for random data pattern</p>                                                                                                                                                                                                                                              |
| 0x504B  | ISP CTRL4B    | 0x30          | RW  | <p>ISP Control<br/>(0: disable; 1: enable)</p> <p>Bit[5]: post_binning_h_enable</p> <p>Bit[4]: post_binning_v_enable</p> <p>Bit[3]: flip_man_en</p> <p>Bit[2]: flip_man</p> <p>Bit[1]: mirror_man_en</p> <p>Bit[0]: Mirror</p>                                                                                                                                                                                                                                                                                                       |

## 5.2 lens correction (LENC)

The lens correction (LENC) algorithm compensates for the illumination drop off in the corners due to the lens. Based on the radius of each pixel to the lens, the algorithm calculates a gain for each pixel and then corrects each pixel with the calculated gain to compensate for the light distribution due to the lens curvature. The LENC correcting curve is automatically calculated based on sensor gain so that LENC adapts with sensor gain.

**table 5-2** LENC control registers (sheet 1 of 2)

| address       | register name  | default value | R/W | description                                                                                                                                                                                                                                                  |
|---------------|----------------|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x5000        | ISP CTRL00     | 0x89          | RW  | Bit[7]: lenc_en<br>0: Disable<br>1: Enable                                                                                                                                                                                                                   |
| 0x5800~0x5023 | GMTRX          | –             | RW  | Bit[5:0]: Green matrix                                                                                                                                                                                                                                       |
| 0x5824~0x503C | BRMTRX         | –             | RW  | Bit[7:4]: Blue matrix<br>Bit[3:0]: Red matrix                                                                                                                                                                                                                |
| 0x583D        | LENC BR OFFSET | 0x88          | RW  | Bit[7:4]: lenc_b_offset<br>Bit[3:0]: lenc_r_offset                                                                                                                                                                                                           |
| 0x583E        | MAX GAIN       | 0x40          | RW  | Bit[7:0]: max_gain                                                                                                                                                                                                                                           |
| 0x583F        | MIN GAIN       | 0x20          | RW  | Bit[7:0]: min_gain                                                                                                                                                                                                                                           |
| 0x5840        | MIN Q          | 0x18          | RW  | Bit[6:0]: min_q                                                                                                                                                                                                                                              |
| 0x5841        | LENC CTRL59    | 0x0D          | RW  | Bit[3]: ADDBLC<br>0: Disable BLC add back function<br>1: Enable BLC add back function<br>Bit[2]: blc_en<br>0: Disable BLC function<br>1: Enable BLC function<br>Bit[1]: gain_man_en<br>Bit[0]: autoq_en<br>0: Used constant Q (0x40)<br>1: Used calculated Q |
| 0x5842        | BR HSCALE      | 0x01          | RW  | Bit[3:0]: br_hscale[11:8]<br>Reciprocal of horizontal step for BR channel. BR channel in whole image is divided into 5x5 blocks.<br>The step is used to point to the border of the adjacent block                                                            |

**table 5-2** LENC control registers (sheet 2 of 2)

| address | register name | default value | R/W | description                                                                                                                                                                                   |
|---------|---------------|---------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x5843  | BR HSCALE     | 0x2B          | RW  | Bit[7:0]: br_hscale[7:0]<br>Reciprocal of horizontal step for BR channel. BR channel in whole image is divided into 5x5 blocks. The step is used to point to the border of the adjacent block |
| 0x5844  | BR VSCALE     | 0x01          | RW  | Bit[2:0]: br_vscale[10:8]<br>Reciprocal of vertical step for BR channel. BR channel in whole image is divided into 5x5 blocks. The step is used to point to the border of the adjacent block  |
| 0x5845  | BR VSCALE     | 0x8D          | RW  | Bit[7:0]: br_vscale[7:0]<br>Reciprocal of vertical step for BR channel. BR channel in whole image is divided into 5x5 blocks. The step is used to point to the border of the adjacent block   |
| 0x5846  | G HSCALE      | 0x01          | RW  | Bit[3:0]: g_hscale[11:8]<br>Reciprocal of horizontal step for G channel. G channel in whole image is divided into 6x6 blocks. The step is used to point to the border of the adjacent block   |
| 0x5847  | G HSCALE      | 0x8F          | RW  | Bit[7:0]: g_hscale[7:0]<br>Reciprocal of horizontal step for G channel. G channel in whole image is divided into 6x6 blocks. The step is used to point to the border of the adjacent block    |
| 0x5848  | G VSCALE      | 0x01          | RW  | Bit[2:0]: g_vscale[10:8]<br>Reciprocal of vertical step for G channel. G channel in whole image is divided into 6x6 blocks. The step is used to point to the border of the adjacent block     |
| 0x5849  | G VSCALE      | 0x09          | RW  | Bit[7:0]: g_vscale[7:0]<br>Reciprocal of vertical step for G channel. G channel in whole image is divided into 6x6 blocks. The step is used to point to the border of the adjacent block      |

### 5.3 defect pixel cancellation (DPC)

Primarily due to process anomalies, pixel defects in the sensor array will occur, generating incorrect pixel levels and color values. The purpose of the defect pixel cancellation (DPC) is to remove the effects caused by defective pixels. To correctly remove defective pixels, the proper threshold should first be determined. Additionally, there are special functions available for those pixels located at the image boundary.

**table 5-3** defect pixel cancellation registers

| address | register name | default value | R/W | description                                                                          |
|---------|---------------|---------------|-----|--------------------------------------------------------------------------------------|
| 0x5000  | ISP CTRL00    | 0xFF          | RW  | Bit[2]: bc_en<br>0: Disable<br>1: Enable<br>Bit[1]: wc_en<br>0: Disable<br>1: Enable |

### 5.4 auto white balance (AWB)

The purpose of the auto white balance (AWB) block is to avoid unrealistic colors so that objects that appear white to the human eye are rendered white in the final image or video. This image sensor supports both manual white balance and simple auto white balance.

**table 5-4** AWB control registers (sheet 1 of 3)

| address | register name | default value | R/W | description                                    |
|---------|---------------|---------------|-----|------------------------------------------------|
| 0x5001  | ISP CTRL01    | 0x01          | RW  | Bit[0]: awb_en<br>0: Disable<br>1: Enable      |
| 0x5002  | ISP CTRL02    | 0x41          | RW  | Bit[0]: AWB_gain_en<br>0: Disable<br>1: Enable |

**table 5-4** AWB control registers (sheet 2 of 3)

| address | register name         | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|-----------------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x5180  | AWB CTRL              | 0x00          | RW  | <p>Bit[6]: fast_awb<br/>0: Disable fast AWB calculation function<br/>1: Enable fast AWB calculation function</p> <p>Bit[5]: freeze_gain_en<br/>When it is enabled, the output AWB gains will be input AWB gains</p> <p>Bit[4]: freeze_sum_en<br/>When it is set, the sums and averages value will be same as previous frame</p> <p>Bit[3]: gain_man_en<br/>0: Output calculated gains<br/>1: Output manual gains set by registers</p> <p>Bit[2]: start_sel<br/>0: Select the last HREF falling edge of before gain input as calculated start signal<br/>1: Select the last HREF falling edge of after gain input as calculated start signal</p> |
| 0x5181  | AWB DELTA             | 0x20          | RW  | <p>Bit[7]: delta_opt<br/>Bit[6]: base_man_en<br/>Bit[5:0]: awb_delta<br/>Delta value to increase or decrease the gains</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0x5182  | STABLE RANGE          | 0x04          | RW  | Bit[7:0]: stable_range                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0x5183  | STABLE RANGEW         | 0x08          | RW  | Bit[7:0]: stable_rangew<br>Wide stable range                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0x5186  | MANUAL RED GAIN MSB   | 0x04          | RW  | Bit[3:0]: red_gain_man[11:8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0x5187  | MANUAL RED GAIN LSB   | 0x00          | RW  | Bit[7:0]: red_gain_man[7:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x5188  | MANUAL GREEN GAIN MSB | 0x04          | RW  | Bit[3:0]: grn_gain_man[11:8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0x5189  | MANUAL GREEN GAIN LSB | 0x00          | RW  | Bit[7:0]: grn_gain_man[7:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x518A  | MANUAL BLUE GAIN MSB  | 0x04          | RW  | Bit[3:0]: blu_gain_man[11:8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0x518B  | MANUAL BLUE GAIN LSB  | 0x00          | RW  | Bit[7:0]: blu_gain_man[7:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

**table 5-4** AWB control registers (sheet 3 of 3)

| address | register name    | default value | R/W | description                                                                                                                                                                                                  |
|---------|------------------|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x518C  | RED GAIN LIMIT   | 0xF0          | RW  | Bit[7:4]: red_gain_up_limit<br>Bit[3:0]: red_gain_dn_limit<br>They are only the highest 4 bits of limitation.<br>Max red gain is {red_gan_up_limit,FF}<br>Min red gain is {red_gain_dn_limit,00}             |
| 0x518D  | GREEN GAIN LIMIT | 0xF0          | RW  | Bit[7:4]: green_gain_up_limit<br>Bit[3:0]: green_gain_dn_limit<br>They are only the highest 4 bits of limitation.<br>Max green gain is {green_gan_up_limit,FF}<br>Min green gain is {green_gain_dn_limit,00} |
| 0x518E  | BLUE GAIN LIMIT  | 0xF0          | RW  | Bit[7:4]: blue_gain_up_limit<br>Bit[3:0]: blue_gain_dn_limit<br>They are only the highest 4 bits of limitation.<br>Max blue gain is {blue_gan_up_limit,FF}<br>Min blue gain is {blue_gain_dn_limit,00}       |

## 5.5 post binning filter

Sub-sampling in the raw domain will cause zigzag artifacts on slanted edges and a color shift because of the non-uniformity of the pixel coordinates. The post binning filter maps the pixels to their physically correct location.

**table 5-5** post binning control registers

| address | register name | default value | R/W | description                  |
|---------|---------------|---------------|-----|------------------------------|
| 0x5003  | ISP CTRL3     | 0x0A          | RW  | Bit[2]: bin_en               |
| 0x504B  | ISP CTRL75    | 0x30          | RW  | Bit[5]: h_en<br>Bit[4]: v_en |

**OV5647**

color CMOS QSXGA (5 megapixel) image sensor with OmniBSI™ technology

Confidential for  
Zhongxindian



proprietary to OmniVision Technologies

PRODUCT SPECIFICATION

version 2.1

## 6 image sensor output interface digital functions

### 6.1 system control

System control registers include clock, reset control, and PLL configure.

**table 6-1** system control registers (sheet 1 of 4)

| address | register name     | default value | R/W | description                                                                                                                                                             |
|---------|-------------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3000  | SC_CMMN_PAD_OEN0  | 0x00          | RW  | I/O Direction (0: input; 1: output)<br>Bit[1:0]: D[9:8]                                                                                                                 |
| 0x3001  | SC_CMMN_PAD_OEN1  | 0x00          | RW  | I/O Direction (0: input; 1: output)<br>Bit[7:0]: D[7:0]                                                                                                                 |
| 0x3002  | SC_CMMN_PAD_OEN2  | 0x00          | RW  | I/O Direction (0: input; 1: output)<br>Bit[7]: VSYNC<br>Bit[6]: HREF<br>Bit[5]: PCLK<br>Bit[4]: FREX<br>Bit[3]: STROBE<br>Bit[2]: SDA<br>Bit[1]: GPIO1<br>Bit[0]: GPIO0 |
| 0x3006  | SC_CMMN_PLL_CTR13 | 0x00          | RW  | Bit[5:2]: SDIV<br>Clock divider for 50/60 Hz detection block                                                                                                            |
| 0x3008  | SC_CMMN_PAD_OUT0  | 0x00          | RW  | I/O Output Value<br>Bit[1:0]: D[9:8]                                                                                                                                    |
| 0x3009  | SC_CMMN_PAD_OUT1  | 0x00          | RW  | I/O Output Value<br>Bit[7:0]: D[7:0]                                                                                                                                    |
| 0x300A  | SC_CMMN_CHIP_ID   | 0x56          | R   | Chip ID High Byte                                                                                                                                                       |
| 0x300B  | SC_CMMN_CHIP_ID   | 0x47          | R   | Chip ID Low Byte                                                                                                                                                        |
| 0x300C  | SC_CMMN_SCCB_ID   | 0x6C          | RW  | SCCB ID                                                                                                                                                                 |
| 0x300D  | SC_CMMN_PAD_OUT2  | 0x00          | RW  | I/O Output Value<br>Bit[7]: VSYNC<br>Bit[6]: HREF<br>Bit[5]: PCLK<br>Bit[4]: FREX<br>Bit[3]: STROBE<br>Bit[2]: SDA<br>Bit[1]: GPIO1<br>Bit[0]: GPIO0                    |
| 0x300E  | SC_CMMN_PAD_SEL0  | 0x00          | RW  | I/O Pad Select<br>Bit[1:0]: D[9:8]                                                                                                                                      |

**table 6-1** system control registers (sheet 2 of 4)

| address | register name      | default value | R/W | description                                                                                                                                                                                                                                                                                                               |
|---------|--------------------|---------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x300F  | SC_CMMN_PAD_SEL1   | 0x00          | RW  | I/O Pad Select<br>Bit[7:0]: D[7:0]                                                                                                                                                                                                                                                                                        |
| 0x3010  | SC_CMMN_PAD_SEL2   | 0x00          | RW  | I/O Pad Select<br>Bit[7]: VSYNC<br>Bit[6]: HREF<br>Bit[5]: PCLK<br>Bit[4]: FREX<br>Bit[3]: STROBE<br>Bit[2]: SDA<br>Bit[1]: GPIO1<br>Bit[0]: GPIO0                                                                                                                                                                        |
| 0x3011  | SC_CMMN_PAD_PK     | 0x02          | RW  | Bit[7]: pd_data_en<br>Bit[6:5]: IO drive strength<br>00: 1x<br>01: 1x<br>10: 2x<br>11: 2x<br>Bit[1]: FREX pad enable                                                                                                                                                                                                      |
| 0x3013  | SC_CMMN_A_PWC_PK_O | 0x00          | RW  | Bit[3]: bp_regulator<br>0: Enable internal regulator<br>1: Disable internal regulator                                                                                                                                                                                                                                     |
| 0x3014  | SC_CMMN_A_PWC_PK_O | 0x0B          | RW  | Bit[6:4]: apd[2:0]<br>Bit[3:0]: dio                                                                                                                                                                                                                                                                                       |
| 0x3016  | SC_CMMN_MIPI_PHY   | 0x00          | RW  | Bit[7:6]: lph<br>Bit[3]: mipi_pad_enable<br>Bit[2]: pgm_bp_hs_en_lat<br>Bypass the latch of hs_enable<br>Bit[1:0]: ictl[1:0]<br>Bias current adjustment                                                                                                                                                                   |
| 0x3017  | SC_CMMN_MIPI_PHY   | 0x10          | RW  | Bit[7:6]: pgm_vcm[1:0]<br>High speed common mode voltage<br>Bit[5:4]: pgm_lptx[1:0]<br>Driving strength of low speed transmitter 01<br>Bit[3]: ihalf<br>Bias current reduction<br>Bit[2]: pgm_vicd<br>CD input low voltage<br>Bit[1]: pgm_vih<br>CD input high voltage-dummy<br>Bit[0]: pgm_hs_valid<br>Valid delay-dummy |

**table 6-1** system control registers (sheet 3 of 4)

| address | register name        | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|----------------------|---------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3018  | SC_CMMN_MIPI_SC_CTRL | 0x58          | RW  | <p>Bit[7:5]: mipi_lane_mode<br/>001: One lane mode<br/>010: Two lane mode<br/>others: Not used</p> <p>Bit[4]: r_phy_pd_mipi<br/>1: Power down PHY HS TX</p> <p>Bit[3]: r_phy_pd_lprx<br/>1: Power down PHY LP RX module</p> <p>Bit[2]: mipi_en<br/>0: DVP enable<br/>1: MIPI enable</p> <p>Bit[1]: mipi_susp_reg<br/>MIPI system suspend register<br/>1: Suspend</p> <p>Bit[0]: lane_dis_op<br/>0: Use mipi_release1/2 and lane_disable1/2 to disable two data lane<br/>1: Use lane_disable1/2 to disable two data lane</p> |
| 0x3019  | SC_CMMN_MIPI_SC_CTRL | 0x10          | RW  | Bit[7:0]: MIPI ULPS resume mark1 detect length                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0x3021  | SC_CMMN_MISC_CTRL    | 0x23          | RW  | <p>Bit[5]: fst_stby_ctr<br/>0: Software standby enter at v_blk<br/>1: Software standby enter at l_blk</p> <p>Bit[4]: mipi_ctr_en<br/>0: Disable the function<br/>1: Enable MIPI remote reset and suspend control SC</p> <p>Bit[3]: mipi_RST_SEL<br/>0: MIPI remote reset all registers<br/>1: MIPI remote reset all digital modules</p> <p>Bit[2]: gpio_pclk_en</p> <p>Bit[1]: frex_ef_sel</p> <p>Bit[0]: cen_global_o</p>                                                                                                  |
| 0x3022  | SC_CMMN_MIPI_SC_CTRL | 0x00          | RW  | <p>Bit[3]: lptx_ck_opt</p> <p>Bit[2]: pull_down_clk_lane</p> <p>Bit[1]: pull_down_data_lane2</p> <p>Bit[0]: pull_down_data_lane1</p>                                                                                                                                                                                                                                                                                                                                                                                        |
| 0x302A  | SC_CMMN_SUB_ID       | 0xB1          | R   | <p>Bit[7:4]: Process</p> <p>Bit[3:0]: Version</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

**table 6-1 system control registers (sheet 4 of 4)**

| address | register name          | default value | R/W | description                                                                                                                                                                |
|---------|------------------------|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3034  | SC_CMMN_PLL_CTRL0      | 0x1A          | RW  | Bit[6:4]: pll_charge_pump<br>Bit[3:0]: mipi_bit_mode<br>0000: 8 bit mode<br>0001: 10 bit mode                                                                              |
| 0x3035  | SC_CMMN_PLL_CTRL1      | 0x11          | RW  | Bit[7:4]: system_pll_div<br>Bit[3:0]: scale_divider_mipi                                                                                                                   |
| 0x3036  | SC_CMMN_PLL_MULTIPLIER | 0x69          | RW  | Bit[7:0]: PLL_multiplier (4~252)<br>This can be any integer during 4~127 and only even integer during 128~252                                                              |
| 0x3037  | SC_CMMN_PLL_CTR13      | 0x03          | RW  | Bit[4]: pll_root_div<br>0: Bypass<br>1: /2<br>Bit[3:0]: pll_prediv<br>1, 2, 3, 4, 6, 8                                                                                     |
| 0x3038  | SC_CMMN_PLL_DEBUG_OPT  | 0x00          | RW  | Bit[7]: pll_mult_debug_en<br>Bit[1:0]: pll_mult1_debug                                                                                                                     |
| 0x3039  | SC_CMMN_PLL_CTRL_R     | 0x00          | RW  | Bit[7]: pll_bypass                                                                                                                                                         |
| 0x303A  | SC_CMMN_PLLS_CTRL0     | 0x00          | RW  | Bit[7]: plls_bypass                                                                                                                                                        |
| 0x303B  | SC_CMMN_PLLS_CTRL1     | 0x19          | RW  | Bit[4:0]: plls_multiplier                                                                                                                                                  |
| 0x303C  | SC_CMMN_PLLS_CTRL2     | 0x11          | RW  | Bit[6:4]: plls_cp<br>Bit[3:0]: plls_sys_div                                                                                                                                |
| 0x303D  | SC_CMMN_PLLS_CTRL3     | 0x30          | RW  | Bit[5:4]: plls_pre_div<br>00: /1<br>01: /1.5<br>10: /2<br>11: /3<br>Bit[2]: plls_div_r<br>0: /1<br>1: /2<br>Bit[1:0]: plls_seld5<br>00: /1<br>01: /1<br>10: /2<br>11: /2.5 |

## 6.2 SCCB

**table 6-2** system control registers

| address | register name   | default value | R/W | description |
|---------|-----------------|---------------|-----|-------------|
| 0x300C  | SC_CMMN_SCCB_ID | 0x6C          | RW  | SCCB ID     |

## 6.3 group register write

The OV5647 supports group register write with up to four groups. Each group could have up to 16 registers.

Example settings:

```
6C 0x3208 0x00; Group 0 begin
6C 0x3503 0x03; register 1
6C 0x3501 0x7A; register 2
6C 0x3502 0xA0; register 3
6C 0x3208 0x10; Group 0 end
6C 0x3208 0xA0; write register group 0
```

**table 6-3** group hold control registers (sheet 1 of 2)

| address | register name | default value | R/W | description                                                         |
|---------|---------------|---------------|-----|---------------------------------------------------------------------|
| 0x3200  | GROUP ADR0    | 0x00          | RW  | Group0 Start Address in SRAM, actual address is {0x3200[3:0], 4'h0} |
| 0x3201  | GROUP ADR1    | 0x04          | RW  | Group1 Start Address in SRAM, actual address is {0x3201[3:0], 4'h0} |
| 0x3202  | GROUP ADR2    | 0x08          | RW  | Group2 Start Address in SRAM, actual address is {0x3202[3:0], 4'h0} |
| 0x3203  | GROUP ADR3    | 0x0B          | RW  | Group3 Start Address in SRAM, actual address is {0x3203[3:0], 4'h0} |
| 0x3204  | GROUP LEN0    | —             | R   | Length of Group0                                                    |
| 0x3205  | GROUP LEN1    | —             | R   | Length of Group1                                                    |
| 0x3206  | GROUP LEN2    | —             | R   | Length of Group2                                                    |
| 0x3207  | GROUP LEN3    | —             | R   | Length of Group3                                                    |

**table 6-3** group hold control registers (sheet 2 of 2)

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                |
|---------|---------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3208  | GROUP ACCESS  | –             | W   | <p>Bit[7:4]: Group_ctrl<br/>           0000: Enter group write mode<br/>           0001: Exit group write mode<br/>           1010: Initiate group write</p> <p>Bit[3:0]: Group ID<br/>           0000: Group 0<br/>           0001: Group 1<br/>           0010: Group 2<br/>           0011: Group 3</p> |

## 6.4 timing control

**table 6-4** timing control registers (sheet 1 of 2)

| address | register name        | default value | R/W | description                                 |
|---------|----------------------|---------------|-----|---------------------------------------------|
| 0x3800  | TIMING_X_ADDR_START  | 0x00          | RW  | Bit[3:0]: x_addr_start[11:8]                |
| 0x3801  | TIMING_X_ADDR_START  | 0x0C          | RW  | Bit[7:0]: x_addr_start[7:0]                 |
| 0x3802  | TIMING_Y_ADDR_START  | 0x00          | RW  | Bit[3:0]: y_addr_start[11:8]                |
| 0x3803  | TIMING_Y_ADDR_START  | 0x04          | RW  | Bit[7:0]: y_addr_start[7:0]                 |
| 0x3804  | TIMING_X_ADDR_END    | 0x0A          | RW  | Bit[3:0]: x_addr_end[11:8]                  |
| 0x3805  | TIMING_X_ADDR_END    | 0x33          | RW  | Bit[7:0]: x_addr_end[7:0]                   |
| 0x3806  | TIMING_Y_ADDR_END    | 0x07          | RW  | Bit[3:0]: y_addr_end[11:8]                  |
| 0x3807  | TIMING_Y_ADDR_END    | 0xA3          | RW  | Bit[7:0]: y_addr_end[7:0]                   |
| 0x3808  | TIMING_X_OUTPUT_SIZE | 0x0A          | RW  | Bit[3:0]: DVP output horizontal width[11:8] |
| 0x3809  | TIMING_X_OUTPUT_SIZE | 0x20          | RW  | Bit[7:0]: DVP output horizontal width[7:0]  |
| 0x380A  | TIMING_Y_OUTPUT_SIZE | 0x07          | RW  | Bit[3:0]: DVP output vertical height[11:8]  |
| 0x380B  | TIMING_Y_OUTPUT_SIZE | 0x98          | RW  | Bit[7:0]: DVP output vertical height[7:0]   |
| 0x380C  | TIMINGHTS            | 0x0A          | RW  | Bit[4:0]: Total horizontal size[12:8]       |
| 0x380D  | TIMINGHTS            | 0x8C          | RW  | Bit[7:0]: Total horizontal size[7:0]        |
| 0x380E  | TIMING_VTS           | 0x07          | RW  | Bit[7:0]: Total vertical size[15:8]         |
| 0x380F  | TIMING_VTS           | 0xB0          | RW  | Bit[7:0]: Total vertical size[7:0]          |
| 0x3810  | TIMING_ISP_X_WIN     | 0x00          | RW  | Bit[3:0]: ISP horizontal offset[11:8]       |

**table 6-4** timing control registers (sheet 2 of 2)

| address | register name    | default value | R/W | description                                                                                                                          |
|---------|------------------|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------|
| 0x3811  | TIMING_ISP_X_WIN | 0x04          | RW  | Bit[7:0]: ISP horizontal offset[7:0]                                                                                                 |
| 0x3812  | TIMING_ISP_Y_WIN | 0x00          | RW  | Bit[3:0]: ISP vertical offset[11:8]                                                                                                  |
| 0x3813  | TIMING_ISP_Y_WIN | 0x02          | RW  | Bit[7:0]: ISP vertical offset[7:0]                                                                                                   |
| 0x3814  | TIMING_X_INC     | 0x11          | RW  | Bit[7:4]: h_odd_inc<br>Horizontal subsample odd increase number<br>Bit[3:0]: h_even_inc<br>Horizontal subsample even increase number |
| 0x3815  | TIMING_Y_INC     | 0x11          | RW  | Bit[7:4]: v_odd_inc<br>Vertical subsample odd increase number<br>Bit[3:0]: v_even_inc<br>Vertical subsample even increase number     |
| 0x3816  | TIMING_HSYNCST   | 0x00          | RW  | Bit[3:0]: HSYNC start point[11:8]                                                                                                    |
| 0x3817  | TIMING_HSYNCST   | 0x00          | RW  | Bit[7:0]: HSYNC start point[7:0]                                                                                                     |
| 0x3818  | TIMING_HSYNCW    | 0x00          | RW  | Bit[3:0]: HSYNC window[11:8]                                                                                                         |
| 0x3819  | TIMING_HSYNCW    | 0x00          | RW  | Bit[7:0]: HSYNC window[7:0]                                                                                                          |
| 0x3820  | TIMING_TC_REG20  | 0x40          | RW  | Bit[2]: ISP vertical flip<br>Bit[1]: Sensor vertical flip<br>Bit[0]: Vertical binning                                                |
| 0x3821  | TIMING_TC_REG21  | 0x00          | RW  | Bit[2]: ISP mirror<br>Bit[1]: Sensor mirror<br>Bit[0]: Horizontal binning                                                            |

Confidential  
Zhongxingdian

## 6.5 frame control (FC)

Frame control (FC) is used to mask some specified frame by setting the appropriate registers.

**table 6-5** frame control registers

| address | register name   | default value | R/W | description                                                                                                                                                                |
|---------|-----------------|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x4200  | FRAME CONTROL00 | 0x00          | RW  | Bit[2]: fcnt_eof_sel<br>Bit[1]: fcnt_mask_dis<br>Bit[0]: Frame counter reset                                                                                               |
| 0x4201  | FRAME CONTROL01 | 0x00          | RW  | Control Passed Frame Number<br>Bit[3:0]: Frame ON number<br>When both ON and OFF numbers are set to 0x00, frame control is in bypass mode                                  |
| 0x4202  | FRAME CONTROL02 | 0x00          | RW  | Control Masked Frame Number<br>Bit[3:0]: Frame OFF number<br>When both ON and OFF numbers are set to 0x00, frame control is in bypass mode                                 |
| 0x4203  | FRAME CONTROL03 | 0x00          | RW  | Bit[6]: rblue_mask_dis<br>Bit[5]: data_mask_dis<br>Bit[4]: valid_mask_dis<br>Bit[3]: href_mask_dis<br>Bit[2]: eof_mask_dis<br>Bit[1]: sof_mask_dis<br>Bit[0]: all_mask_dis |

## 6.6 digital video port (DVP)

The Digital Video Port (DVP) provides 10-bit parallel data output in all formats supported and extended features including compression mode, HSYNC mode, CCIR656 mode, and test pattern output.

**table 6-6** DVP registers (sheet 1 of 2)

| address | register name        | default value | R/W | description                                                                                                |
|---------|----------------------|---------------|-----|------------------------------------------------------------------------------------------------------------|
| 0x4700  | DVP MODE SELECT      | 0x04          | RW  | Bit[3]: CCIR v select<br>Bit[2]: CCIR f select<br>Bit[1]: CCIR656 mode enable<br>Bit[0]: HSYNC mode enable |
| 0x4701  | DVP VSYNC WIDTH CTRL | 0x01          | RW  | VSYNC Width (in terms of number of lines)                                                                  |
| 0x4702  | DVP_HSYVSY_NEG_WIDTH | 0x01          | RW  | Bit[7:0]: VSYNC length[15:8] (in terms of pixel count)                                                     |

**table 6-6** DVP registers (sheet 2 of 2)

| address | register name        | default value | R/W | description                                                                                                                                                                                                                           |
|---------|----------------------|---------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x4703  | DVP_HSYVSY_NEG_WIDTH | 0x00          | RW  | Bit[7:0]: VSYNC length[7:0] (in terms of pixel count)                                                                                                                                                                                 |
| 0x4704  | DVP VSYNC MODE       | 0x00          | RW  | Bit[3:2]: r_vsyncount_sel<br>Bit[1]: r_vsync3_mod<br>Bit[0]: r_vsync2_mod                                                                                                                                                             |
| 0x4705  | DVP_EOF_VSYNC DELAY  | 0x00          | RW  | Bit[7:0]: eof_vsync_delay[23:16]<br>SOF/EOF negative edge to VSYNC positive edge delay                                                                                                                                                |
| 0x4706  | DVP_EOF_VSYNC DELAY  | 0x00          | RW  | Bit[7:0]: eof_vsync_delay[15:8]<br>SOF/EOF negative edge to VSYNC positive edge delay                                                                                                                                                 |
| 0x4707  | DVP_EOF_VSYNC DELAY  | 0x00          | RW  | Bit[7:0]: eof_vsync_delay[7:0]<br>SOF/EOF negative edge to VSYNC positive edge delay                                                                                                                                                  |
| 0x4708  | DVP_POL_CTRL         | 0x01          | RW  | Bit[7]: Clock DDR mode enable<br>Bit[5]: VSYNC gated clock enable<br>Bit[4]: HREF gated clock enable<br>Bit[3]: No first for FIFO<br>Bit[2]: HREF polarity reverse<br>Bit[1]: VSYNC polarity reverse<br>Bit[0]: PCLK polarity reverse |
| 0x4709  | BIT_TEST_PATTERN     | 0x00          | RW  | Bit[7]: FIFO bypass mode<br>Bit[6:4]: Data bit swap<br>Bit[3]: Bit test mode<br>Bit[2]: 10-bit bit test<br>Bit[1]: 8-bit bit test<br>Bit[0]: Bit test enable                                                                          |
| 0x470A  | DVP_BYP_CTRL         | 0x00          | RW  | Bit[7:0]: bypass_ctrl[15:8]                                                                                                                                                                                                           |
| 0x470B  | DVP_BYP_CTRL         | 0x00          | RW  | Bit[7:0]: bypass_ctrl[7:0]                                                                                                                                                                                                            |
| 0x470C  | DVP_BYP_SEL          | 0x00          | RW  | Bit[4]: HREF select<br>Bit[3:0]: Bypass select                                                                                                                                                                                        |

## 6.6.1 DVP timing

figure 6-1 DVP timing diagram

**note**

Timing values shown in **table 6-7** may vary depending upon register settings.

table 6-7 DVP timing specifications (sheet 1 of 2)

| mode                     | timing                                                                                                                                                                                                                          |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5 Megapixel<br>2592x1944 | <ul style="list-style-type: none"> <li>(1) 5,313,600 tp</li> <li>(2) 2,956 tp</li> <li>(3) 29,624 tp</li> <li>(4) 2,700 tp</li> <li>(5) 32,328 tp</li> <li>(6) 2,592 tp</li> <li>(7) 108 tp</li> </ul> <p>where tp = 1 pclk</p> |
| 1080p<br>1920x1080       | <ul style="list-style-type: none"> <li>(1) 2,720,256 tp</li> <li>(2) 2,720 tp</li> <li>(3) 27,464 tp</li> <li>(4) 2,464 tp</li> <li>(5) 29,496 tp</li> <li>(6) 1,920 tp</li> <li>(7) 544 tp</li> </ul> <p>where tp = 1 pclk</p> |
| 960p<br>1280x960         | <ul style="list-style-type: none"> <li>(1) 1,857,792 tp</li> <li>(2) 2,144 tp</li> <li>(3) 13,640 tp</li> <li>(4) 1,888 tp</li> <li>(5) 30,136 tp</li> <li>(6) 1,280 tp</li> <li>(7) 608 tp</li> </ul> <p>where tp = 1 pclk</p> |

**table 6-7** DVP timing specifications (sheet 2 of 2)

| mode             | timing                                                                                                                                                                                                                          |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 720p<br>1280x720 | <ul style="list-style-type: none"> <li>(1) 1,404,672 tp</li> <li>(2) 2,144 tp</li> <li>(3) 21,192 tp</li> <li>(4) 1,888 tp</li> <li>(5) 22,584 tp</li> <li>(6) 1,280 tp</li> <li>(7) 608 tp</li> </ul> <p>where tp = 1 pclk</p> |
| VGA<br>640x480   | <ul style="list-style-type: none"> <li>(1) 927,360 tp</li> <li>(2) 2,096 tp</li> <li>(3) 12,056 tp</li> <li>(4) 1,840 tp</li> <li>(5) 31,208 tp</li> <li>(6) 640 tp</li> <li>(7) 1,200 tp</li> </ul> <p>where tp = 1 pclk</p>   |

Confidential for  
Zhongxindian

## 6.7 mobile industry processor interface (MIPI)

The OV5647 provides one clock lane and two data lanes for the communications link between sensor (transmitter) and receiver inside a mobile device. It follows MIPI specifications D-PHY 0.89 and above and CSI2-V1, and supports all mandatory MIPI features. Most of the optional features (e.g., LP transfer mode) are not supported unless otherwise specified in this specification. For any further questions, contact your local OmniVision FAE for more details.

**table 6-8** MIPI transmitter registers (sheet 1 of 6)

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|---------------|---------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x4800  | MIPI CTRL 00  | 0x04          | RW  | <p>MIPI Control 00</p> <p>Bit[7:6]: Debug mode</p> <p>Bit[5]: Clock lane gate enable</p> <p>0: Clock lane is free running<br/>1: Gate clock lane when no packet to transmit</p> <p>Bit[4]: Line sync enable</p> <p>0: Do not send line short packet for each line<br/>1: Send line short packet for each line</p> <p>Lane select</p> <p>0: Use lane1 as default data lane<br/>1: Use lane2 as default data lane</p> <p>Bit[2]: Idle status</p> <p>0: MIPI bus will be LP00 when no packet to transmit<br/>1: MIPI bus will be LP11 when no packet to transmit</p> <p>Bit[1:0]: Debug mode</p> |

Confidential for  
Zhongxindian

**table 6-8** MIPI transmitter registers (sheet 2 of 6)

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|---------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x4801  | MIPI CTRL 01  | 0x0F          | RW  | <p>MIPI Control 01</p> <p>Bit[7]: Long packet data type manual enable<br/>0: Use mipi_dt<br/>1: Use dt_man_o as long packet data (see register 0x4814[5:0])</p> <p>Bit[6]: Short packet data type manual enable<br/>1: Use dt_spkt as short packet data (see register 0x4815[5:0])</p> <p>Bit[5]: Short packet word counter manual enable<br/>0: Use frame counter or line counter<br/>1: Select spkt_wc_reg_o (see {0x4812, 0x4813})</p> <p>Bit[4]: PH bit order for ECC<br/>0: {DI[7:0],WC[7:0],WC[15:8]}<br/>1: {DI[0:7],WC[0:7],WC[8:15]}</p> <p>Bit[3]: PH byte order for ECC<br/>0: {DI,WC_L,WC_h}<br/>1: {DI,WC_h,WC_L}</p> <p>Bit[2]: PH byte order2 for ECC<br/>0: {DI,WC}<br/>1: {WC,DI}</p> <p>Bit[1:0]: Debug mode</p> |

Confidential  
Zhongxindian

**table 6-8 MIPI transmitter registers (sheet 3 of 6)**

| address | register name        | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|----------------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x4802  | MIPI CTRL 02         | 0x00          | RW  | <p>MIPI Control 02</p> <p>Bit[7]: hs_prepare_sel<br/>0: Auto calculate T_hs_prepare, unit pclk2x<br/>1: Use hs_prepare_min_o[7:0]</p> <p>Bit[6]: clk_prepare_sel<br/>0: Auto calculate T_clk_prepare, unit pclk2x<br/>1: Use clk_prepare_min_o[7:0]</p> <p>Bit[5]: clk_post_sel<br/>0: Auto calculate T_clk_post, unit pclk2x<br/>1: Use clk_post_min_o[7:0]</p> <p>Bit[4]: clk_trail_sel<br/>0: Auto calculate T_clk_trail, unit pclk2x<br/>1: Use clk_trail_min_o[7:0]</p> <p>Bit[3]: hs_exit_sel<br/>0: Auto calculate T_hs_exit, unit pclk2x<br/>1: Use hs_exit_min_o[7:0]</p> <p>Bit[2]: hs_zero_sel<br/>0: Auto calculate T_hs_zero, unit pclk2x<br/>1: Use hs_zero_min_o[7:0]</p> <p>Bit[1]: hs_trail_sel<br/>0: Auto calculate T_hs_trail, unit pclk2x<br/>1: Use hs_trail_min_o[7:0]</p> <p>Bit[0]: clk_zero_sel<br/>0: Auto calculate T_clk_zero, unit pclk2x<br/>1: Use clk_zero_min_o[7:0]</p> |
| 0x4805  | MIPI CTRL 05         | 0x10          | RW  | <p>MIPI Control 05</p> <p>Bit[7]: MIPI lane1 disable<br/>1: Disable MIPI data lane1, lane1 will be LP00</p> <p>Bit[6]: MIPI lane2 disable<br/>1: Disable MIPI data lane2, lane2 will be LP00</p> <p>Bit[5]: lpx_p_sel<br/>0: Auto calculate t_lpx_o in pclkex domain, unit pclk2x<br/>1: Use lp_p_min[7:0]</p> <p>Bit[4]: lp_rx_intr_sel<br/>0: Send lp_rx_intr_o at the first byte of receiving<br/>1: Send lp_rx_intr_o at the end of receiving</p> <p>Bit[3:1]: Debug mode</p> <p>Bit[0]: Not used</p>                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0x4810  | MIPI MAX FRAME COUNT | 0xFF          | RW  | High Byte of Max Frame Count of Frame Sync Short Packet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

**table 6-8** MIPI transmitter registers (sheet 4 of 6)

| address | register name        | default value | R/W | description                                                                                                                            |
|---------|----------------------|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------|
| 0x4811  | MIPI MAX FRAME COUNT | 0xFF          | RW  | Low Byte of Max Frame Count of Frame Sync Short Packet                                                                                 |
| 0x4814  | MIPI CTRL14          | 0x2A          | RW  | MIPI Control 14<br>Bit[7:6]: Virtual channel of MIPI<br>Bit[5:0]: Data type in manual mode                                             |
| 0x4815  | MIPI_DT_SPKT         | 0x00          | RW  | Bit[6]: Debug Mode<br>Bit[5:0]: Manual data type for short packet                                                                      |
| 0x4818  | HS_ZERO_MIN          | 0x00          | RW  | High Byte of the Minimum Value for hs_zero Unit ns                                                                                     |
| 0x4819  | HS_ZERO_MIN          | 0x96          | RW  | Low Byte of the Minimum Value for hs_zero, unit ns<br>$hs\_zero\_real = hs\_zero\_min\_o + Tui * ui\_hs\_zero\_min\_o$                 |
| 0x481A  | HS_TRAIL_MIN         | 0x00          | RW  | High Byte of the Minimum Value for hs_trail, unit ns                                                                                   |
| 0x481B  | HS_TRAIL_MIN         | 0x3C          | RW  | Low Byte of the Minimum Value for hs_trail, unit ns<br>$hs\_trail\_real = hs\_trail\_min\_o + Tui * ui\_hs\_trail\_min\_o$             |
| 0x481C  | CLK_ZERO_MIN         | 0x01          | RW  | High Byte of the Minimum Value for clk_zero, unit ns                                                                                   |
| 0x481D  | CLK_ZERO_MIN         | 0x86          | RW  | Low Byte of the Minimum Value for clk_zero, unit ns<br>$clk\_zero\_real = clk\_zero\_min\_o + Tui * ui\_clk\_zero\_min\_o$             |
| 0x481E  | CLK_PREPARE_MIN      | 0x00          | RW  | High Byte of the Minimum Value for clk_prepare, unit ns<br>Bit[1:0]: clk_prepare_min[9:8]                                              |
| 0x481F  | CLK_PREPARE_MIN      | 0x3C          | RW  | Low Byte of the Minimum Value for clk_prepare, unit ns<br>$clk\_prepare\_real = clk\_prepare\_min\_o + Tui * ui\_clk\_prepare\_min\_o$ |
| 0x4820  | CLK_POST_MIN         | 0x00          | RW  | High Byte of the Minimum Value for clk_post, unit ns<br>Bit[1:0]: clk_post_min[9:8]                                                    |
| 0x4821  | CLK_POST_MIN         | 0x56          | RW  | Low Byte of the Minimum Value for clk_post, unit ns<br>$clk\_post\_real = clk\_post\_min\_o + Tui * ui\_clk\_post\_min\_o$             |
| 0x4822  | CLK_TRAIL_MIN        | 0x00          | RW  | High Byte of the Minimum Value for clk_trail, unit ns<br>Bit[1:0]: clk_trail_min[9:8]                                                  |
| 0x4823  | CLK_TRAIL_MIN        | 0x3C          | RW  | Low Byte of the Minimum Value for clk_trail, unit ns<br>$clk\_trail\_real = clk\_trail\_min\_o + Tui * ui\_clk\_trail\_min\_o$         |
| 0x4824  | Lpx_P_MIN            | 0x00          | RW  | High Byte of the Minimum Value for lpx_p, unit ns<br>Bit[1:0]: lpx_p_min[9:8]                                                          |
| 0x4825  | Lpx_P_MIN            | 0x32          | RW  | Low Byte of the Minimum Value for lpx_p, unit ns<br>$lpx\_p\_real = lpx\_p\_min\_o + Tui * ui\_lpx\_p\_min\_o$                         |

**table 6-8** MIPI transmitter registers (sheet 5 of 6)

| address | register name      | default value | R/W | description                                                                                                                  |
|---------|--------------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------|
| 0x4826  | HS_PREPARE_MIN     | 0x00          | RW  | High Byte of the Minimum Value for hs_prepare, unit ns<br>Bit[1:0]: hs_prepare_min[9:8]                                      |
| 0x4827  | HS_PREPARE_MIN     | 0x32          | RW  | Low Byte of the Minimum Value for hs_prepare<br>hs_prepare_real = hs_prepare_min_o +<br>Tui*ui_hs_prepare_min_o              |
| 0x4828  | HS_EXIT_MIN        | 0x00          | RW  | High Byte of the Minimum Value for hs_exit, unit ns<br>Bit[1:0]: hs_exit_min[9:8]                                            |
| 0x4829  | HS_EXIT_MIN        | 0x64          | RW  | Low Byte of the Minimum Value for hs_exit<br>hs_exit_real = hs_exit_min_o + Tui*ui_hs_exit_min_o                             |
| 0x482A  | UI_HS_ZERO_MIN     | 0x05          | RW  | Minimum UI Value of hs_zero, unit UI                                                                                         |
| 0x482B  | UI_HS_TRAIL_MIN    | 0x04          | RW  | Minimum UI Value of hs_trail, unit UI                                                                                        |
| 0x482C  | UI_CLK_ZERO_MIN    | 0x00          | RW  | Minimum UI Value of clk_zero, unit UI                                                                                        |
| 0x482D  | UI_CLK_PREPARE_MIN | 0x00          | RW  | Minimum UI Value of clk_prepare, unit UI                                                                                     |
| 0x482E  | UI_CLK_POST_MIN    | 0x34          | RW  | Minimum UI Value of clk_post, unit UI                                                                                        |
| 0x482F  | UI_CLK_TRAIL_MIN   | 0x00          | RW  | Minimum UI Value of clk_trail, unit UI                                                                                       |
| 0x4830  | UI_LPX_P_MIN       | 0x00          | RW  | Minimum UI Value of lpx_p, unit UI                                                                                           |
| 0x4831  | UI_HS_PREPARE_MIN  | 0x04          | RW  | Minimum UI Value of hs_prepare, unit UI                                                                                      |
| 0x4832  | UI_HS_EXIT_MIN     | 0x00          | RW  | Minimum UI Value of hs_exit, unit UI                                                                                         |
| 0x4833  | MIPI_REG_MIN       | 0x00          | RW  | MIPI Register Address, Lower Bound (High Byte)<br>Address range of MIPI RW registers is from<br>mipi_reg_min to mipi_reg_max |
| 0x4834  | MIPI_REG_MIN       | 0x00          | RW  | MIPI Register Address, Lower Bound (Low Byte)                                                                                |
| 0x4835  | MIPI_REG_MAX       | 0xFF          | RW  | MIPI Register Address, Upper Bound (High Byte)                                                                               |
| 0x4836  | MIPI_REG_MAX       | 0xFF          | RW  | MIPI Register Address, Upper Bound (Low Byte)                                                                                |
| 0x4837  | PCLK_PERIOD        | 0x15          | RW  | Period of pclk2x, pclk_div = 1, and 1-bit decimal                                                                            |
| 0x4838  | WKUP_DLY           | 0x02          | RW  | Wakeup delay for MIPI                                                                                                        |
| 0x483A  | DEBUG MODE         | -             | -   | Debug Mode                                                                                                                   |

**table 6-8** MIPI transmitter registers (sheet 6 of 6)

| address       | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------|---------------|---------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x483B        | MIPI_LP_GPIO  | 0x33          | RW  | <p>Bit[7]: lp_sel1<br/>0: Auto generate mipi_lp_dir1_o<br/>1: Use lp_dir_man1 as mipi_lp_dir1_o</p> <p>Bit[6]: lp_dir_man1<br/>0: Input<br/>1: Output</p> <p>Bit[5]: lp_p1_o</p> <p>Bit[4]: lp_n1_o</p> <p>Bit[3]: lp_sel2<br/>0: Auto generate mipi_lp_dir2_o<br/>1: Use lp_dir_man2 as mipi_lp_dir2_o</p> <p>Bit[2]: lp_dir_man2<br/>0: Input<br/>1: Output</p> <p>Bit[1]: lp_p2_o</p> <p>Bit[0]: lp_n2_o</p> |
| 0x483C        | MIPI CTRL 33  | 0x4F          | RW  | <p>Bit[7:4]: t_lpx<br/>Unit: sclk cycles</p> <p>Bit[3:0]: t_clk_pre<br/>Unit: sclk cycles</p>                                                                                                                                                                                                                                                                                                                   |
| 0x483D~0x483F | DEBUG MODE    | -             | -   | Debug Mode                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0x4843        | SNR_PCLK_DIV  | 0x00          | RW  | <p>Bit[0]: PCLK divider<br/>0: PCLK/SCLK = 2 and pclk_div = 1<br/>1: PCLK/SCLK = 1 and pclk_div = 1</p>                                                                                                                                                                                                                                                                                                         |

**OV5647**

color CMOS QSXGA (5 megapixel) image sensor with OmniBSI™ technology

Confidential for  
Zhongxindian



proprietary to OmniVision Technologies

PRODUCT SPECIFICATION

version 2.1

## 7 register tables

The following tables provide descriptions of the device control registers contained in the OV5647. For all registers enable/disable bits, ENABLE = 1 and DISABLE = 0. The device slave addresses are 0x6C for write and 0x6D for read.

### 7.1 system control [0x3000 - 0x3209]

**table 7-1** system control registers (sheet 1 of 5)

| address       | register name     | default value | R/W | description                                                                                                                                                                                                      |
|---------------|-------------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3000        | SC_CMMN_PAD_OEN0  | 0x00          | RW  | I/O Direction (0: input; 1: output)<br>Bit[7:2]: Not used<br>Bit[1:0]: D[9:8]                                                                                                                                    |
| 0x3001        | SC_CMMN_PAD_OEN1  | 0x00          | RW  | I/O Direction (0: input; 1: output)<br>Bit[7:0]: D[7:0]                                                                                                                                                          |
| 0x3002        | SC_CMMN_PAD_OEN2  | 0x00          | RW  | I/O Direction (0: input; 1: output)<br>Bit[7]: VSYNC<br>Bit[6]: HREF<br>Bit[5]: PCLK<br>Bit[4]: FREX<br>Bit[3]: STROBE<br>Bit[2]: SDA<br>Bit[1]: GPIO1<br>Bit[0]: GPIO0                                          |
| 0x3003~0x3005 | DEBUG MODE        | -             | -   | Debug Mode                                                                                                                                                                                                       |
| 0x3006        | SC_CMMN_PLL_CTR13 | 0x00          | RW  | Bit[7:6]: Debug control<br>Changing these registers is not recommended<br>Bit[5:2]: SDIV<br>Clock divider for 50/60 Hz detection block<br>Bit[1:0]: Debug control<br>Changing these registers is not recommended |
| 0x3007        | DEBUG MODE        | -             | -   | Debug Mode                                                                                                                                                                                                       |
| 0x3008        | SC_CMMN_PAD_OUT0  | 0x00          | RW  | I/O Output Value<br>Bit[7:2]: Not used<br>Bit[1:0]: D[9:8]                                                                                                                                                       |
| 0x3009        | SC_CMMN_PAD_OUT1  | 0x00          | RW  | I/O Output Value<br>Bit[7:0]: D[7:0]                                                                                                                                                                             |
| 0x300A        | SC_CMMN_CHIP_ID   | 0x56          | R   | Chip ID High Byte                                                                                                                                                                                                |
| 0x300B        | SC_CMMN_CHIP_ID   | 0x47          | R   | Chip ID Low Byte                                                                                                                                                                                                 |

**table 7-1** system control registers (sheet 2 of 5)

| address | register name      | default value | R/W | description                                                                                                                                                                                                                                                                                      |
|---------|--------------------|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x300C  | SC_CMMN_SCCB_ID    | 0x6C          | RW  | SCCB ID                                                                                                                                                                                                                                                                                          |
| 0x300D  | SC_CMMN_PAD_OUT2   | 0x00          | RW  | <p>I/O Output Value</p> <p>Bit[7]: VSYNC<br/>       Bit[6]: HREF<br/>       Bit[5]: PCLK<br/>       Bit[4]: FREX<br/>       Bit[3]: STROBE<br/>       Bit[2]: SDA<br/>       Bit[1]: GPIO1<br/>       Bit[0]: GPIO0</p>                                                                          |
| 0x300E  | SC_CMMN_PAD_SEL0   | 0x00          | RW  | <p>I/O Pad Select</p> <p>Bit[7:2]: Not used<br/>       Bit[1:0]: D[9:8]</p>                                                                                                                                                                                                                      |
| 0x300F  | SC_CMMN_PAD_SEL1   | 0x00          | RW  | <p>I/O Pad Select</p> <p>Bit[7:0]: D[7:0]</p>                                                                                                                                                                                                                                                    |
| 0x3010  | SC_CMMN_PAD_SEL2   | 0x00          | RW  | <p>I/O Pad Select</p> <p>Bit[7]: VSYNC<br/>       Bit[6]: HREF<br/>       Bit[5]: PCLK<br/>       Bit[4]: FREX<br/>       Bit[3]: STROBE<br/>       Bit[2]: SDA<br/>       Bit[1]: GPIO1<br/>       Bit[0]: GPIO0</p>                                                                            |
| 0x3011  | SC_CMMN_PAD_PK     | 0x02          | RW  | <p>Bit[7]: pd_dato_en<br/>       Bit[6:5]: IO drive strength<br/>       00: 1x<br/>       01: 1x<br/>       10: 2x<br/>       11: 2x<br/>       Bit[4:2]: Not used<br/>       Bit[1]: FREX pad enable<br/>       0: Enable<br/>       1: Disable<br/>       Bit[0]: Not used</p>                 |
| 0x3012  | DEBUG MODE         | -             | -   | Debug Mode                                                                                                                                                                                                                                                                                       |
| 0x3013  | SC_CMMN_A_PWC_PK_O | 0x00          | RW  | <p>Bit[7:4]: Debug control<br/>       Changing these registers is not recommended<br/>       Bit[3]: bp_regulator<br/>       0: Enable internal regulator<br/>       1: Disable internal regulator<br/>       Bit[2:0]: Debug control<br/>       Changing these registers is not recommended</p> |

**table 7-1** system control registers (sheet 3 of 5)

| address | register name        | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|----------------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3014  | SC_CMMN_A_PWC_PK_O   | 0x0B          | RW  | Bit[7]: Not used<br>Bit[6:4]: apd[2:0]<br>Bit[3:0]: dio                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0x3016  | SC_CMMN_MIPI_PHY     | 0x00          | RW  | Bit[7:6]: lph<br>Bit[5:4]: Not used<br>Bit[3]: mipi_pad_enable<br>Bit[2]: pgm_bp_hs_en_lat<br>Bypass the latch of hs_enable<br>Bit[1:0]: ictl[1:0]<br>Bias current adjustment                                                                                                                                                                                                                                                                                                                                                      |
| 0x3017  | SC_CMMN_MIPI_PHY     | 0x10          | RW  | Bit[7:6]: pgm_vcm[1:0]<br>High speed common mode voltage<br>Bit[5:4]: pgm_lptx[1:0]<br>Driving strength of low speed transmitter 01<br>Bit[3]: ihalf<br>Bias current reduction<br>Bit[2]: pgm_vicd<br>CD input low voltage<br>Bit[1]: pgm_vih<br>CD input high voltage-dummy<br>Bit[0]: pgm_hs_valid<br>Valid delay-dummy                                                                                                                                                                                                          |
| 0x3018  | SC_CMMN_MIPI_SC_CTRL | 0x58          | RW  | Bit[7:5]: mipi_lane_mode<br>001: One lane mode<br>010: Two lane mode<br>others: Not used<br>Bit[4]: r_phy_pd_mipi<br>0: Not used<br>1: Power down PHY HS TX<br>Bit[3]: r_phy_pd_lprx<br>0: Not used<br>1: Power down PHY LP RX module<br>Bit[2]: mipi_en<br>0: DVP enable<br>1: MIPI enable<br>Bit[1]: mipi_susp_reg<br>MIPI system suspend register<br>0: Not used<br>1: Suspend<br>Bit[0]: lane_dis_op<br>0: Use mipi_release1/2 and lane_disable1/2 to disable two data lane<br>1: Use lane_disable1/2 to disable two data lane |

**table 7-1** system control registers (sheet 4 of 5)

| address       | register name          | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------|------------------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3019        | SC_CMMN_MIPI_SC_CTRL   | 0x10          | RW  | Bit[7:0]: MIPI ULPS resume mark1 detect length                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0x301A~0x3020 | DEBUG MODE             | -             | -   | Debug Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0x3021        | SC_CMMN_MISC_CTRL      | 0x23          | RW  | <p>Bit[7:6]: Not used</p> <p>Bit[5]: fst_stby_ctrl</p> <p>0: Software standby enter at v_blk</p> <p>1: Software standby enter at l_blk</p> <p>Bit[4]: mipi_ctr_en</p> <p>1: Enable MIPI remote reset and suspend control SC</p> <p>0: Disable the function</p> <p>Bit[3]: mipi_RST_SEL</p> <p>0: MIPI remote reset all registers</p> <p>1: MIPI remote reset all digital modules</p> <p>Bit[2]: gpio_pclk_en</p> <p>Bit[1]: frex_ef_sel</p> <p>Bit[0]: cen_global_o</p> |
| 0x3022        | SC_CMMN_MIPI_SC_CTRL   | 0x00          | RW  | <p>Bit[7:4]: Not used</p> <p>Bit[3]: lptx_ck_opt</p> <p>Bit[2]: pull_down_clk_lane</p> <p>Bit[1]: pull_down_data_lane2</p> <p>Bit[0]: pull_down_data_lane1</p>                                                                                                                                                                                                                                                                                                          |
| 0x302A        | SC_CMMN_SUB_ID         | 0xB1          | R   | <p>Bit[7:4]: Process Version</p> <p>Bit[3:0]: Version</p>                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0x3034        | SC_CMMN_PLL_CTRL0      | 0x1A          | RW  | <p>Bit[7]: Not used</p> <p>Bit[6:4]: pll_charge_pump</p> <p>Bit[3:0]: mipi_bit_mode</p> <p>1000: 8 bit mode</p> <p>1010: 10 bit mode</p>                                                                                                                                                                                                                                                                                                                                |
| 0x3035        | SC_CMMN_PLL_CTRL1      | 0x11          | RW  | <p>Bit[7:4]: system_pll_div</p> <p>Bit[3:0]: scale_divider_mipi</p>                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x3036        | SC_CMMN_PLL_MULTIPLIER | 0x69          | RW  | <p>Bit[7:0]: PLL_multiplier (4~252)</p> <p>This can be any integer during 4~127 and only even integer during 128~252</p>                                                                                                                                                                                                                                                                                                                                                |

**table 7-1** system control registers (sheet 5 of 5)

| address       | register name         | default value | R/W | description                                                                                                                                                                                                                                                                                    |
|---------------|-----------------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3037        | SC_CMMN_PLL_CTR13     | 0x03          | RW  | <p>Bit[7:5]: Debug mode</p> <p>Bit[4]: pll_root_div</p> <p>0: Bypass</p> <p>1: /2</p> <p>Bit[3:0]: pll_preditv</p> <p>1, 2, 3, 4, 6, 8</p>                                                                                                                                                     |
| 0x3038        | SC_CMMN_PLL_DEBUG_OPT | 0x00          | RW  | <p>Bit[7]: pll_mult_debug_en</p> <p>Bit[1:0]: pll_mult1_debug</p>                                                                                                                                                                                                                              |
| 0x3039        | SC_CMMN_PLL_CTRL_R    | 0x00          | RW  | <p>Bit[7]: pll_bypass</p> <p>Bit[6:0]: Not used</p>                                                                                                                                                                                                                                            |
| 0x303A        | SC_CMMN_PLLS_CTRL0    | 0x00          | RW  | <p>Bit[7]: plls_bypass</p> <p>Bit[6:0]: Not used</p>                                                                                                                                                                                                                                           |
| 0x303B        | SC_CMMN_PLLS_CTRL1    | 0x19          | RW  | <p>Bit[7:5]: Not used</p> <p>Bit[4:0]: plls_multiplier</p>                                                                                                                                                                                                                                     |
| 0x303C        | SC_CMMN_PLLS_CTRL2    | 0x11          | RW  | <p>Bit[6:4]: plls_cp</p> <p>Bit[3:0]: plls_sys_div</p>                                                                                                                                                                                                                                         |
| 0x303D        | SC_CMMN_PLLS_CTRL3    | 0x30          | RW  | <p>Bit[7:6]: Not used</p> <p>Bit[5:4]: plls_pre_div</p> <p>00: /1</p> <p>01: /1.5</p> <p>10: /2</p> <p>11: /3</p> <p>Bit[2]: plls_div_r</p> <p>0: /1</p> <p>1: /2</p> <p>Bit[1:0]: plls_seld5</p> <p>00: /1</p> <p>01: /1</p> <p>10: /2</p> <p>11: /2.5</p>                                    |
| 0x3040~0x3044 | DEBUG MODE            | -             | -   | Debug Mode                                                                                                                                                                                                                                                                                     |
| 0x3106        | SRB CTRL              | 0xF9          | RW  | <p>Bit[7:4]: Not used</p> <p>Bit[3:2]: PLL clock divider</p> <p>00: pll_sclk</p> <p>01: pll_sclk/2</p> <p>10: pll_sclk/4</p> <p>11: pll_sclk</p> <p>Bit[1]: rst_arb</p> <p>0: Not used</p> <p>1: Reset arbiter</p> <p>Bit[0]: sclk_arb</p> <p>0: Not used</p> <p>1: Enable SCLK to arbiter</p> |

## 7.2 group hold control [0x3200 - 0x3208]

**table 7-2** group hold control registers

| address | register name | default value | R/W | description                                                                                                                                                                                                 |
|---------|---------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3200  | GROUP ADR0    | 0x00          | RW  | Group0 Start Address in SRAM, actual address is {0x3200[3:0], 4'h0}                                                                                                                                         |
| 0x3201  | GROUP ADR1    | 0x04          | RW  | Group1 Start Address in SRAM, actual address is {0x3201[3:0], 4'h0}                                                                                                                                         |
| 0x3202  | GROUP ADR2    | 0x08          | RW  | Group2 Start Address in SRAM, actual address is {0x3202[3:0], 4'h0}                                                                                                                                         |
| 0x3203  | GROUP ADR3    | 0x0B          | RW  | Group3 Start Address in SRAM, actual address is {0x3203[3:0], 4'h0}                                                                                                                                         |
| 0x3204  | GROUP LEN0    | –             | R   | Length of Group0                                                                                                                                                                                            |
| 0x3205  | GROUP LEN1    | –             | R   | Length of Group1                                                                                                                                                                                            |
| 0x3206  | GROUP LEN2    | –             | R   | Length of Group2                                                                                                                                                                                            |
| 0x3207  | GROUP LEN3    | –             | R   | Length of Group3                                                                                                                                                                                            |
| 0x3208  | GROUP ACCESS  | –             | W   | Bit[7:4]: Group_ctrl<br>0000: Enter group write mode<br>0001: Exit group write mode<br>1010: Initiate group write<br>Bit[3:0]: Group ID<br>0000: Group 0<br>0001: Group 1<br>0010: Group 2<br>0011: Group 3 |
| 0x3209  | DEBUG MODE    | –             | –   | Debug Mode                                                                                                                                                                                                  |

### 7.3 AEC/AGC [0x3500 - 0x373A, 0x3A00 - 0x3A21, 0x5680 - 0x5A41]

**table 7-3** AEC/AGC registers (sheet 1 of 6)

| address       | register name  | default value | R/W | description                                                                                                                                                                                                                                                                                   |
|---------------|----------------|---------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3500        | EXPOSURE       | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: Exposure[19:16]<br>Exposure in units of 1/16 line                                                                                                                                                                                                             |
| 0x3501        | EXPOSURE       | 0x02          | RW  | Bit[7:0]: Exposure[15:8]<br>Exposure in units of 1/16 line                                                                                                                                                                                                                                    |
| 0x3502        | EXPOSURE       | 0x00          | RW  | Bit[7:0]: Exposure[7:0]<br>Exposure in units of 1/16 line; lower four bits are a fraction of a line; they should be 0 since OV5647 does not support fraction line exposure                                                                                                                    |
| 0x3503        | MANUAL CTRL    | 0x00          | RW  | Bit[7:6]: Not used<br>Bit[5:4]: Gain latch timing delay<br>x0: Gain has no latch delay<br>01: Gain delay of 1 frame<br>11: Gain delay of 2 frames<br>Bit[2]: Not used<br>Bit[1]: AGC manual<br>0: Auto enable<br>1: Manual enable<br>Bit[0]: AEC manual<br>0: Auto enable<br>1: Manual enable |
| 0x350A        | AGC            | 0x00          | RW  | Bit[7:2]: Not used<br>Bit[1:0]: Gain[9:8]<br>AGC real gain output high byte<br>Gain = {0x350A[1:0], 0x350B[7:0]}/16                                                                                                                                                                           |
| 0x350B        | AGC            | 0x10          | RW  | Bit[7:0]: Gain[7:0]<br>AGC real gain output low byte                                                                                                                                                                                                                                          |
| 0x3600~0x3637 | ANALOG_CONTROL | -             | RW  | Analog Control Registers                                                                                                                                                                                                                                                                      |
| 0x3700~0x373A | ANALOG_CONTROL | -             | RW  | Analog Control Registers                                                                                                                                                                                                                                                                      |
| 0x3A00        | AEC CTRL00     | 0x78          | RW  | Bit[7:6]: Not used<br>Bit[5]: Band function<br>Bit[4]: Band low limit mode<br>Bit[3]: start_sel<br>Bit[2]: Night mode<br>Bit[1]: Not used<br>Bit[0]: Freeze                                                                                                                                   |

**table 7-3 AEC/AGC registers (sheet 2 of 6)**

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                          |
|---------|---------------|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3A01  | MIN EXPO      | 0x01          | RW  | Bit[7:0]: Min expo                                                                                                                                                                                                                                                                                                                                                   |
| 0x3A02  | MAX EXPO 60   | 0x3D          | RW  | Bit[7:0]: Max expo[15:8]<br>Night mode ceiling of 60 Hz                                                                                                                                                                                                                                                                                                              |
| 0x3A03  | MAX EXPO 60   | 0x80          | RW  | Bit[7:0]: Max expo[7:0]<br>Night mode ceiling of 60 Hz                                                                                                                                                                                                                                                                                                               |
| 0x3A05  | AEC CTRL05    | 0x30          | RW  | Bit[7]: f50_reverse<br>0: Hold 50, 60Hz detect input<br>1: Switch 50, 60Hz detect input<br>Bit[6]: frame_insert<br>0: In night mode, insert frame disable<br>1: In night mode, insert frame enable<br>Bit[5]: step_auto_en<br>0: Step manual mode<br>1: Step auto mode<br>Bit[4:0]: step_auto_ratio<br>In step auto mode, set the step ratio setting to adjust speed |
| 0x3A06  | AEC CTRL06    | 0x10          | RW  | Bit[7:5]: Not used<br>Bit[4:0]: step_man1<br>Step manual<br>Increase mode fast step                                                                                                                                                                                                                                                                                  |
| 0x3A07  | AEC CTRL07    | 0x18          | RW  | Bit[7:4]: step_man2<br>Step manual, slow step<br>Bit[3:0]: step_man3<br>Step manual, decrease mode fast step                                                                                                                                                                                                                                                         |
| 0x3A08  | B50 STEP      | 0x01          | RW  | Bit[7:2]: Not used<br>Bit[1:0]: b50_step[9:8]<br>Banding step size for 50 Hz                                                                                                                                                                                                                                                                                         |
| 0x3A09  | B50 STEP      | 0x27          | RW  | Bit[7:0]: b50_step[7:0]<br>Banding step size for 50 Hz                                                                                                                                                                                                                                                                                                               |
| 0x3A0A  | B60 STEP      | 0x00          | RW  | Bit[7:2]: Not used<br>Bit[1:0]: b60_step[9:8]<br>Banding step size for 60 Hz                                                                                                                                                                                                                                                                                         |
| 0x3A0B  | B60 STEP      | 0xF6          | RW  | Bit[7:0]: b60_step[7:0]<br>Banding step size for 60 Hz                                                                                                                                                                                                                                                                                                               |
| 0x3A0C  | AEC CTRL0C    | 0xE4          | RW  | Bit[7:4]: e1_max<br>Decimal line high limit zone<br>Bit[3:0]: e1_min<br>Decimal line low limit zone                                                                                                                                                                                                                                                                  |

**table 7-3** AEC/AGC registers (sheet 3 of 6)

| address | register name        | default value | R/W | description                                                                                                      |
|---------|----------------------|---------------|-----|------------------------------------------------------------------------------------------------------------------|
| 0x3A0D  | B60 MAX              | 0x08          | RW  | Bit[7:6]: Not used<br>Bit[5:0]: b60_max<br>Max banding step number for 60 Hz                                     |
| 0x3A0E  | B50 MAX              | 0x06          | RW  | Bit[7:6]: Not used<br>Bit[5:0]: b50_max<br>Max banding step number for 50 Hz                                     |
| 0x3A0F  | WPT                  | 0x78          | RW  | Bit[7:0]: WPT<br>Stable range high limit (from unstable state to stable state)                                   |
| 0x3A10  | BPT                  | 0x68          | RW  | Bit[7:0]: BPT<br>Stable range low limit (from unstable state to stable state)                                    |
| 0x3A11  | HIGH VPT             | 0xD0          | RW  | Bit[7:0]: vpt_high<br>Fast zone high limit (when step ratio auto mode is disabled)                               |
| 0x3A12  | MANUAL AVG           | 0x00          | RW  | Bit[7:0]: avg_man                                                                                                |
| 0x3A13  | PRE GAIN             | 0x40          | RW  | Bit[7]: Not used<br>Bit[6]: Pre-gain enable<br>Bit[5:0]: Pre-gain value                                          |
| 0x3A14  | MAX EXPO 50          | 0x0E          | RW  | Bit[7:0]: Maximum expo[15:8]<br>Night mode ceiling of 50 Hz                                                      |
| 0x3A15  | MAX EXPO 50          | 0x40          | RW  | Bit[7:0]: Maximum expo[7:0]<br>Night mode ceiling of 50 Hz                                                       |
| 0x3A17  | NIGHT MODE GAIN BASE | 0x01          | RW  | Bit[7:2]: Not used<br>Bit[1:0]: gnight_thre<br>Night mode gain threshold<br>00: 1x<br>01: 2x<br>10: 4x<br>11: 8x |
| 0x3A18  | AEC GAIN CEILING     | 0x00          | RW  | Bit[7:2]: Not used<br>Bit[1:0]: gain_ceiling[9:8]<br>Gain ceiling = {0x3A18[1:0], 0x3A19[7:0]}/16                |
| 0x3A19  | AEC GAIN CEILING     | 0x7C          | RW  | Bit[7:0]: gain_ceiling[7:0]                                                                                      |
| 0x3A1A  | DIFF MAX             | 0x04          | RW  | Bit[7:0]: diff_max                                                                                               |
| 0x3A1B  | WPT2                 | 0x78          | RW  | Bit[7:0]: wpt2<br>Stable range high limit (from stable state to unstable state)                                  |

**table 7-3 AEC/AGC registers (sheet 4 of 6)**

| address | register name | default value | R/W | description                                                                                             |
|---------|---------------|---------------|-----|---------------------------------------------------------------------------------------------------------|
| 0x3A1C  | LED ADD ROW   | 0x06          | RW  | Bit[7:0]: led_add_row[15:8]<br>Exposure values added when STROBE is ON                                  |
| 0x3A1D  | LED ADD ROW   | 0x18          | RW  | Bit[7:0]: led_add_row[7:0]<br>Exposure values added when STROBE is ON                                   |
| 0x3A1E  | BPT2          | 0x68          | RW  | Bit[7:0]: bpt2<br>Stable range low limit (from stable state to unstable state)                          |
| 0x3A1F  | LOW VPT       | 0x40          | RW  | Bit[7:0]: vpt_low<br>Fast zone low limit (when step ration auto mode is disabled)                       |
| 0x3A20  | AEC CTRL20    | 0x00          | RW  | Bit[7:2]: Not used<br>Bit[1]: man_avg_en_i<br>0: Disable<br>1: Enable<br>Bit[0]: Not used               |
| 0x3A21  | AEC CTRL21    | 0x70          | RW  | Bit[7]: Not used<br>Bit[6:4]: Frame insert number<br>Bit[3:0]: Not used                                 |
| 0x5680  | X START       | 0x00          | RW  | Bit[7:5]: Not used<br>Bit[4:0]: x_start[11:8]<br>Horizontal start position for average window high byte |
| 0x5681  | X START       | 0x00          | RW  | Bit[7:0]: x_start[7:0]<br>Horizontal start position for average window low byte                         |
| 0x5682  | Y START       | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: y_start[10:8]<br>Vertical start position for average window high byte   |
| 0x5683  | Y START       | 0x00          | RW  | Bit[7:0]: y_start[7:0]<br>Vertical start position for average window low byte                           |
| 0x5684  | X WINDOW      | 0x0A          | RW  | Bit[7:5]: Not used<br>Bit[4:0]: x_window[12:8]<br>Window X in manual average window mode high byte      |
| 0x5685  | X WINDOW      | 0x20          | RW  | Bit[7:0]: x_window[7:0]<br>Window X in manual average window mode low byte                              |

**table 7-3 AEC/AGC registers (sheet 5 of 6)**

| address | register name  | default value | R/W | description                                                                                                                |
|---------|----------------|---------------|-----|----------------------------------------------------------------------------------------------------------------------------|
| 0x5686  | Y WINDOW       | 0x07          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: y_window[11:8]<br>Window Y in manual average window mode high byte                         |
| 0x5687  | Y WINDOW       | 0x98          | RW  | Bit[7:0]: y_window[7:0]<br>Window Y in manual average window mode low byte                                                 |
| 0x5688  | WEIGHT00       | 0x11          | RW  | Bit[7:4]: window1_weight<br>Bit[3:0]: window0_weight                                                                       |
| 0x5689  | WEIGHT01       | 0x11          | RW  | Bit[7:4]: window3_weight<br>Bit[3:0]: window2_weight                                                                       |
| 0x568A  | WEIGHT02       | 0x11          | RW  | Bit[7:4]: window5_weight<br>Bit[3:0]: window4_weight                                                                       |
| 0x568B  | WEIGHT03       | 0x11          | RW  | Bit[7:4]: window7_weight<br>Bit[3:0]: window6_weight                                                                       |
| 0x568C  | WEIGHT04       | 0x11          | RW  | Bit[7:4]: window9_weight<br>Bit[3:0]: window8_weight                                                                       |
| 0x568D  | WEIGHT05       | 0x11          | RW  | Bit[7:4]: window11_weight<br>Bit[3:0]: window10_weight                                                                     |
| 0x568E  | WEIGHT06       | 0x11          | RW  | Bit[7:4]: window13_weight<br>Bit[3:0]: window12_weight                                                                     |
| 0x568F  | WEIGHT07       | 0x11          | RW  | Bit[7:4]: window15_weight<br>Bit[3:0]: window14_weight                                                                     |
| 0x5690  | AVG CTRL10     | 0x02          | RW  | Bit[7:2]: Not used<br>Bit[1]: avg_opt<br>Bit[0]: avg_man<br>0: Auto average window<br>1: Manual average window             |
| 0x5691  | AVG WEIGHT SUM | -             | R   | avg_wt_sum_o                                                                                                               |
| 0x5692  | DEBUG MODE     | -             | -   | Debug Mode                                                                                                                 |
| 0x5693  | AVG READOUT    | -             | R   | Bit[7:0]: AVG value                                                                                                        |
| 0x5A00  | DIGC CTRL0     | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3]: Debug mode<br>Bit[2]: dig_comp_bypass<br>Bit[1]: dig_comp_man_opt<br>Bit[0]: dig_comp_man_en |
| 0x5A02  | DIG COMP MAN   | 0x02          | RW  | Bit[7:2]: Not used<br>Bit[1:0]: dig_comp_man[9:8]                                                                          |
| 0x5A03  | DIG COMP MAN   | 0x00          | RW  | Bit[7:0]: dig_comp_man[7:0]                                                                                                |

**table 7-3 AEC/AGC registers (sheet 6 of 6)**

| address | register name   | default value | R/W | description                                                                            |
|---------|-----------------|---------------|-----|----------------------------------------------------------------------------------------|
| 0x5A20  | SENSOR GAIN MAN | 0x00          | RW  | Bit[7:1]: Not used<br>Bit[0]: gainc_sensorgain_man[8]                                  |
| 0x5A21  | SENR GAIN MAN   | 0x00          | RW  | Bit[7:0]: gainc_sensorgain_man[7:0]                                                    |
| 0x5A22  | DIG COMP MAN    | 0x00          | RW  | Bit[7:2]: Not used<br>Bit[1:0]: gainc_dgc_man[9:8]                                     |
| 0x5A23  | DIG COMP MAN    | 0x00          | RW  | Bit[7:0]: gainc_dgc_man[7:0]                                                           |
| 0x5A24  | GAINC CTRL0     | 0x00          | RW  | Bit[7:3]: Not used<br>Bit[2]: Debug mode<br>Bit[1]: bypass_opt<br>Bit[0]: gainc_man_en |
| 0x5A40  | GAINF ANA NUM   | 0x07          | RW  | Bit[7:0]: gainf_ana_bit_num                                                            |
| 0x5A41  | GAINF DIG GAIN  | 0x00          | RW  | Bit[7:0]: gainf_dig_gain                                                               |

## 7.4 timing control [0x3800 - 0x3834]

**table 7-4 system timing registers (sheet 1 of 3)**

| address | register name        | default value | R/W | description                                                       |
|---------|----------------------|---------------|-----|-------------------------------------------------------------------|
| 0x3800  | TIMING_X_ADDR_START  | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: x_addr_start[11:8]                |
| 0x3801  | TIMING_X_ADDR_START  | 0x0C          | RW  | Bit[7:0]: x_addr_start[7:0]                                       |
| 0x3802  | TIMING_Y_ADDR_START  | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: y_addr_start[11:8]                |
| 0x3803  | TIMING_Y_ADDR_START  | 0x04          | RW  | Bit[7:0]: y_addr_start[7:0]                                       |
| 0x3804  | TIMING_X_ADDR_END    | 0x0A          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: x_addr_end[11:8]                  |
| 0x3805  | TIMING_X_ADDR_END    | 0x33          | RW  | Bit[7:0]: x_addr_end[7:0]                                         |
| 0x3806  | TIMING_Y_ADDR_END    | 0x07          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: y_addr_end[11:8]                  |
| 0x3807  | TIMING_Y_ADDR_END    | 0xA3          | RW  | Bit[7:0]: y_addr_end[7:0]                                         |
| 0x3808  | TIMING_X_OUTPUT_SIZE | 0x0A          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: DVP output horizontal width[11:8] |

**table 7-4** system timing registers (sheet 2 of 3)

| address | register name        | default value | R/W | description                                                                                                                          |
|---------|----------------------|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------|
| 0x3809  | TIMING_X_OUTPUT_SIZE | 0x20          | RW  | Bit[7:0]: DVP output horizontal width[7:0]                                                                                           |
| 0x380A  | TIMING_Y_OUTPUT_SIZE | 0x07          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: DVP output vertical height[11:8]                                                                     |
| 0x380B  | TIMING_Y_OUTPUT_SIZE | 0x98          | RW  | Bit[7:0]: DVP output vertical height[7:0]                                                                                            |
| 0x380C  | TIMINGHTS            | 0x0A          | RW  | Bit[7:5]: Not used<br>Bit[4:0]: Total horizontal size[12:8]                                                                          |
| 0x380D  | TIMINGHTS            | 0x8C          | RW  | Bit[7:0]: Total horizontal size[7:0]                                                                                                 |
| 0x380E  | TIMINGVTS            | 0x07          | RW  | Bit[7:0]: Total vertical size[15:8]                                                                                                  |
| 0x380F  | TIMINGVTS            | 0xB0          | RW  | Bit[7:0]: Total vertical size[7:0]                                                                                                   |
| 0x3810  | TIMING_ISP_X_WIN     | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: ISP horizontal offset[11:8]                                                                          |
| 0x3811  | TIMING_ISP_X_WIN     | 0x04          | RW  | Bit[7:0]: ISP horizontal offset[7:0]                                                                                                 |
| 0x3812  | TIMING_ISP_Y_WIN     | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: ISP vertical offset[11:8]                                                                            |
| 0x3813  | TIMING_ISP_Y_WIN     | 0x02          | RW  | Bit[7:0]: ISP vertical offset[7:0]                                                                                                   |
| 0x3814  | TIMING_X_INC         | 0x11          | RW  | Bit[7:4]: h_odd_inc<br>Horizontal subsample odd increase number<br>Bit[3:0]: h_even_inc<br>Horizontal subsample even increase number |
| 0x3815  | TIMING_Y_INC         | 0x11          | RW  | Bit[7:4]: v_odd_inc<br>Vertical subsample odd increase number<br>Bit[3:0]: v_even_inc<br>Vertical subsample even increase number     |
| 0x3816  | TIMING_HSYNCST       | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: HSYNC start point[11:8]                                                                              |
| 0x3817  | TIMING_HSYNCST       | 0x00          | RW  | Bit[7:0]: HSYNC start point[7:0]                                                                                                     |
| 0x3818  | TIMING_HSYNCW        | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: HSYNC window[11:8]                                                                                   |
| 0x3819  | TIMING_HSYNCW        | 0x00          | RW  | Bit[7:0]: HSYNC window[7:0]                                                                                                          |

**table 7-4** system timing registers (sheet 3 of 3)

| address       | register name   | default value | R/W | description                                                                                                                                                 |
|---------------|-----------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3820        | TIMING_TC_REG20 | 0x40          | RW  | Bit[7]: Not used<br>Bit[6:4]: For testing only<br>Bit[3]: Not used<br>Bit[2]: ISP vertical flip<br>Bit[1]: Sensor vertical flip<br>Bit[0]: Vertical binning |
| 0x3821        | TIMING_TC_REG21 | 0x00          | RW  | Bit[7:5]: For testing only<br>Bit[4]: Not used<br>Bit[3]: For testing only<br>Bit[2]: ISP mirror<br>Bit[1]: Sensor mirror<br>Bit[0]: Horizontal binning     |
| 0x3822~0x3834 | DEBUG MODE      | -             | -   | Debug Mode                                                                                                                                                  |

## 7.5 strobe/frame exposure [0x3B00 ~ 0x3B0C]

**table 7-5** strobe/frame exposure control registers (sheet 1 of 2)

| address | register name      | default value | R/W | description                                                                                                                                                                                                                                                                                     |
|---------|--------------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3B00  | STROBE_RSTRB       | 0x00          | RW  | Strobe Control<br>Bit[7]: Strobe request ON/OFF<br>0: OFF/BLC<br>1: ON<br>Bit[6]: Strobe pulse reverse<br>Bit[3:2]: width_in_xenon<br>00: 1 row period<br>01: 2 row period<br>10: 3 row period<br>11: 4 row period<br>Bit[1:0]: Strobe mode<br>00: xenon<br>01: LED 1<br>10: LED 2<br>11: LED 3 |
| 0x3B01  | STROBE_FREX_EXP_H2 | 0x00          | RW  | Bit[7:0]: frex_exp[23:16]                                                                                                                                                                                                                                                                       |
| 0x3B02  | STROBE_SHUTTER_DLY | 0x08          | RW  | Bit[7:0]: shutter_dly[12:8]                                                                                                                                                                                                                                                                     |
| 0x3B03  | STROBE_SHUTTER_DLY | 0x00          | RW  | Bit[7:0]: shutter_dly[7:0]                                                                                                                                                                                                                                                                      |
| 0x3B04  | STROBE_FREX_EXP_H  | 0x04          | RW  | Bit[7:0]: frex_exp[15:8]                                                                                                                                                                                                                                                                        |

**table 7-5** strobe/frame exposure control registers (sheet 2 of 2)

| address | register name          | default value | R/W | description                                                                                                                                                |
|---------|------------------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3B05  | STROBE_FREX_EXP_L      | 0x00          | RW  | Bit[7:0]: frex_exp[7:0]                                                                                                                                    |
| 0x3B06  | STROBE_FREX_CTRL0      | 0x04          | RW  | Bit[7:6]: frex_pchg_width<br>Bit[5:4]: frex_strobe_option<br>Bit[3:0]: frex_strobe_width[3:0]                                                              |
| 0x3B07  | STROBE_FREX_MODE_SEL   | 0x08          | RW  | Bit[4]: frex_sa1<br>Bit[3]: fx1_fm_en<br>Bit[2]: frex_inv<br>Bit[1:0]: FREX strobe<br>00: frex_strobe mode1<br>01: frex_strobe mode2<br>1x: Rolling strobe |
| 0x3B08  | STROBE_FREX_EXP_REQ    | 0x00          | RW  | Bit[7:1]: Not used<br>Bit[0]: frex_exp_req                                                                                                                 |
| 0x3B09  | FREX_SHUTTER_DELAY     | 0x00          | RW  | Bit[7:3]: Not used<br>Bit[2:0]: FREX end option                                                                                                            |
| 0x3B0A  | STROBE_FREX_RST_LENGTH | 0x04          | RW  | Bit[7:3]: Not used<br>Bit[2:0]: frex_RST_length[2:0]                                                                                                       |
| 0x3B0B  | STROBE_WIDTH           | 0x00          | RW  | Bit[7:0]: frex_strobe_width[19:12]                                                                                                                         |
| 0x3B0C  | STROBE_WIDTH           | 0x3D          | RW  | Bit[7:0]: frex_strobe_width[11:4]                                                                                                                          |

## 7.6 50/60 Hz detection [0x3C00 - 0x3C1E]

**table 7-6** 50/60 Hz detection registers (sheet 1 of 2)

| address | register name             | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|---------------------------|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3C00  | 50/60 HZ DETECTION CTRL00 | 0x00          | RW  | <p>Bit[7:6]: Debug control<br/>Changing these registers is not recommended</p> <p>Bit[5:3]: 50/60 Hz detection control<br/>Contact your local OmniVision FAE for the correct settings</p> <p>Bit[2]: band_def<br/>Band50 default value<br/>0: 60 Hz as default value<br/>1: 50 Hz as default value</p> <p>Bit[1:0]: 50/60 Hz detection control register<br/>Contact your local OmniVision FAE for the correct settings</p> |

**table 7-6** 50/60 Hz detection registers (sheet 2 of 2)

| address       | register name             | default value | R/W | description                                                                                                                                                                                                               |
|---------------|---------------------------|---------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3C01        | 50/60 HZ DETECTION CTRL01 | 0x00          | RW  | <p>Bit[7]: band_man_en<br/>Band detection manual mode<br/>0: Manual mode disable<br/>1: Manual mode enable</p> <p>Bit[6:0]: 50/60 Hz detection control<br/>Contact your local OmniVision FAE for the correct settings</p> |
| 0x3C02~0x3C0B | 50/60 HZ DETECTION CTRL02 | -             | RW  | 50/60 Hz detection Control<br>Contact your local OmniVision FAE for the correct settings                                                                                                                                  |
| 0x3C0C        | 50/60 HZ DETECTION CTRL0C | -             | R   | <p>Bit[7:1]: Debug control<br/>Changing these registers is not recommended</p> <p>band50<br/>0: Detection result is 60 Hz<br/>1: Detection result is 50 Hz</p>                                                            |
| 0x3C0D~0x3C1E | DEBUG INFORMATION         | -             | RW  | 50/60 Hz Detection Control<br>Contact your local OmniVision FAE for the correct settings                                                                                                                                  |

## 7.7 OTP control [0x3D00 - 0x3D21]

**table 7-7** OTP control registers (sheet 1 of 3)

| address             | register name | default value | R/W | description  |
|---------------------|---------------|---------------|-----|--------------|
| 0x3D00 <sup>a</sup> | OTP_DATA_0    | 0x00          | RW  | OTP Buffer 0 |
| 0x3D01 <sup>a</sup> | OTP_DATA_1    | 0x00          | RW  | OTP Buffer 1 |
| 0x3D02 <sup>a</sup> | OTP_DATA_2    | 0x00          | RW  | OTP Buffer 2 |
| 0x3D03 <sup>a</sup> | OTP_DATA_3    | 0x00          | RW  | OTP Buffer 3 |
| 0x3D04 <sup>a</sup> | OTP_DATA_4    | 0x00          | RW  | OTP Buffer 4 |
| 0x3D05              | OTP_DATA_5    | 0x00          | RW  | OTP Buffer 5 |
| 0x3D06              | OTP_DATA_6    | 0x00          | RW  | OTP Buffer 6 |
| 0x3D07              | OTP_DATA_7    | 0x00          | RW  | OTP Buffer 7 |
| 0x3D08              | OTP_DATA_8    | 0x00          | RW  | OTP Buffer 8 |
| 0x3D09              | OTP_DATA_9    | 0x00          | RW  | OTP Buffer 9 |

**table 7-7** OTP control registers (sheet 2 of 3)

| address             | register name    | default value | R/W | description                                                                                                                                                                                                                                                                             |
|---------------------|------------------|---------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3D0A              | OTP_DATA_A       | 0x00          | RW  | OTP Buffer A                                                                                                                                                                                                                                                                            |
| 0x3D0B              | OTP_DATA_B       | 0x00          | RW  | OTP Buffer B                                                                                                                                                                                                                                                                            |
| 0x3D0C              | OTP_DATA_C       | 0x00          | RW  | OTP Buffer C                                                                                                                                                                                                                                                                            |
| 0x3D0D              | OTP_DATA_D       | 0x00          | RW  | OTP Buffer D                                                                                                                                                                                                                                                                            |
| 0x3D0E              | OTP_DATA_E       | 0x00          | RW  | OTP Buffer E                                                                                                                                                                                                                                                                            |
| 0x3D0F              | OTP_DATA_F       | 0x00          | RW  | OTP Buffer F                                                                                                                                                                                                                                                                            |
| 0x3D10              | OTP_DATA_16      | 0x00          | RW  | OTP Buffer 10                                                                                                                                                                                                                                                                           |
| 0x3D11              | OTP_DATA_17      | 0x00          | RW  | OTP Buffer 11                                                                                                                                                                                                                                                                           |
| 0x3D12              | OTP_DATA_18      | 0x00          | RW  | OTP Buffer 12                                                                                                                                                                                                                                                                           |
| 0x3D13              | OTP_DATA_19      | 0x00          | RW  | OTP Buffer 13                                                                                                                                                                                                                                                                           |
| 0x3D14              | OTP_DATA_20      | 0x00          | RW  | OTP Buffer 14                                                                                                                                                                                                                                                                           |
| 0x3D15              | OTP_DATA_21      | 0x00          | RW  | OTP Buffer 15                                                                                                                                                                                                                                                                           |
| 0x3D16              | OTP_DATA_22      | 0x00          | RW  | OTP Buffer 16                                                                                                                                                                                                                                                                           |
| 0x3D17              | OTP_DATA_23      | 0x00          | RW  | OTP Buffer 17                                                                                                                                                                                                                                                                           |
| 0x3D18              | OTP_DATA_24      | 0x00          | RW  | OTP Buffer 18                                                                                                                                                                                                                                                                           |
| 0x3D19              | OTP_DATA_25      | 0x00          | RW  | OTP Buffer 19                                                                                                                                                                                                                                                                           |
| 0x3D1A              | OTP_DATA_26      | 0x00          | RW  | OTP Buffer 1A                                                                                                                                                                                                                                                                           |
| 0x3D1B              | OTP_DATA_27      | 0x00          | RW  | OTP Buffer 1B                                                                                                                                                                                                                                                                           |
| 0x3D1C              | OTP_DATA_28      | 0x00          | RW  | OTP Buffer 1C                                                                                                                                                                                                                                                                           |
| 0x3D1D              | OTP_DATA_29      | 0x00          | RW  | OTP Buffer 1D                                                                                                                                                                                                                                                                           |
| 0x3D1E              | OTP_DATA_30      | 0x00          | RW  | OTP Buffer 1E                                                                                                                                                                                                                                                                           |
| 0x3D1F              | OTP_DATA_31      | 0x00          | RW  | OTP Buffer 1F                                                                                                                                                                                                                                                                           |
| 0x3D20 <sup>b</sup> | OTP_PROGRAM_CTRL | 0x00          | RW  | <p>Bit[7]: OTP_wr_busy<br/>       Bit[6:2]: Debug control<br/>       Changing these registers is not recommended</p> <p>Bit[1]: OTP_program_speed<br/>       0: Fast<br/>       1: Slow</p> <p>Bit[0]: OTP_program_enable<br/>       Changing from 0 to 1 initiates OTP programming</p> |

**table 7-7** OTP control registers (sheet 3 of 3)

| address | register name | default value | R/W | description                                                                                                                                                                                     |
|---------|---------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3D21  | OTP_LOAD_CTRL | 0x00          | RW  | <p>Bit[7]: OTP_rd_busy<br/>           Bit[1]: OTP speed<br/>           0: Fast<br/>           1: Slow</p> <p>Bit[0]: OTP_load_enable<br/>           Changing from 0 to 1 initiates OTP read</p> |

- a. 0x3D00~0x3D04 is reserved for OmniVision internal use.
- b. AVDD must be  $2.5V \pm 5\%$  when writing/programming OTP; otherwise, there will be reliability issues. There is no such limitation when reading OTP under normal operating conditions.

## 7.8 BLC control [0x4000 - 0x4067]

**table 7-8** BLC registers (sheet 1 of 2)

| address       | register name | default value | R/W | description                                                                                                                                                             |
|---------------|---------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x4000        | BLC CTRL00    | 0x89          | RW  | <p>BLC Control</p> <p>Bit[7:1]: Debug mode<br/>           Bit[0]: BLC enable<br/>           0: Disable<br/>           1: Enable</p>                                     |
| 0x4001        | BLC CTRL01    | 0x00          | RW  | <p>Bit[7:6]: Debug mode<br/>           Bit[5:0]: start_line</p>                                                                                                         |
| 0x4002        | BLC CTRL02    | 0x45          | RW  | <p>Bit[7]: Debug mode<br/>           Bit[6]: blc_auto_en<br/>           Bit[5:0]: reset_frame_num</p>                                                                   |
| 0x4003        | BLC CTRL03    | 0x08          | RW  | <p>Bit[7]: blc_redo_en<br/>           Bit[6]: Freeze writing 1 to this bit will trigger a BLC redo N frames begin<br/>           Bit[5:0]: manual_frame_num</p>         |
| 0x4004        | DEBUG MODE    | 0x08          | RW  | Bit[7:0]: Black line num                                                                                                                                                |
| 0x4005        | BLC CTRL05    | 0x18          | RW  | <p>Bit[7:2]: Debug mode<br/>           Bit[1]: blc_always_up_en<br/>           0: Normal freeze<br/>           1: BLC always update<br/>           Bit[0]: Not used</p> |
| 0x4006~0x4008 | DEBUG MODE    | –             | –   | Debug Mode                                                                                                                                                              |

**table 7-8** BLC registers (sheet 2 of 2)

| address       | register name | default value | R/W | description                                           |
|---------------|---------------|---------------|-----|-------------------------------------------------------|
| 0x4009        | BLACK LEVEL   | 0x10          | RW  | Bit[7:0]: blc_blackleveltarget0<br>Black level target |
| 0x400A~0x4067 | DEBUG MODE    | -             | -   | Debug Mode                                            |

## 7.9 frame control [0x4200 - 0x4202]

**table 7-9** frame control registers

| address | register name    | default value | R/W | description                                                                                                                       |
|---------|------------------|---------------|-----|-----------------------------------------------------------------------------------------------------------------------------------|
| 0x4200  | FRAME CTRL0      | 0x00          | RW  | Bit[7:3]: Not used<br>Bit[2]: fcnt_eof_sel<br>Bit[1]: fcnt_mask_dis<br>Bit[0]: fcnt_reset                                         |
| 0x4201  | FRAME ON NUMBER  | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: Frame ON number<br>When both ON and OFF numbers are set to 0x00, frame control is in bypass mode  |
| 0x4202  | FRAME OFF NUMBER | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: Frame OFF number<br>When both ON and OFF numbers are set to 0x00, frame control is in bypass mode |

## 7.10 DVP control [0x4700 - 0x470C]

**table 7-10** DVP registers (sheet 1 of 2)

| address | register name | default value | R/W | description                                                                                                                      |
|---------|---------------|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------|
| 0x4700  | MODE SELECT   | 0x04          | RW  | Bit[7:4]: Not used<br>Bit[3]: CCIR V select<br>Bit[2]: CCIR F select<br>Bit[1]: CCIR656 mode enable<br>Bit[0]: HSYNC mode enable |
| 0x4701  | VSYNC WIDTH   | 0x01          | RW  | VSYNC Length in Terms of Line Count                                                                                              |

**table 7-10 DVP registers (sheet 2 of 2)**

| address | register name     | default value | R/W | description                                                                                                                                                                                                                                                                  |
|---------|-------------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x4702  | VSYNC NEG_WIDTH_H | 0x01          | RW  | Bit[7:0]: VSYNC length in terms of pixel count[15:8]                                                                                                                                                                                                                         |
| 0x4703  | VSYNC NEG_WIDTH_L | 0x00          | RW  | Bit[7:0]: VSYNC length in terms of pixel count[7:0]                                                                                                                                                                                                                          |
| 0x4704  | VSYNC MODE        | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3:2]: r_vsyncout_sel<br>Bit[1]: VSYNC mode3<br>Bit[0]: VSYNC mode2                                                                                                                                                                                 |
| 0x4705  | EOF VSYNC_DELAY_2 | 0x00          | RW  | Bit[7:0]: eof_vsync_delay[23:16]<br>SOF/EOF negative edge to VSYNC positive edge delay                                                                                                                                                                                       |
| 0x4706  | EOF VSYNC_DELAY_1 | 0x00          | RW  | Bit[7:0]: eof_vsync_delay[15:8]<br>SOF/EOF negative edge to VSYNC positive edge delay                                                                                                                                                                                        |
| 0x4707  | EOF VSYNC_DELAY_0 | 0x00          | RW  | Bit[7:0]: eof_vsync_delay[7:0]<br>SOF/EOF negative edge to VSYNC positive edge delay                                                                                                                                                                                         |
| 0x4708  | POLARITY CTRL     | 0x01          | RW  | Bit[7]: Clock DDR mode enable<br>Bit[6]: Not used<br>Bit[5]: VSYNC gate clock enable<br>Bit[4]: HREF gate clock enable<br>Bit[3]: No first for FIFO<br>Bit[2]: HREF polarity reverse option<br>Bit[1]: VSYNC polarity reverse option<br>Bit[0]: PCLK polarity reverse option |
| 0x4709  | BIT TEST ORDER    | 0x00          | RW  | Bit[7]: FIFO bypass mode<br>Bit[6:4]: Data bit swap<br>Bit[3]: Bit test mode<br>Bit[2]: 10-bit bit test<br>Bit[1]: 8-bit bit test<br>Bit[0]: Bit test enable                                                                                                                 |
| 0x470A  | BYP CTRL1         | 0x00          | RW  | Bit[7:0]: bypass_ctrl[15:8]                                                                                                                                                                                                                                                  |
| 0x470B  | BYP CTRL0         | 0x00          | RW  | Bit[7:0]: bypass_ctrl[7:0]                                                                                                                                                                                                                                                   |
| 0x470C  | BYP SEL           | 0x00          | RW  | Bit[7:5]: Not used<br>Bit[4]: href_sel<br>Bit[3:0]: bypass_sel                                                                                                                                                                                                               |

## 7.11 MIPI control [0x4800 - 0x4843]

**table 7-11 MIPI registers (sheet 1 of 6)**

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|---------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x4800  | MIPI CTRL 00  | 0x04          | RW  | <p>MIPI Control 00</p> <p>Bit[7:6]: Debug mode</p> <p>Bit[5]: Clock lane gate enable<br/>0: Clock lane is free running<br/>1: Gate clock lane when no packet to transmit</p> <p>Bit[4]: Line sync enable<br/>0: Do not send line short packet for each line<br/>1: Send line short packet for each line</p> <p>Bit[3]: Lane select<br/>0: Use lane1 as default data lane<br/>1: Use lane2 as default data lane</p> <p>Bit[2]: Idle status<br/>0: MIPI bus will be LP00 when no packet to transmit<br/>1: MIPI bus will be LP11 when no packet to transmit</p> <p>Bit[1:0]: Debug mode</p>                                                                                                                                          |
| 0x4801  | MIPI CTRL 01  | 0x0F          | RW  | <p>MIPI Control 01</p> <p>Bit[7]: Long packet data type manual enable<br/>0: Use mipi_dt<br/>1: Use dt_man_o as long packet data (see register 0x4814[5:0])</p> <p>Bit[6]: Short packet data type manual enable<br/>1: Use dt_spkt as short packet data (see register 0x4815[5:0])</p> <p>Bit[5]: Short packet WORD COUNTER manual enable<br/>0: Use frame counter or line counter<br/>1: Select spkt_wc_reg_o (see {0x4812, 0x4813})</p> <p>Bit[4]: PH bit order for ECC<br/>0: {DI[7:0],WC[7:0],WC[15:8]}<br/>1: {DI[0:7],WC[0:7],WC[8:15]}</p> <p>Bit[3]: PH byte order for ECC<br/>0: {DI,WC_L,WC_h}<br/>1: {DI,WC_h,WC_L}</p> <p>Bit[2]: PH byte order2 for ECC<br/>0: {DI,WC}<br/>1: {WC,DI}</p> <p>Bit[1:0]: Debug mode</p> |

**table 7-11 MIPI registers (sheet 2 of 6)**

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|---------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x4802  | MIPI CTRL 02  | 0x00          | RW  | <p>MIPI Control 02</p> <p>Bit[7]: hs_prepare_sel<br/>0: Auto calculate T_hs_prepare, unit pclk2x<br/>1: Use hs_prepare_min_o[7:0]</p> <p>Bit[6]: clk_prepare_sel<br/>0: Auto calculate T_clk_prepare, unit pclk2x<br/>1: Use clk_prepare_min_o[7:0]</p> <p>Bit[5]: clk_post_sel<br/>0: Auto calculate T_clk_post, unit pclk2x<br/>1: Use clk_post_min_o[7:0]</p> <p>Bit[4]: clk_trail_sel<br/>0: Auto calculate T_clk_trail, unit pclk2x<br/>1: Use clk_trail_min_o[7:0]</p> <p>Bit[3]: hs_exit_sel<br/>0: Auto calculate T_hs_exit, unit pclk2x<br/>1: Use hs_exit_min_o[7:0]</p> <p>Bit[2]: hs_zero_sel<br/>0: Auto calculate T_hs_zero, unit pclk2x<br/>1: Use hs_zero_min_o[7:0]</p> <p>Bit[1]: hs_trail_sel<br/>0: Auto calculate T_hs_trail, unit pclk2x<br/>1: Use hs_trail_min_o[7:0]</p> <p>Bit[0]: clk_zero_sel<br/>0: Auto calculate T_clk_zero, unit pclk2x<br/>1: Use clk_zero_min_o[7:0]</p> |
| 0x4803  | MIPI CTRL 03  | 0x50          | RW  | Bit[7:0]: Debug mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x4804  | MIPI CTRL 04  | 0x8D          | RW  | Bit[7:0]: Debug mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

**table 7-11 MIPI registers (sheet 3 of 6)**

| address | register name        | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|----------------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x4805  | MIPI CTRL 05         | 0x10          | RW  | <p>MIPI Control 05</p> <p>Bit[7]: MIPI lane1 disable<br/>0: Not used<br/>1: Disable MIPI data lane1, lane1 will be LP00</p> <p>Bit[6]: MIPI lane2 disable<br/>0: Not used<br/>1: Disable MIPI data lane2, lane2 will be LP00</p> <p>Bit[5]: lp_p_sel<br/>0: Auto calculate t_lp_x_o in pclkex domain, unit pclk2x<br/>1: Use lp_p_min[7:0]</p> <p>lp_rx_intr_sel<br/>0: Send lp_rx_intr_o at the first byte<br/>1: Send lp_rx_intr_o at the end of receiving</p> <p>Bit[3:1]: Debug mode<br/>Bit[0]: Not used</p> |
| 0x4806  | DEBUG MODE           | -             | -   | Debug Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0x4810  | MIPI MAX FRAME COUNT | 0xFF          | RW  | High Byte of Max Frame Count of Frame Sync Short Packet                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0x4811  | MIPI MAX FRAME COUNT | 0xFF          | RW  | Low Byte of Max Frame Count of Frame Sync Short Packet                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0x4814  | MIPI CTRL14          | 0x2A          | RW  | <p>MIPI Control 14</p> <p>Bit[7:6]: Virtual channel of MIPI<br/>Bit[5:0]: Data type in manual mode</p>                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0x4815  | MIPI_DT_SPKT         | 0x00          | RW  | <p>Bit[7]: Not used<br/>Bit[6]: Debug mode<br/>Bit[5:0]: Manual data type for short packet</p>                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0x4818  | HS_ZERO_MIN          | 0x00          | RW  | High Byte of the Minimum Value for hs_zero Unit ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0x4819  | HS_ZERO_MIN          | 0x96          | RW  | Low Byte of the Minimum Value for hs_zero, unit ns<br>$hs\_zero\_real = hs\_zero\_min\_o + Tui * ui\_hs\_zero\_min\_o$                                                                                                                                                                                                                                                                                                                                                                                            |
| 0x481A  | HS_TRAIL_MIN         | 0x00          | RW  | High Byte of the Minimum Value for hs_trail, unit ns                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0x481B  | HS_TRAIL_MIN         | 0x3C          | RW  | Low Byte of the Minimum Value for hs_trail, unit ns<br>$hs\_trail\_real = hs\_trail\_min\_o + Tui * ui\_hs\_trail\_min\_o$                                                                                                                                                                                                                                                                                                                                                                                        |
| 0x481C  | CLK_ZERO_MIN         | 0x01          | RW  | High Byte of the Minimum Value for clk_zero, unit ns                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

**table 7-11 MIPI registers (sheet 4 of 6)**

| address | register name   | default value | R/W | description                                                                                                         |
|---------|-----------------|---------------|-----|---------------------------------------------------------------------------------------------------------------------|
| 0x481D  | CLK_ZERO_MIN    | 0x86          | RW  | Low Byte of the Minimum Value for clk_zero,<br>clk_zero_real = clk_zero_min_o +<br>Tui*ui_clk_zero_min_o            |
| 0x481E  | CLK_PREPARE_MIN | 0x00          | RW  | High Byte of the Minimum Value for clk_prepare, unit ns<br>Bit[7:2]: Not used<br>Bit[1:0]: clk_prepare_min[9:8]     |
| 0x481F  | CLK_PREPARE_MIN | 0x3C          | RW  | Low Byte of the Minimum Value for clk_prepare<br>clk_prepare_real = clk_prepare_min_o +<br>Tui*ui_clk_prepare_min_o |
| 0x4820  | CLK_POST_MIN    | 0x00          | RW  | High Byte of the Minimum Value for clk_post, unit ns<br>Bit[7:2]: Not used<br>Bit[1:0]: clk_post_min[9:8]           |
| 0x4821  | CLK_POST_MIN    | 0x56          | RW  | Low Byte of the Minimum Value for clk_post<br>clk_post_real = clk_post_min_o +<br>Tui*ui_clk_post_min_o             |
| 0x4822  | CLK_TRAIL_MIN   | 0x00          | RW  | High Byte of the Minimum Value for clk_trail, unit ns<br>Bit[7:2]: Not used<br>Bit[1:0]: clk_trail_min[9:8]         |
| 0x4823  | CLK_TRAIL_MIN   | 0x3C          | RW  | Low Byte of the Minimum Value for clk_trail<br>clk_trail_real = clk_trail_min_o +<br>Tui*ui_clk_trail_min_o         |
| 0x4824  | LPX_P_MIN       | 0x00          | RW  | High Byte of the Minimum Value for lpx_p, unit ns<br>Bit[7:2]: Not used<br>Bit[1:0]: lpx_p_min[9:8]                 |
| 0x4825  | LPX_P_MIN       | 0x32          | RW  | Low Byte of the Minimum Value for lpx_p<br>lpx_p_real = lpx_p_min_o + Tui*ui_lpx_p_min_o                            |
| 0x4826  | HS_PREPARE_MIN  | 0x00          | RW  | High Byte of the Minimum Value for hs_prepare, unit ns<br>Bit[7:2]: Not used<br>Bit[1:0]: hs_prepare_min[9:8]       |
| 0x4827  | HS_PREPARE_MIN  | 0x32          | RW  | Low Byte of the Minimum Value for hs_prepare<br>hs_prepare_real = hs_prepare_min_o +<br>Tui*ui_hs_prepare_min_o     |
| 0x4828  | HS_EXIT_MIN     | 0x00          | RW  | High Byte of the Minimum Value for hs_exit, unit ns<br>Bit[7:2]: Not used<br>Bit[1:0]: hs_exit_min[9:8]             |
| 0x4829  | HS_EXIT_MIN     | 0x64          | RW  | Low Byte of the Minimum Value for hs_exit<br>hs_exit_real = hs_exit_min_o +<br>Tui*ui_hs_exit_min_o                 |
| 0x482A  | UI_HS_ZERO_MIN  | 0x05          | RW  | Minimum UI Value of hs_zero, unit UI                                                                                |

**table 7-11 MIPI registers (sheet 5 of 6)**

| address | register name      | default value | R/W | description                                                                                                                  |
|---------|--------------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------|
| 0x482B  | UI_HS_TRAIL_MIN    | 0x04          | RW  | Minimum UI Value of hs_trail, unit UI                                                                                        |
| 0x482C  | UI_CLK_ZERO_MIN    | 0x00          | RW  | Minimum UI Value of clk_zero, unit UI                                                                                        |
| 0x482D  | UI_CLK_PREPARE_MIN | 0x00          | RW  | Minimum UI Value of clk_prepare, unit UI                                                                                     |
| 0x482E  | UI_CLK_POST_MIN    | 0x34          | RW  | Minimum UI Value of clk_post, unit UI                                                                                        |
| 0x482F  | UI_CLK_TRAIL_MIN   | 0x00          | RW  | Minimum UI Value of clk_trail, unit UI                                                                                       |
| 0x4830  | UI_LPX_P_MIN       | 0x00          | RW  | Minimum UI Value of lpx_p, unit UI                                                                                           |
| 0x4831  | UI_HS_PREPARE_MIN  | 0x04          | RW  | Minimum UI Value of hs_prepare, unit UI                                                                                      |
| 0x4832  | UI_HS_EXIT_MIN     | 0x00          | RW  | Minimum UI Value of hs_exit, unit UI                                                                                         |
| 0x4833  | MIPI_REG_MIN       | 0x00          | RW  | MIPI Register Address, Lower Bound (High Byte)<br>Address range of MIPI RW registers is from<br>mipi_reg_min to mipi_reg_max |
| 0x4834  | MIPI_REG_MIN       | 0x00          | RW  | MIPI Register Address, Lower Bound (Low Byte)                                                                                |
| 0x4835  | MIPI_REG_MAX       | 0xFF          | RW  | MIPI Register Address, Upper Bound (High Byte)                                                                               |
| 0x4836  | MIPI_REG_MAX       | 0xFF          | RW  | MIPI Register Address, Upper Bound (Low Byte)                                                                                |
| 0x4837  | PCLK_PERIOD        | 0x15          | RW  | Period of pclk2x, pclk_div = 1, and 1-bit decimal                                                                            |
| 0x4838  | WKUP_DLY           | 0x02          | RW  | Wakeup Delay for MIPI                                                                                                        |
| 0x483A  | DEBUG MODE         | —             | —   | Debug Mode                                                                                                                   |

**table 7-11 MIPI registers (sheet 6 of 6)**

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|---------------|---------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x483B  | MIPI_LP_GPIO  | 0x33          | RW  | <p>Bit[7]: ip_sel1<br/>0: Auto generate mipi_lp_dir1_o<br/>1: Use lp_dir_man1 as mipi_lp_dir1_o</p> <p>Bit[6]: lp_dir_man1<br/>0: Input<br/>1: Output</p> <p>Bit[5]: lp_p1_o</p> <p>Bit[4]: lp_n1_o</p> <p>Bit[3]: lp_sel2<br/>0: Auto generate mipi_lp_dir2_o<br/>1: Use lp_dir_man2 as mipi_lp_dir2_o</p> <p>Bit[2]: lp_dir_man2<br/>0: Input<br/>1: Output</p> <p>Bit[1]: lp_p2_o</p> <p>Bit[0]: lp_n2_o</p> |
| 0x4843  | SNR_PCLK_DIV  | 0x00          | RW  | <p>Bit[7:1]: Not used</p> <p>Bit[0]: PCLK divider<br/>0: PCLK/SCLK = 2 and pclk_div = 1<br/>1: PCLK/SCLK = 1 and pclk_div = 1</p>                                                                                                                                                                                                                                                                               |

## 7.12 ISP control [0x5000 - 0x5059]

**table 7-12 ISP control registers (sheet 1 of 6)**

| address | register name | default value | R/W | description                                                                                                                                                                              |
|---------|---------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x5000  | ISP CTRL00    | 0xFF          | RW  | <p>ISP Control 00 (0: disable; 1: enable)</p> <p>Bit[7]: Lens shading correction</p> <p>Bit[2]: Black pixel correction</p> <p>Bit[1]: White pixel correction</p> <p>Bit[0]: Not used</p> |
| 0x5001  | ISP CTRL01    | 0x01          | RW  | <p>ISP Control 01</p> <p>Bit[7:1]: Not used</p> <p>Bit[0]: AWB<br/>0: Disable<br/>1: Enable</p>                                                                                          |

**table 7-12 ISP control registers (sheet 2 of 6)**

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|---------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x5002  | ISP CTRL02    | 0x41          | RW  | ISP Control 02 (0: disable; 1: enable)<br>Bit[7:5]: Not used<br>Bit[6]: win_en<br>Bit[1]: otp_en<br>Bit[0]: AWB gain                                                                                                                                                                                                                                                                                                                                        |
| 0x5003  | ISP CTRL03    | 0x0A          | RW  | ISP Control 03 (0: disable; 1: enable)<br>Bit[7:4]: Not used<br>Bit[3]: buf_en<br>Bit[2]: bin_man_set<br>Bit[1]: bin_auto_en                                                                                                                                                                                                                                                                                                                                |
| 0x5004  | ISP CTRL04    | 0x00          | RW  | ISP Control 04<br>Bit[7:4]: Not used<br>Bit[3]: size_man_en<br>0: Disable<br>1: Enable<br>Bit[2:0]: Not used                                                                                                                                                                                                                                                                                                                                                |
| 0x5005  | ISP CTRL05    | 0x31          | RW  | ISP Control 05<br>Bit[7]: sof_man<br>0: SOF from BLC module<br>1: SOF from pre_isp module<br>Bit[6]: awb_bias_man_en<br>0: AWB bias manual disable<br>1: AWB bias manual enable<br>Bit[5]: awb_bias_on<br>0: Disable AWB bias<br>1: Enable AWB bias<br>Bit[4:3]: Not used<br>Bit[2]: lenc_bias_on<br>0: Disable LENC bias<br>1: Enable LENC bias<br>Bit[1]: Disable LENC bias<br>s2p_sw_en_o<br>Bit[0]: Disable LENC bias avg_en<br>0: Disable<br>1: Enable |
| 0x5006  | ISP CTRL06    | 0x00          | RW  | ISP Control 06 (0: disable; 1: enable)<br>Bit[7]: x_odd_inc_man_en<br>Bit[6]: y_even_inc_man_en<br>Bit[5]: x_odd_inc_man_en<br>Bit[4]: y_even_inc_man_en<br>Bit[3]: x_offset_man_en<br>Bit[2]: y_offset_man_en<br>Bit[1]: x_skip_man_en<br>Bit[0]: y_skip_man_en                                                                                                                                                                                            |

**table 7-12 ISP control registers (sheet 3 of 6)**

| address | register name    | default value | R/W | description                                                                                                                                                                                                                                                           |
|---------|------------------|---------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x5007  | ISP CTRL07       | 0x00          | RW  | ISP Control 07 (0: disable; 1: enable)<br>Bit[7]: bin_mode_man_en<br>Bit[6]: bin_mode_man<br>Bit[5]: win_x_off_man_en<br>Bit[4]: win_y_off_man_en<br>Bit[3]: win_x_out_man_en<br>Bit[2]: win_y_out_man_en<br>Bit[1]: isp_input_h_man_en<br>Bit[0]: isp_input_v_man_en |
| 0x5008  | X OFFSET MAN     | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: x_offset_man[11:8]                                                                                                                                                                                                                    |
| 0x5009  | X OFFSET MAN     | 0x00          | RW  | Bit[7:0]: x_offset_man[7:0]                                                                                                                                                                                                                                           |
| 0x500A  | Y OFFSET MAN     | 0x00          | RW  | Bit[7:3]: Not used<br>Bit[2:0]: y_offset_man[10:8]                                                                                                                                                                                                                    |
| 0x500B  | Y OFFSET MAN     | 0x00          | RW  | Bit[7:0]: y_offset_man[7:0]                                                                                                                                                                                                                                           |
| 0x500C  | WIN X OFFSET MAN | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: win_x_offset_man[11:8]                                                                                                                                                                                                                |
| 0x500D  | WIN X OFFSET MAN | 0x00          | RW  | Bit[7:0]: win_x_offset_man[7:0]                                                                                                                                                                                                                                       |
| 0x500E  | WIN Y OFFSET MAN | 0x00          | RW  | Bit[7:3]: Not used<br>Bit[2:0]: win_y_offset_man[10:8]                                                                                                                                                                                                                |
| 0x500F  | WIN Y OFFSET MAN | 0x00          | RW  | Bit[7:0]: win_y_offset_man[7:0]                                                                                                                                                                                                                                       |
| 0x5010  | WIN X OUT MAN    | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: win_x_out_man[11:8]                                                                                                                                                                                                                   |
| 0x5011  | WIN X OUT MAN    | 0x00          | RW  | Bit[7:0]: win_x_out_man[7:0]                                                                                                                                                                                                                                          |
| 0x5012  | WIN Y OUT MAN    | 0x00          | RW  | Bit[7:3]: Not used<br>Bit[2:0]: win_y_out_man[10:8]                                                                                                                                                                                                                   |
| 0x5013  | WIN Y OUT MAN    | 0x00          | RW  | Bit[7:0]: win_y_out_man[7:0]                                                                                                                                                                                                                                          |
| 0x5014  | ISP INPUT X MAN  | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: isp_x_input_man[11:8]                                                                                                                                                                                                                 |
| 0x5015  | ISP INPUT X MAN  | 0x00          | RW  | Bit[7:0]: isp_x_input_man[7:0]                                                                                                                                                                                                                                        |
| 0x5016  | ISP INPUT Y MAN  | 0x00          | RW  | Bit[7:3]: Not used<br>Bit[2:0]: isp_y_input_man[10:8]                                                                                                                                                                                                                 |
| 0x5017  | ISP INPUT Y MAN  | 0x00          | RW  | Bit[7:0]: isp_y_input_man[7:0]                                                                                                                                                                                                                                        |
| 0x5018  | ISP CTRL18       | 0x00          | RW  | Bit[7:4]: x_odd_inc_man<br>Bit[3:0]: x_even_inc_man                                                                                                                                                                                                                   |
| 0x5019  | ISP CTRL19       | 0x00          | RW  | Bit[7:4]: y_odd_inc_man<br>Bit[3:0]: y_even_inc_man                                                                                                                                                                                                                   |

**table 7-12 ISP control registers (sheet 4 of 6)**

| address       | register name | default value | R/W | description                                                                                                                                                                                                                                                                          |
|---------------|---------------|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x501A        | ISP CTRL1A    | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3:2]: x_skip_man<br>Bit[1:0]: y_skip_man                                                                                                                                                                                                                   |
| 0x501B~0x501C | DEBUG MODE    | -             | -   | Debug Mode                                                                                                                                                                                                                                                                           |
| 0x501D        | ISP CTRL1D    | 0x00          | RW  | Bit[7]: Not used<br>Bit[6:4]: win_y_offset_adjust<br>Bit[3:0]: Not used                                                                                                                                                                                                              |
| 0x501F        | ISP CTRL1F    | 0x03          | RW  | Bit[7:6]: Not used<br>Bit[5]: enable_opt<br>0: Not latched by VSYNC<br>1: Enable latched by VSYNC<br>Bit[4]: cal_sel<br>0: DPC cal_start using SOF<br>1: DPC cal_start using VSYNC<br>Bit[3]: Not used<br>Bit[2:0]: fmt_sel<br>011: ISP output data<br>Others: ISP input data bypass |
| 0x5025        | ISP CTRL25    | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[1:0]: avg_sel<br>00: Inputs of AVG module are from LENC output<br>01: Inputs of AVG module are from AWB gain output<br>10: Inputs of AVG module are from DPC output<br>11: Inputs of AVG module are from binning output                                    |
| 0x5026~0x503C | DEBUG MODE    | -             | -   | Debug Mode                                                                                                                                                                                                                                                                           |

**table 7-12 ISP control registers (sheet 5 of 6)**

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|---------------|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x503D  | ISP CTRL3D    | 0x00          | RW  | <p>Bit[7]: test_pattern_en<br/>0: Disable<br/>1: Enable</p> <p>Bit[6]: rolling_bar<br/>0: Disable rolling bar<br/>1: Enable rolling bar</p> <p>Bit[5]: transparent_mode<br/>0: Disable<br/>1: Enable</p> <p>Bit[4]: squ_bw_mode<br/>0: Output square is color square<br/>1: Output square is black-white square</p> <p>Bit[3:2]: bar_style<br/>When set to a different value, a different type color bar will be output</p> <p>Bit[1:0]: test_pattern_type<br/>00: Color bar<br/>01: Square<br/>10: Random data<br/>11: Input data</p> |
| 0x503E  | ISP CTRL3E    | 0x00          | RW  | <p>Bit[7]: Not used</p> <p>Bit[6]: win_cut_en</p> <p>Bit[5]: isp_test<br/>0: Two lowest bits are 1<br/>1: Two lowest bits are 0</p> <p>Bit[4]: Two lowest bits are rnd_same<br/>0: Frame-changing random data pattern<br/>1: Frame-fixed random data pattern</p> <p>Bit[3:0]: rnd_seed<br/>Initial seed for random data pattern</p>                                                                                                                                                                                                    |
| 0x504B  | ISP CTRL4B    | 0x30          | RW  | <p>ISP Control 4B (0: disable; 1: enable)</p> <p>Bit[7:6]: Not used</p> <p>Bit[5]: post_binning h_enable</p> <p>Bit[4]: post_binning v_enable</p> <p>Bit[3]: flip_man_en</p> <p>Bit[2]: flip_man</p> <p>Bit[1]: mirror_man_en</p> <p>Bit[0]: Mirror</p>                                                                                                                                                                                                                                                                                |
| 0x504C  | ISP CTRL4C    | 0x04          | RW  | Bit[7:0]: bias_man                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

**table 7-12 ISP control registers (sheet 6 of 6)**

| address | register name | default value | R/W | description                                                                                                                                                                  |
|---------|---------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x504D  | ISP CTRL4D    | 0x00          | RW  | ISP Control 4D (0: disable; 1: enable)<br>Bit[7:4]: Not used<br>Bit[3]: lenc_xoff_man_en<br>Bit[2]: lenc_yoff_man_en<br>Bit[1]: lenc_gain_man_en<br>Bit[0]: lenc_bias_man_en |
| 0x504E  | ISP CTRL4E    | 0x04          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: lenc_xoff_man[11:8]                                                                                                                          |
| 0x504F  | ISP CTRL4F    | 0x00          | RW  | Bit[7:0]: lenc_xoff_man[7:0]                                                                                                                                                 |
| 0x5052  | ISP CTRL52    | 0x0A          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: lenc_yoff_man[11:8]                                                                                                                          |
| 0x5053  | ISP CTRL53    | 0x00          | RW  | Bit[7:0]: lenc_yoff_man[7:0]                                                                                                                                                 |
| 0x5054  | ISP CTRL54    | 0x00          | RW  | Bit[7:2]: Not used<br>Bit[1:0]: lenc_gain_man[9:8]                                                                                                                           |
| 0x5055  | ISP CTRL55    | 0x00          | RW  | Bit[7:0]: lenc_gain_man[7:0]                                                                                                                                                 |
| 0x5056  | ISP CTRL56    | 0x00          | RW  | Bit[7:6]: Not used<br>Bit[5]: lenc_skipx_man<br>Bit[4]: lenc_skipy_man<br>Bit[3:2]: lenc_skipy_man<br>Bit[1:0]: lenc_skipx_man                                               |
| 0x5057  | ISP CTRL57    | 0x00          | RW  | Bit[7]: sram_test_dpc1<br>Bit[6]: sram_test_dpc2<br>Bit[5]: sram_test_dpc3<br>Bit[4]: sram_test_dpc4<br>Bit[3:0]: Not used                                                   |
| 0x5058  | ISP CTRL58    | 0xAA          | RW  | Bit[7:4]: sram_rm_dpc1<br>Bit[3:0]: sram_rm_dpc2                                                                                                                             |
| 0x5059  | ISP CTRL59    | 0xAA          | RW  | Bit[7:4]: sram_rm_dpc3<br>Bit[3:0]: sram_rm_dpc4                                                                                                                             |

### 7.13 AWB control [0x5180 - 0x51DF]

**table 7-13 AWB registers (sheet 1 of 2)**

| address       | register name       | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------|---------------------|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x5180        | AWB CTRL            | 0x00          | RW  | <p>Bit[7]: hsize_man_en<br/>         Bit[6]: fast_awb<br/>         0: Disable fast AWB calculation function<br/>         1: Enable fast AWB calculation function</p> <p>Bit[5]: freeze_gain_en<br/>         When it is enabled, the output AWB gains are input AWB gains</p> <p>Bit[4]: freeze_sum_en<br/>         When it is set, the sums and averages value are the same as previous frame</p> <p>Bit[3]: gain_man_en<br/>         0: Output calculated gains<br/>         1: Output manual gains set by registers</p> <p>Bit[2]: start_sel<br/>         0: Select the last HREF falling edge of before gain input as calculated start signal<br/>         1: Select the last HREF falling edge of after gain input as calculated start signal</p> <p>Bit[1]: after_gma<br/>         Bit[0]: Not used</p> |
| 0x5181        | AWB DELTA           | 0x20          | RW  | <p>Bit[7]: delta_opt<br/>         Bit[6]: base_man_en<br/>         Bit[5:0]: awb_delta<br/>         Delta value to increase or decrease the gains</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0x5182        | STABLE RANGE        | 0x04          | RW  | Bit[7:0]: stable_range                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x5183        | STABLE RANGEW       | 0x08          | RW  | Bit[7:0]: stable_rangew<br>Wide stable range                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0x5184~0x5185 | AWB CTRL            | –             | –   | Debug Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0x5185        | HSIZE_MAN           | 0xE0          | RW  | Bit[7:0]: hsize_man[7:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x5186        | MANUAL RED GAIN MSB | 0x04          | RW  | <p>Bit[7:4]: Not used<br/>         Bit[3:0]: red_gain_man[11:8]</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

**table 7-13 AWB registers (sheet 2 of 2)**

| address | register name         | default value | R/W | description                                                                                                                                                                                                          |
|---------|-----------------------|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x5187  | MANUAL RED GAIN LSB   | 0x00          | RW  | Bit[7:0]: red_gain_man[7:0]                                                                                                                                                                                          |
| 0x5188  | MANUAL GREEN GAIN MSB | 0x04          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: grn_gain_man[11:8]                                                                                                                                                                   |
| 0x5189  | MANUAL GREEN GAIN LSB | 0x00          | RW  | Bit[7:0]: grn_gain_man[7:0]                                                                                                                                                                                          |
| 0x518A  | MANUAL BLUE GAIN MSB  | 0x04          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: blu_gain_man[11:8]                                                                                                                                                                   |
| 0x518B  | MANUAL BLUE GAIN LSB  | 0x00          | RW  | Bit[7:0]: blu_gain_man[7:0]                                                                                                                                                                                          |
| 0x518C  | RED GAIN LIMIT        | 0xF0          | RW  | Bit[7:4]: red_gain_up_limit<br>Bit[3:0]: red_gain_dn_limit<br>They are only the highest 4 bits of limitation.<br>Maximum red gain is {red_gan_up_limit,FF}<br>Minimum red gain is {red_gain_dn_limit,00}             |
| 0x518D  | GREEN GAIN LIMIT      | 0xF0          | RW  | Bit[7:4]: green_gain_up_limit<br>Bit[3:0]: green_gain_dn_limit<br>They are only the highest 4 bits of limitation.<br>Maximum green gain is {green_gan_up_limit,FF}<br>Minimum green gain is {green_gain_dn_limit,00} |
| 0x518E  | BLUE GAIN LIMIT       | 0xF0          | RW  | Bit[7:4]: blue_gain_up_limit<br>Bit[3:0]: blue_gain_dn_limit<br>They are only the highest 4 bits of limitation.<br>Maximum blue gain is {blue_gan_up_limit,FF}<br>Minimum blue gain is {blue_gain_dn_limit,00}       |
| 0x518F  | FRAME CNT             | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: awb_frame_cnt                                                                                                                                                                        |
| 0x51DF  | BASE MAN              | 0x10          | RW  | Bit[7:0]: base_man                                                                                                                                                                                                   |

## 7.14 LENC control [0x5800 ~ 0x5849]

**table 7-14 LENC registers (sheet 1 of 2)**

| address       | register name  | default value | R/W | description                                                                                                                                                                                                                                                                          |
|---------------|----------------|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x5800~0x5823 | GMTRX          | –             | RW  | Bit[7:6]: Not used<br>Bit[5:0]: Green matrix                                                                                                                                                                                                                                         |
| 0x5824~0x583C | BRMTRX         | –             | RW  | Bit[7:4]: Blue matrix<br>Bit[3:0]: Red matrix                                                                                                                                                                                                                                        |
| 0x583D        | LENC BR OFFSET | 0x88          | RW  | Bit[7:4]: lenc_b_offset<br>Bit[3:0]: lenc_r_offset                                                                                                                                                                                                                                   |
| 0x583E        | MAX GAIN       | 0x40          | RW  | Bit[7:0]: max_gain                                                                                                                                                                                                                                                                   |
| 0x583F        | MIN GAIN       | 0x20          | RW  | Bit[7:0]: min_gain                                                                                                                                                                                                                                                                   |
| 0x5840        | MIN Q          | 0x18          | RW  | Bit[6:0]: min_q                                                                                                                                                                                                                                                                      |
| 0x5841        | LENC CTRL59    | 0x0D          | RW  | Bit[7:4]: Debug mode<br>Bit[3]: ADDBLC<br>0: Disable BLC add back function<br>1: Enable BLC add back function<br>Bit[2]: blc_en<br>0: Disable BLC function<br>1: Enable BLC function<br>Bit[1]: gain_man_en<br>Bit[0]: autoq_en<br>0: Used constant Q (0x40)<br>1: Used calculated Q |
| 0x5842        | BR HSCALE      | 0x01          | RW  | Bit[7:4]: Debug mode<br>Bit[3:0]: br_hscale[11:8]<br>Reciprocal of horizontal step for BR channel. BR channel in whole image is divided into 5x5 blocks. The step is used to point to the border of the adjacent block                                                               |
| 0x5843        | BR HSCALE      | 0x2B          | RW  | Bit[7:0]: br_hscale[7:0]<br>Reciprocal of horizontal step for BR channel. BR channel in whole image is divided into 5x5 blocks. The step is used to point to the border of the adjacent block                                                                                        |
| 0x5844        | BR VSCALE      | 0x01          | RW  | Bit[7:3]: Debug mode<br>Bit[2:0]: br_vscale[10:8]<br>Reciprocal of vertical step for BR channel. BR channel in whole image is divided into 5x5 blocks. The step is used to point to the border of the adjacent block                                                                 |

**table 7-14** LENC registers (sheet 2 of 2)

| address | register name | default value | R/W | description                                                                                                                                                                                    |
|---------|---------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x5845  | BR VSCALE     | 0x8D          | RW  | Bit[7:0]: br_vscode[7:0]<br>Reciprocal of vertical step for BR channel.<br>BR channel in whole image is divided into 5x5 blocks. The step is used to point to the border of the adjacent block |
| 0x5846  | G HSCALE      | 0x01          | RW  | Bit[3:0]: g_hscale[11:8]<br>Reciprocal of horizontal step for G channel. G channel in whole image is divided into 6x6 blocks. The step is used to point to the border of the adjacent block    |
| 0x5847  | G HSCALE      | 0x8F          | RW  | Bit[7:0]: g_hscale[7:0]<br>Reciprocal of horizontal step for G channel. G channel in whole image is divided into 6x6 blocks. The step is used to point to the border of the adjacent block     |
| 0x5848  | G VSCALE      | 0x01          | RW  | Bit[2:0]: g_vscode[10:8]<br>Reciprocal of vertical step for G channel. G channel in whole image is divided into 6x6 blocks. The step is used to point to the border of the adjacent block      |
| 0x5849  | G VSCALE      | 0x09          | RW  | Bit[7:0]: g_vscode[7:0]<br>Reciprocal of vertical step for G channel. G channel in whole image is divided into 6x6 blocks. The step is used to point to the border of the adjacent block       |

Confidential  
Zhongxindian

## 7.15 ISP output windows [0x5980 - 0x5988]

table 7-15 ISP output windows registers

| address | register name | default value | R/W | description                                                                          |
|---------|---------------|---------------|-----|--------------------------------------------------------------------------------------|
| 0x5980  | WINDOW XSTART | 0x00          | RW  | Bit[7:5]: Not used<br>Bit[4:0]: window_xstart[12:8]                                  |
| 0x5981  | WINDOW XSTART | 0x00          | RW  | Bit[7:0]: window_xstart[7:0]                                                         |
| 0x5982  | WINDOW YSTART | 0x00          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: window_ystart[11:8]                                  |
| 0x5983  | WINDOW YSTART | 0x00          | RW  | Bit[7:0]: window_ystart[7:0]                                                         |
| 0x5984  | WIN X WIN     | 0x10          | RW  | Bit[7:5]: Not used<br>Bit[4:0]: window_x_win[12:8]                                   |
| 0x5985  | WIN X WIN     | 0xA0          | RW  | Bit[7:0]: window_x_win[7:0]                                                          |
| 0x5986  | WIN Y WIN     | 0x0C          | RW  | Bit[7:4]: Not used<br>Bit[3:0]: window_y_win[11:8]                                   |
| 0x5987  | WIN Y WIN     | 0x78          | RW  | Bit[7:0]: window_y_win[7:0]                                                          |
| 0x5988  | WIN MAN       | 0x00          | RW  | Bit[7:1]: Not used<br>Bit[0]: Window manual enable<br>0: Auto mode<br>1: Manual mode |

## 8 operating specifications

### 8.1 absolute maximum ratings

**table 8-1** absolute maximum ratings

| parameter                                          | absolute maximum rating <sup>a</sup> |       |
|----------------------------------------------------|--------------------------------------|-------|
| ambient storage temperature                        | -40°C to +125°C                      |       |
|                                                    | $V_{DD-A}$                           | 4.5V  |
| supply voltage (with respect to ground)            | $V_{DD-D}$                           | 3V    |
|                                                    | $V_{DD-IO}$                          | 4.5V  |
| electro-static discharge (ESD)                     | human body model                     | 2000V |
|                                                    | machine model                        | 200V  |
| all input/output voltages (with respect to ground) | -0.3V to $V_{DD-IO} + 1V$            |       |
| I/O current on any input or output pin             | $\pm 200\text{ mA}$                  |       |

- a. exceeding the absolute maximum ratings shown above invalidates all AC and DC electrical specifications and may result in permanent damage to the device. Exposure to absolute maximum rated conditions for extended periods may affect device reliability.

### 8.2 functional temperature

**table 8-2** functional temperature

| parameter                             | range                               |
|---------------------------------------|-------------------------------------|
| operating temperature <sup>a</sup>    | -30°C to +70°C junction temperature |
| stable image temperature <sup>b</sup> | 0°C to +50°C junction temperature   |

- a. sensor functions but image quality may be noticeably different at temperatures outside of stable image range
- b. image quality remains stable throughout this temperature range

### 8.3 DC characteristics

**table 8-3 DC characteristics (-30°C < T<sub>J</sub> < 70°C)**

| symbol                                                                           | parameter                                                       | min   | typ | max   | unit |
|----------------------------------------------------------------------------------|-----------------------------------------------------------------|-------|-----|-------|------|
| <b>supply</b>                                                                    |                                                                 |       |     |       |      |
| V <sub>DD-A</sub>                                                                | supply voltage (analog)                                         | 2.6   | 2.8 | 3.0   | V    |
| V <sub>DD-DO</sub>                                                               | supply voltage (digital I/O)                                    | 1.7   | 1.8 | 3.0   | V    |
| V <sub>DD-D</sub>                                                                | supply voltage (digital core) <sup>a</sup>                      | 1.425 | 1.5 | 1.575 | V    |
| V <sub>DD-E</sub>                                                                | supply voltage (MIPI)                                           | 1.425 | 1.5 | 1.575 | V    |
| <b>internal DVDD, EVDD short to DVDD, DVP output, AVDD = 2.8V, DOVDD = 2.8V</b>  |                                                                 |       |     |       |      |
| I <sub>DD-A</sub>                                                                | active (operating) current<br>2592 x 1944 @ 15 fps <sup>b</sup> | 31    | 45  | mA    |      |
| I <sub>DD-DO</sub>                                                               |                                                                 | 65    | 85  | mA    |      |
| I <sub>DD-A</sub>                                                                | active (operating) current<br>1080p @ 30fps                     | 32    | 45  | mA    |      |
| I <sub>DD-DO</sub>                                                               |                                                                 | 60    | 78  | mA    |      |
| I <sub>DD-A</sub>                                                                | active (operating) current<br>720p @ 60fps                      | 34    | 45  | mA    |      |
| I <sub>DD-DO</sub>                                                               |                                                                 | 58    | 75  | mA    |      |
| I <sub>DD-A</sub>                                                                | active (operating) current<br>720p @ 30fps                      | 34    | 45  | mA    |      |
| I <sub>DD-DO</sub>                                                               |                                                                 | 35    | 48  | mA    |      |
| I <sub>DD-A</sub>                                                                | active (operating) current<br>VGA @ 60fps                       | 34    | 45  | mA    |      |
| I <sub>DD-DO</sub>                                                               |                                                                 | 32    | 44  | mA    |      |
| I <sub>DD-A</sub>                                                                | active (operating) current<br>VGA @ 30fps                       | 34    | 45  | mA    |      |
| I <sub>DD-DO</sub>                                                               |                                                                 | 20    | 28  | mA    |      |
| <b>internal DVDD, EVDD short to DVDD, MIPI output, AVDD = 2.8V, DOVDD = 1.8V</b> |                                                                 |       |     |       |      |
| I <sub>DD-A</sub>                                                                | active (operating) current<br>2592 x 1944 @ 15 fps              | 31    | 45  | mA    |      |
| I <sub>DD-DO</sub>                                                               |                                                                 | 60    | 78  | mA    |      |
| I <sub>DD-A</sub>                                                                | active (operating) current<br>1080p @ 30fps                     | 32    | 45  | mA    |      |
| I <sub>DD-DO</sub>                                                               |                                                                 | 56    | 73  | mA    |      |
| I <sub>DD-A</sub>                                                                | active (operating) current<br>720p @ 60fps                      | 34    | 45  | mA    |      |
| I <sub>DD-DO</sub>                                                               |                                                                 | 56    | 74  | mA    |      |
| I <sub>DD-A</sub>                                                                | active (operating) current<br>720p @ 30fps                      | 34    | 45  | mA    |      |
| I <sub>DD-DO</sub>                                                               |                                                                 | 32    | 44  | mA    |      |

**table 8-3 DC characteristics (-30°C < T<sub>J</sub> < 70°C)**

| symbol                                                                      | parameter                                 | min  | typ  | max  | unit |
|-----------------------------------------------------------------------------|-------------------------------------------|------|------|------|------|
| I <sub>DD-A</sub>                                                           | active (operating) current<br>VGA @ 60fps |      | 34   | 45   | mA   |
| I <sub>DD-DO</sub>                                                          |                                           |      | 32   | 44   | mA   |
| I <sub>DD-A</sub>                                                           | active (operating) current<br>VGA @30fps  |      | 34   | 45   | mA   |
| I <sub>DD-DO</sub>                                                          |                                           |      | 20   | 28   | mA   |
| standby current                                                             |                                           |      |      |      |      |
| I <sub>DDS-SCCB<sup>c</sup></sub>                                           | standby current <sup>d</sup>              |      | 20   | 50   | µA   |
| I <sub>DDS-PWDN</sub>                                                       |                                           |      | 20   | 50   | µA   |
| digital inputs (typical conditions: AVDD = 2.8V, DVDD = 1.5V, DOVDD = 1.8V) |                                           |      |      |      |      |
| V <sub>IL</sub>                                                             | input voltage LOW                         |      |      | 0.54 | V    |
| V <sub>IH</sub>                                                             | input voltage HIGH                        | 1.26 |      |      | V    |
| C <sub>IN</sub>                                                             | input capacitor                           |      | 10   |      | pF   |
| digital outputs (standard loading 25 pF)                                    |                                           |      |      |      |      |
| V <sub>OH<sup>e</sup></sub>                                                 | output voltage HIGH                       | 1.62 |      |      | V    |
| V <sub>OL<sup>e</sup></sub>                                                 | output voltage LOW                        |      | 0.18 |      | V    |
| serial interface inputs                                                     |                                           |      |      |      |      |
| V <sub>IL<sup>e</sup></sub>                                                 | SCL and SDA                               | -0.5 | 0    | 0.54 | V    |
| V <sub>IH<sup>e</sup></sub>                                                 | SCL and SDA                               | 1.26 | 1.8  | 2.3  | V    |

- a. when internal regulator is bypassed
- b. using internal regulator for DVDD and short DVDD with EVDD; DOVDD = 2.8V. The currents are for DVP output. MIPI output will result in 5%-10% lower active current on I<sub>DD-DO</sub>
- c. external clock is stopped during measurement
- d. standby current is based on room temperature
- e. based on DOVDD = 1.8V

## 8.4 AC characteristics

**table 8-4** timing characteristics

| symbol                          | parameter                  | min | typ | max                  | unit |
|---------------------------------|----------------------------|-----|-----|----------------------|------|
| oscillator and clock input      |                            |     |     |                      |      |
| fosc                            | frequency (XCLK)           | 6   | 24  | 27                   | MHz  |
| t <sub>r</sub> , t <sub>f</sub> | clock input rise/fall time |     |     | 5 (10 <sup>a</sup> ) | ns   |

a. if using the internal PLL

Confidential for  
Zhongxindian

## 9 mechanical specifications

### 9.1 physical specifications

**figure 9-1** die specifications



**note 1** all dimensions and coordinates are in μm.

5647\_COB\_DS\_9\_1

**table 9-1** pad location coordinates (sheet 1 of 3)

| pad number | pad name | x coordinate | y coordinate | x pitch | y pitch | bond pad size |
|------------|----------|--------------|--------------|---------|---------|---------------|
| 1          | AVDD     | -2408        | 2280         |         |         | 94x94         |
| 2          | AGND     | -2131        | 2280         | 277     | —       | 94x94         |
| 3          | DOGND    | -1888        | 2280         | 243     | —       | 94x94         |
| 4          | SCL      | -1722        | 2280         | 166     | —       | 94x94         |
| 5          | SDA      | -1571        | 2280         | 151     | —       | 94x94         |
| 6          | DVDD     | -1304        | 2280         | 267     | —       | 94x94         |
| 7          | SGND     | -1057        | 2280         | 247     | —       | 94x94         |
| 8          | GPIO1    | -671         | 2280         | 386     | —       | 94x94         |

**table 9-1** pad location coordinates (sheet 2 of 3)

| pad number | pad name | x coordinate | y coordinate | x pitch | y pitch | bond pad size |
|------------|----------|--------------|--------------|---------|---------|---------------|
| 9          | GPIO0    | -437         | 2280         | 234     | —       | 94x94         |
| 10         | STROBE   | -203         | 2280         | 234     | —       | 94x94         |
| 11         | FREX     | 31           | 2280         | 234     | —       | 94x94         |
| 12         | DOVDD    | 238          | 2280         | 207     | —       | 94x94         |
| 13         | VREF2    | 414          | 2280         | 176     | —       | 94x94         |
| 14         | VREF1    | 574          | 2280         | 160     | —       | 94x94         |
| 15         | PWDN     | 782          | 2280         | 208     | —       | 94x94         |
| 16         | DVDD     | 950          | 2280         | 168     | —       | 94x94         |
| 17         | RESETB   | 1159         | 2280         | 209     | —       | 94x94         |
| 18         | AVDD     | 1366         | 2280         | 207     | —       | 94x94         |
| 19         | AGND     | 1643         | 2280         | 277     | —       | 94x94         |
| 20         | TM       | 1897         | 2280         | 254     | —       | 94x94         |
| 21         | DOGND    | 2102         | 2280         | 205     | —       | 94x94         |
| 22         | DVDD     | 2386         | 2280         | 284     | —       | 94x94         |
| 23         | DVDD     | 2385         | -2280        | -1      | -4560   | 94x94         |
| 24         | DOVDD    | 2106         | -2280        | -279    | —       | 94x94         |
| 25         | DOGND    | 1822         | -2280        | -284    | —       | 94x94         |
| 26         | AVDD     | 1585         | -2280        | -237    | —       | 94x94         |
| 27         | HREF     | 1410         | -2280        | -175    | —       | 94x94         |
| 28         | PCLK     | 1260         | -2280        | -150    | —       | 94x94         |
| 29         | VSYNC    | 1110         | -2280        | -150    | —       | 94x94         |
| 30         | DOVDD    | 928          | -2280        | -182    | —       | 94x94         |
| 31         | D0       | 760          | -2280        | -168    | —       | 94x94         |
| 32         | D1       | 610          | -2280        | -150    | —       | 94x94         |
| 33         | D2       | 460          | -2280        | -150    | —       | 94x94         |
| 34         | D3       | 310          | -2280        | -150    | —       | 94x94         |
| 35         | D9/MDN0  | 160          | -2280        | -150    | —       | 94x94         |
| 36         | D8/MDP0  | 10           | -2280        | -150    | —       | 94x94         |
| 37         | EVDD     | -180         | -2280        | -190    | —       | 94x94         |
| 38         | D7/MCN   | -340         | -2280        | -160    | —       | 94x94         |

**table 9-1** pad location coordinates (sheet 3 of 3)

| pad number | pad name | x coordinate | y coordinate | x pitch | y pitch | bond pad size |
|------------|----------|--------------|--------------|---------|---------|---------------|
| 39         | D6/MCP   | -490         | -2280        | -150    | –       | 94x94         |
| 40         | EGND     | -656         | -2280        | -166    | –       | 94x94         |
| 41         | D5/MDN1  | -806         | -2280        | -150    | –       | 94x94         |
| 42         | D4/MDP1  | -956         | -2280        | -150    | –       | 94x94         |
| 43         | EGND     | -1122        | -2280        | -166    | –       | 94x94         |
| 44         | PVDD     | -1298        | -2280        | -176    | –       | 94x94         |
| 45         | XCLK     | -1466        | -2280        | -168    | –       | 94x94         |
| 46         | DOVDD    | -1667        | -2280        | -201    | –       | 94x94         |
| 47         | DVDD     | -1875        | -2280        | -208    | –       | 94x94         |
| 48         | DOGND    | -2051        | -2280        | -176    | –       | 94x94         |
| 49         | AVDD     | -2279        | -2280        | -228    | –       | 94x94         |
| 50         | AGND     | -2463        | -2280        | -184    | –       | 94x94         |

Confidential  
Zhongxindian

**OV5647**

color CMOS QSXGA (5 megapixel) image sensor with OmniBSI™ technology

Confidential for  
Zhongxindian



proprietary to OmniVision Technologies

PRODUCT SPECIFICATION

version 2.1

## 10 optical specifications

### 10.1 sensor array center

**figure 10-1** sensor array center



**note 1** this drawing is not to scale and is for reference only.

**note 2** as most optical assemblies invert and mirror the image, the chip is typically mounted with pad 1 oriented down on the PCB.

5647\_COB\_DS\_10\_1

CC  
Zhongxing

## 10.2 lens chief ray angle (CRA)

figure 10-2 chief ray angle (CRA)



5647\_DS\_10\_2

table 10-1 CRA versus image height plot (sheet 1 of 2)

| field (%) | image height (mm) | CRA (degrees) |
|-----------|-------------------|---------------|
| 0.00      | 0.000             | 0.0           |
| 0.05      | 0.114             | 2.0           |
| 0.10      | 0.227             | 4.1           |
| 0.15      | 0.341             | 6.1           |
| 0.20      | 0.454             | 8.1           |
| 0.25      | 0.568             | 10.1          |
| 0.30      | 0.681             | 12.0          |
| 0.35      | 0.795             | 13.8          |
| 0.40      | 0.908             | 15.6          |
| 0.45      | 1.022             | 17.3          |
| 0.50      | 1.135             | 18.9          |

**table 10-1** CRA versus image height plot (sheet 2 of 2)

| field (%) | image height (mm) | CRA (degrees) |
|-----------|-------------------|---------------|
| 0.55      | 1.249             | 20.4          |
| 0.60      | 1.362             | 21.6          |
| 0.65      | 1.476             | 22.6          |
| 0.70      | 1.589             | 23.4          |
| 0.75      | 1.703             | 23.9          |
| 0.80      | 1.816             | 24.1          |
| 0.85      | 1.930             | 24.1          |
| 0.90      | 2.043             | 23.9          |
| 0.95      | 2.157             | 23.7          |
| 1.00      | 2.270             | 23.6          |

Confidential for  
Zhongxindian

**OV5647**

color CMOS QSXGA (5 megapixel) image sensor with OmniBSI™ technology

Confidential for  
Zhongxindian



proprietary to OmniVision Technologies

PRODUCT SPECIFICATION

version 2.1

## appendix A handling of RW devices

### A.1 ESD /EOS prevention

1. Ensure that there is 500V ESD control in all work areas.
2. Use ESD safety shoes, ground strap, and static control smocks in test areas.
3. Use grounded work carts and tables in inspection areas.
4. OmniVision recommends the use of ionized air in all work areas.

### A.2 particles and cleanliness of environment

1. All production, inspection and packaging areas should meet Class10 environment requirements.
2. Use optical microscopes with 50X and 100X magnifications for particle inspection.
3. Ensure that there is good cassette sealing for particle protection during storage.
4. OmniVision recommends air blowing to remove removable particles.
5. RW die should be stored in nitrogen gas purged cabinets with temperature less than 30°C and relative humidity of 60% before assembly.

### A.3 other requirements

1. Reliability assurance of RW or COB bare die is certified by product reliability of the bare die in a CLCC, CSP or QFP package form factor. Precautions should be taken if the packaging form factor of the bare die is other than these specified.
2. Avoid exposure to strong sunlight for extended periods of time as the color filter of the image sensor may become discolored.
3. Avoid direct exposure of the sensor bare die to high temperature and/or humidity environment as sensor characteristics will be affected. Extra precautions should be exercised if the bare die experiences temperatures exceeding 260°C for more than 75 seconds.

**OV5647**

color CMOS QSXGA (5 megapixel) image sensor with OmniBSI™ technology

Confidential for  
Zhongxindian



proprietary to OmniVision Technologies

PRODUCT SPECIFICATION

version 1.11

## revision history

**version 1.0**            **11.03.2009**

- initial release

**version 1.1**            **04.05.2010**

- in chapter 1, updated VREF2 description from "reference analog circuit (connect to 0.1uF capacitor to ground)" changed to reference analog circuit (connect to 1  $\mu$ F capacitor to ground)"
- in chapter 2, updated figure 2-2 reference design schematic
- in chapter 2, updated table 2-1 format and frame rate; update all pixel clock values
- in chapter 4, updated the following registers in table 4-5 AEC/AGC control functions: 0x3501, 00x3502, 0x3503, 0x350B, 0x350C, 0x350D
- in chapter 4, updated the overview for section 4.5.3 average luminance (YAVG)
- in chapter 4, updated entire section 4.10 frame exposure (FREX) mode
- in chapter 5, updated the overview for section 5.2 lens correction (LENC)
- in chapter 6, updated the entire table 6-8 DVP specifications
- in chapter 7, updated the following registers: 0x3000, 0x3001, 0x3002, 0x3008, 0x3009, 0x300A, 0x300B, 0x300D, 0x300E, 0x300F, 0x3010, 0x3011, 0x3018, 0x3035, 0x3501, 0x3502, 0x3503, 0x350C (removed), 0x350D (removed), 0x3800, 0x3802, 0x3804, 0x3806, 0x3808, 0x380A, 0x380C, 0x380E, 0x380F, 0x3810, 0x3812, 0x3816, 0x3818
- in chapter 9, updated figure 9-1 and table 9-1 pad location coordinates

**version 1.2**            **06.24.2010**

- in the key specifications section, removed "global shutter"
- in chapter 1, updated table 1-1 signal description "Strobe" to "strobe"
- in chapter 1, added to table 1-1 signal description default status column
- in chapter 1, updated table 1-2 pad configuration under various conditions
- in chapter 2, updated figure 2-2 reference design schematic
- in chapter 4, updated table 4-1 mirror flip control registers from:

|        |                 |      |    |                                                                |
|--------|-----------------|------|----|----------------------------------------------------------------|
| 0x3820 | TIMING_TC_REG20 | 0x40 | RW | Timing Control<br>Bit[2]: r_vflip_isp<br>Bit[1]: r_vflip_snr   |
| 0x3821 | TIMING_TC_REG21 | 0x00 | RW | Timing Control<br>Bit[2]: r_mirror_isp<br>Bit[1]: r_mirror_snr |

changed to

|        |                 |      |    |                                                                             |
|--------|-----------------|------|----|-----------------------------------------------------------------------------|
| 0x3820 | TIMING_TC_REG20 | 0x40 | RW | Timing Control<br>Bit[2]: ISP vertical flip<br>Bit[1]: Sensor vertical flip |
| 0x3821 | TIMING_TC_REG21 | 0x00 | RW | Timing Control<br>Bit[2]: ISP mirror<br>Bit[1]: Sensor mirror               |

- in chapter 4, updated table 4-5 AEC/AGC control function registers
- in chapter 4, updated section 4.7 black level calibration and table 4-8 BLC control functions
- in chapter 4, updated figure 4-15 FREX mode 2 timing diagram (when shutter delay is longer than exposure time)
- in chapter 4, updated 4-17 Strobe control in FREX mode
- in chapter 4, updated table 4-11 FREX strobe control functions register 0x3B00 and 0x3B07
- in chapter 5, updated table 5-4 AWB control registers changed register 0x5001 and added 0x50020
- in chapter 6, updated all values for table 6-1 system control registers
- in chapter 6, removed section 6.5 strobe
- in chapter 7, in table 7-1 system control registers; updated the following registers: 0x3008, 0x3009, 0x300E, 0x3011, 0x302A, 0x3034, 0x3500, 0x3501, 0x3502, 0x350A, 0x380E, 0x3820, 0x3821, 0x3A00, 0x3A02, 0x3A03, 0x3A08, 0x3A09, 0x3A0A, 0x3A0D, 0x3A0E, 0x3A14, 0x3A15, 0x3A17, 0x3A18, 0x3A19, 0x3B07, 0x4000~0x4067
- added appendix A

version 2.0

11.19.2010

- changed document from Preliminary Specification to Product Specification
- under key specifications on page iii, changed power requirements active and standby from "TBD" to "96, 20"
- under key specifications on page iii, added "max" to S/N ratio and changed from "TBD" to "34 dB"
- under key specifications on page iii, changed dynamic range from "TBD" to "67 dB@8xgain"
- under key specifications on page iii, changed sensitivity from "TBD" to "600mV/Lux-sec"
- under key specifications on page iii, removed well capacity and fixed pattern noise (FPN)
- under key specifications on page iii, changed dark current from "TBD" to "8mV/s @ 50°C junction temperature"
- in table 1-1, changed description to "connect to ground via..." for DVDD, VREF1, VREF2,
- in table 1-1, changed pin type to "ground" for DOGND, AGND, SGND, and EGND
- in table 1-2, removed "Some customer assume" from note a
- in section 2, updated figure 2-2, 2-1 and removed "For customized.." from last sentence of section 2.1
- in table 2-1, changed pixel clock values from 79.7 to 96, 81.6 to 96, 83.6 to 96, 84.3 to 96, 83.5 to 48, and 81.1 to 24
- in sub-sections 2.5.1 and 2.5.2 changed "if" to "when", "V<sub>DD-IO</sub> to DOVDD", "V<sub>DD-A</sub>" to "AVDD", "SCCB" to registers", removed "at the same", updated figures 2-3 and 2-4
- in section 2.7, changed section title to hardware and software standby, bullet "SCCB software sleep" to "software standby" and "sleep" to "standby" in the body text
- in sub-section 2.8.5, removed the last sentence and 0x320D~0x320F from table 2-4
- in section 2.7, added sentence, "While in MIPI mode,..."
- in section 2, added section 2.8
- in table 2-4, changed table title to "group hold registers"
- in section 3.2, removed "Sub-sampling is..."
- in section 3.4 removed "It can operate at up to 27 MHz..." and added "and resolution"

- in section 4.12, removed "a maximum"
- in table 4-13, added footnotes a and b
- in section 5, removed registers 0x5780~0x5791 and 0x5184~0x5185
- in section 5.2, updated paragraph by changing "imperfection" to "fall off", "the area where..." to "the distance of each...", removed "to compensate..."
- in section 5.4, updated paragraph by moving "in different color.." to after "...appear white in person", removed "Thus, the AWB makes sure..." and "For auto white balance..."
- in section 5.5, changed section title from "function" to "filter", "CFA image subsample" to "Sub-sample in raw...", "suffer" to "cause", "for" to "because" and added "filter" after "Post Binning..."
- in table 6-2, removed registers 0x3100~0x3106
- in section 6.7, removed "uni-directional", "bi-directional", and "The two data lanes have..."
- in table 6-7, added commas where necessary and "where tp = 1 pclk" to each cell in timing column
- in table 6-8, changed register bit description for 0x4800[7:6], 0x4800[1:0], and 0x4801 to "Debug mode"
- in table 6-8, removed registers 0x4803, 0x4804, 0x4806, 0x480A, 0x483A, 0x483C~0x483F, 0x4860~0x4867
- in table 6-8, changed register bit description for 0x4805[3:1] to "Debug mode" and 0x4805[0] to "Not used"
- in section 7, added section titles to each register table, removed table 7-2, moved register 0x3106 to table 7-1, merged tables 7-6, 7-17, and 7-22 to 7-3
- in table 7-9, added footnotes a and b
- in table 7-10, changed bit description for register 0x4001[7:6] to "Debug mode", 0x4001[5:0] to "start\_line" and changed default value to "0x00"
- in table 7-10, changed bit description for register 0x4004[7:0] to "black line num" changed default value to "0x08"
- in table 7-11, removed register 0x4203
- in table 7-13, changed bit description for register 0x4800[7:6], 0x4800[1:0], 0x4801[1:0], 0x4803, 0x4804, 0x4805[3:1], 0x4806, 0x4815[6], 0x483A, 0x483D~0x483F to "Debug mode"
- in table 7-13, removed registers 0x4860~0x4867 and "top" from table title
- in section 7, removed table 7-14
- in table 7-15, changed byte for register 0x501F from "010" to "011" and "011" to "others" and removed "TOP" from table title
- in table 7-16, changed bit description for 0x5184~0x5185 to "Debug Mode"
- in section 7, removed table 7-18
- in table 7-19, changed register address for 0x5800~0x5023 to 0x5800~0x5823 and 0x5824~0x503C and 0x5824~0x583C
- in section 7, removed table 7-20 and added "ISP output" to table title for table 7-22
- in table 7-22, changed register description for register 0x5A00[7:4] to "Not used", 0x5A00[3] to "Debug mode", 0x5A00[1] to "dig\_comp\_man\_opt", 0x5A00[0] to "dig\_comp\_man\_en", 0x5A20[0] to "gainc\_sensorgain\_man[8]", 0x5A21[7:0] to "gainc\_sensorgain[7:0]", 0x5A22[1:0] to "gainc\_dgc\_man", 0x5A23[9:8] to "gainc\_dgc\_man[7:0]", 0x5A24[2] to "Debug mode"
- in table 7-22, changed register name from "SNR" to "SENSOR" for 0x5A20 and 0x5A21
- in table 7-22, changed register name from "GAIN" to "COMP" for 0x5A22 and 0x5A23

- in table 8-3, replaced TBDs, added sections for DVP and MIPI outputs, added note e to  $V_{OH}$ ,  $V_{OL}$  and changed note d to note e for  $V_{IH}$
- in section 8.4, removed table 8-4
- added appendix A

version 2.01            12.07.2010

- in the key specifications section, added "junction temperature" to temperature range
- in chapter 8, added "junction temperature" to table 8-2 functional temperature
- added appendix A

version 2.02            04.11.2011

- in chapter 8, updated table 8-3 title to DC characteristics ( $-30^{\circ}\text{C} < T_J < 70^{\circ}\text{C}$ ) and added table footnote c, standby current is based on room temperature
- added appendix A

version 2.03            05.26.2011

- in chapter 3, replaced figure 3-2
- in chapter 4, updated table 4-5 AEC/AGC control function register 0x3502 description
- in chapter 7, updated table 7-3 AEC/AGC register 0x3502 description

version 2.04            07.29.2011

- replaced paragraph in section 6.7

version 2.1            03.08.2012

- changed all instances of I<sup>2</sup>C to SCCB
- in key specifications, removed maximum image transfer rate specification for QVGA
- in table 1-1, added table footnote a, "GPIO pins' pad design is IO pad, but there are no registers in the sensor to read their input values and they can only serve as general output pins
- in section 2.1.1, deleted "or MIPI interface" from last sentence of first paragraph, changed first sentence of second paragraph to "...data transfer and camera functions...", and changed last sentence of second paragraph to "The OV5647 uses OmniBSI technology to improve sensor performance without any physical or optical trade-offs."
- modified figure 2-1 to show arrows to row select
- in table 2-1, changed name of fourth column to "methodology"
- in section 2.4.1, changed first sentence to "The OV5647 has an on-chip PLL..."
- in table 2-1, removed row for QVGA
- in section 2.5.1, changed step 3 to "PWDN must be high during the power up period" and changed step 7 to "master clock XVCLK should be provided..."

- in section 2.5.2, changed step 5 to "all power supplies are..." and changed step 8 to "master clock XVCLK should be provided..."
- changed title of section 3.2 to "subsampling" and replaced first paragraph
- in section 4.2, changed last sentence to "Windowing is achieved by simply masking off the pixels outside the defined window; thus, the original timing is not affected"
- in section 4.6, changed paragraph to "The AEC and AGC work together to achieve optimal exposure and gain based on the environmental illumination. In order to achieve the best signal-to-noise ratio (SNR), extending the exposure time is always preferred to raising the analog gain when the illumination level is decreasing. Similarly, with increasing illumination, decreasing the gain prior to shortening the exposure time is preferred."
- in section 4.6.5, deleted last sentence
- in section 4.8.1, changed the last sentence to "The OV5647 supports..."
- in section 4.10.1, changed second and third sentences to "In FREX mode, all pixels in the frame start integration at the same time, rather than integrating row by row. After a user-defined exposure time (either by external control in mode 1 or registers {0x3B01, 0x3B04, 0x3B05} in mode 2), the mechanical shutter should be closed, preventing further integration, and then the image begins to read out."
- in section 4.12, replaced first paragraph and added second paragraph
- in section 4.12, added subsections 4.12.1 and 4.12.2
- in section 5.1, added "The ISP module provides image processor functions, including lens correction and defect pixel correction."
- in section 5.2, changed paragraph to "The lens correction (LENC) algorithm compensates for the illumination drop off in the corners due to the lens. Based on the radius of each pixel to the lens, the algorithm calculates a gain for each pixel and then corrects each pixel with the calculated gain to compensate for the light distribution due to the lens curvature. The LENC correcting curve is automatically calculated based on sensor gain so that LENC adapts with sensor gain."
- in section 5.3, changed paragraph to "Primarily due to process anomalies, pixel defects in the sensor array will occur, generating incorrect pixel levels and color values. The purpose of the defect pixel cancellation (DPC) is to remove the effects caused by defective pixels. To correctly remove defective pixels, the proper threshold should first be determined. Additionally, there are special functions available for those pixels located at the image boundary."
- in section 5.4, changed paragraph to "The purpose of the auto white balance (AWB) block is to avoid unrealistic colors so that objects that appear white to the human eye are rendered white in the final image or video. This image sensor supports both manual white balance and simple auto white balance."
- in section 5.5, changed paragraph to "Sub-sampling in the raw domain will cause zigzag artifacts on slanted edges and a color shift because of the non-uniformity of the pixel coordinates. The post binning filter maps the pixels to their physically correct location."
- in table 6-7, removed row for QVGA
- in table 8-3, changed subtitle "internal DVDD, EVDD short to DVDD, MIPI output, AVDD = 2.8V, DOVDD = 2.8V" to "internal DVDD, EVDD short to DVDD, MIPI output, AVDD = 2.8V, DOVDD = 1.8V"

**OV5647**

color CMOS QSXGA (5 megapixel) image sensor with OmniBSI™ technology

Confidential for  
Zhongxindian



proprietary to OmniVision Technologies

PRODUCT SPECIFICATION

version 2.1



the clear advantage™

## OmniVision Technologies, Inc.

### UNITED STATES

4275 Burton Drive  
Santa Clara, CA 95054

**tel:** +1 408 567 3000  
**fax:** +1 408 567 3001  
**email:** salesamerican@ovt.com

### UNITED KINGDOM

Hampshire +44 1256 744 610

### FINLAND

Mouhijärvi +358 3 341 1898

### GERMANY

Munich +49 89 63 81 99 88

### CHINA

Beijing +86 10 6580 1690  
Shanghai +86 21 6175 9888  
Shenzhen +86 755 8384 9733  
Hong Kong +852 2403 4011

### JAPAN

Tokyo +81 3 5765 6321

### KOREA

Seoul +82 2 3478 2812

### SINGAPORE

+65 6562 8250

### TAIWAN

Taipei +886 2 2657 9800 -  
ext.#100