5c4a87cfbe8d377a0bfd2cf24d7c5c6f2f6079e1
[linux-2.6.git] / include / media / ov5650.h
1 /*
2  * Copyright (C) 2010 Motorola, Inc.
3  * Copyright (C) 2011 NVIDIA Corporation.
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License version 2 as
7  * published by the Free Software Foundation.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software
16  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
17  * 02111-1307, USA
18  */
19
20 #ifndef __OV5650_H__
21 #define __OV5650_H__
22
23 #include <linux/ioctl.h>  /* For IOCTL macros */
24
25 #define OV5650_IOCTL_SET_MODE                   _IOW('o', 1, struct ov5650_mode)
26 #define OV5650_IOCTL_SET_FRAME_LENGTH   _IOW('o', 2, __u32)
27 #define OV5650_IOCTL_SET_COARSE_TIME    _IOW('o', 3, __u32)
28 #define OV5650_IOCTL_SET_GAIN                   _IOW('o', 4, __u16)
29 #define OV5650_IOCTL_GET_STATUS                 _IOR('o', 5, __u8)
30 #define OV5650_IOCTL_SET_BINNING        _IOW('o', 6, __u8)
31 #define OV5650_IOCTL_TEST_PATTERN               _IOW('o', 7, enum ov5650_test_pattern)
32 #define OV5650_IOCTL_SET_GROUP_HOLD         _IOW('o', 8, struct ov5650_ae)
33 #define OV5650_IOCTL_SET_CAMERA_MODE    _IOW('o', 10, __u32)
34 #define OV5650_IOCTL_SYNC_SENSORS               _IOW('o', 11, __u32)
35
36 /* OV5650 registers */
37 #define OV5650_SRM_GRUP_ACCESS          (0x3212)
38 #define OV5650_ARRAY_CONTROL_01         (0x3621)
39 #define OV5650_ANALOG_CONTROL_D         (0x370D)
40 #define OV5650_TIMING_TC_REG_18         (0x3818)
41 #define OV5650_TIMING_CONTROL_HS_HIGH   (0x3800)
42 #define OV5650_TIMING_CONTROL_HS_LOW    (0x3801)
43 #define OV5650_TIMING_CONTROL_VS_HIGH   (0x3802)
44 #define OV5650_TIMING_CONTROL_VS_LOW    (0x3803)
45 #define OV5650_TIMING_HW_HIGH           (0x3804)
46 #define OV5650_TIMING_HW_LOW            (0x3805)
47 #define OV5650_TIMING_VH_HIGH           (0x3806)
48 #define OV5650_TIMING_VH_LOW            (0x3807)
49 #define OV5650_TIMING_TC_REG_18         (0x3818)
50 #define OV5650_TIMING_HREFST_MAN_HIGH   (0x3824)
51 #define OV5650_TIMING_HREFST_MAN_LOW    (0x3825)
52 #define OV5650_H_BINNING_BIT            (1 << 7)
53 #define OV5650_H_SUBSAMPLING_BIT        (1 << 6)
54 #define OV5650_V_BINNING_BIT            (1 << 6)
55 #define OV5650_V_SUBSAMPLING_BIT        (1 << 0)
56 #define OV5650_GROUP_HOLD_BIT           (1 << 7)
57 #define OV5650_GROUP_LAUNCH_BIT         (1 << 5)
58 #define OV5650_GROUP_HOLD_END_BIT       (1 << 4)
59 #define OV5650_GROUP_ID(id)             (id)
60
61 enum ov5650_test_pattern {
62         TEST_PATTERN_NONE,
63         TEST_PATTERN_COLORBARS,
64         TEST_PATTERN_CHECKERBOARD
65 };
66
67 struct ov5650_mode {
68         int xres;
69         int yres;
70         __u32 frame_length;
71         __u32 coarse_time;
72         __u16 gain;
73 };
74
75 struct ov5650_ae {
76         __u32 frame_length;
77         __u8 frame_length_enable;
78         __u32 coarse_time;
79         __u8 coarse_time_enable;
80         __s32 gain;
81         __u8 gain_enable;
82 };
83
84 #ifdef __KERNEL__
85 struct ov5650_platform_data {
86         int (*power_on)(void);
87         int (*power_off)(void);
88         void (*synchronize_sensors)(void);
89 };
90 #endif /* __KERNEL__ */
91
92 #endif  /* __OV5650_H__ */
93