119 lines
3.1 KiB
C
119 lines
3.1 KiB
C
|
/* Copyright (c) 2010, The Linux Foundation. All rights reserved.
|
||
|
*
|
||
|
* This program is free software; you can redistribute it and/or modify
|
||
|
* it under the terms of the GNU General Public License version 2 and
|
||
|
* only version 2 as published by the Free Software Foundation.
|
||
|
*
|
||
|
* This program is distributed in the hope that it will be useful,
|
||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
|
* GNU General Public License for more details.
|
||
|
*/
|
||
|
|
||
|
#ifndef IMX074_H
|
||
|
#define IMX074_H
|
||
|
#include <linux/types.h>
|
||
|
#include <mach/board.h>
|
||
|
extern struct imx074_reg imx074_regs;
|
||
|
struct reg_struct_init {
|
||
|
/* PLL setting */
|
||
|
uint8_t pre_pll_clk_div; /* 0x0305 */
|
||
|
uint8_t plstatim; /* 0x302b */
|
||
|
uint8_t reg_3024; /*ox3024*/
|
||
|
uint8_t image_orientation; /* 0x0101*/
|
||
|
uint8_t vndmy_ablmgshlmt; /*0x300a*/
|
||
|
uint8_t y_opbaddr_start_di; /*0x3014*/
|
||
|
uint8_t reg_0x3015; /*0x3015*/
|
||
|
uint8_t reg_0x301c; /*0x301c*/
|
||
|
uint8_t reg_0x302c; /*0x302c*/
|
||
|
uint8_t reg_0x3031; /*0x3031*/
|
||
|
uint8_t reg_0x3041; /* 0x3041 */
|
||
|
uint8_t reg_0x3051; /* 0x3051 */
|
||
|
uint8_t reg_0x3053; /* 0x3053 */
|
||
|
uint8_t reg_0x3057; /* 0x3057 */
|
||
|
uint8_t reg_0x305c; /* 0x305c */
|
||
|
uint8_t reg_0x305d; /* 0x305d */
|
||
|
uint8_t reg_0x3060; /* 0x3060 */
|
||
|
uint8_t reg_0x3065; /* 0x3065 */
|
||
|
uint8_t reg_0x30aa; /* 0x30aa */
|
||
|
uint8_t reg_0x30ab;
|
||
|
uint8_t reg_0x30b0;
|
||
|
uint8_t reg_0x30b2;
|
||
|
uint8_t reg_0x30d3;
|
||
|
uint8_t reg_0x3106;
|
||
|
uint8_t reg_0x310c;
|
||
|
uint8_t reg_0x3304;
|
||
|
uint8_t reg_0x3305;
|
||
|
uint8_t reg_0x3306;
|
||
|
uint8_t reg_0x3307;
|
||
|
uint8_t reg_0x3308;
|
||
|
uint8_t reg_0x3309;
|
||
|
uint8_t reg_0x330a;
|
||
|
uint8_t reg_0x330b;
|
||
|
uint8_t reg_0x330c;
|
||
|
uint8_t reg_0x330d;
|
||
|
uint8_t reg_0x330f;
|
||
|
uint8_t reg_0x3381;
|
||
|
};
|
||
|
|
||
|
struct reg_struct {
|
||
|
uint8_t pll_multiplier; /* 0x0307 */
|
||
|
uint8_t frame_length_lines_hi; /* 0x0340*/
|
||
|
uint8_t frame_length_lines_lo; /* 0x0341*/
|
||
|
uint8_t y_addr_start; /* 0x347 */
|
||
|
uint8_t y_add_end; /* 0x034b */
|
||
|
uint8_t x_output_size_msb; /* 0x034c */
|
||
|
uint8_t x_output_size_lsb; /* 0x034d */
|
||
|
uint8_t y_output_size_msb; /* 0x034e */
|
||
|
uint8_t y_output_size_lsb; /* 0x034f */
|
||
|
uint8_t x_even_inc; /* 0x0381 */
|
||
|
uint8_t x_odd_inc; /* 0x0383 */
|
||
|
uint8_t y_even_inc; /* 0x0385 */
|
||
|
uint8_t y_odd_inc; /* 0x0387 */
|
||
|
uint8_t hmodeadd; /* 0x3001 */
|
||
|
uint8_t vmodeadd; /* 0x3016 */
|
||
|
uint8_t vapplinepos_start;/*ox3069*/
|
||
|
uint8_t vapplinepos_end;/*306b*/
|
||
|
uint8_t shutter; /* 0x3086 */
|
||
|
uint8_t haddave; /* 0x30e8 */
|
||
|
uint8_t lanesel; /* 0x3301 */
|
||
|
};
|
||
|
|
||
|
struct imx074_i2c_reg_conf {
|
||
|
unsigned short waddr;
|
||
|
unsigned short wdata;
|
||
|
};
|
||
|
|
||
|
enum imx074_test_mode_t {
|
||
|
TEST_OFF,
|
||
|
TEST_1,
|
||
|
TEST_2,
|
||
|
TEST_3
|
||
|
};
|
||
|
|
||
|
enum imx074_resolution_t {
|
||
|
QTR_SIZE,
|
||
|
FULL_SIZE,
|
||
|
INVALID_SIZE
|
||
|
};
|
||
|
enum imx074_setting {
|
||
|
RES_PREVIEW,
|
||
|
RES_CAPTURE
|
||
|
};
|
||
|
enum mt9p012_reg_update {
|
||
|
/* Sensor egisters that need to be updated during initialization */
|
||
|
REG_INIT,
|
||
|
/* Sensor egisters that needs periodic I2C writes */
|
||
|
UPDATE_PERIODIC,
|
||
|
/* All the sensor Registers will be updated */
|
||
|
UPDATE_ALL,
|
||
|
/* Not valid update */
|
||
|
UPDATE_INVALID
|
||
|
};
|
||
|
|
||
|
struct imx074_reg {
|
||
|
const struct reg_struct_init *reg_pat_init;
|
||
|
const struct reg_struct *reg_pat;
|
||
|
};
|
||
|
#endif /* IMX074_H */
|