



The background features a dynamic, abstract graphic of orange and white wavy lines that resemble light or data streams. Small white square icons are scattered across these lines, suggesting pixels or data points. In the bottom right corner, there is a small, realistic image of a blue and green rectangular sensor chip.

**datasheet**

PRODUCT SPECIFICATION

1/4" color CMOS WXGA (1 megapixel) HD sensor  
with OmniPixel3-HS™ technology

OV9712





## list of tables

|            |                                                       |      |
|------------|-------------------------------------------------------|------|
| table 1-1  | signal descriptions                                   | 1-1  |
| table 2-1  | driving capability and direction control for I/O pins | 2-4  |
| table 4-1  | mirror and flip function control                      | 4-1  |
| table 4-2  | test pattern selection control                        | 4-2  |
| table 4-3  | AEC/AGC control functions                             | 4-3  |
| table 4-4  | AEC control functions                                 | 4-5  |
| table 4-5  | average-based algorithm functions                     | 4-6  |
| table 4-6  | histogram-based AEC algorithm adjustment controls     | 4-7  |
| table 4-7  | histogram-based AEC/AGC reference area option         | 4-10 |
| table 4-8  | BLC control functions                                 | 4-11 |
| table 4-9  | digital gain control functions                        | 4-12 |
| table 5-1  | ISP top registers                                     | 5-1  |
| table 5-2  | pre-DSP registers                                     | 5-1  |
| table 5-3  | LENC gain COEF registers                              | 5-3  |
| table 5-4  | LENC registers                                        | 5-5  |
| table 5-5  | white balance function related registers              | 5-7  |
| table 5-6  | WBC registers                                         | 5-9  |
| table 5-7  | SMPH registers                                        | 5-9  |
| table 5-8  | YAVG registers                                        | 5-10 |
| table 5-9  | system control registers                              | 5-11 |
| table 6-1  | DVP timing specifications                             | 6-3  |
| table 6-2  | DVP control registers                                 | 6-4  |
| table 7-1  | system control registers                              | 7-1  |
| table 7-2  | DSP control registers                                 | 7-13 |
| table 8-1  | absolute maximum ratings                              | 8-1  |
| table 8-2  | DC characteristics (-30°C < TA < 70°C)                | 8-2  |
| table 8-3  | AC characteristics (TA = 25°C, VDD-A = 2.8V)          | 8-3  |
| table 8-4  | timing characteristics                                | 8-3  |
| table 9-1  | package dimensions                                    | 9-1  |
| table 9-2  | reflow conditions                                     | 9-2  |
| table 10-1 | CRA versus image height plot                          | 10-2 |

**OV9712**

color CMOS WXGA (1 megapixel) HD image sensor with OmniPixel3-HS™ technology



proprietary to OmniVision Technologies

PRODUCT SPECIFICATION

version 2.0

# 1 signal descriptions

**table 1-1** lists the signal descriptions and their corresponding pin numbers for the OV9712 image sensor. The package information is shown in [section 9](#).

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

| pin number | signal name | pin type  | description                              | default I/O status |
|------------|-------------|-----------|------------------------------------------|--------------------|
| A1         | AVDD        | power     | analog power (3.0 ~ 3.6V)                |                    |
| A2         | AGND        | ground    | ground                                   |                    |
| A3         | TM          | I/O       | test mode input with pull-down resistor  | input              |
| A4         | AVDD        | power     | analog power (3.0 ~ 3.6V)                |                    |
| A5         | AGND        | ground    | ground                                   |                    |
| A6         | XCLK        | I/O       | input clock                              | input              |
| B1         | VREFN       | reference | reference voltage                        |                    |
| B2         | PWDN        | I/O       | power down input with pull-down resistor | input              |
| B3         | SIOD        | I/O       | SCCB data                                |                    |
| B4         | SIOC        | input     | SCCB clock                               |                    |
| B5         | VSYNC       | I/O       | vertical sync output                     | output             |
| B6         | HREF        | I/O       | horizontal sync output                   | output             |
| C1         | VREFH       | reference | reference voltage                        |                    |
| C2         | Y6          | I/O       | DVP output bit[6]                        | output             |
| C3         | RSTB        | I/O       | reset input with pull-up resistor        | input              |
| C6         | Y5          | I/O       | DVP output bit[5]                        | output             |
| D1         | Y8          | I/O       | DVP output bit[8]                        | output             |
| D2         | Y2          | I/O       | DVP output bit[2]                        | output             |
| D3         | PCLK        | I/O       | pixel clock output                       | output             |
| D4         | Y0          | I/O       | DVP output bit[0]                        | output             |
| D5         | Y3          | I/O       | DVP output bit[3]                        | output             |
| D6         | Y7          | I/O       | DVP output bit[7]                        | output             |
| E1         | DOVDD       | power     | power for I/O circuit (1.7 ~ 3.6V)       |                    |
| E2         | Y4          | I/O       | DVP output bit[4]                        | output             |
| E3         | DGND        | ground    | ground                                   |                    |



## 2.7 reset

The OV9712 sensor includes a **RSTB** pin that forces a complete hardware reset when it is pulled low (GND). The OV9712 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 0x12[7] 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 host reset can be inserted 1 ms after PWDN goes low. The reset pulse width should be greater than or equal to 1 ms.

## 2.8 power OFF

For the full sensor power OFF, all external powers must be turned OFF and RSTB, PWDN and XCLK pins must be pulled to low.

## 2.9 power down

Two methods are available to place the OV9712 into power down mode:

- hardware power down
- SCCB software power down

To initiate hardware power down, the **PWDN** pin must be tied to high. When this occurs, the OV9712 internal device clock is halted and all internal counters are reset.

Executing a software power down through the SCCB interface suspends internal circuit activity but does not halt the device clock. All register content is maintained in standby mode.

**OV9712**

color CMOS WXGA (1 megapixel) HD image sensor with OmniPixel3-HS™ technology



proprietary to OmniVision Technologies

PRODUCT SPECIFICATION

version 2.0

## 3 block level description

### 3.1 pixel array structure

The OV9712 sensor has an image array of 1296 columns by 818 rows (1,060,128 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 1,060,128 pixels, 1,024,000 (1280x800) are active pixels and can be output. The other pixels are used for black level calibration.

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 analog amplifier

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

#### 3.2.1 gain control

The amplifier gain can either be programmed by the user or controlled by the internal automatic gain control (AGC) circuit.

### 3.3 10-bit A/D converters

After passing through the analog amplifier, the Bayer pattern raw signal is fed to two 10-bit analog-to-digital (A/D) converters, one for the G channel and one shared by the BR channels. These A/D converters operate at speeds up to 20 MHz and are fully synchronous to the pixel rate (actual conversion rate is related to the frame rate).

## 4 image sensor core digital functions

### 4.1 mirror and flip

The OV9712 provides Mirror and Flip readout modes, which respectively reverse the sensor data readout order horizontally and vertically (see **figure 4-1**). In mirror, the readout sequence of R/G or B/G is programmable. In flip, the starting line for VREF must be adjusted. Then, the DSP block will auto detect whether the pixel is in the red line or blue line and make the necessary adjustment.

**figure 4-1** mirror and flip samples



9712.DS\_4.1

**table 4-1** mirror and flip function control

| function          | register | description                                                   |
|-------------------|----------|---------------------------------------------------------------|
| mirror            | 0x04     | Bit[7]: mirror ON/OFF select<br>0: mirror OFF<br>1: mirror ON |
| flip <sup>a</sup> | 0x04     | Bit[6]: flip ON/OFF select<br>0: flip OFF<br>1: flip ON       |

a. When using the flip function, the starting line of VREF, {**VSTART**[7:0] (0x19), **REG03**[1:0] (0x03)}, must be adjusted.

## 4.2 test pattern

For testing purposes, the OV9712 offers one kind of test pattern, color bar

**figure 4-2** test pattern



**table 4-2** test pattern selection control

| function                             | register    | description                                                                                                                                                            |
|--------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| color bar<br>(with pixel overlay)    | <b>0x12</b> | Bit[1]: color bar enable<br>0: normal image<br>1: color bar with pixel overlay                                                                                         |
| color bar<br>(without pixel overlay) | <b>0x97</b> | Bit[3]: color bar without pixel overlay<br>0: normal image<br>1: color bar enable                                                                                      |
| color bar pattern select             | <b>0x97</b> | Bit[1:0]: pattern options for color bar without pixel overlay<br>00: color bar 1 (solid color)<br>01: color bar 2 (fade to gray)<br>10: color bar 3<br>11: not allowed |

## 4.3 AEC/AGC algorithms

### 4.3.1 overview

The Auto Exposure Control (AEC) and Auto Gain Control (AGC) functions allow 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-3](#).

**table 4-3** AEC/AGC control functions

| function                                   | register     | description                                                                             |
|--------------------------------------------|--------------|-----------------------------------------------------------------------------------------|
| AEC enable                                 | 0x13         | Bit[0]: auto/manual exposure control select<br>0: manual<br>1: auto                     |
| LAEC<br>(less than 1 row of exposure time) | {0x3C, 0x1F} | LAEC[15:8] = 0x3C[15:8]<br>LAEC[7:0] = 0x1F[7:0]                                        |
| AEC exposure time                          | {0x16, 0x10} | AEC[15:8] = 0x16[15:8]<br>AEC[7:0] = 0x10[7:0]                                          |
| AGC gain                                   | 0x00         | Bit[7]: digital gain<br>Bit[6:0]: analog gain                                           |
| AGC enable                                 | 0x13         | Bit[2]: auto/manual gain control select<br>0: manual<br>1: auto                         |
| histogram / average-based selection        | 0x0E         | Bit[0]: AEC/AGC method select<br>0: average-based AEC/AGC<br>1: histogram-based AEC/AGC |

There are two different algorithms that decide whether the current frame is too bright or too dark and determine if the exposure time/gain should increase or decrease for the next frame. One algorithm, Histogram algorithm, is based on the statistics of the percentage of high/low luminance pixels, and the other is based on the weighted-average of a frame.

### 4.3.2 average-based algorithm

The average-based AEC controls image luminance using registers **WPT/HisH** (0x24) and **BPT/HisL** (0x25). In average-based mode, the value of register **WPT/HisH** (0x24) indicates the high threshold value and the value of register **BPT/HisL** (0x25) indicates the low threshold value. When the target image luminance average value **YAVG** (0x2F) is within the range specified by registers **WPT/HisH** (0x24) and **BPT/HisL** (0x25), the AEC keeps the image exposure. When register **YAVG** (0x2F) is greater than the value in register **WPT/HisH** (0x24), the AEC will decrease the image exposure. When register **YAVG** (0x2F) is less than the value in register **BPT/HisL** (0x25), the AEC will increase the image exposure. Accordingly, the value in register **WPT/HisH** (0x24) should be greater than the value in register **BPT/HisL** (0x25). The gap between the values of registers **WPT/HisH** (0x24) and **BPT/HisL** (0x25) controls the image stability.

The AEC function supports both normal and fast speed selections in order to bring the image exposure into the range set by the values in registers **WPT/HisH** (0x24) and **BPT/HisL** (0x25). AEC set to normal mode will allow for single-step increment or decrement in the image exposure to maintain the specified range. A value of "0" in register **FASTEN[7]** (0x13) will result in normal speed operation and a "1" will result in fast speed operation.

Register **VPT** (0x26) controls the fast AEC range. If the target image **YAVG** (0x2F) is greater than **VPT[7:4] × 16**, AEC will decrease by 2. If register **YAVG** (0x2F) is less than **VPT[3:0] × 16**, AEC will increase by 2.

As shown in **figure 4-3**, the AEC/AGC convergence uses two regions, the inner stable operating region and the outer control zone, which defines the convergence step size change as follows:

#### 4.3.2.1 outside control zone

step size:  $2 \times (\text{AEC}[15:0])$

$$t_{\text{STEP}}: t_{\text{ROW}} \times (2 \times \text{AEC}[15:0])$$

#### 4.3.2.2 inside control zone

step size:  $2 \times (\text{AEC}[15:0]) \div 16$

$$t_{\text{STEP}}: t_{\text{ROW}} \times (2 \times \text{AEC}[15:0] \div 16)$$

Once the current value is inside the stable operating region, the AEC/AGC value has converged.

The Step Limit register acts to create a "middle ground" by limiting the maximum step size to 32 rows (delay time =  $t_{\text{ROW}} \times 32$ ).

**figure 4-3** desired convergence



9712\_DS\_4\_3

control zone upper limit: {**VPT[7:4]** (0x26[7:4]), 4'b0000}

control zone lower limit: {**VPT[3:0]** (0x26[3:0]), 4'b0000}

stable operating region upper limit: **WPT[7:0]** (0x24)

stable operating region lower limit: **BPT[7:0]** (0x25)

**table 4-4** AEC control functions

| function | register | AEC / AGC method | description                                                                                                                                                                                                                       |
|----------|----------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WPT/HisH | 0x24     | histogram-based  | luminance signal / histogram high range for AEC/AGC operation                                                                                                                                                                     |
|          |          | average-based    | AEC/AGC value decreases in auto mode when average luminance histogram is greater than <b>WPT/HisH</b> [7:0].                                                                                                                      |
| BPT/HisL | 0x25     | histogram-based  | luminance signal / histogram low range for AEC/AGC operation                                                                                                                                                                      |
|          |          | average-based    | AEC/AGC value increases in auto mode when average luminance histogram is less than <b>BPT/HisL</b> [7:0].                                                                                                                         |
| VPT      | 0x26     | histogram-based  | fast mode large step range thresholds - effective only in AEC/AGC fast mode<br>Bit[7:4]: high threshold<br>Bit[3:0]: low threshold                                                                                                |
|          |          | average-based    | AEC/AGC may change in larger steps when luminance average is greater than <b>VPT</b> [7:4] or less than <b>VPT</b> [3:0].                                                                                                         |
| YAVG     | 0x2F     |                  | luminance average - this register will auto update. Average luminance is calculated from the B/Gb/Gr/R channel average as follows:<br><br>B/Gb/Gr/R channel average =<br>(BAVG[7:0] + GbAVG[7:0] + GrAVG[7:0] + RAVG[7:0]) × 0.25 |
| FASTEN   | 0x13     |                  | Bit[7]: AEC speed select<br>0: normal<br>1: faster AEC adjustment                                                                                                                                                                 |

For the average-based AEC/AGC algorithm, the measured window is horizontally and vertically adjustable and divided into sixteen (4x4) zones (see **figure 4-4**). Each zone (or block) is 1/16th of the image and has a 4-bit weight in calculating the average luminance (YAVG). The 4-bit weight could be n/16 where n is from 0 to 15. The final YAVG is the weighted average of the sixteen zones. For more details on adjusting horizontal and vertical windows and weight for each window, refer to **section 4.3.2.3**, average luminance (YAVG).

#### 4.3.2.3 average luminance (YAVG)

Auto exposure time calculation is based on a frame brightness average value. By properly setting AHS, AVS, AHW, and AVH as shown in **figure 4-4**, a 4x4 grid average window is defined. The average value is the weighted average of the 16 sections. **table 4-5** lists the corresponding registers.

**figure 4-4** average-based window definition

**note 1** sensor array size (for WXGA, VTH=1296, VTS=818)  
valid pixel size (for WXGA, VTH=1280, VTS=800)

9712\_DS\_4.4

**table 4-5** average-based algorithm functions

| function                  | register  | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| average section weighting | 0x4E~0x51 | section 1 weight = 0x4E[1:0]<br>section 2 weight = 0x4E[3:2]<br>section 3 weight = 0x4E[5:4]<br>section 4 weight = 0x4E[7:6]<br>section 5 weight = 0x4F[1:0]<br>section 6 weight = 0x4F[3:2]<br>section 7 weight = 0x4F[5:4]<br>section 8 weight = 0x4F[7:6]<br>section 9 weight = 0x50[1:0]<br>section 10 weight = 0x50[3:2]<br>section 11 weight = 0x50[5:4]<br>section 12 weight = 0x50[7:6]<br>section 13 weight = 0x51[1:0]<br>section 14 weight = 0x51[3:2]<br>section 15 weight = 0x51[5:4]<br>section 16 weight = 0x51[7:6] |

### 4.3.3 histogram-based algorithm

The OV9712 histogram-based AEC controls exposure levels based on image histogram distribution and probability.

**table 4-6 histogram-based AEC algorithm adjustment controls**

| function   | register | description                                                              |
|------------|----------|--------------------------------------------------------------------------|
| BP level   | 0x72     | upper limit of luminance level for B pixels                              |
| WP level   | 0x73     | lower limit of luminance level for W pixels                              |
|            |          | lower limit of probability for B pixels to trigger auto AEC/AGC          |
| BP number  | 0x76     | If B pixel probability > BP number, AEC/AGC will increase automatically. |
|            |          | lower limit of probability for W pixels to trigger auto AEC/AGC          |
| WP number  | 0x77     | If W pixel probability > WP number, AEC/AGC will decrease automatically. |
| VBP level  | 0x74     | upper limit of luminance level for VB pixels                             |
| VWP level  | 0x75     | lower limit of luminance level for VW pixels                             |
|            |          | lower limit of probability for B pixels to trigger fast AEC/AGC          |
| VBP number | 0x78     | If B pixel probability > BP number, AEC/AGC will increase in fast mode.  |
|            |          | lower limit of probability for W pixels to trigger fast AEC/AGC          |
| VWP number | 0x79     | If W pixel probability > WP number, AEC/AGC will decrease in fast mode.  |

## 4.4 AEC/AGC steps

**figure 4-5** shows how the AEC and AGC work together to obtain adequate exposure/gain based on the current environment's illumination. The upper one illustrates the non-banding operation which time unit is based on Tline. The lower one shows exposure in banding. The x-axis represents the length of exposure in time scale. In normal light circumstances, the length of exposure will fall into a range from 1 Tline to 1 Tframe. In extremely bright or dark circumstances, exposure time less than 1 Tline/Tband or greater than 1 Tframe may be required accordingly. In order to achieve the best signal-to-noise ratio (SNR), extending the exposure time is always preferred, rather than raising the analog gain, when the current illumination is getting brighter. Vice versa, under dark conditions, the action to decrease the gain is always taken prior to shortening the exposure time.

**figure 4-5** darker illumination situation / brighter illumination situation



### 4.4.1 auto exposure control (AEC)

The function of the AEC is to calculate 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.

In extremely bright situations, the LAEC activates, allowing integration time to be less than one row. In extremely dark situations, the VAEC activates, allowing integration time to be larger than one frame.

To avoid image flickering under a periodic light source, the integration time step can be adjusted as an integer multiple of the period of the light source. This new AEC step system is called banding, suggesting that the steps are not continuous but fall in some bands.

#### 4.4.1.1 LAEC

If the integration time is only one row but the image is too bright, AEC will enter LAEC mode. Within LAEC, the integration time can be further decreased to a minimal of 1/16 row or so. LAEC ON/OFF can be set in 0x13[3].

#### 4.4.1.2 banding mode ON with AEC

When banding mode is ON, AEC step, which is also called 'band', increments by an integer multiple of the period of light intensity. This design is to reject image flickering when light source is not steady but periodical.

For a given operating frequency, band step can be expressed in terms of row timing.

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 0x49~0x4A.

When auto-banding is ON, if the next integration time is less than the minimal band step, banding will automatically turn OFF. It will turn ON again until the next integration time becomes larger than minimal band. If auto-banding is disabled, the minimal integration time is one minimal band. Auto-banding can be set in register 0x13[5].

#### 4.4.1.3 banding mode OFF with AEC

When Banding is OFF, integration time increases/decreases by 1/16 of the previous step in slow mode or becomes twice/half of the previous step in fast mode.

#### 4.4.1.4 VAEC

In extremely dark situations, the integration time must be longer than one frame.

The OV9712 supports long integration time such as 1 frame, 2 frames, 3 frames and 7 frames. This is achieved by slowing down original frame rate and waiting for exposure. VAEC ceiling can be set in register 0x03[7:5]. VAEC can be disable by setting register 0x0E[3] to 0.

### 4.4.2 auto gain control (AGC)

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

#### 4.4.2.1 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. For example, from AEC = 2 rows to AEC = 3 rows, there are 7 more AGC steps ( $1 + x/16$ ,  $x=1\sim7$ ) inserted, which ensures every step change is less than 1/16.

#### 4.4.2.2 gain insertion between AEC banding steps

In Banding ON mode, the minimal integration time change is the period of light intensity (10ms for 50Hz, 16.67ms for 60Hz). For the first 16 band steps, since the change between adjacent steps is larger than 1/16, AGC steps are inserted to ensure image stability.

#### 4.4.2.3 gain insertion between VAEC steps

Between VAEC 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 (6.25%).



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

| function                | address      | register name                         | description                                                                                                                                                |
|-------------------------|--------------|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LENC enable             | 0x96         | <b>DSP_CTRL_0</b>                     | Bit[3]: LENC correction function enable<br>0: Disable<br>1: Enable                                                                                         |
| manual center operation | 0xA1         | <b>LENCTRL_3</b>                      | Bit[4]: Manually selects the center of the R, G, B circle                                                                                                  |
| rnd_en                  | 0xA1         | <b>LENCTRL_3</b>                      | Bit[3]: Determines whether or not to round off the last two bits of LENC input data<br>0: Do not round off the last 2 bits<br>1: Round off the last 2 bits |
| lenc_off_man            | 0xA2         | <b>LENCTRL_4[7:0]</b>                 | Bit[7:0]: Black level manual setting for LENC<br>Range: 0 ~ 255                                                                                            |
| R_X0                    | {0xA5, 0xA3} | {LENCTRL_7[2:0],<br>LENCTRL_5[7:0]}   | LCC_X for Red Channel                                                                                                                                      |
| R_Y0                    | {0xA5, 0xA4} | {LENCTRL_7[5:4],<br>LENCTRL_6[7:0]}   | LCC_Y for Red Channel                                                                                                                                      |
| R_A1                    | 0xA6         | <b>LENCTRL_8</b>                      | Bit[6:0]: Composed of the first group of factors used in the LENC correction of the red color channel.                                                     |
| R_A2                    | 0xA8         | <b>LENCTRL_10</b>                     | Bit[3:0]: Composed of the first group of factors used in the LENC correction of the red color channel.                                                     |
| R_B1                    | 0xA7         | <b>LENCTRL_9</b>                      | Bit[7:0]: Composed of the second group of factors used in the LENC correction of the red color channel.                                                    |
| R_B2                    | 0xA8         | <b>LENCTRL_10</b>                     | Bit[7:4]: Composed of the second group of factors used in the LENC correction of the red color channel.                                                    |
| G_X0                    | {0xAB, 0xA9} | {LENCTRL_13[2:0],<br>LENCTRL_11[7:0]} | LCC_X for Green Channel                                                                                                                                    |
| G_Y0                    | {0xAB, 0xAA} | {LENCTRL_13[5:4],<br>LENCTRL_12[7:0]} | LCC_Y for Green Channel                                                                                                                                    |
| G_A1                    | 0xAC         | <b>LENCTRL_14</b>                     | Bit[6:0]: Composed of the first group of factors used in the LENC correction of the green color channel.                                                   |
| G_A2                    | 0xAE         | <b>LENCTRL_16</b>                     | Bit[3:0]: Composed of the first group of factors used in the LENC correction of the green color channel.                                                   |
| G_B1                    | 0xAD         | <b>LENCTRL_15</b>                     | Bit[7:0]: Composed of the second group of factors used in the LENC correction of the green color channel.                                                  |

table 5-4 LENC registers (sheet 2 of 2)

| function | address      | register name                             | description                                                                                                                                                                              |
|----------|--------------|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| G_B2     | 0xAE         | <b>LENC_CTRL_16</b>                       | Bit[7:4]: Composed of the second group of factors used in the LENC correction of the green color channel.                                                                                |
| B_X0     | {0xB1, 0xAF} | {LENC_CTRL_19[2:0],<br>LENC_CTRL_17[7:0]} | LCC_X for Blue Channel                                                                                                                                                                   |
| B_Y0     | {0xB1, 0xB0} | {LENC_CTRL_19[5:4],<br>LENC_CTRL_18[7:0]} | LCC_Y for Blue Channel                                                                                                                                                                   |
| B_A1     | 0xB2         | <b>LENC_CTRL_20</b>                       | Bit[6:0]: Composed of the first group of factors used in the LENC correction of the blue color channel.                                                                                  |
| B_A2     | 0xB4         | <b>LENC_CTRL_22</b>                       | Bit[3:0]: Composed of the first group of factors used in the LENC correction of the blue color channel.                                                                                  |
| B_B1     | 0xB3         | <b>LENC_CTRL_21</b>                       | Bit[7:0]: Composed of the second group of factors used in the LENC correction of the blue color channel.                                                                                 |
| B_B2     | 0xB4         | <b>LENC_CTRL_22</b>                       | Bit[7:4]: Composed of the second group of factors used in the LENC correction of the blue color channel.                                                                                 |
| V_skip   | 0xB5         | <b>LENC_CTRL_23</b>                       | Bit[2]: Lens correction option for sub-sampling mode. This register should be set during sub-sampling.<br>0: Normal image output (full size and cropped image)<br>1: Sub-sampling output |
| H_skip   | 0xB5         | <b>LENC_CTRL_23</b>                       | Bit[0]: Lens correction option for sub-sampling mode. This register should be set during sub-sampling.<br>0: Normal image output (full size and cropped image)<br>1: Sub-sampling output |

## 5.5 white balance control

The OV09712 provides options for manual white balance control and auto white balance control.

### 5.5.1 manual white balance control

In manual white balance control mode, the user has full control of the image white balance based on different preferences. It can be easily interfaced with a backend image processor through SCCB register control.

In manual mode, the OV09712 internal red, green, and blue channels can be fully controlled by a backend companion chip.

To enable manual white balance mode, turn OFF both 0x34[4] and 0x97[4]. Then, adjust the color gain using the following registers:

- Blue[11:0] {0x01[7:0], 0x06[7:4]}
- Red[11:0] {0x02[7:0], 0x06[3:0]}
- Green[11:0] {0x05[7:4], 0x07[7:4]}

For example, blue gain = Blue[11:0] / 0x400

### 5.5.2 automatic white balance control

In general, the automatic white balance is done by adjusting the red, blue, and green channels to make the red, blue, and green averages equal. The automatic mode can be enabled by setting both registers 0x34[4] and 0x97[4].

The main purpose of the AWB is to provide auto white balance correction. The algorithm is based on the gray world. In other words, the mean values of red, blue and green in the image are equal.

**table 5-5** white balance function related registers (sheet 1 of 2)

| function    | address      | register name                          | description                                                                                                                                     |
|-------------|--------------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| AWB_options | 0x38         | <b>COM25</b>                           | Bit[4]: AWB gain write options<br>0: Manual white balance control<br>1: ISP automatically controls the white balance function                   |
| AWB_en      | 0x96         | <b>DSP_CTRL_0</b>                      | Bit[4]: AWB enable<br>ISP automatically judges the image color temperature and decides how to correct color balance.<br>0: Disable<br>1: Enable |
| Blue        | {0x01, 0x06} | { <b>BLUE</b> [7:0], <b>BRL</b> [7:4]} | AWB blue channel gain<br>$\text{Blue}[11:0] = \{\text{0x01}[7:0], \text{0x06}[7:4]\} / 0x400$                                                   |
| Red         | {0x02, 0x06} | { <b>RED</b> [7:0], <b>BRL</b> [3:0]}  | AWB red channel gain<br>$\text{Red}[11:0] = \{\text{0x02}[7:0], \text{0x06}[3:0]\} / 0x400$                                                     |
| Green       | {0x05, 0x07} | { <b>GREEN</b> [7:4], <b>GL</b> [7:4]} | AWB green channel gain<br>$\text{Green}[11:0] = \{\text{0x05}[7:4], \text{0x07}[7:4]\} / 0x400$                                                 |

**table 5-5** white balance function related registers (sheet 2 of 2)

| function      | address | register name     | description                                                                                                                                                        |
|---------------|---------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AWB_gain_en   | 0x96    | <b>DSP_CTRL_0</b> | Bit[5]: AWB gain enable<br>Applies auto white balance gain according to the ISP results or manual adjustment.<br>0: Disable<br>1: Enable                           |
| AWB_fast      | 0xB6    | <b>AWB_CTRL_0</b> | Bit[2]: AWB fast mode enable<br>0: Disable<br>1: Enable                                                                                                            |
| AWB_bias      | 0xB6    | <b>AWB_CTRL_0</b> | Bit[1]: AWB bias enable<br>0: Disable<br>1: Enable                                                                                                                 |
| AWB_bias_plus | 0xB6    | <b>AWB_CTRL_0</b> | Bit[0]: AWB bias plus enable<br>Adds AWB bias back after AWB gain is calculated<br>0: Disable<br>1: Enable                                                         |
| stable_range  | 0xB8    | <b>AWB_CTRL_2</b> | Bit[7:0]: AWB stable range 1<br>Stable range when computing the gain value for R, G, and B in AWB module.                                                          |
| stable_rangew | 0xB9    | <b>AWB_CTRL_3</b> | Bit[7:0]: AWB stable range 2<br>Stable range after the gain value for R, G, and B is stable. AWB gain will be recalculated after the values exceed stable range 2. |
| AWB_frame_cnt | 0xBA    | <b>AWB_CTRL_4</b> | Bit[7:0]: AWB frame count<br>Number of frame count to apply AWB gain after AWB calculation is done.                                                                |
| delta         | 0xBB    | <b>AWB_CTRL_5</b> | Bit[7:0]: AWB delta<br>Number of steps toward stable range.                                                                                                        |

## 5.6 white black pixel cancellation (WBC)

The main purpose of the WBC function is to remove the white/black pixel effect.

**table 5-6** WBC registers

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                       |
|---------|---------------|---------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x96    | DSP_CTRL_0    | 0xF9          | RW  | <p>Bit[7]: black_en<br/>Black pixel cancel function can remove the black pixels introduced because of sensor defect (default = 1'b1)</p> <p>Bit[6]: white_en<br/>White pixel cancel function can remove the white pixels introduced because of sensor defect (default = 1'b1)</p> |

## 5.7 SMPH

The SMPH function is an option for sub-sampling mode. It should be enabled during sub-sampling mode.

**table 5-7** SMPH registers

| function  | address | register name | description                                                                              |
|-----------|---------|---------------|------------------------------------------------------------------------------------------|
| SMPH_mean | 0x97    | DSP_CTRL_1    | <p>Bit[7]: SMPH mean enable (sub-sampling mode options)<br/>0: Disable<br/>1: Enable</p> |

## 5.8 YAVG

The main purpose of the YAVG function is to determine the average value of Y.

**table 5-8** YAVG registers

| address | register name | default value | R/W | description                                                                                                                                                                                                       |
|---------|---------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x9C    | DSP_CTRL_6    | 0x00          | RW  | Bit[7:0]: blk_thresh                                                                                                                                                                                              |
| 0x9D    | DSP_CTRL_7    | 0xFF          | RW  | Bit[7:0]: wht_thresh                                                                                                                                                                                              |
| 0xBD    | YAVG_CTRL_0   | 0xA0          | RW  | Bit[7:0]: yavg_winh                                                                                                                                                                                               |
| 0xBE    | YAVG_CTRL_1   | 0xC8          | RW  | Bit[7:0]: yavg_winv                                                                                                                                                                                               |
| 0xBF    | YAVG_CTRL_2   | 0x00          | RW  | Bit[7:0]: yavg_winofh[7:0] (valid with <b>YAVG_CTRL_4[2:0]</b> (0xC1))                                                                                                                                            |
| 0xC0    | YAVG_CTRL_3   | 0x00          | RW  | Bit[7:0]: yavg_winofv[7:0] (valid with <b>YAVG_CTRL_4[5:4]</b> (0xC1))                                                                                                                                            |
| 0xC1    | YAVG_CTRL_4   | 0x00          | RW  | Bit[7]: yavg_win_man<br>Bit[6]: Reserved<br>Bit[5:4]: yavg_winofv[9:8] (valid with <b>YAVG_CTRL_3[7:0]</b> (0xC0))<br>Bit[3]: Reserved<br>Bit[2:0]: yavg_winofh[10:8] (valid with <b>YAVG_CTRL_2[7:0]</b> (0xBF)) |

## 5.9 ISP system control

System control registers include clock and reset gated control.

**table 5-9** system control registers

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------|---------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xD6    | SC_CTRL_0     | 0x0C          | RW  | <p>Bit[7]: Bypass DVP<br/>(default value = 1'b0)</p> <p>Bit[6]: Reserved (default value = 1'b0)</p> <p>Bit[5]: snr_rst_ctrl for DVP<br/>(default value = 1'b0)</p> <p>Bit[4]: snr_rst_ctrl for DSP<br/>(default value = 1'b0)</p> <p>Bit[3]: DVP gated clock<br/>(default value = 1'b1)</p> <p>Bit[2]: DSP gated clock<br/>(default value = 1'b1)</p> <p>Bit[1]: DVP reset (default value = 1'b0)</p> <p>Bit[0]: DSP reset (default value = 1'b0)</p> |

**OV9712**

color CMOS WXGA (1 megapixel) HD image sensor with OmniPixel3-HS™ technology



proprietary to OmniVision Technologies

PRODUCT SPECIFICATION

version 2.0

## 6 image sensor output interface digital functions

### 6.1 digital video port (DVP)

#### 6.1.1 overview

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

#### 6.1.2 HREF mode

HREF mode is the default mode of the DVP (see [figure 6-1](#)). Each DVP\_VSYNC indicates the starting of a new frame. The OV9712 supports three types of DVP\_VSYNC signals (vsync\_old, vsync\_new, and vsync3) as shown in [figure 6-2](#). DVP\_VSYNC, DVP\_HREF, and DVP\_PCLK can be reversed using the register settings.

**figure 6-1** DVP timing



**note 1** DVP\_PCLK can be optionally gated when DVP\_HREF is low.

**note 1** the typical values are:  $h2v\_dly=256xTp$ ,  $v2h\_dly=16432Tp$ ,  $line\_length=1608Tp$ .  
these parameters are variable when setting changes.

9712\_DS\_6\_1

**figure 6-2** VSYNC timing

9712\_DS\_6\_2

### 6.1.3 HSYNC mode

In this mode, the line blanking time and VSYNC to the first image line are fixed. Also, there are dummy lines when vertical blanking. The following settings are used to open HSYNC mode (see **table 6-2** for the DVP control registers).

1. write 0xCB to 0x32 (sets hsync\_en = 1)
2. write 0xC3 to 0x21 (starts to calculate the parameters for HSYNC mode)

### 6.1.4 CCIR656 mode

The OV9712 supports standard CCIR656 mode. The sync code can either be automatically generated or by setting registers 0xC3 to 0xC7. "F" of the sync code can be optionally toggled every frame. To set CCIR656 mode setting:

1. write 0xC3 to 0xA0 (sets ccir656\_en = 1)
2. write 0xD4 to 0x23 (sets F\_log\_en = 1)

**figure 6-3** CCIR656 timing

**note 1** Xp: [1, F, V, H, P[3:0]]

F: 0 for field 1; 1 for field 2

V: 0 for all else; 1 for field blanking

H: 0 for SAV; 1 for EAV

P[3:0]: protect bits

|   |   |   |   |    |    |    |    |   |   |   |   |    |    |    |    |
|---|---|---|---|----|----|----|----|---|---|---|---|----|----|----|----|
| 1 | F | V | H | P3 | P2 | P1 | P0 | 1 | F | V | H | P3 | P2 | P1 | P0 |
|---|---|---|---|----|----|----|----|---|---|---|---|----|----|----|----|

|   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|

|   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 0 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|

|   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 0 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|

|   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|

9712\_DS\_6\_3

### 6.1.5 DVP timing

**figure 6-4** DVP timing diagram



**table 6-1** DVP timing specifications

| mode             | timing                                                                                                                                                                                                                                                                       |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WXGA<br>1280x800 | <ul style="list-style-type: none"> <li>(1) 1397664 tp = 828 lines</li> <li>(2) 33584 tp</li> <li>(3) 13832 tp</li> <li>(4) 1688 tp</li> <li>(5) 256 tp</li> <li>(6) 1280 tp</li> <li>(7) 408 tp</li> <li>(8) 274 tp</li> <li>(9) 48 tp</li> </ul> <p>where 1 pclk = 1 tp</p> |
| 640x400          | <ul style="list-style-type: none"> <li>(1) 698832 tp = 414 lines</li> <li>(2) 9944 tp</li> <li>(3) 13840 tp</li> <li>(4) 1688 tp</li> <li>(5) 256 tp</li> <li>(6) 1280 tp</li> <li>(7) 408 tp</li> <li>(8) 286 tp</li> <li>(9) 48 tp</li> </ul> <p>where 1 pclk = 2 tp</p>   |



#### note

The timing values shown in **table 6-1** may vary depending upon register settings.

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

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|---------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xC2    | DVP_CTRL_00   | 0x80          | RW  | <p>Bit[7:6]: VSYNC options<br/>00: vsync_old<br/>01: vsync_new<br/>10: vsync3<br/>11: Invalid</p> <p>Bit[5]: pclk_gate_en<br/>Gate dvp_pclk when there is no data transfer<br/>0: Disable<br/>1: Enable</p> <p>Bit[4]: vsync_gate<br/>Gate dvp_pclk when VSYNC &amp;&amp; pclk_gate_en<br/>0: Disable<br/>1: Enable</p> <p>Bit[3]: vsync3_w_sel<br/>0: VSYNC3 will go low when SOF<br/>1: Use vsync_width × 64 as vsync3_width</p> <p>Bit[2]: pclk_pol<br/>1: Reverse DVP_PCLK</p> <p>Bit[1]: href_pol<br/>1: Reverse DVP_HREF</p> <p>Bit[0]: vsync_pol<br/>0: VSYNC=1 is frame blanking time<br/>1: VSYNC=0 is frame blanking</p> |

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

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|---------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xC3    | DVP_CTRL_01   | 0x20          | RW  | <p>Bit[7]: ccir656_en<br/>0: Disable<br/>1: Enable</p> <p>Bit[6]: sync_code_sel<br/>0: Auto generate sync code for CCIR656<br/>1: Use FS, FE, LS, LE (registers <b>0xC4</b> to <b>0xC7</b>) as sync code</p> <p>Bit[5]: blk_656<br/>0: CCIR656 data is 0x040 or 0x200<br/>1: CCIR656 data is 0x000 when blanking</p> <p>Bit[4]: eav_first<br/>1: CCIR656 sends EAV first</p> <p>Bit[3:1]: dvp_data_sequence<br/>000: Y9,Y8,Y7,Y6,Y5,Y4,Y3,Y2, Y1,Y0<br/>001: Y1,Y0,Y9,Y8,Y7,Y6,Y5,Y4, Y3,Y2<br/>010: Y7,Y6,Y5,Y4,Y3,Y2,Y1,Y0, Y9,Y8<br/>011: Reserved<br/>100: Y0,Y1,Y2,Y3,Y4,Y5,Y6,Y7, Y8,Y9<br/>101: Y8,Y9,Y0,Y1,Y2,Y3,Y4,Y5, Y6,Y7<br/>110: Y2,Y3,Y4,Y5,Y6,Y7,Y8,Y9, Y0,Y1<br/>111: Reserved</p> <p>Bit[0]: chg_flag<br/>Write 1 to this bit will generate change flag for HSYNC mode. This bit will auto clear. DVP will restart to calculate all timing parameters and output a frame.</p> |
| 0xC4    | DVP_CTRL_02   | 0xAB          | RW  | Bit[7:0]: FS for CCIR656                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0xC5    | DVP_CTRL_03   | 0xB6          | RW  | Bit[7:0]: FE for CCIR656                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0xC6    | DVP_CTRL_04   | 0x80          | RW  | Bit[7:0]: LS for CCIR656                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0xC7    | DVP_CTRL_05   | 0x9D          | RW  | Bit[7:0]: LE for CCIR656                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0xC8    | DVP_CTRL_06   | 0x00          | RW  | <p>Bit[7]: blk_tog<br/>1: dvp_data will toggle when blanking</p> <p>Bit[6]: vsync_width_sel<br/>0: Use vsync_widthx64 as VSYNC width<br/>1: Select 4x line length as VSYNC width</p> <p>Bit[5:3]: h2v_dly<br/>VSYNC to HREF delay for vsync_new</p> <p>Bit[2:0]: v2h_dly<br/>HREF to VSYNC delay for vsync_new</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0xC9    | DVP_CTRL_07   | 0x80          | RW  | Bit[7:0]: vsync_width_l<br>vsync_width_real = vsync_width × 64                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

table 6-2 DVP control registers (sheet 3 of 4)

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|---------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xCA    | DVP_CTRL_08   | 0x20          | RW  | <p>Bit[7:6]: vsync_width_h</p> <p>Bit[5:4]: sof2h_dly_offset</p> <p>Bit[3]: ddr_phase<br/>0: First pixel is at rising edge<br/>1: First pixel is at falling edge</p> <p>Bit[2]: Test pattern options<br/>0: 10-bit<br/>1: 8-bit</p> <p>Bit[1:0]: Test pattern mode<br/>00: No test pattern<br/>01: 1, 2, 4, 8, ...<br/>10: 1, 1, 2, 2, ...</p>                                                                                                                                                                                                                                                                                                                                                                   |
| 0xCB    | DVP_CTRL_09   | 0xA6          | RW  | <p>Bit[7]: sof_RST_en<br/>1: DVP state machine will be reset by SOF chg_sel for recalculating DVP timing for HSYNC mode</p> <p>Bit[6:5]:<br/>00: Select snr chg and manu chg (manu chg is in register <b>DVP_CTRL_01[0]</b> (0xC3))<br/>01: Select auto detect chg and manu chg<br/>10: manu set chg</p> <p>Bit[4]: hsync_en<br/>1: Enable HSYNC mode (see <b>figure 6-1</b>)</p> <p>Bit[3]: hsync_dvp_en<br/>1: v2h_dly, h2v_dly and line_length are fixed for each frame (see <b>figure 6-1</b>)</p> <p>Bit[2]: hsync_1st_en<br/>0: Mask the first frame when in HSYNC mode</p> <p>Bit[1:0]: line_length_sel<br/>00: Select line_length_snr<br/>01: Select line_length_reg<br/>10: Select line_length_auto</p> |
| 0xCC    | DVP_CTRL_0A   | 0x40          | RW  | <p>Bit[7:4]: FIFO_BUF size</p> <p>Bit[3:0]: dmy_line_nu<br/>Use CCIR656 first dummy line number to generate VSYNC</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0xCD    | DVP_CTRL_0B   | 0x00          | RW  | Bit[7:0]: eof2v_dly[23:16]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0xCE    | DVP_CTRL_0C   | 0x01          | RW  | Bit[7:0]: eof2v_dly[15:8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0xCF    | DVP_CTRL_0D   | 0x00          | RW  | Bit[7:0]: eof2v_dly[7:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 0xD0    | DVP_CTRL_0E   | 0xFF          | RW  | Bit[7:0]: line_length[15:8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0xD1    | DVP_CTRL_0F   | 0xFF          | RW  | Bit[7:0]: line_length[7:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0xD2    | DVP_CTRL_10   | 0xFF          | RW  | <p>Bit[7:0]: clip_max[9:2]<br/>DVP output data should be less than or equal to clip_max (valid with <b>DVP_CTRL_12[1:0]</b> (0xD4))</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

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

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                      |
|---------|---------------|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xD3    | DVP_CTRL_11   | 0x00          | RW  | <p>Bit[7:0]: clip_min[9:2]<br/>           DVP output data should be larger than or equal to clip_min (valid with <b>DVP_CTRL_12[3:2]</b> (0xD4))</p>                                                                                                                                             |
| 0xD4    | DVP_CTRL_12   | 0x03          | RW  | <p>Bit[5]: f_tog_en<br/>           1: ccir_f will toggle every frame</p> <p>Bit[4]: ddr_en<br/>           1: DVP will output DDR clock</p> <p>Bit[3:2]: clip_min[1:0] (valid with <b>DVP_CTRL_11[7:0]</b> (0xD3))</p> <p>Bit[1:0]: clip_max[1:0] (valid with <b>DVP_CTRL_10[7:0]</b> (0xD2))</p> |

**OV9712**

color CMOS WXGA (1 megapixel) HD image sensor with OmniPixel3-HS™ technology



proprietary to OmniVision Technologies

PRODUCT SPECIFICATION

version 2.0

## 7 register tables

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

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

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                |
|---------|---------------|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x00    | GAIN          | 0x00          | RW  | <p>AGC Gain Control<br/>This AGC register combines analog gain and digital gain</p> <p>Bit[7]: Digital gain<br/>0: apply digital gain only if gain <math>\geq 2x</math><br/>1: apply digital gain only if gain <math>\geq 4x</math></p> <p>Bit[6:0]: Analog gain</p>                                                                       |
| 0x01    | BLUE          | 0x40          | RW  | B Channel Offset MSBs for AWB (LSBs in register <b>BRL</b> [7:4] (0x06))                                                                                                                                                                                                                                                                   |
| 0x02    | RED           | 0x40          | RW  | R Channel Offset MSBs for AWB (LSBs in register <b>BRL</b> [3:0] (0x06))                                                                                                                                                                                                                                                                   |
| 0x03    | REG03         | 0x02          | RW  | <p>Register 03</p> <p>Bit[7:5]: VAEC ceiling<br/>000: 1 frame<br/>010: 2 frames<br/>011: 3 frames<br/>1xx: 7 frames</p> <p>Bit[4]: Reserved</p> <p>Bit[3:2]: Sensor vertical output size LSBs (MSBs in register <b>AVsize</b> (0x1A))</p> <p>Bit[1:0]: Sensor vertical output start point LSBs (MSBs in register <b>VSTART</b> (0x19))</p> |
| 0x04    | REG04         | 0x00          | RW  | <p>Register 04</p> <p>Bit[7]: Mirror</p> <p>Bit[6]: Vertical flip</p> <p>Bit[5:1]: Reserved</p> <p>Bit[0]: Group latch enable</p>                                                                                                                                                                                                          |
| 0x05    | GREEN         | 0x00          | RW  | G Channel Offset MSBs for AWB (LSBs in register <b>GL</b> (0x07))                                                                                                                                                                                                                                                                          |
| 0x06    | BRL           | 0x00          | RW  | <p>Bit[7:4]: B channel offset LSBs for AWB (MSBs in register <b>BLUE</b> (0x01))</p> <p>Bit[3:0]: R channel offset LSBs for AWB (MSBs in register <b>RED</b> (0x02))</p>                                                                                                                                                                   |

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

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                              |
|---------|---------------|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x07    | GL            | 0x00          | RW  | Bit[7:4]: G channel offset LSBs for AWB (MSBs in register <b>GREEN</b> (0x05))<br>Bit[3:0]: Reserved                                                                                                                                                                                                     |
| 0x08    | REG08         | 0x00          | RW  | Bit[7:4]: H window size offset between sensor output and DSP output<br>Bit[3:0]: V window size offset between sensor output and DSP output                                                                                                                                                               |
| 0x09    | COM2          | 0x00          | RW  | Common Control 2<br>Bit[7:5]: Reserved<br>Bit[4]: Chip sleep mode<br>Bit[3]: Reset sensor timing when mode changes<br>Bit[2:0]: Reserved                                                                                                                                                                 |
| 0x0A    | PIDH          | 0x97          | R   | Product ID MSBs (read only)                                                                                                                                                                                                                                                                              |
| 0x0B    | PIDL          | 0x11          | R   | Product ID LSBs (read only)                                                                                                                                                                                                                                                                              |
| 0x0C    | COM3          | 0x00          | RW  | Common Control 3<br>Bit[7:1]: Reserved<br>Bit[0]: Single frame output                                                                                                                                                                                                                                    |
| 0x0D    | COM4          | 0x01          | RW  | Common Control 4<br>Bit[7]: Reserved<br>Bit[6]: Freeze AEC<br>Bit[5]: Initiate BLC calculation manually<br>Bit[4:2]: Reserved<br>Bit[1]: Manual mode for tp level exposure<br>Bit[0]: AEC step control<br>0: AEC max increasing step less than vertical black<br>1: AEC max increasing step has no limit |
| 0x0E    | COM5          | 0x40          | RW  | Common Control 5<br>Bit[7]: Reserved<br>Bit[6]: BLC line selection<br>0: Electrical BLC<br>1: Optical BLC<br>Bit[5:4]: Reserved<br>Bit[3]: VAEC ON/OFF<br>0: OFF<br>1: ON<br>Bit[2:1]: Reserved<br>Bit[0]: AEC/AGC algorithm selection<br>0: Average-based<br>1: Histogram-based                         |
| 0x0F    | COM6          | 0x00          | RW  | Common Control 6<br>Bit[7:0]: Reserved                                                                                                                                                                                                                                                                   |

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

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------|---------------|---------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x10    | AEC           | 0x9A          | RW  | Automatic Exposure Control Bit[7:0] (MSBs in register <b>AECH</b> (0x16))                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0x11    | CLK           | 0x00          | RW  | <p>Clock Rate Control<br/>           Bit[7:6]: Reserved<br/>           Bit[5:0]: Clock divider<br/> <math>SysClk = CLK3 / (\text{decimal value of } CLK[5:0] + 1) / 2</math> (see <b>figure 2-3</b>)</p>                                                                                                                                                                                                                                                                                                                                            |
| 0x12    | COM7          | 0x40          | RW  | <p>Common Control 7<br/>           Bit[7]: SRST<br/>           1: Initiates soft reset. All registers are set to factory default values after which the chip resumes normal operation</p> <p>Bit[6]: VT2<br/>           Down sample mode vertical timing</p> <p>Bit[5:2]: Reserved</p> <p>Bit[1]: Array color bar enable</p> <p>Bit[0]: HT2<br/>           Down sample mode horizontal timing</p>                                                                                                                                                   |
| 0x13    | COM8          | 0x85          | RW  | <p>Common Control 8<br/>           Bit[7]: AEC speed selection<br/>           0: Normal<br/>           1: Faster AEC adjustment</p> <p>Bit[6]: AEC step selection</p> <p>Bit[5]: Banding filter ON/OFF selection<br/>           0: OFF<br/>           1: ON</p> <p>Bit[4]: Reserved</p> <p>Bit[3]: LAEC ON/OFF select<br/>           0: OFF<br/>           1: ON</p> <p>Bit[2]: AGC auto/manual control selection</p> <p>Bit[1]: Reserved</p> <p>Bit[0]: Exposure auto/manual control selection<br/>           0: Manual<br/>           1: Auto</p> |

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

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|---------------|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x14    | COM9          | 0x10          | RW  | <p>Common Control 9</p> <p>Bit[7:5]: AGC gain ceiling<br/>000: 2x analog gain<br/>001: 4x analog gain<br/>010: 8x analog gain<br/>011: 16x analog gain<br/>100: 16x analog gain plus 2x digital gain</p> <p>Bit[4]: Reserved</p> <p>Bit[3]: Enable AEC below banding value<br/>0: Limit the minimum exposure time to 1/100 or 1/120 second under any light conditions when banding filter is enabled<br/>1: Allow exposure time to be less than 1/100 or 1/120 second under strong light conditions when banding filter is enabled</p> <p>Bit[2]: Reserved</p> <p>Bit[1]: Enable frame drop function</p> <p>Bit[0]: Reserved</p> |
| 0x15    | COM10         | 0x00          | RW  | <p>Common Control 10</p> <p>Bit[7]: HSYNC swap<br/>0: HSYNC<br/>1: HREF</p> <p>Bit[6]: HREF pin output swap<br/>0: HREF<br/>1: HSYNC</p> <p>Bit[5:4]: Reserved</p> <p>Bit[3]: HREF polarity<br/>0: Output positive HREF<br/>1: Output negative HREF for valid data</p> <p>Bit[2]: Reserved</p> <p>Bit[1]: VSYNC polarity<br/>0: Positive<br/>1: Negative</p> <p>Bit[0]: HSYNC polarity<br/>0: Positive<br/>1: Negative</p>                                                                                                                                                                                                       |
| 0x16    | AECH          | 0x01          | RW  | Automatic Exposure Control Bit[15:8] (LSBs in register <b>AEC</b> (0x10))                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0x17    | HSTART        | 0x26          | RW  | Sensor Horizontal Output Start Point MSBs (LSBs in register <b>REG32</b> [2:0] (0x32))                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

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

| address | register name | default value | R/W | description                                                                                                                                                               |
|---------|---------------|---------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x18    | AHsize        | 0xA2          | RW  | Sensor Horizontal Output Size MSBs (LSBs in register <b>REG32</b> [5:3] (0x32))                                                                                           |
| 0x19    | VSTART        | 0x01          | RW  | Sensor Vertical Output Start Point MSBs (LSBs in register <b>REG03</b> [1:0] (0x03))                                                                                      |
| 0x1A    | AVsize        | 0xC8          | RW  | Sensor Vertical Output Size MSBs (LSBs in register <b>REG03</b> [3:2] (0x03))                                                                                             |
| 0x1B    | PSHIFT        | 0x81          | RW  | Pixel Shift                                                                                                                                                               |
| 0x1C    | MIDH          | 0x7F          | R   | Manufacturer ID Byte – High                                                                                                                                               |
| 0x1D    | MIDL          | 0xA2          | R   | Manufacturer ID Byte – Low                                                                                                                                                |
| 0x1E    | COM11         | 0x00          | RW  | Common Control 11<br>Bit[7:0]: Reserved                                                                                                                                   |
| 0x1F    | REG1F         | 0x00          | RW  | LSBs for Tp Level Exposure Control when exposure is less than one line (MSBs in register <b>COM28</b> (0x3C))                                                             |
| 0x20    | COM12         | 0x00          | RW  | Common Control 12<br>Bit[7:0]: Reserved                                                                                                                                   |
| 0x21    | COM13         | 0x03          | RW  | Common Control 13<br>Bit[7:6]: Reserved<br>Bit[5:4]: Automatically trigger VAEC when gain is greater than:<br>00: 2x<br>01: 4x<br>10: 8x<br>11: 16x<br>Bit[3:0]: Reserved |
| 0x22    | COM14         | 0x00          | RW  | Common Control 14<br>Bit[7:6]: Reserved<br>Bit[5:0]: Maximum smooth banding steps in terms of row exposure                                                                |
| 0x23    | COM15         | 0x00          | RW  | Common Control 15<br>Bit[7:0]: Reserved                                                                                                                                   |
| 0x24    | WPT           | 0x60          | RW  | Luminance Signal High Range for AEC/AGC Operation                                                                                                                         |
| 0x25    | BPT           | 0x55          | RW  | Luminance Signal Low Range for AEC/AGC Operation                                                                                                                          |
| 0x26    | VPT           | 0x92          | RW  | Fast Mode Large Step Range Thresholds – effective only in AEC/AGC fast mode                                                                                               |
| 0x27    | COM16         | 0x00          | RW  | Common Control 16<br>Bit[7:0]: Reserved                                                                                                                                   |

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

| address   | register name | default value | R/W | description                                                                                                                                                                                                                               |
|-----------|---------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x28      | COM17         | 0x00          | RW  | Common Control 17<br>Bit[7:0]: Reserved                                                                                                                                                                                                   |
| 0x29      | COM18         | 0x00          | RW  | Common Control 18<br>Bit[7:0]: Reserved                                                                                                                                                                                                   |
| 0x2A      | REG2A         | 0x9B          | RW  | Horizontal Tp Counter End Point LSBs (MSBs in register <b>REG2B</b> (0x2B))                                                                                                                                                               |
| 0x2B      | REG2B         | 0x06          | RW  | Horizontal Tp Counter End Point MSBs (LSBs in register <b>REG2A</b> (0x2A))                                                                                                                                                               |
| 0x2C      | COM19         | 0x50          | RW  | Common Control 19<br>Bit[7:0]: Reserved                                                                                                                                                                                                   |
| 0x2D      | REG2D         | 0x00          | RW  | LSBs for Automatically Inserted Dummy Lines in Night Mode (MSBs in register <b>REG2E</b> (0x2E))                                                                                                                                          |
| 0x2E      | REG2E         | 0x00          | RW  | MSBs for Automatically Inserted Dummy Lines in Night Mode (LSBs in register <b>REG2D</b> (0x2E))                                                                                                                                          |
| 0x2F      | YAVG          | 0x00          | RW  | Luminance Average Value                                                                                                                                                                                                                   |
| 0x30      | REG30         | 0x08          | RW  | HSYNC Start Point                                                                                                                                                                                                                         |
| 0x31      | REG31         | 0x20          | RW  | HSYNC Stop Point                                                                                                                                                                                                                          |
| 0x32      | REG32         | 0x01          | RW  | Register 32<br>Bit[7:6]: Reserved<br>Bit[5:3]: Sensor horizontal output size length LSBs (MSBs in register <b>AHsize</b> (0x18))<br>Bit[2:0]: Sensor horizontal output start point LSBs (MSBs in register <b>HSTART</b> (0x17))           |
| 0x33~0x36 | RSVD          | —             | —   | Reserved                                                                                                                                                                                                                                  |
| 0x37      | COM24         | 0x02          | RW  | Common Control 24<br>Bit[7:4]: Reserved<br>Bit[3]: Trigger BLC manually for 64 frames<br>Bit[2]: BLC select<br>0: BLC triggered by gain change<br>1: BLC is always ON, meaning BLC offsets are adjusted every frame<br>Bit[1:0]: Reserved |

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

| address   | register name | default value | R/W | description                                                                                                                                                                                                                                       |
|-----------|---------------|---------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x38      | COM25         | 0x10          | RW  | <p>Common Control 25</p> <p>Bit[7:5]: Reserved</p> <p>Bit[4]: AWB_gain write options</p> <p>0: ISP controls white balance function<br/>1: Manual white balance control</p> <p>Bit[3:0]: Reserved</p>                                              |
| 0x39~0x3B | RSVD          | —             | —   | Reserved                                                                                                                                                                                                                                          |
| 0x3C      | COM28         | 0x00          | RW  | MSBs for Tp Level Exposure Control when exposure is less than one line (LSBs in register <b>REG1F</b> (0x1F))                                                                                                                                     |
| 0x3D      | RENDL         | 0x3C          | RW  | R Counter End Point LSBs (MSBs in register <b>RENDH</b> (0x3E))                                                                                                                                                                                   |
| 0x3E      | RENDH         | 0x03          | RW  | R Counter End Point MSBs (LSBs in register <b>RENDL</b> (0x3E))                                                                                                                                                                                   |
| 0x3F~0x40 | RSVD          | —             | —   | Reserved                                                                                                                                                                                                                                          |
| 0x41      | REG41         | 0x82          | RW  | <p>Register 41</p> <p>Bit[7]: BLC window enable</p> <p>Bit[6:4]: Reserved</p> <p>Bit[3:0]: BLC target base</p>                                                                                                                                    |
| 0x42      | REG42         | 0x14          | RW  | Register 42<br>Bit[7:0]: Reserved                                                                                                                                                                                                                 |
| 0x43      | REG43         | 0xC0          | RW  | <p>Register 43</p> <p>Bit[7:6]: BLC line selection</p> <p>00: Not used<br/>01: Only selects red line as BLC line<br/>10: Only selects blue line as BLC line<br/>11: Selects both blue line and red line as BLC line</p> <p>Bit[5:0]: Reserved</p> |
| 0x44      | ROFFS         | 0x00          | R   | LSBs for BLC Offset of R Channel (MSBs in register <b>HOFFS</b> [1:0] (0x48))                                                                                                                                                                     |
| 0x45      | BOFFS         | 0x00          | R   | LSBs for BLC Offset of B Channel (MSBs in register <b>HOFFS</b> [3:2] (0x48))                                                                                                                                                                     |
| 0x46      | GrOFFS        | 0x00          | R   | LSBs for BLC Offset of Gr Channel (MSBs in register <b>HOFFS</b> [5:4] (0x48))                                                                                                                                                                    |

table 7-1 system control registers (sheet 8 of 12)

| address   | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------|---------------|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x47      | GbOFFS        | 0x00          | R   | LSBs for BLC Offset of Gb Channel (MSBs in register <b>HOFFS</b> [7:6] (0x48))                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0x48      | HOFFS         | 0x00          | R   | <p>Bit[7:6]: MSBs for BLC offset of Gb channel (LSBs in register <b>GbOFFS</b> (0x47))</p> <p>Bit[5:4]: MSBs for BLC offset of Gr channel (LSBs in register <b>GrOFFS</b> (0x46))</p> <p>Bit[3:2]: MSBs for BLC offset of B channel (LSBs in register <b>BOFFS</b> (0x45))</p> <p>Bit[1:0]: MSBs for BLC offset of R channel (LSBs in register <b>ROFFS</b> (0x44))</p>                                                                                                                                                                                                                                                                                                                      |
| 0x49      | REG49         | 0x00          | RW  | Banding Step LSBs (MSBs in register <b>REG4A</b> [1:0] (0x4A))                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0x4A      | REG4A         | 0xD0          | RW  | <p>Register 4A</p> <p>Bit[7:2]: Reserved</p> <p>Bit[1:0]: Banding step MSBs (LSBs in register <b>REG49</b> (0x49))</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x4B~0x4D | RSVD          | —             | —   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x4E      | REG4E         | 0x55          | RW  | <p>16-Zone Y Average Select</p> <p>Bit[7:6]: Zone 4</p> <ul style="list-style-type: none"> <li>00: Not allowed</li> <li>01: Weight x1</li> <li>10: Weight x2</li> <li>11: Weight x4</li> </ul> <p>Bit[5:4]: Zone 3</p> <ul style="list-style-type: none"> <li>00: Not selected</li> <li>01: Weight x1</li> <li>10: Weight x2</li> <li>11: Weight x4</li> </ul> <p>Bit[3:2]: Zone 2</p> <ul style="list-style-type: none"> <li>00: Not allowed</li> <li>01: Weight x1</li> <li>10: Weight x2</li> <li>11: Weight x4</li> </ul> <p>Bit[1:0]: Zone 1</p> <ul style="list-style-type: none"> <li>00: Not allowed</li> <li>01: Weight x1</li> <li>10: Weight x2</li> <li>11: Weight x4</li> </ul> |

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

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------|---------------|---------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x4F    | REG4F         | 0x55          | RW  | <p>16-Zone Y Average Select</p> <p>Bit[7:6]: Zone 8</p> <ul style="list-style-type: none"> <li>00: Not allowed</li> <li>01: Weight x1</li> <li>10: Weight x2</li> <li>11: Weight x4</li> </ul> <p>Bit[5:4]: Zone 7</p> <ul style="list-style-type: none"> <li>00: Not allowed</li> <li>01: Weight x1</li> <li>10: Weight x2</li> <li>11: Weight x4</li> </ul> <p>Bit[3:2]: Zone 6</p> <ul style="list-style-type: none"> <li>00: Not allowed</li> <li>01: Weight x1</li> <li>10: Weight x2</li> <li>11: Weight x4</li> </ul> <p>Bit[1:0]: Zone 5</p> <ul style="list-style-type: none"> <li>00: Not allowed</li> <li>01: Weight x1</li> <li>10: Weight x2</li> <li>11: Weight x4</li> </ul>    |
| 0x50    | REG50         | 0x55          | RW  | <p>16-Zone Y Average Select</p> <p>Bit[7:6]: Zone 12</p> <ul style="list-style-type: none"> <li>00: Not allowed</li> <li>01: Weight x1</li> <li>10: Weight x2</li> <li>11: Weight x4</li> </ul> <p>Bit[5:4]: Zone 11</p> <ul style="list-style-type: none"> <li>00: Not allowed</li> <li>01: Weight x1</li> <li>10: Weight x2</li> <li>11: Weight x4</li> </ul> <p>Bit[3:2]: Zone 10</p> <ul style="list-style-type: none"> <li>00: Not allowed</li> <li>01: Weight x1</li> <li>10: Weight x2</li> <li>11: Weight x4</li> </ul> <p>Bit[1:0]: Zone 9</p> <ul style="list-style-type: none"> <li>00: Not allowed</li> <li>01: Weight x1</li> <li>10: Weight x2</li> <li>11: Weight x4</li> </ul> |

table 7-1 system control registers (sheet 10 of 12)

| address   | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------|---------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x51      | REG51         | 0x55          | RW  | <p>16-Zone Y Average Select</p> <p>Bit[7:6]: Zone 16</p> <ul style="list-style-type: none"> <li>00: Not allowed</li> <li>01: Weight x1</li> <li>10: Weight x2</li> <li>11: Weight x4</li> </ul> <p>Bit[5:4]: Zone 15</p> <ul style="list-style-type: none"> <li>00: Not allowed</li> <li>01: Weight x1</li> <li>10: Weight x2</li> <li>11: Weight x4</li> </ul> <p>Bit[3:2]: Zone 14</p> <ul style="list-style-type: none"> <li>00: Not allowed</li> <li>01: Weight x1</li> <li>10: Weight x2</li> <li>11: Weight x4</li> </ul> <p>Bit[1:0]: Zone 13</p> <ul style="list-style-type: none"> <li>00: Not allowed</li> <li>01: Weight x1</li> <li>10: Weight x2</li> <li>11: Weight x4</li> </ul> |
| 0x52~0x54 | RSVD          | -             | -   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0x55      | REG55         | 0xFF          | RW  | <p>Data Pins In/Out Control (1: output; 0: input)</p> <ul style="list-style-type: none"> <li>Bit[7]: Y7</li> <li>Bit[6]: Y6</li> <li>Bit[5]: Y5</li> <li>Bit[4]: Y4</li> <li>Bit[3]: Y3</li> <li>Bit[2]: Y2</li> <li>Bit[1]: Y1</li> <li>Bit[0]: Y0</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0x56      | REG56         | 0x1F          | RW  | <p>In/Out Control (1: output; 0: input)</p> <ul style="list-style-type: none"> <li>Bit[7:5]: Reserved</li> <li>Bit[4]: HREF</li> <li>Bit[3]: VSYNC</li> <li>Bit[2]: PCLK</li> <li>Bit[1]: Y9</li> <li>Bit[0]: Y8</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x57      | REG57         | 0x00          | RW  | <p>Register 57</p> <ul style="list-style-type: none"> <li>Bit[7:5]: Reserved</li> <li>Bit[4:2]: DSP output horizontal size LSBs (MSBs in register <b>REG59</b> (0x59))</li> <li>Bit[1:0]: DSP output vertical size LSBs (MSBs in register <b>REG58</b> (0x58))</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0x58      | REG58         | 0xC8          | RW  | DSP Output Vertical Size MSBs (LSBs in register <b>REG57</b> [1:0] (0x57))                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

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

| address   | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                 |
|-----------|---------------|---------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x59      | REG59         | 0xA0          | RW  | DSP Output Horizontal Size MSBs (LSBs in register <b>REG57</b> [4:2] (0x57))                                                                                                                                                                                                                                                                |
| 0x5A~0x5B | RSVD          | —             | —   | Reserved                                                                                                                                                                                                                                                                                                                                    |
| 0x5C      | REG5C         | 0x59          | RW  | <p>Register 5C</p> <p>Bit[7]: Reserved</p> <p>Bit[6:5]: PLL pre-divider</p> <p>0x: <math>\div 1</math></p> <p>10: <math>\div 2</math></p> <p>11: <math>\div 4</math></p> <p>Bit[4:0]: PLL_d</p> <p>PLL multiplier</p> <p><math>CLK2 = CLK1 \times (32 - PLL\_d)</math></p> <p>(see <b>figure 2-3</b>)</p>                                   |
| 0x5D      | REG5D         | 0xC4          | RW  | <p>Register 5D</p> <p>Bit[7]: Reserved</p> <p>Bit[6]: Bypass PLL</p> <p>Bit[5:4]: Output drive capability control</p> <p>00: 1x</p> <p>01: 2x</p> <p>10: 3x</p> <p>11: 4x</p> <p>Bit[3:2]: PLL_sel</p> <p>PLL divider control</p> <p><math>CLK3 = CLK2 / (PLL\_sel + 1)</math></p> <p>(see <b>figure 2-3</b>)</p> <p>Bit[1:0]: Reserved</p> |
| 0x5E~0x71 | RSVD          | —             | —   | Reserved                                                                                                                                                                                                                                                                                                                                    |
| 0x72      | REG72         | 0x60          | RW  | Upper Limit of Luminance Level for B Pixels                                                                                                                                                                                                                                                                                                 |
| 0x73      | REG73         | 0x49          | RW  | Lower Limit of Luminance Level for W Pixels                                                                                                                                                                                                                                                                                                 |
| 0x74      | REG74         | 0xE0          | RW  | <p>Lower Limit of Probability for B Pixels to Trigger Auto AEC/AGC</p> <p>If B pixel probability &gt; <b>REG74</b>, AEC/AGC will increase automatically</p>                                                                                                                                                                                 |
| 0x75      | REG75         | 0xE0          | RW  | <p>Lower Limit of Probability for W Pixels to Trigger Auto AEC/AGC</p> <p>If W pixel probability &gt; <b>REG75</b>, AEC/AGC will increase automatically</p>                                                                                                                                                                                 |
| 0x76      | REG76         | 0xC0          | RW  | Upper Limit of Luminance Level for VB pixels                                                                                                                                                                                                                                                                                                |
| 0x77      | REG77         | 0xC0          | RW  | Lower Limit of Luminance Level for VW pixels                                                                                                                                                                                                                                                                                                |

table 7-1 system control registers (sheet 12 of 12)

| address   | register name | default value | R/W | description                                                                                                                                   |
|-----------|---------------|---------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 0x78      | REG78         | 0xFF          | RW  | Lower Limit of Probability for B Pixels to Trigger Fast AEC/AGC<br>If B pixel probability > <b>REG78</b> , AEC/AGC will increase in fast mode |
| 0x79      | REG79         | 0xFF          | RW  | Lower Limit of Probability for W Pixels to Trigger Fast AEC/AGC<br>If W pixel probability > <b>REG79</b> , AEC/AGC will increase in fast mode |
| 0x7A~0x95 | RSVD          | —             | —   | Reserved                                                                                                                                      |

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

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|---------------|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x96    | DSP_CTRL_0    | 0xF9          | RW  | <p>DSP Control 0</p> <p>Bit[7]: black_en<br/>Enable black pixel removal function</p> <p>Bit[6]: white_en<br/>Enable white pixel removal function</p> <p>Bit[5]: awbg_en<br/>Auto white balance gain function<br/>adjusts image gain according to auto white balance function result</p> <p>Bit[4]: awb_en<br/>Auto white balance function<br/>scans image color temperature<br/>and determines how to set white balance</p> <p>Bit[3]: lenc_en<br/>Enable LENC module</p> <p>Bit[2]: lenc_det_en<br/>Enable the LENC gain coef module</p> <p>Bit[1]: Reserved</p> <p>Bit[0]: isp_en<br/>Enable/disable the ISP</p> |
| 0x97    | DSP_CTRL_1    | 0x80          | RW  | <p>DSP Control 1</p> <p>Bit[7]: smph_mean<br/>Enable computation of mean value</p> <p>Bit[6:4]: Reserved</p> <p>Bit[3]: bar_en<br/>Enable/disable color bar output</p> <p>Bit[2]: sht_neg<br/>Enable delay of data HREF/valid clock</p> <p>Bit[1:0]: bar_style<br/>Select type of color bar to output</p>                                                                                                                                                                                                                                                                                                          |
| 0x98    | DSP_CTRL_2    | 0x00          | RW  | <p>DSP Control 2</p> <p>Bit[7:0]: pre_out_hoff[7:0]<br/>Horizontal offset of the pre_win output (valid with <b>DSP_CTRL_4[2:0]</b> (0x9A))</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x99    | DSP_CTRL_3    | 0x00          | RW  | <p>DSP Control 3</p> <p>Bit[7:0]: pre_out_voff[7:0]<br/>Vertical offset of the pre_win output (valid with <b>DSP_CTRL_4[5:4]</b> (0x9A))</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

table 7-2 DSP control registers (sheet 2 of 13)

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                               |
|---------|---------------|---------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x9A    | DSP_CTRL_4    | 0x00          | RW  | <p>DSP Control 4</p> <p>Bit[7:6]: Reserved</p> <p>Bit[5:4]: pre_out_voff[9:8]<br/>Vertical offset of the pre_win output (valid with <b>DSP_CTRL_3[7:0]</b> (0x99))</p> <p>Bit[3]: Reserved</p> <p>Bit[2:0]: pre_out_hoff[10:8]<br/>Horizontal offset of the pre_win output (valid with <b>DSP_CTRL_2[7:0]</b> (0x98))</p> |
| 0x9B    | DSP_CTRL_5    | 0x04          | RW  | <p>DSP Control 5</p> <p>Bit[7:4]: pre_pad_vrgt<br/>Padding the column number in pre_winc</p> <p>Bit[3:0]: pre_pad_hrgt<br/>Padding the row number in pre_win</p>                                                                                                                                                          |
| 0x9C    | DSP_CTRL_6    | 0x00          | RW  | <p>DSP Control 6</p> <p>Bit[7:0]: blk_thresh<br/>Black threshold used in YAVG</p>                                                                                                                                                                                                                                         |
| 0x9D    | DSP_CTRL_7    | 0xFF          | RW  | <p>DSP Control 7</p> <p>Bit[7:0]: wht_thresh<br/>White threshold used in YAVG</p>                                                                                                                                                                                                                                         |
| 0x9E    | LENC_CTRL_0   | 0x00          | RW  | <p>LENC Control 0</p> <p>Bit[7:0]: det_coeff_man<br/>Manual value of the LENC gain coef</p>                                                                                                                                                                                                                               |
| 0x9F    | LENC_CTRL_1   | 0x80          | RW  | <p>LENC Control 1</p> <p>Bit[7:0]: lenc_coeff_th</p>                                                                                                                                                                                                                                                                      |
| 0xA0    | LENC_CTRL_2   | 0xF1          | RW  | <p>LENC Control 2</p> <p>Bit[7:4]: lenc_gain_thre2[3:0]<br/>High threshold of the LENC gain (valid with <b>LENC_CTRL_3[1]</b> (0xA1))</p> <p>Bit[3:0]: lenc_gain_thre1[3:0]<br/>Low threshold of the LENC gain (valid with <b>LENC_CTRL_3[0]</b> (0xA1))</p>                                                              |

table 7-2 DSP control registers (sheet 3 of 13)

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|---------------|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xA1    | LENC_CTRL_3   | 0x0D          | RW  | <p>LENC Control 3</p> <p>Bit[7:5]: Reserved</p> <p>Bit[4]: center_man<br/>Manually selects center of R, G, B circle</p> <p>Bit[3]: md_en<br/>Signal indicating if the result is rounded off</p> <p>Bit[2]: det_coef_man_en<br/>Enable manual mode of the LENC gain coef</p> <p>Bit[1]: lenc_gain_thre2[4]<br/>High threshold of the LENC gain (valid with <a href="#">LENC_CTRL_2</a>[7:4] (0xA0))</p> <p>Bit[0]: lenc_gain_thre1[4]<br/>Low threshold of the LENC gain (valid with <a href="#">LENC_CTRL_2</a>[3:0] (0xA0))</p> |
| 0xA2    | LENC_CTRL_4   | 0x00          | RW  | <p>LENC Control 4</p> <p>Bit[7:0]: lenc_off_man[7:0]<br/>Black level manual setting for LENC. Range from 0 to 255.</p>                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0xA3    | LENC_CTRL_5   | 0x80          | RW  | <p>LENC Control 5</p> <p>Bit[7:0]: R_X0[7:0]<br/>R_X0 is the horizontal center position in red color channels. It should be fixed as the horizontal position of the image which comes from the middle of the lens, so it is usually set as the horizontal position of the middle pixel of each image. Range from 0 to 1296. Valid with <a href="#">LENC_CTRL_7</a>[2:0] (0xA5).</p>                                                                                                                                              |
| 0xA4    | LENC_CTRL_6   | 0x90          | RW  | <p>LENC Control 6</p> <p>Bit[7:0]: R_Y0[7:0]<br/>R_Y0 is the vertical center position in red color channels. It should be fixed as the vertical position of the image which comes from the middle of the lens, so it is usually set as the vertical position of the middle pixel of each image. Range from 0 to 800. Valid with <a href="#">LENC_CTRL_7</a>[5:4] (0xA5).</p>                                                                                                                                                     |

table 7-2 DSP control registers (sheet 4 of 13)

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                             |
|---------|---------------|---------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xA5    | LENC_CTRL_7   | 0x12          | RW  | <p>LENC Control 7</p> <p>Bit[7:6]: Reserved</p> <p>Bit[5:4]: R_Y0[9:8]<br/>Valid with <a href="#">LENC_CTRL_6</a>[7:0] (0xA4)</p> <p>Bit[3]: Reserved</p> <p>Bit[2:0]: R_X0[9:8]<br/>Valid with <a href="#">LENC_CTRL_5</a>[7:0] (0xA3)</p>                                                                                                                                             |
| 0xA6    | LENC_CTRL_8   | 0x22          | RW  | <p>LENC Control 8</p> <p>Bit[7]: Reserved</p> <p>Bit[6:0]: R_A1<br/>Composed of the first group of factors used in the LENC correction of the red color channels.</p>                                                                                                                                                                                                                   |
| 0xA7    | LENC_CTRL_9   | 0xC2          | RW  | <p>LENC Control 9</p> <p>Bit[7:0]: R_B1<br/>Composed of the second group of factors used in the LENC correction of the red color channels.</p>                                                                                                                                                                                                                                          |
| 0xA8    | LENC_CTRL_10  | 0x87          | RW  | <p>LENC Control 10</p> <p>Bit[7:4]: R_B2<br/>Composed of the second group of factors used in the LENC correction of the red color channels.</p> <p>Bit[3:0]: R_A2<br/>Composed of the first group of factors used in the LENC correction of the red color channels.</p>                                                                                                                 |
| 0xA9    | LENC_CTRL_11  | 0x80          | RW  | <p>LENC Control 11</p> <p>Bit[7:0]: G_X0[7:0]<br/>G_X0 is the horizontal center position in green color channels. It should be fixed as the horizontal position of the image which comes from the middle of the lens, so it is usually set as the horizontal position of the middle pixel of each image. Range from 0 to 1296. Valid with <a href="#">LENC_CTRL_13</a>[2:0] (0xAB).</p> |

**table 7-2** DSP control registers (sheet 5 of 13)

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                   |
|---------|---------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xAA    | LEN_CTR_12    | 0x90          | RW  | <p>LEN Control 12</p> <p>Bit[7:0]: G_Y0[7:0]<br/>G_Y0 is the vertical center position in green color channels. It should be fixed as the vertical position of the image which comes from the middle of the lens, so it is usually set as the vertical position of the middle pixel of each image. Range from 0 to 800. Valid with <a href="#">LEN_CTR_13[5:4]</a> (0xAB).</p> |
| 0xAB    | LEN_CTR_13    | 0x12          | RW  | <p>LEN Control 13</p> <p>Bit[7:6]: Reserved<br/>Bit[5:4]: G_Y0[9:8]<br/>Valid with <a href="#">LEN_CTR_12[7:0]</a> (0xAA)</p> <p>Bit[3]: Reserved<br/>Bit[2:0]: G_X0[9:8]<br/>Valid with <a href="#">LEN_CTR_11[7:0]</a> (0xA9)</p>                                                                                                                                           |
| 0xAC    | LEN_CTR_14    | 0x22          | RW  | <p>LEN Control 14</p> <p>Bit[7]: Reserved<br/>Bit[6:0]: G_A1<br/>Composed of the first group of factors used in the LEN correction of the green color channels.</p>                                                                                                                                                                                                           |
| 0xAD    | LEN_CTR_15    | 0xC2          | RW  | <p>LEN Control 15</p> <p>Bit[7:0]: G_B1<br/>Composed of the second group of factors used in the LEN correction of the green color channels.</p>                                                                                                                                                                                                                               |
| 0xAE    | LEN_CTR_16    | 0x87          | RW  | <p>LEN Control 16</p> <p>Bit[7:4]: G_B2<br/>Composed of the second group of factors used in the LEN correction of the green color channels.</p> <p>Bit[3:0]: G_A2<br/>Composed of the first group of factors used in the LEN correction of the green color channels.</p>                                                                                                      |

table 7-2 DSP control registers (sheet 6 of 13)

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                         |
|---------|---------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xAF    | LENC_CTRL_17  | 0x80          | RW  | <p>LENC Control 17<br/>Bit[7:0]: B_X0[7:0]<br/>B_X0 is the horizontal center position in blue color channels. It should be fixed as the horizontal position of the image which comes from the middle of the lens, so it is usually set as the horizontal position of the middle pixel of each image. Range from 0 to 1296. Valid with <a href="#">LENC_CTRL_19[2:0]</a> (0xB1).</p> |
| 0xB0    | LENC_CTRL_18  | 0x90          | RW  | <p>LENC Control 18<br/>Bit[7:0]: B_Y0[7:0]<br/>B_Y0 is the vertical center position in blue color channels. It should be fixed as the vertical position of the image which comes from the middle of the lens, so it is usually set as the vertical position of the middle pixel of each image. Range from 0 to 800. Valid with <a href="#">LENC_CTRL_19[5:4]</a> (0xB1).</p>        |
| 0xB1    | LENC_CTRL_19  | 0x12          | RW  | <p>LENC Control 19<br/>Bit[7:6]: Reserved<br/>Bit[5:4]: B_Y0[9:8]<br/>Valid with <a href="#">LENC_CTRL_18[7:0]</a> (0xB0)<br/>Bit[3]: Reserved<br/>Bit[2:0]: B_X0[9:8]<br/>Valid with <a href="#">LENC_CTRL_17[7:0]</a> (0xAF)</p>                                                                                                                                                  |
| 0xB2    | LENC_CTRL_20  | 0x22          | RW  | <p>LENC Control 20<br/>Bit[7]: Reserved<br/>Bit[6:0]: B_A1<br/>Composed of the first group of factors used in the LENC correction of the blue color channels.</p>                                                                                                                                                                                                                   |
| 0xB3    | LENC_CTRL_21  | 0xC2          | RW  | <p>LENC Control 21<br/>Bit[7:0]: B_B1<br/>Composed of the second group of factors used in the LENC correction of the blue color channels.</p>                                                                                                                                                                                                                                       |

**table 7-2** DSP control registers (sheet 7 of 13)

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                            |
|---------|---------------|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xB4    | LENC_CTRL_22  | 0x87          | RW  | <p>LENC Control 22</p> <p>Bit[7:4]: B_B2<br/>Composed of the second group of factors used in the LENC correction of the blue color channels.</p> <p>Bit[3:0]: B_A2<br/>Composed of the first group of factors used in the LENC correction of the blue color channels.</p>                                                                                                              |
| 0xB5    | LENC_CTRL_23  | 0x00          | RW  | <p>LENC Control 23</p> <p>Bit[7:3]: Reserved<br/>Bit[2]: v_skip[1:0]<br/>Bit[1]: Reserved<br/>Bit[0]: h_skip[1:0]</p>                                                                                                                                                                                                                                                                  |
| 0xB6    | AWB_CTRL_0    | 0x07          | RW  | <p>AWB Control 0</p> <p>Bit[7:4]: Reserved<br/>Bit[3]: awb_off_man_en<br/>Enable manual AWB bias<br/>0: From sensor_bias<br/>1: From AWB_off_man</p> <p>Bit[2]: awb_fast<br/>AWB in fast mode</p> <p>Bit[1]: awb_bias_on<br/>Enable the AWB bias<br/>0: Disable<br/>1: Enable</p> <p>Bit[0]: awb_bias_plus<br/>Decides if the AWB_bias is added back when the AWB_gain is finished</p> |
| 0xB7    | AWB_CTRL_1    | 0x00          | RW  | <p>AWB Control 1</p> <p>Bit[7:0]: awb_off_man<br/>Manual value of the AWB_bias</p>                                                                                                                                                                                                                                                                                                     |
| 0xB8    | AWB_CTRL_2    | 0x04          | RW  | <p>AWB Control 2</p> <p>Bit[7:0]: stable_range<br/>Stable range when computing the gain value for R, G, and B in the AWB module</p>                                                                                                                                                                                                                                                    |
| 0xB9    | AWB_CTRL_3    | 0x08          | RW  | <p>AWB Control 3</p> <p>Bit[7:0]: stable_rangew<br/>Range after the gain for R, G, and B is stable</p>                                                                                                                                                                                                                                                                                 |

table 7-2 DSP control registers (sheet 8 of 13)

| address | register name | default value | R/W | description                                                                                                                                                                                                                         |
|---------|---------------|---------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xBA    | AWB_CTRL_4    | 0x00          | RW  | AWB Control 4<br>Bit[7:0]: awb_frame_cnt<br>After AWB, AWB can output the gain for R, G, and B                                                                                                                                      |
| 0xBB    | AWB_CTRL_5    | 0x20          | RW  | AWB Control 5<br>Bit[7:0]: awb_delta                                                                                                                                                                                                |
| 0xBC    | WBC_CTRL_0    | 0x68          | RW  | WBC Control 0<br>Bit[7:0]: Reserved                                                                                                                                                                                                 |
| 0xBD    | YAVG_CTRL_0   | 0xA0          | RW  | YAVG Control 0<br>Bit[7:0]: yavg_winh                                                                                                                                                                                               |
| 0xBE    | YAVG_CTRL_1   | 0xC8          | RW  | YAVG Control 1<br>Bit[7:0]: yavg_winv                                                                                                                                                                                               |
| 0xBF    | YAVG_CTRL_2   | 0x00          | RW  | YAVG Control 2<br>Bit[7:0]: yavg_winofh[7:0] (valid with <b>YAVG_CTRL_4[2:0]</b> (0xC1))                                                                                                                                            |
| 0xC0    | YAVG_CTRL_3   | 0x00          | RW  | YAVG Control 3<br>Bit[7:0]: yavg_winovf[7:0] (valid with <b>YAVG_CTRL_4[5:4]</b> (0xC1))                                                                                                                                            |
| 0xC1    | YAVG_CTRL_4   | 0x00          | RW  | YAVG Control 4<br>Bit[7]: yavg_win_man<br>Bit[6]: Reserved<br>Bit[5:4]: yavg_winofv[9:8] (valid with <b>YAVG_CTRL_3[7:0]</b> (0xC0))<br>Bit[3]: Reserved<br>Bit[2:0]: yavg_winofh[10:8] (valid with <b>YAVG_CTRL_2[7:0]</b> (0xBF)) |

**table 7-2** DSP control registers (sheet 9 of 13)

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|---------------|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xC2    | DVP_CTRL_00   | 0x80          | RW  | <p>Bit[7:6]: VSYNC options<br/>     00: vsync_old<br/>     01: vsync_new<br/>     10: vsync3<br/>     11: Invalid</p> <p>Bit[5]: pclk_gate_en<br/>     Gate dvp_pclk when there is no data transfer<br/>     0: Disable<br/>     1: Enable</p> <p>Bit[4]: vsync_gate<br/>     Gate dvp_pclk when VSYNC &amp;&amp; pclk_gate_en<br/>     0: Disable<br/>     1: Enable</p> <p>Bit[3]: vsync3_w_sel<br/>     0: VSYNC3 will go low when SOF<br/>     1: Use vsync_width × 64 as vsync3_width</p> <p>Bit[2]: pclk_pol<br/>     1: Reverse DVP_PCLK</p> <p>Bit[1]: href_pol<br/>     1: Reverse DVP_HREF</p> <p>Bit[0]: vsync_pol<br/>     0: VSYNC=1 is frame blanking time<br/>     1: VSYNC=0 is frame blanking</p> |

table 7-2 DSP control registers (sheet 10 of 13)

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------|---------------|---------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xC3    | DVP_CTRL_01   | 0x20          | RW  | <p>DVP Control 01</p> <p>Bit[7]: ccir656_en<br/>0: Disable<br/>1: Enable</p> <p>Bit[6]: sync_code_sel<br/>0: Auto generate sync code for CCIR656<br/>1: Use FS, FE, LS, LE<br/>(registers <b>0xC4</b> to <b>0xC7</b>) as sync code</p> <p>Bit[5]: blk_656<br/>0: CCIR656 data is 0x040 or 0x200<br/>1: CCIR656 data is 0x000 when blanking</p> <p>Bit[4]: eav_first<br/>1: CCIR656 sends EAV first</p> <p>Bit[3:1]: dvp_data_sequence<br/>000: Y9,Y8,Y7,Y6,Y5,Y4,Y3,Y2,Y1,Y0<br/>001: Y1,Y0,Y9,Y8,Y7,Y6,Y5,Y4,Y3,Y2<br/>010: Y7,Y6,Y5,Y4,Y3,Y2,Y1,Y0,Y9,Y8<br/>011: Reserved<br/>100: Y0,Y1,Y2,Y3,Y4,Y5,Y6,Y7,Y8,Y9<br/>101: Y8,Y9,Y0,Y1,Y2,Y3,Y4,Y5,Y6,Y7<br/>110: Y2,Y3,Y4,Y5,Y6,Y7,Y8,Y9,Y0,Y1<br/>111: Reserved</p> <p>Bit[0]: chg_flag<br/>Write 1 to this bit will generate change flag for HSYNC mode. This bit will auto clear. DVP will restart to calculate all timing parameters and output a frame.</p> |
| 0xC4    | DVP_CTRL_02   | 0xAB          | RW  | DVP Control 02<br>Bit[7:0]: FS for CCIR656                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0xC5    | DVP_CTRL_03   | 0xB6          | RW  | DVP Control 03<br>Bit[7:0]: FE for CCIR656                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0xC6    | DVP_CTRL_04   | 0x80          | RW  | DVP Control 04<br>Bit[7:0]: LS for CCIR656                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0xC7    | DVP_CTRL_05   | 0x9D          | RW  | DVP Control 05<br>Bit[7:0]: LE for CCIR656                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

**table 7-2** DSP control registers (sheet 11 of 13)

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                          |
|---------|---------------|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xC8    | DVP_CTRL_06   | 0x00          | RW  | <p>DVP Control 06</p> <p>Bit[7]: blk_tog<br/>1: dvp_data will toggle when blanking</p> <p>Bit[6]: vsync_width_sel<br/>0: Use vsync_widthx64 as VSYNC width</p> <p>1: Select 4x line length as VSYNC width</p> <p>Bit[5:3]: h2v_dly<br/>VSYNC to HREF delay for vsync_new</p> <p>Bit[2:0]: v2h_dly<br/>HREF to VSYNC delay for vsync_new</p>                          |
| 0xC9    | DVP_CTRL_07   | 0x80          | RW  | <p>DVP Control 07</p> <p>Bit[7:0]: vsync_width_l<br/>vsync_width_real = vsync_width × 64</p>                                                                                                                                                                                                                                                                         |
| 0xCA    | DVP_CTRL_08   | 0x20          | RW  | <p>DVP Control 08</p> <p>Bit[7:6]: vsync_width_h</p> <p>Bit[5:4]: sof2h_dly_offset</p> <p>Bit[3]: ddr_phase<br/>0: First pixel is at rising edge<br/>1: First pixel is at falling edge</p> <p>Bit[2]: Test pattern options<br/>0: 10-bit<br/>1: 8-bit</p> <p>Bit[1:0]: Test pattern mode<br/>00: No test pattern<br/>01: 1, 2, 4, 8, ...<br/>10: 1, 1, 2, 2, ...</p> |

table 7-2 DSP control registers (sheet 12 of 13)

| address | register name | default value | R/W | description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|---------------|---------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xCB    | DVP_CTRL_09   | 0xA6          | RW  | <p>DVP Control 09</p> <p>Bit[7]: sof_rst_en<br/>1: DVP state machine will be reset by SOF</p> <p>Bit[6:5]: chg_sel for recalculating DVP timing for HSYNC mode<br/>00: Select snr chg and manu chg (manu chg is in register <b>DVP_CTRL_01[0]</b> (0xC3))<br/>01: Select auto detect chg and manu chg<br/>10: manu set chg</p> <p>Bit[4]: hsync_en<br/>1: Enable HSYNC mode (see <a href="#">figure 6-1</a>)</p> <p>Bit[3]: hsync_dvp_en<br/>1: v2h_dly, h2v_dly and line_length are fixed for each frame (see <a href="#">figure 6-1</a>)</p> <p>Bit[2]: hsync_1st_en<br/>0: Mask the first frame when in HSYNC mode</p> <p>Bit[1:0]: line_length_sel<br/>00: Select line_length_snr<br/>01: Select line_length_reg<br/>10: Select line_length_auto</p> |
| 0xCC    | DVP_CTRL_0A   | 0x40          | RW  | <p>DVP Control 0A</p> <p>Bit[7:4]: FIFO_BUF size</p> <p>Bit[3:0]: dmy_line_nu<br/>Use CCIR656 first dummy line number to generate VSYNC</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0xCD    | DVP_CTRL_0B   | 0x00          | RW  | DVP Control 0B<br>Bit[7:0]: eof2v_dly[23:16]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0xCE    | DVP_CTRL_0C   | 0x01          | RW  | DVP Control 0C<br>Bit[7:0]: eof2v_dly[15:8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0xCF    | DVP_CTRL_0D   | 0x00          | RW  | DVP Control 0D<br>Bit[7:0]: eof2v_dly[7:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0xD0    | DVP_CTRL_0E   | 0xFF          | RW  | DVP Control 0E<br>Bit[7:0]: line_length[15:8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0xD1    | DVP_CTRL_0F   | 0xFF          | RW  | DVP Control 0F<br>Bit[7:0]: line_length[7:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

**table 7-2** DSP control registers (sheet 13 of 13)

| address   | register name | default value | R/W | description                                                                                                                                                                                                                                                                                      |
|-----------|---------------|---------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0xD2      | DVP_CTRL_10   | 0xFF          | RW  | <p>DVP Control 10</p> <p>Bit[7:0]: clip_max[9:2]</p> <p>DVP output data should be less than or equal to clip_max (valid with <b>DVP_CTRL_12[1:0]</b> (0xD4))</p>                                                                                                                                 |
| 0xD3      | DVP_CTRL_11   | 0x00          | RW  | <p>DVP Control 11</p> <p>Bit[7:0]: clip_min[9:2]</p> <p>DVP output data should be larger than or equal to clip_min (valid with <b>DVP_CTRL_12[3:2]</b> (0xD4))</p>                                                                                                                               |
| 0xD4      | DVP_CTRL_12   | 0x03          | RW  | <p>DVP Control 12</p> <p>Bit[5]: f_tog_en<br/>1: ccir_f will toggle every frame</p> <p>Bit[4]: ddr_en<br/>1: DVP will output DDR clock</p> <p>Bit[3:2]: clip_min[1:0] (valid with <b>DVP_CTRL_11[7:0]</b> (0xD3))</p> <p>Bit[1:0]: clip_max[1:0] (valid with <b>DVP_CTRL_10[7:0]</b> (0xD2))</p> |
| 0xD5      | RSVD          | -             | -   | Reserved                                                                                                                                                                                                                                                                                         |
| 0xD6      | SC_CTRL_0     | 0x0C          | RW  | <p>SC Control 0</p> <p>Bit[7]: Bypass DVP</p> <p>Bit[6]: Reserved</p> <p>Bit[5]: snr_RST_DVP</p> <p>Bit[4]: snr_RST_DSP</p> <p>Bit[3]: dvp_SCLK_GATE</p> <p>Bit[2]: dsp_SCLK_GATE</p> <p>Bit[1]: dvp_RST</p> <p>Bit[0]: dsp_RST</p>                                                              |
| 0xD7~0xFF | RSVD          | -             | -   | Reserved                                                                                                                                                                                                                                                                                         |

**OV9712**

color CMOS WXGA (1 megapixel) HD image sensor with OmniPixel3-HS™ technology

## 8 electrical specifications

**table 8-1** absolute maximum ratings

| parameter                                          | absolute maximum rating <sup>a</sup> |                           |
|----------------------------------------------------|--------------------------------------|---------------------------|
| operating temperature range <sup>b</sup>           |                                      | -30 °C to +70 °C          |
| stable image temperature range <sup>c</sup>        |                                      | 0 °C to 50 °C             |
| ambient storage temperature                        |                                      | -40 °C to +125 °C         |
| supply voltage (with respect to ground)            | $V_{DD-A}$                           | 4.5V                      |
|                                                    | $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             |                                      | ± 200 mA                  |
| peak solder temperature (10 second dwell time)     |                                      | 245 °C                    |

- 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.
- b. sensor functions but image quality may be noticeably different at temperatures outside of stable image range
- c. image quality remains stable throughout this temperature range

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

| symbol                                                                             | parameter                     | min   | typ  | max   | unit |
|------------------------------------------------------------------------------------|-------------------------------|-------|------|-------|------|
| <b>supply</b>                                                                      |                               |       |      |       |      |
| V <sub>DD-A</sub>                                                                  | supply voltage (analog)       | 3.0   | 3.3  | 3.6   | V    |
| V <sub>DD-D</sub>                                                                  | supply voltage (digital core) | 1.425 | 1.5  | 1.575 | V    |
| V <sub>DD-IO</sub>                                                                 | supply voltage (digital I/O)  | 1.7   | 1.8  | 3.6   | V    |
| I <sub>DD-A</sub>                                                                  |                               | 22    | 30   |       | mA   |
| I <sub>DD-D</sub>                                                                  | active (operating) current    | 6     | 10   |       | mA   |
| I <sub>DD-IO</sub>                                                                 |                               | 8     | 14   |       | mA   |
| I <sub>DDS-SCCB</sub>                                                              |                               | 250   | 600  |       | µA   |
| I <sub>DDS-PWDN</sub>                                                              | standby current               | 50    | 100  |       | µA   |
| <b>digital inputs (typical conditions: AVDD = 3.3V, DVDD = 1.5V, DOVDD = 1.8V)</b> |                               |       |      |       |      |
| 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   |
| <b>digital outputs (standard loading 25 pF)</b>                                    |                               |       |      |       |      |
| V <sub>OH</sub>                                                                    | output voltage HIGH           | 1.62  |      |       | V    |
| V <sub>OL</sub>                                                                    | output voltage LOW            |       | 0.18 |       | V    |
| <b>serial interface inputs</b>                                                     |                               |       |      |       |      |
| V <sub>IL</sub> <sup>a</sup>                                                       | SIOC and SIOD                 | -0.5  | 0    | 0.54  | V    |
| V <sub>IH</sub> <sup>a</sup>                                                       | SIOC and SIOD                 | 1.26  | 1.8  | 2.3   | V    |

a. based on DOVDD = 1.8V.

**table 8-3** AC characteristics ( $T_A = 25^\circ\text{C}$ ,  $V_{DD-A} = 2.8\text{V}$ )

| symbol                | parameter                                | min | typ  | max | unit |
|-----------------------|------------------------------------------|-----|------|-----|------|
| <b>ADC parameters</b> |                                          |     |      |     |      |
| B                     | analog bandwidth                         | 30  |      |     | MHz  |
| DLE                   | DC differential linearity error          | 0.5 |      |     | LSB  |
| ILE                   | DC integral linearity error              | 1   |      |     | LSB  |
|                       | settling time for hardware reset         |     | <1   |     | ms   |
|                       | settling time for software reset         |     | <1   |     | ms   |
|                       | settling time for resolution mode change |     | <1   |     | ms   |
|                       | settling time for register setting       |     | <300 |     | ms   |

**table 8-4** timing characteristics

| symbol                            | parameter                  | min | typ | max                  | unit |
|-----------------------------------|----------------------------|-----|-----|----------------------|------|
| <b>oscillator and clock input</b> |                            |     |     |                      |      |
| $f_{osc}$                         | frequency (XCLK)           | 6   | 24  | 27                   | MHz  |
| $t_p, t_f$                        | clock input rise/fall time |     |     | 5 (10 <sup>a</sup> ) | ns   |

a. if using the internal PLL

**OV9712**

color CMOS WXGA (1 megapixel) HD image sensor with OmniPixel3-HS™ technology



proprietary to OmniVision Technologies

PRODUCT SPECIFICATION

version 2.0

## 9 mechanical specifications

### 9.1 physical specifications

**figure 9-1** package specifications



9712\_CSP\_DS\_9\_1

**table 9-1** package dimensions

| parameter                            | symbol | min  | typ  | max  | unit |
|--------------------------------------|--------|------|------|------|------|
| package body dimension x             | A      | 5390 | 5415 | 5440 | μm   |
| package body dimension y             | B      | 4390 | 4415 | 4440 | μm   |
| package height                       | C      | 845  | 905  | 965  | μm   |
| ball height                          | C1     | 150  | 180  | 210  | μm   |
| package body thickness               | C2     | 680  | 725  | 770  | μm   |
| thickness of glass surface to wafer  | C3     | 425  | 445  | 465  | μm   |
| ball diameter                        | D      | 320  | 350  | 380  | μm   |
| total pin count                      | N      |      | 28   |      |      |
| pin count x-axis                     | N1     |      | 6    |      |      |
| pin count y-axis                     | N2     |      | 5    |      |      |
| pins pitch x-axis                    | J1     |      | 800  |      | μm   |
| pins pitch y-axis                    | J2     |      | 750  |      | μm   |
| edge-to-pin center distance analog x | S1     | 678  | 708  | 738  | μm   |
| edge-to-pin center distance analog y | S2     | 678  | 708  | 738  | μm   |

## 9.2 IR reflow specifications

**figure 9-2** IR reflow ramp rate requirements



**note**

The OV9712 uses a lead-free package.



**table 9-2** reflow conditions

| condition                            | exposure                               |
|--------------------------------------|----------------------------------------|
| average ramp-up rate (30°C to 217°C) | less than 3°C per second               |
| > 100°C                              | between 330 - 600 seconds              |
| > 150°C                              | at least 210 seconds                   |
| > 217°C                              | at least 30 seconds (30 ~ 120 seconds) |
| peak temperature                     | 245°C                                  |
| cool-down rate (peak to 50°C)        | less than 6°C per second               |
| time from 30°C to 245°C              | no greater than 390 seconds            |

## 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 pins A1 to A6 oriented down on the PCB. 9712\_CSP\_DS\_10\_1

## 10.2 lens chief ray angle (CRA)

**figure 10-2** chief ray angle (CRA)



**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.113             | 2.4           |
| 0.10      | 0.226             | 4.7           |
| 0.15      | 0.340             | 7.0           |
| 0.20      | 0.453             | 9.3           |
| 0.25      | 0.566             | 11.6          |
| 0.30      | 0.679             | 13.8          |
| 0.35      | 0.792             | 16.0          |
| 0.40      | 0.906             | 18.0          |
| 0.45      | 1.019             | 19.9          |
| 0.50      | 1.132             | 21.6          |

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

| field (%) | image height (mm) | CRA (degrees) |
|-----------|-------------------|---------------|
| 0.55      | 1.245             | 23.0          |
| 0.60      | 1.358             | 24.0          |
| 0.65      | 1.472             | 24.7          |
| 0.70      | 1.585             | 25.0          |
| 0.75      | 1.698             | 25.0          |
| 0.80      | 1.811             | 25.0          |
| 0.85      | 1.924             | 24.9          |
| 0.90      | 2.038             | 24.9          |
| 0.95      | 2.151             | 24.9          |
| 1.00      | 2.264             | 25.0          |

**OV9712**

color CMOS WXGA (1 megapixel) HD image sensor with OmniPixel3-HS™ technology



proprietary to OmniVision Technologies

PRODUCT SPECIFICATION

version 2.0

## revision history

version 2.0                  02.17.2009

- initial release

**OV9712**

color CMOS WXGA (1 megapixel) HD image sensor with OmniPixel3-HS™ technology



proprietary to OmniVision Technologies

PRODUCT SPECIFICATION

version 2.0



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 6105 5100

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