aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/media/video/gspca/m5602/m5602_ov9650.c14
-rw-r--r--drivers/media/video/gspca/m5602/m5602_ov9650.h40
2 files changed, 51 insertions, 3 deletions
diff --git a/drivers/media/video/gspca/m5602/m5602_ov9650.c b/drivers/media/video/gspca/m5602/m5602_ov9650.c
index fcca3adefc5b..98c979dbbe3d 100644
--- a/drivers/media/video/gspca/m5602/m5602_ov9650.c
+++ b/drivers/media/video/gspca/m5602/m5602_ov9650.c
@@ -150,7 +150,6 @@ int ov9650_start(struct sd *sd)
150 150
151 switch (cam->cam_mode[sd->gspca_dev.curr_mode].width) 151 switch (cam->cam_mode[sd->gspca_dev.curr_mode].width)
152 { 152 {
153 default:
154 case 640: 153 case 640:
155 PDEBUG(D_V4L2, "Configuring camera for VGA mode"); 154 PDEBUG(D_V4L2, "Configuring camera for VGA mode");
156 155
@@ -163,6 +162,19 @@ int ov9650_start(struct sd *sd)
163 err = m5602_write_bridge(sd, VGA_ov9650[i][1], data); 162 err = m5602_write_bridge(sd, VGA_ov9650[i][1], data);
164 } 163 }
165 break; 164 break;
165
166 case 320:
167 PDEBUG(D_V4L2, "Configuring camera for QVGA mode");
168
169 for (i = 0; i < ARRAY_SIZE(QVGA_ov9650) && !err; i++) {
170 u8 data = QVGA_ov9650[i][2];
171 if (QVGA_ov9650[i][0] == SENSOR)
172 err = m5602_write_sensor(sd,
173 QVGA_ov9650[i][1], &data, 1);
174 else
175 err = m5602_write_bridge(sd, QVGA_ov9650[i][1], data);
176 }
177 break;
166 } 178 }
167 return err; 179 return err;
168} 180}
diff --git a/drivers/media/video/gspca/m5602/m5602_ov9650.h b/drivers/media/video/gspca/m5602/m5602_ov9650.h
index 17f3382af76a..636dce61c49d 100644
--- a/drivers/media/video/gspca/m5602/m5602_ov9650.h
+++ b/drivers/media/video/gspca/m5602/m5602_ov9650.h
@@ -20,7 +20,6 @@
20#define M5602_OV9650_H_ 20#define M5602_OV9650_H_
21 21
22#include <linux/dmi.h> 22#include <linux/dmi.h>
23
24#include "m5602_sensor.h" 23#include "m5602_sensor.h"
25 24
26/*****************************************************************************/ 25/*****************************************************************************/
@@ -94,6 +93,7 @@
94 93
95#define OV9650_REGISTER_RESET (1 << 7) 94#define OV9650_REGISTER_RESET (1 << 7)
96#define OV9650_VGA_SELECT (1 << 6) 95#define OV9650_VGA_SELECT (1 << 6)
96#define OV9650_QVGA_SELECT (1 << 4)
97#define OV9650_RGB_SELECT (1 << 2) 97#define OV9650_RGB_SELECT (1 << 2)
98#define OV9650_RAW_RGB_SELECT (1 << 0) 98#define OV9650_RAW_RGB_SELECT (1 << 0)
99 99
@@ -258,9 +258,19 @@ static struct m5602_sensor ov9650 = {
258 } 258 }
259 }, 259 },
260 260
261 .nmodes = 1, 261 .nmodes = 2,
262 .modes = { 262 .modes = {
263 { 263 {
264 320,
265 240,
266 V4L2_PIX_FMT_SBGGR8,
267 V4L2_FIELD_NONE,
268 .sizeimage =
269 320 * 240,
270 .bytesperline = 320,
271 .colorspace = V4L2_COLORSPACE_SRGB,
272 .priv = 0
273 }, {
264 640, 274 640,
265 480, 275 480,
266 V4L2_PIX_FMT_SBGGR8, 276 V4L2_PIX_FMT_SBGGR8,
@@ -464,4 +474,30 @@ static const unsigned char VGA_ov9650[][3] =
464 {BRIDGE, M5602_XB_HSYNC_PARA, 0xe4} 474 {BRIDGE, M5602_XB_HSYNC_PARA, 0xe4}
465}; 475};
466 476
477static const unsigned char QVGA_ov9650[][3] =
478{
479 {SENSOR, OV9650_COM7, OV9650_QVGA_SELECT |
480 OV9650_RGB_SELECT |
481 OV9650_RAW_RGB_SELECT},
482
483 {BRIDGE, M5602_XB_LINE_OF_FRAME_H, 0x82},
484 {BRIDGE, M5602_XB_LINE_OF_FRAME_L, 0x00},
485 {BRIDGE, M5602_XB_PIX_OF_LINE_H, 0x82},
486 {BRIDGE, M5602_XB_PIX_OF_LINE_L, 0x00},
487 {BRIDGE, M5602_XB_SIG_INI, 0x01},
488
489 /* Moves the view window in a vertical orientation */
490 {BRIDGE, M5602_XB_VSYNC_PARA, 0x00},
491 {BRIDGE, M5602_XB_VSYNC_PARA, 0x08},
492 {BRIDGE, M5602_XB_VSYNC_PARA, 0x00},
493 {BRIDGE, M5602_XB_VSYNC_PARA, 0x00},
494 {BRIDGE, M5602_XB_VSYNC_PARA, 0xf0}, /* 240 */
495 {BRIDGE, M5602_XB_VSYNC_PARA, 0x00},
496 {BRIDGE, M5602_XB_VSYNC_PARA, 0x00},
497 {BRIDGE, M5602_XB_HSYNC_PARA, 0x00},
498 {BRIDGE, M5602_XB_HSYNC_PARA, 0x31}, /* 50 */
499 {BRIDGE, M5602_XB_HSYNC_PARA, 0x01}, /* 320 + 50 */
500 {BRIDGE, M5602_XB_HSYNC_PARA, 0x71}
501};
502
467#endif 503#endif