M7350/kernel/drivers/media/platform/msm/camera_v1/mt9e013.h
2024-09-09 08:52:07 +00:00

175 lines
4.9 KiB
C

/* Copyright (c) 2011, 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 MT9E013_H
#define MT9E013_H
#include <linux/types.h>
#include <mach/board.h>
extern struct mt9e013_reg mt9e013_regs;
struct reg_struct_init {
uint8_t reg_0x0112; /* 0x0112*/
uint8_t reg_0x0113; /* 0x0113*/
uint8_t vt_pix_clk_div; /* 0x0301*/
uint8_t pre_pll_clk_div; /* 0x0305*/
uint8_t pll_multiplier; /* 0x0307*/
uint8_t op_pix_clk_div; /* 0x0309*/
uint8_t reg_0x3030; /*0x3030*/
uint8_t reg_0x0111; /*0x0111*/
uint8_t reg_0x0b00; /*0x0b00*/
uint8_t reg_0x3001; /*0x3001*/
uint8_t reg_0x3004; /*0x3004*/
uint8_t reg_0x3007; /*0x3007*/
uint8_t reg_0x3016; /*0x3016*/
uint8_t reg_0x301d; /*0x301d*/
uint8_t reg_0x317e; /*0x317E*/
uint8_t reg_0x317f; /*0x317F*/
uint8_t reg_0x3400; /*0x3400*/
uint8_t reg_0x0b06; /*0x0b06*/
uint8_t reg_0x0b07; /*0x0b07*/
uint8_t reg_0x0b08; /*0x0b08*/
uint8_t reg_0x0b09; /*0x0b09*/
uint8_t reg_0x0136;
uint8_t reg_0x0137;
/* Edof */
uint8_t reg_0x0b83; /*0x0b83*/
uint8_t reg_0x0b84; /*0x0b84*/
uint8_t reg_0x0b85; /*0x0b85*/
uint8_t reg_0x0b88; /*0x0b88*/
uint8_t reg_0x0b89; /*0x0b89*/
uint8_t reg_0x0b8a; /*0x0b8a*/
};
struct reg_struct {
uint8_t coarse_integration_time_hi; /*REG_COARSE_INTEGRATION_TIME_HI*/
uint8_t coarse_integration_time_lo; /*REG_COARSE_INTEGRATION_TIME_LO*/
uint8_t analogue_gain_code_global;
uint8_t frame_length_lines_hi; /* 0x0340*/
uint8_t frame_length_lines_lo; /* 0x0341*/
uint8_t line_length_pck_hi; /* 0x0342*/
uint8_t line_length_pck_lo; /* 0x0343*/
uint8_t reg_0x3005; /* 0x3005*/
uint8_t reg_0x3010; /* 0x3010*/
uint8_t reg_0x3011; /* 0x3011*/
uint8_t reg_0x301a; /* 0x301a*/
uint8_t reg_0x3035; /* 0x3035*/
uint8_t reg_0x3036; /* 0x3036*/
uint8_t reg_0x3041; /*0x3041*/
uint8_t reg_0x3042; /*0x3042*/
uint8_t reg_0x3045; /*0x3045*/
uint8_t reg_0x0b80; /* 0x0b80*/
uint8_t reg_0x0900; /*0x0900*/
uint8_t reg_0x0901; /* 0x0901*/
uint8_t reg_0x0902; /*0x0902*/
uint8_t reg_0x0383; /*0x0383*/
uint8_t reg_0x0387; /* 0x0387*/
uint8_t reg_0x034c; /* 0x034c*/
uint8_t reg_0x034d; /*0x034d*/
uint8_t reg_0x034e; /* 0x034e*/
uint8_t reg_0x034f; /* 0x034f*/
uint8_t reg_0x1716; /*0x1716*/
uint8_t reg_0x1717; /*0x1717*/
uint8_t reg_0x1718; /*0x1718*/
uint8_t reg_0x1719; /*0x1719*/
uint8_t reg_0x3210;/*0x3210*/
uint8_t reg_0x111; /*0x111*/
uint8_t reg_0x3410; /*0x3410*/
uint8_t reg_0x3098;
uint8_t reg_0x309D;
uint8_t reg_0x0200;
uint8_t reg_0x0201;
};
struct mt9e013_i2c_reg_conf {
unsigned short waddr;
unsigned short wdata;
};
enum mt9e013_test_mode_t {
TEST_OFF,
TEST_1,
TEST_2,
TEST_3
};
enum mt9e013_resolution_t {
QTR_SIZE,
FULL_SIZE,
HFR_60FPS,
HFR_90FPS,
HFR_120FPS,
INVALID_SIZE
};
enum mt9e013_setting {
RES_PREVIEW,
RES_CAPTURE
};
enum mt9e013_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
};
enum mt9e013_reg_pll {
E013_VT_PIX_CLK_DIV,
E013_VT_SYS_CLK_DIV,
E013_PRE_PLL_CLK_DIV,
E013_PLL_MULTIPLIER,
E013_OP_PIX_CLK_DIV,
E013_OP_SYS_CLK_DIV
};
enum mt9e013_reg_mode {
E013_X_ADDR_START,
E013_X_ADDR_END,
E013_Y_ADDR_START,
E013_Y_ADDR_END,
E013_X_OUTPUT_SIZE,
E013_Y_OUTPUT_SIZE,
E013_DATAPATH_SELECT,
E013_READ_MODE,
E013_ANALOG_CONTROL5,
E013_DAC_LD_4_5,
E013_SCALING_MODE,
E013_SCALE_M,
E013_LINE_LENGTH_PCK,
E013_FRAME_LENGTH_LINES,
E013_COARSE_INTEGRATION_TIME,
E013_FINE_INTEGRATION_TIME,
E013_FINE_CORRECTION
};
struct mt9e013_reg {
const struct mt9e013_i2c_reg_conf *reg_mipi;
const unsigned short reg_mipi_size;
const struct mt9e013_i2c_reg_conf *rec_settings;
const unsigned short rec_size;
const struct mt9e013_i2c_reg_conf *reg_pll;
const unsigned short reg_pll_size;
const struct mt9e013_i2c_reg_conf *reg_pll_60fps;
const unsigned short reg_pll_60fps_size;
const struct mt9e013_i2c_reg_conf *reg_pll_120fps;
const unsigned short reg_pll_120fps_size;
const struct mt9e013_i2c_reg_conf *reg_prev;
const unsigned short reg_prev_size;
const struct mt9e013_i2c_reg_conf *reg_snap;
const unsigned short reg_snap_size;
const struct mt9e013_i2c_reg_conf *reg_60fps;
const unsigned short reg_60fps_size;
const struct mt9e013_i2c_reg_conf *reg_120fps;
const unsigned short reg_120fps_size;
};
#endif /* MT9E013_H */