39f31b11facb4187c9085bbf495e26870168b28a
[firefly-linux-kernel-4.4.55.git] / arch / arm / plat-rk / include / plat / rk_camera.h
1 /*
2     camera.h - PXA camera driver header file
3
4     Copyright (C) 2003, Intel Corporation
5     Copyright (C) 2008, Guennadi Liakhovetski <kernel@pengutronix.de>
6
7     This program is free software; you can redistribute it and/or modify
8     it under the terms of the GNU General Public License as published by
9     the Free Software Foundation; either version 2 of the License, or
10     (at your option) any later version.
11
12     This program is distributed in the hope that it will be useful,
13     but WITHOUT ANY WARRANTY; without even the implied warranty of
14     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15     GNU General Public License for more details.
16
17     You should have received a copy of the GNU General Public License
18     along with this program; if not, write to the Free Software
19     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 */
21
22 #ifndef __ASM_ARCH_CAMERA_RK_H_
23 #define __ASM_ARCH_CAMERA_RK_H_
24
25 #include <linux/videodev2.h>
26 #include <media/soc_camera.h>
27
28
29 #define RK29_CAM_PLATFORM_DEV_ID 33
30 #define RK_CAM_PLATFORM_DEV_ID_0 RK29_CAM_PLATFORM_DEV_ID
31 #define RK_CAM_PLATFORM_DEV_ID_1 (RK_CAM_PLATFORM_DEV_ID_0+1)
32 #define INVALID_GPIO -1
33 #define INVALID_VALUE -1
34 #define RK29_CAM_IO_SUCCESS 0
35 #define RK29_CAM_EIO_INVALID -1
36 #define RK29_CAM_EIO_REQUESTFAIL -2
37
38 #define RK_CAM_NUM 6
39 #define RK29_CAM_SUPPORT_NUMS  RK_CAM_NUM
40 #define RK_CAM_SUPPORT_RESOLUTION 0x500000
41 /*---------------- Camera Sensor Must Define Macro Begin  ------------------------*/
42 #define RK29_CAM_SENSOR_OV7675 ov7675
43 #define RK29_CAM_SENSOR_OV9650 ov9650
44 #define RK29_CAM_SENSOR_OV2640 ov2640
45 #define RK29_CAM_SENSOR_OV2655 ov2655
46 #define RK29_CAM_SENSOR_OV2659 ov2659
47 #define RK29_CAM_SENSOR_OV7690 ov7690
48 #define RK29_CAM_SENSOR_OV3640 ov3640
49 #define RK29_CAM_SENSOR_OV3660 ov3660
50 #define RK29_CAM_SENSOR_OV5640 ov5640
51 #define RK29_CAM_SENSOR_OV5642 ov5642
52 #define RK29_CAM_SENSOR_S5K6AA s5k6aa
53 #define RK29_CAM_SENSOR_MT9D112 mt9d112
54 #define RK29_CAM_SENSOR_MT9D113 mt9d113
55 #define RK29_CAM_SENSOR_MT9P111 mt9p111
56 #define RK29_CAM_SENSOR_MT9T111 mt9t111
57 #define RK29_CAM_SENSOR_GT2005  gt2005
58 #define RK29_CAM_SENSOR_GC0307  gc0307
59 #define RK29_CAM_SENSOR_GC0308  gc0308
60 #define RK29_CAM_SENSOR_GC0309  gc0309
61 #define RK29_CAM_SENSOR_GC2015  gc2015
62 #define RK29_CAM_SENSOR_SIV120B  siv120b
63 #define RK29_CAM_SENSOR_SIV121D  siv121d
64 #define RK29_CAM_SENSOR_SID130B  sid130B
65 #define RK29_CAM_SENSOR_HI253  hi253
66 #define RK29_CAM_SENSOR_HI704  hi704
67 #define RK29_CAM_SENSOR_NT99250 nt99250
68
69 #define RK29_CAM_SENSOR_NAME_OV7675 "ov7675"
70 #define RK29_CAM_SENSOR_NAME_OV9650 "ov9650"
71 #define RK29_CAM_SENSOR_NAME_OV2640 "ov2640"
72 #define RK29_CAM_SENSOR_NAME_OV2655 "ov2655"
73 #define RK29_CAM_SENSOR_NAME_OV2659 "ov2659"
74 #define RK29_CAM_SENSOR_NAME_OV7690 "ov7690"
75 #define RK29_CAM_SENSOR_NAME_OV3640 "ov3640"
76 #define RK29_CAM_SENSOR_NAME_OV3660 "ov3660"
77 #define RK29_CAM_SENSOR_NAME_OV5640 "ov5640"
78 #define RK29_CAM_SENSOR_NAME_OV5642 "ov5642"
79 #define RK29_CAM_SENSOR_NAME_S5K6AA "s5k6aa"
80 #define RK29_CAM_SENSOR_NAME_MT9D112 "mt9d112"
81 #define RK29_CAM_SENSOR_NAME_MT9D113 "mt9d113"
82 #define RK29_CAM_SENSOR_NAME_MT9P111 "mt9p111"
83 #define RK29_CAM_SENSOR_NAME_MT9T111 "mt9t111"
84 #define RK29_CAM_SENSOR_NAME_GT2005  "gt2005"
85 #define RK29_CAM_SENSOR_NAME_GC0307  "gc0307"
86 #define RK29_CAM_SENSOR_NAME_GC0308  "gc0308"
87 #define RK29_CAM_SENSOR_NAME_GC0309  "gc0309"
88 #define RK29_CAM_SENSOR_NAME_GC2015  "gc2015"
89 #define RK29_CAM_SENSOR_NAME_SIV120B "siv120b"
90 #define RK29_CAM_SENSOR_NAME_SIV121D "siv121d"
91 #define RK29_CAM_SENSOR_NAME_SID130B "sid130B"
92 #define RK29_CAM_SENSOR_NAME_HI253  "hi253"
93 #define RK29_CAM_SENSOR_NAME_HI704  "hi704"
94 #define RK29_CAM_SENSOR_NAME_NT99250 "nt99250"
95
96 #define ov7675_FULL_RESOLUTION     0x30000            // 0.3 megapixel
97 #define ov9650_FULL_RESOLUTION     0x130000           // 1.3 megapixel   
98 #define ov2640_FULL_RESOLUTION     0x200000           // 2 megapixel
99 #define ov2655_FULL_RESOLUTION     0x200000           // 2 megapixel
100 #define ov2659_FULL_RESOLUTION     0x200000           // 2 megapixel
101 #define ov7690_FULL_RESOLUTION     0x300000           // 2 megapixel
102 #define ov3640_FULL_RESOLUTION     0x300000           // 3 megapixel
103 #define ov3660_FULL_RESOLUTION     0x300000           // 3 megapixel
104 #define ov5640_FULL_RESOLUTION     0x500000           // 5 megapixel
105 #define ov5642_FULL_RESOLUTION     0x500000           // 5 megapixel
106 #define s5k6aa_FULL_RESOLUTION     0x130000           // 1.3 megapixel
107 #define mt9d112_FULL_RESOLUTION    0x200000           // 2 megapixel
108 #define mt9d113_FULL_RESOLUTION    0x200000           // 2 megapixel
109 #define mt9t111_FULL_RESOLUTION    0x300000           // 3 megapixel
110 #define mt9p111_FULL_RESOLUTION    0x500000           // 5 megapixel
111 #define gt2005_FULL_RESOLUTION     0x200000           // 2 megapixel
112 #define gc0308_FULL_RESOLUTION     0x30000            // 0.3 megapixel
113 #define gc0309_FULL_RESOLUTION     0x30000            // 0.3 megapixel
114 #define gc2015_FULL_RESOLUTION     0x200000           // 2 megapixel
115 #define siv120b_FULL_RESOLUTION     0x30000            // 0.3 megapixel
116 #define siv121d_FULL_RESOLUTION     0x30000            // 0.3 megapixel
117 #define sid130B_FULL_RESOLUTION     0x200000           // 2 megapixel    
118 #define hi253_FULL_RESOLUTION       0x200000           // 2 megapixel
119 #define hi704_FULL_RESOLUTION       0x30000            // 0.3 megapixel
120 #define nt99250_FULL_RESOLUTION     0x200000           // 2 megapixel
121 /*---------------- Camera Sensor Must Define Macro End  ------------------------*/
122
123
124 #define RK29_CAM_POWERACTIVE_BITPOS     0x00
125 #define RK29_CAM_POWERACTIVE_MASK       (1<<RK29_CAM_POWERACTIVE_BITPOS)
126 #define RK29_CAM_POWERACTIVE_H  (0x01<<RK29_CAM_POWERACTIVE_BITPOS)
127 #define RK29_CAM_POWERACTIVE_L  (0x00<<RK29_CAM_POWERACTIVE_BITPOS)
128
129 #define RK29_CAM_RESETACTIVE_BITPOS     0x01
130 #define RK29_CAM_RESETACTIVE_MASK       (1<<RK29_CAM_RESETACTIVE_BITPOS)
131 #define RK29_CAM_RESETACTIVE_H  (0x01<<RK29_CAM_RESETACTIVE_BITPOS)
132 #define RK29_CAM_RESETACTIVE_L  (0x00<<RK29_CAM_RESETACTIVE_BITPOS)
133
134 #define RK29_CAM_POWERDNACTIVE_BITPOS   0x02
135 #define RK29_CAM_POWERDNACTIVE_MASK     (1<<RK29_CAM_POWERDNACTIVE_BITPOS)
136 #define RK29_CAM_POWERDNACTIVE_H        (0x01<<RK29_CAM_POWERDNACTIVE_BITPOS)
137 #define RK29_CAM_POWERDNACTIVE_L        (0x00<<RK29_CAM_POWERDNACTIVE_BITPOS)
138
139 #define RK29_CAM_FLASHACTIVE_BITPOS     0x03
140 #define RK29_CAM_FLASHACTIVE_MASK       (1<<RK29_CAM_FLASHACTIVE_BITPOS)
141 #define RK29_CAM_FLASHACTIVE_H  (0x01<<RK29_CAM_FLASHACTIVE_BITPOS)
142 #define RK29_CAM_FLASHACTIVE_L  (0x00<<RK29_CAM_FLASHACTIVE_BITPOS)
143
144 /* v4l2_subdev_core_ops.ioctl  ioctl_cmd macro */
145 #define RK29_CAM_SUBDEV_ACTIVATE            0x00
146 #define RK29_CAM_SUBDEV_DEACTIVATE          0x01
147 #define RK29_CAM_SUBDEV_IOREQUEST                       0x02
148 #define RK29_CAM_SUBDEV_CB_REGISTER         0x03
149
150 enum rk29camera_ioctrl_cmd
151 {
152         Cam_Power,
153         Cam_Reset,
154         Cam_PowerDown,
155         Cam_Flash
156 };
157
158 enum rk29sensor_power_cmd
159 {
160         Sensor_Reset,
161         Sensor_PowerDown,
162         Sensor_Flash
163 };
164
165 enum rk29camera_flash_cmd
166 {
167     Flash_Off,
168     Flash_On,
169     Flash_Torch
170 };
171
172 struct rk29camera_gpio_res {
173     unsigned int gpio_reset;
174     unsigned int gpio_power;
175         unsigned int gpio_powerdown;
176         unsigned int gpio_flash;
177         unsigned int gpio_flag;
178         unsigned int gpio_init;
179         const char *dev_name;
180 };
181
182 struct rk29camera_mem_res {
183         const char *name;
184         unsigned int start;
185         unsigned int size;
186 };
187 struct rk29camera_info {
188     const char *dev_name;
189     unsigned int orientation;
190     struct v4l2_frmivalenum fival[10];
191 };
192
193 struct reginfo_t
194 {
195         u16 reg;
196         u16 val;
197         u16 reg_len;
198         u16 rev;
199 };
200 typedef struct rk_sensor_user_init_data{
201         int rk_sensor_init_width;
202         int rk_sensor_init_height;
203         unsigned long rk_sensor_init_bus_param;
204         enum v4l2_mbus_pixelcode rk_sensor_init_pixelcode;
205         struct reginfo_t * rk_sensor_init_data;
206         int rk_sensor_winseq_size;
207         struct reginfo_t * rk_sensor_init_winseq;
208         int rk_sensor_init_data_size;
209 }rk_sensor_user_init_data_s;
210
211 typedef struct rk_camera_device_register_info {
212     struct i2c_board_info i2c_cam_info;
213     struct soc_camera_link link_info;
214     struct platform_device device_info;
215 }rk_camera_device_register_info_t;
216
217 struct rk29camera_platform_data {
218     int (*io_init)(void);
219     int (*io_deinit)(int sensor);
220     int (*iomux)(int pin);
221         int (*sensor_ioctrl)(struct device *dev,enum rk29camera_ioctrl_cmd cmd,int on);
222         rk_sensor_user_init_data_s* sensor_init_data[RK_CAM_NUM];
223         struct rk29camera_gpio_res gpio_res[RK_CAM_NUM];
224         struct rk29camera_mem_res meminfo;
225         struct rk29camera_mem_res meminfo_cif1;
226         struct rk29camera_info info[RK_CAM_NUM];
227     rk_camera_device_register_info_t register_dev[RK_CAM_NUM];
228 };
229
230 struct rk29camera_platform_ioctl_cb {
231     int (*sensor_power_cb)(struct rk29camera_gpio_res *res, int on);
232     int (*sensor_reset_cb)(struct rk29camera_gpio_res *res, int on);
233     int (*sensor_powerdown_cb)(struct rk29camera_gpio_res *res, int on);
234     int (*sensor_flash_cb)(struct rk29camera_gpio_res *res, int on);    
235 };
236
237 typedef struct rk29_camera_sensor_cb {
238     int (*sensor_cb)(void *arg); 
239 }rk29_camera_sensor_cb_s;
240 #endif /* __ASM_ARCH_CAMERA_H_ */
241