| /* Copyright (c) 2010, Code Aurora Forum. 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 */ |