1951a39d68df598db08dfced8b4707755864a0492Ying Wang/****************************************************************************
2951a39d68df598db08dfced8b4707755864a0492Ying Wang ****************************************************************************
3951a39d68df598db08dfced8b4707755864a0492Ying Wang ***
4951a39d68df598db08dfced8b4707755864a0492Ying Wang ***   This header was automatically generated from a Linux kernel header
5951a39d68df598db08dfced8b4707755864a0492Ying Wang ***   of the same name, to make information necessary for userspace to
6951a39d68df598db08dfced8b4707755864a0492Ying Wang ***   call into the kernel available to libc.  It contains only constants,
7951a39d68df598db08dfced8b4707755864a0492Ying Wang ***   structures, and macros generated from the original header, and thus,
8951a39d68df598db08dfced8b4707755864a0492Ying Wang ***   contains no copyrightable information.
9951a39d68df598db08dfced8b4707755864a0492Ying Wang ***
10951a39d68df598db08dfced8b4707755864a0492Ying Wang ****************************************************************************
11951a39d68df598db08dfced8b4707755864a0492Ying Wang ****************************************************************************/
12951a39d68df598db08dfced8b4707755864a0492Ying Wang#ifndef CAMERA_MT9T013_H
13951a39d68df598db08dfced8b4707755864a0492Ying Wang#define CAMERA_MT9T013_H
14951a39d68df598db08dfced8b4707755864a0492Ying Wang#include <linux/cdev.h>
15951a39d68df598db08dfced8b4707755864a0492Ying Wang#include <linux/types.h>
16951a39d68df598db08dfced8b4707755864a0492Ying Wang#include <linux/ioctl.h>
17951a39d68df598db08dfced8b4707755864a0492Ying Wang#include <asm/sizes.h>
18951a39d68df598db08dfced8b4707755864a0492Ying Wang
19951a39d68df598db08dfced8b4707755864a0492Ying Wang#define MT9T013_I2C_IOCTL_MAGIC 'm'
20951a39d68df598db08dfced8b4707755864a0492Ying Wang
21951a39d68df598db08dfced8b4707755864a0492Ying Wang#define MT9T013_I2C_IOCTL_W   _IOW(MT9T013_I2C_IOCTL_MAGIC, 0, unsigned)
22951a39d68df598db08dfced8b4707755864a0492Ying Wang
23951a39d68df598db08dfced8b4707755864a0492Ying Wang#define MT9T013_I2C_IOCTL_R   _IOR(MT9T013_I2C_IOCTL_MAGIC, 1, unsigned)
24951a39d68df598db08dfced8b4707755864a0492Ying Wang
25951a39d68df598db08dfced8b4707755864a0492Ying Wang#define MT9T013_I2C_IOCTL_AF_W   _IOW(MT9T013_I2C_IOCTL_MAGIC, 2, unsigned)
26951a39d68df598db08dfced8b4707755864a0492Ying Wang
27951a39d68df598db08dfced8b4707755864a0492Ying Wang#define MT9T013_I2C_IOCTL_CAMIF_PAD_REG_RESET   _IO(MT9T013_I2C_IOCTL_MAGIC, 3)
28951a39d68df598db08dfced8b4707755864a0492Ying Wang
29951a39d68df598db08dfced8b4707755864a0492Ying Wang#define MT9T013_I2C_IOCTL_CAMIF_PAD_REG_RESET_2   _IO(MT9T013_I2C_IOCTL_MAGIC, 4)
30951a39d68df598db08dfced8b4707755864a0492Ying Wang
31951a39d68df598db08dfced8b4707755864a0492Ying Wang#define CAMERA_CONFIGURE_GPIOS   _IO(MT9T013_I2C_IOCTL_MAGIC, 7)
32951a39d68df598db08dfced8b4707755864a0492Ying Wang
33951a39d68df598db08dfced8b4707755864a0492Ying Wang#define CAMERA_UNCONFIGURE_GPIOS   _IO(MT9T013_I2C_IOCTL_MAGIC, 8)
34951a39d68df598db08dfced8b4707755864a0492Ying Wang
35951a39d68df598db08dfced8b4707755864a0492Ying Wang#define CAMERA_LENS_POWER_ON   _IO(MT9T013_I2C_IOCTL_MAGIC, 9)
36951a39d68df598db08dfced8b4707755864a0492Ying Wang
37951a39d68df598db08dfced8b4707755864a0492Ying Wang#define CAMERA_LENS_POWER_OFF   _IO(MT9T013_I2C_IOCTL_MAGIC, 10)
38951a39d68df598db08dfced8b4707755864a0492Ying Wang
39951a39d68df598db08dfced8b4707755864a0492Ying Wang#define MT9T013_I2C_IOCTL_CAMIF_APPS_RESET   _IO(MT9T013_I2C_IOCTL_MAGIC, 11)
40951a39d68df598db08dfced8b4707755864a0492Ying Wang
41951a39d68df598db08dfced8b4707755864a0492Ying Wang#define CAMIO_VFE_MDC_CLK 1
42951a39d68df598db08dfced8b4707755864a0492Ying Wang#define CAMIO_MDC_CLK 2
43951a39d68df598db08dfced8b4707755864a0492Ying Wang#define CAMIO_VFE_CLK 3
44951a39d68df598db08dfced8b4707755864a0492Ying Wang
45951a39d68df598db08dfced8b4707755864a0492Ying Wang#define MT9T013_I2C_IOCTL_CLK_ENABLE   _IOW(MT9T013_I2C_IOCTL_MAGIC, 12, unsigned)
46951a39d68df598db08dfced8b4707755864a0492Ying Wang
47951a39d68df598db08dfced8b4707755864a0492Ying Wang#define MT9T013_I2C_IOCTL_CLK_DISABLE   _IOW(MT9T013_I2C_IOCTL_MAGIC, 13, unsigned)
48951a39d68df598db08dfced8b4707755864a0492Ying Wang
49951a39d68df598db08dfced8b4707755864a0492Ying Wang#define MT9T013_I2C_IOCTL_CLK_SELECT   _IOW(MT9T013_I2C_IOCTL_MAGIC, 14, unsigned)
50951a39d68df598db08dfced8b4707755864a0492Ying Wang
51951a39d68df598db08dfced8b4707755864a0492Ying Wang#define MT9T013_I2C_IOCTL_CLK_FREQ_PROG   _IOW(MT9T013_I2C_IOCTL_MAGIC, 15, unsigned)
52951a39d68df598db08dfced8b4707755864a0492Ying Wang
53951a39d68df598db08dfced8b4707755864a0492Ying Wang#define CAMSENSOR_REG_INIT 0<<0
54951a39d68df598db08dfced8b4707755864a0492Ying Wang#define CAMSENSOR_REG_UPDATE_PERIODIC 1<<0
55951a39d68df598db08dfced8b4707755864a0492Ying Wang#define CAMSENSOR_TYPE_PREVIEW 0<<1
56951a39d68df598db08dfced8b4707755864a0492Ying Wang#define CAMSENSOR_TYPE_SNAPSHOT 1<<1
57951a39d68df598db08dfced8b4707755864a0492Ying Wang
58951a39d68df598db08dfced8b4707755864a0492Ying Wang#define MT9T013_I2C_IOCTL_SENSOR_SETTING   _IOW(MT9T013_I2C_IOCTL_MAGIC, 16, uint32_t)
59951a39d68df598db08dfced8b4707755864a0492Ying Wang
60951a39d68df598db08dfced8b4707755864a0492Ying Wangstruct mt9t013_reg_struct
61951a39d68df598db08dfced8b4707755864a0492Ying Wang{
62951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t vt_pix_clk_div;
63951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t vt_sys_clk_div;
64951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t pre_pll_clk_div;
65951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t pll_multiplier;
66951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t op_pix_clk_div;
67951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t op_sys_clk_div;
68951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t scale_m;
69951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t row_speed;
70951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t x_addr_start;
71951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t x_addr_end;
72951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t y_addr_start;
73951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t y_addr_end;
74951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t read_mode;
75951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t x_output_size ;
76951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t y_output_size;
77951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t line_length_pck;
78951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t frame_length_lines;
79951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t coarse_integration_time;
80951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t fine_integration_time;
81951a39d68df598db08dfced8b4707755864a0492Ying Wang};
82951a39d68df598db08dfced8b4707755864a0492Ying Wang
83951a39d68df598db08dfced8b4707755864a0492Ying Wangstruct mt9t013_reg_pat {
84951a39d68df598db08dfced8b4707755864a0492Ying Wang struct mt9t013_reg_struct reg[2];
85951a39d68df598db08dfced8b4707755864a0492Ying Wang};
86951a39d68df598db08dfced8b4707755864a0492Ying Wang
87951a39d68df598db08dfced8b4707755864a0492Ying Wang#define MT9T013_I2C_IOCTL_GET_REGISTERS   _IOR(MT9T013_I2C_IOCTL_MAGIC, 17, struct mt9t013_reg_pat *)
88951a39d68df598db08dfced8b4707755864a0492Ying Wang
89951a39d68df598db08dfced8b4707755864a0492Ying Wangstruct mt9t013_exposure_gain {
90951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t gain;
91951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t line;
92951a39d68df598db08dfced8b4707755864a0492Ying Wang uint32_t mode;
93951a39d68df598db08dfced8b4707755864a0492Ying Wang};
94951a39d68df598db08dfced8b4707755864a0492Ying Wang
95951a39d68df598db08dfced8b4707755864a0492Ying Wang#define MT9T013_I2C_IOCTL_EXPOSURE_GAIN   _IOW(MT9T013_I2C_IOCTL_MAGIC, 18, struct exposure_gain *)
96951a39d68df598db08dfced8b4707755864a0492Ying Wang
97951a39d68df598db08dfced8b4707755864a0492Ying Wang#define MT9T013_I2C_IOCTL_MOVE_FOCUS   _IOW(MT9T013_I2C_IOCTL_MAGIC, 19, uint32_t)
98951a39d68df598db08dfced8b4707755864a0492Ying Wang
99951a39d68df598db08dfced8b4707755864a0492Ying Wang#define MT9T013_I2C_IOCTL_SET_DEFAULT_FOCUS   _IOW(MT9T013_I2C_IOCTL_MAGIC, 20, uint32_t)
100951a39d68df598db08dfced8b4707755864a0492Ying Wang
101951a39d68df598db08dfced8b4707755864a0492Ying Wang#define MT9T013_I2C_IOCTL_POWER_DOWN   _IO(MT9T013_I2C_IOCTL_MAGIC, 21)
102951a39d68df598db08dfced8b4707755864a0492Ying Wang
103951a39d68df598db08dfced8b4707755864a0492Ying Wangstruct mt9t013_init {
104951a39d68df598db08dfced8b4707755864a0492Ying Wang int preview;
105951a39d68df598db08dfced8b4707755864a0492Ying Wang uint16_t chipid;
106951a39d68df598db08dfced8b4707755864a0492Ying Wang};
107951a39d68df598db08dfced8b4707755864a0492Ying Wang
108951a39d68df598db08dfced8b4707755864a0492Ying Wang#define MT9T013_I2C_IOCTL_INIT   _IOWR(MT9T013_I2C_IOCTL_MAGIC, 22, struct mt9t013_init *)
109951a39d68df598db08dfced8b4707755864a0492Ying Wang
110951a39d68df598db08dfced8b4707755864a0492Ying Wang#endif
111951a39d68df598db08dfced8b4707755864a0492Ying Wang
112