diff options
author | Németh Márton <nm127@freemail.hu> | 2010-10-19 02:33:47 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2010-10-21 12:31:06 -0400 |
commit | 76ad3b684ae6bf43662f8fc57501e4ad0e3b12e8 (patch) | |
tree | 986fbd1a41ff35afe8e8548cb3e37bb63ccf9ccd /drivers/media/video | |
parent | ccbc5df21ca0c616c5e47d1e7f58ff5b312e03a7 (diff) |
[media] gspca - sonixj: Add horizontal and vertical flip for po2030n
The PO2030N sensor chip found in hama AC-150 webcam supports horizontal
and vertical flipping the image by hardware.
Signed-off-by: Jean-François Moine <moinejf@free.fr>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media/video')
-rw-r--r-- | drivers/media/video/gspca/sonixj.c | 65 |
1 files changed, 51 insertions, 14 deletions
diff --git a/drivers/media/video/gspca/sonixj.c b/drivers/media/video/gspca/sonixj.c index da64947fc08..f5dab675c96 100644 --- a/drivers/media/video/gspca/sonixj.c +++ b/drivers/media/video/gspca/sonixj.c | |||
@@ -40,6 +40,7 @@ enum e_ctrl { | |||
40 | RED, | 40 | RED, |
41 | GAMMA, | 41 | GAMMA, |
42 | AUTOGAIN, | 42 | AUTOGAIN, |
43 | HFLIP, | ||
43 | VFLIP, | 44 | VFLIP, |
44 | SHARPNESS, | 45 | SHARPNESS, |
45 | INFRARED, | 46 | INFRARED, |
@@ -102,7 +103,7 @@ static void setcolors(struct gspca_dev *gspca_dev); | |||
102 | static void setredblue(struct gspca_dev *gspca_dev); | 103 | static void setredblue(struct gspca_dev *gspca_dev); |
103 | static void setgamma(struct gspca_dev *gspca_dev); | 104 | static void setgamma(struct gspca_dev *gspca_dev); |
104 | static void setautogain(struct gspca_dev *gspca_dev); | 105 | static void setautogain(struct gspca_dev *gspca_dev); |
105 | static void setvflip(struct gspca_dev *gspca_dev); | 106 | static void sethvflip(struct gspca_dev *gspca_dev); |
106 | static void setsharpness(struct gspca_dev *gspca_dev); | 107 | static void setsharpness(struct gspca_dev *gspca_dev); |
107 | static void setinfrared(struct gspca_dev *gspca_dev); | 108 | static void setinfrared(struct gspca_dev *gspca_dev); |
108 | static void setfreq(struct gspca_dev *gspca_dev); | 109 | static void setfreq(struct gspca_dev *gspca_dev); |
@@ -195,7 +196,18 @@ static const struct ctrl sd_ctrls[NCTRLS] = { | |||
195 | }, | 196 | }, |
196 | .set_control = setautogain | 197 | .set_control = setautogain |
197 | }, | 198 | }, |
198 | /* ov7630/ov7648 only */ | 199 | [HFLIP] = { |
200 | { | ||
201 | .id = V4L2_CID_HFLIP, | ||
202 | .type = V4L2_CTRL_TYPE_BOOLEAN, | ||
203 | .name = "Mirror", | ||
204 | .minimum = 0, | ||
205 | .maximum = 1, | ||
206 | .step = 1, | ||
207 | .default_value = 0, | ||
208 | }, | ||
209 | .set_control = sethvflip | ||
210 | }, | ||
199 | [VFLIP] = { | 211 | [VFLIP] = { |
200 | { | 212 | { |
201 | .id = V4L2_CID_VFLIP, | 213 | .id = V4L2_CID_VFLIP, |
@@ -206,7 +218,7 @@ static const struct ctrl sd_ctrls[NCTRLS] = { | |||
206 | .step = 1, | 218 | .step = 1, |
207 | .default_value = 0, | 219 | .default_value = 0, |
208 | }, | 220 | }, |
209 | .set_control = setvflip | 221 | .set_control = sethvflip |
210 | }, | 222 | }, |
211 | [SHARPNESS] = { | 223 | [SHARPNESS] = { |
212 | { | 224 | { |
@@ -252,59 +264,72 @@ static const struct ctrl sd_ctrls[NCTRLS] = { | |||
252 | static const __u32 ctrl_dis[] = { | 264 | static const __u32 ctrl_dis[] = { |
253 | [SENSOR_ADCM1700] = (1 << AUTOGAIN) | | 265 | [SENSOR_ADCM1700] = (1 << AUTOGAIN) | |
254 | (1 << INFRARED) | | 266 | (1 << INFRARED) | |
267 | (1 << HFLIP) | | ||
255 | (1 << VFLIP) | | 268 | (1 << VFLIP) | |
256 | (1 << FREQ), | 269 | (1 << FREQ), |
257 | 270 | ||
258 | [SENSOR_GC0307] = (1 << INFRARED) | | 271 | [SENSOR_GC0307] = (1 << INFRARED) | |
272 | (1 << HFLIP) | | ||
259 | (1 << VFLIP) | | 273 | (1 << VFLIP) | |
260 | (1 << FREQ), | 274 | (1 << FREQ), |
261 | 275 | ||
262 | [SENSOR_HV7131R] = (1 << INFRARED) | | 276 | [SENSOR_HV7131R] = (1 << INFRARED) | |
277 | (1 << HFLIP) | | ||
263 | (1 << FREQ), | 278 | (1 << FREQ), |
264 | 279 | ||
265 | [SENSOR_MI0360] = (1 << INFRARED) | | 280 | [SENSOR_MI0360] = (1 << INFRARED) | |
281 | (1 << HFLIP) | | ||
266 | (1 << VFLIP) | | 282 | (1 << VFLIP) | |
267 | (1 << FREQ), | 283 | (1 << FREQ), |
268 | 284 | ||
269 | [SENSOR_MI0360B] = (1 << INFRARED) | | 285 | [SENSOR_MI0360B] = (1 << INFRARED) | |
286 | (1 << HFLIP) | | ||
270 | (1 << VFLIP) | | 287 | (1 << VFLIP) | |
271 | (1 << FREQ), | 288 | (1 << FREQ), |
272 | 289 | ||
273 | [SENSOR_MO4000] = (1 << INFRARED) | | 290 | [SENSOR_MO4000] = (1 << INFRARED) | |
291 | (1 << HFLIP) | | ||
274 | (1 << VFLIP) | | 292 | (1 << VFLIP) | |
275 | (1 << FREQ), | 293 | (1 << FREQ), |
276 | 294 | ||
277 | [SENSOR_MT9V111] = (1 << VFLIP) | | 295 | [SENSOR_MT9V111] = (1 << HFLIP) | |
296 | (1 << VFLIP) | | ||
278 | (1 << FREQ), | 297 | (1 << FREQ), |
279 | 298 | ||
280 | [SENSOR_OM6802] = (1 << INFRARED) | | 299 | [SENSOR_OM6802] = (1 << INFRARED) | |
300 | (1 << HFLIP) | | ||
281 | (1 << VFLIP) | | 301 | (1 << VFLIP) | |
282 | (1 << FREQ), | 302 | (1 << FREQ), |
283 | 303 | ||
284 | [SENSOR_OV7630] = (1 << INFRARED), | 304 | [SENSOR_OV7630] = (1 << INFRARED) | |
305 | (1 << HFLIP), | ||
285 | 306 | ||
286 | [SENSOR_OV7648] = (1 << INFRARED), | 307 | [SENSOR_OV7648] = (1 << INFRARED) | |
308 | (1 << HFLIP), | ||
287 | 309 | ||
288 | [SENSOR_OV7660] = (1 << AUTOGAIN) | | 310 | [SENSOR_OV7660] = (1 << AUTOGAIN) | |
289 | (1 << INFRARED) | | 311 | (1 << INFRARED) | |
312 | (1 << HFLIP) | | ||
290 | (1 << VFLIP), | 313 | (1 << VFLIP), |
291 | 314 | ||
292 | [SENSOR_PO1030] = (1 << AUTOGAIN) | | 315 | [SENSOR_PO1030] = (1 << AUTOGAIN) | |
293 | (1 << INFRARED) | | 316 | (1 << INFRARED) | |
317 | (1 << HFLIP) | | ||
294 | (1 << VFLIP) | | 318 | (1 << VFLIP) | |
295 | (1 << FREQ), | 319 | (1 << FREQ), |
296 | 320 | ||
297 | [SENSOR_PO2030N] = (1 << AUTOGAIN) | | 321 | [SENSOR_PO2030N] = (1 << AUTOGAIN) | |
298 | (1 << INFRARED) | | 322 | (1 << INFRARED) | |
299 | (1 << VFLIP) | | ||
300 | (1 << FREQ), | 323 | (1 << FREQ), |
301 | [SENSOR_SOI768] = (1 << AUTOGAIN) | | 324 | [SENSOR_SOI768] = (1 << AUTOGAIN) | |
302 | (1 << INFRARED) | | 325 | (1 << INFRARED) | |
326 | (1 << HFLIP) | | ||
303 | (1 << VFLIP) | | 327 | (1 << VFLIP) | |
304 | (1 << FREQ), | 328 | (1 << FREQ), |
305 | 329 | ||
306 | [SENSOR_SP80708] = (1 << AUTOGAIN) | | 330 | [SENSOR_SP80708] = (1 << AUTOGAIN) | |
307 | (1 << INFRARED) | | 331 | (1 << INFRARED) | |
332 | (1 << HFLIP) | | ||
308 | (1 << VFLIP) | | 333 | (1 << VFLIP) | |
309 | (1 << FREQ), | 334 | (1 << FREQ), |
310 | }; | 335 | }; |
@@ -2237,14 +2262,11 @@ static void setautogain(struct gspca_dev *gspca_dev) | |||
2237 | sd->ag_cnt = -1; | 2262 | sd->ag_cnt = -1; |
2238 | } | 2263 | } |
2239 | 2264 | ||
2240 | /* hv7131r/ov7630/ov7648 only */ | 2265 | static void sethvflip(struct gspca_dev *gspca_dev) |
2241 | static void setvflip(struct gspca_dev *gspca_dev) | ||
2242 | { | 2266 | { |
2243 | struct sd *sd = (struct sd *) gspca_dev; | 2267 | struct sd *sd = (struct sd *) gspca_dev; |
2244 | u8 comn; | 2268 | u8 comn; |
2245 | 2269 | ||
2246 | if (gspca_dev->ctrl_dis & (1 << VFLIP)) | ||
2247 | return; | ||
2248 | switch (sd->sensor) { | 2270 | switch (sd->sensor) { |
2249 | case SENSOR_HV7131R: | 2271 | case SENSOR_HV7131R: |
2250 | comn = 0x18; /* clkdiv = 1, ablcen = 1 */ | 2272 | comn = 0x18; /* clkdiv = 1, ablcen = 1 */ |
@@ -2258,13 +2280,28 @@ static void setvflip(struct gspca_dev *gspca_dev) | |||
2258 | comn |= 0x80; | 2280 | comn |= 0x80; |
2259 | i2c_w1(gspca_dev, 0x75, comn); | 2281 | i2c_w1(gspca_dev, 0x75, comn); |
2260 | break; | 2282 | break; |
2261 | default: | 2283 | case SENSOR_OV7648: |
2262 | /* case SENSOR_OV7648: */ | ||
2263 | comn = 0x06; | 2284 | comn = 0x06; |
2264 | if (sd->ctrls[VFLIP].val) | 2285 | if (sd->ctrls[VFLIP].val) |
2265 | comn |= 0x80; | 2286 | comn |= 0x80; |
2266 | i2c_w1(gspca_dev, 0x75, comn); | 2287 | i2c_w1(gspca_dev, 0x75, comn); |
2267 | break; | 2288 | break; |
2289 | case SENSOR_PO2030N: | ||
2290 | /* Reg. 0x1E: Timing Generator Control Register 2 (Tgcontrol2) | ||
2291 | * (reset value: 0x0A) | ||
2292 | * bit7: HM: Horizontal Mirror: 0: disable, 1: enable | ||
2293 | * bit6: VM: Vertical Mirror: 0: disable, 1: enable | ||
2294 | * bit5: ST: Shutter Selection: 0: electrical, 1: mechanical | ||
2295 | * bit4: FT: Single Frame Transfer: 0: disable, 1: enable | ||
2296 | * bit3-0: X | ||
2297 | */ | ||
2298 | comn = 0x0a; | ||
2299 | if (sd->ctrls[HFLIP].val) | ||
2300 | comn |= 0x80; | ||
2301 | if (sd->ctrls[VFLIP].val) | ||
2302 | comn |= 0x40; | ||
2303 | i2c_w1(&sd->gspca_dev, 0x1e, comn); | ||
2304 | break; | ||
2268 | } | 2305 | } |
2269 | } | 2306 | } |
2270 | 2307 | ||
@@ -2650,7 +2687,7 @@ static int sd_start(struct gspca_dev *gspca_dev) | |||
2650 | reg_w1(gspca_dev, 0x17, reg17); | 2687 | reg_w1(gspca_dev, 0x17, reg17); |
2651 | reg_w1(gspca_dev, 0x01, reg1); | 2688 | reg_w1(gspca_dev, 0x01, reg1); |
2652 | 2689 | ||
2653 | setvflip(gspca_dev); | 2690 | sethvflip(gspca_dev); |
2654 | setbrightness(gspca_dev); | 2691 | setbrightness(gspca_dev); |
2655 | setcontrast(gspca_dev); | 2692 | setcontrast(gspca_dev); |
2656 | setcolors(gspca_dev); | 2693 | setcolors(gspca_dev); |