aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/media/video/gspca/mars.c206
1 files changed, 75 insertions, 131 deletions
diff --git a/drivers/media/video/gspca/mars.c b/drivers/media/video/gspca/mars.c
index 45be6a87279..cd0d69277b0 100644
--- a/drivers/media/video/gspca/mars.c
+++ b/drivers/media/video/gspca/mars.c
@@ -28,14 +28,21 @@ MODULE_AUTHOR("Michel Xhaard <mxhaard@users.sourceforge.net>");
28MODULE_DESCRIPTION("GSPCA/Mars USB Camera Driver"); 28MODULE_DESCRIPTION("GSPCA/Mars USB Camera Driver");
29MODULE_LICENSE("GPL"); 29MODULE_LICENSE("GPL");
30 30
31/* controls */
32enum e_ctrl {
33 BRIGHTNESS,
34 COLORS,
35 GAMMA,
36 SHARPNESS,
37 NCTRLS /* number of controls */
38};
39
31/* specific webcam descriptor */ 40/* specific webcam descriptor */
32struct sd { 41struct sd {
33 struct gspca_dev gspca_dev; /* !! must be the first item */ 42 struct gspca_dev gspca_dev; /* !! must be the first item */
34 43
35 u8 brightness; 44 struct gspca_ctrl ctrls[NCTRLS];
36 u8 colors; 45
37 u8 gamma;
38 u8 sharpness;
39 u8 quality; 46 u8 quality;
40#define QUALITY_MIN 40 47#define QUALITY_MIN 40
41#define QUALITY_MAX 70 48#define QUALITY_MAX 70
@@ -45,17 +52,13 @@ struct sd {
45}; 52};
46 53
47/* V4L2 controls supported by the driver */ 54/* V4L2 controls supported by the driver */
48static int sd_setbrightness(struct gspca_dev *gspca_dev, __s32 val); 55static void setbrightness(struct gspca_dev *gspca_dev);
49static int sd_getbrightness(struct gspca_dev *gspca_dev, __s32 *val); 56static void setcolors(struct gspca_dev *gspca_dev);
50static int sd_setcolors(struct gspca_dev *gspca_dev, __s32 val); 57static void setgamma(struct gspca_dev *gspca_dev);
51static int sd_getcolors(struct gspca_dev *gspca_dev, __s32 *val); 58static void setsharpness(struct gspca_dev *gspca_dev);
52static int sd_setgamma(struct gspca_dev *gspca_dev, __s32 val); 59
53static int sd_getgamma(struct gspca_dev *gspca_dev, __s32 *val); 60static const struct ctrl sd_ctrls[NCTRLS] = {
54static int sd_setsharpness(struct gspca_dev *gspca_dev, __s32 val); 61[BRIGHTNESS] = {
55static int sd_getsharpness(struct gspca_dev *gspca_dev, __s32 *val);
56
57static const struct ctrl sd_ctrls[] = {
58 {
59 { 62 {
60 .id = V4L2_CID_BRIGHTNESS, 63 .id = V4L2_CID_BRIGHTNESS,
61 .type = V4L2_CTRL_TYPE_INTEGER, 64 .type = V4L2_CTRL_TYPE_INTEGER,
@@ -63,13 +66,11 @@ static const struct ctrl sd_ctrls[] = {
63 .minimum = 0, 66 .minimum = 0,
64 .maximum = 30, 67 .maximum = 30,
65 .step = 1, 68 .step = 1,
66#define BRIGHTNESS_DEF 15 69 .default_value = 15,
67 .default_value = BRIGHTNESS_DEF,
68 }, 70 },
69 .set = sd_setbrightness, 71 .set_control = setbrightness
70 .get = sd_getbrightness,
71 }, 72 },
72 { 73[COLORS] = {
73 { 74 {
74 .id = V4L2_CID_SATURATION, 75 .id = V4L2_CID_SATURATION,
75 .type = V4L2_CTRL_TYPE_INTEGER, 76 .type = V4L2_CTRL_TYPE_INTEGER,
@@ -77,13 +78,11 @@ static const struct ctrl sd_ctrls[] = {
77 .minimum = 1, 78 .minimum = 1,
78 .maximum = 255, 79 .maximum = 255,
79 .step = 1, 80 .step = 1,
80#define COLOR_DEF 200 81 .default_value = 200,
81 .default_value = COLOR_DEF,
82 }, 82 },
83 .set = sd_setcolors, 83 .set_control = setcolors
84 .get = sd_getcolors,
85 }, 84 },
86 { 85[GAMMA] = {
87 { 86 {
88 .id = V4L2_CID_GAMMA, 87 .id = V4L2_CID_GAMMA,
89 .type = V4L2_CTRL_TYPE_INTEGER, 88 .type = V4L2_CTRL_TYPE_INTEGER,
@@ -91,13 +90,11 @@ static const struct ctrl sd_ctrls[] = {
91 .minimum = 0, 90 .minimum = 0,
92 .maximum = 3, 91 .maximum = 3,
93 .step = 1, 92 .step = 1,
94#define GAMMA_DEF 1 93 .default_value = 1,
95 .default_value = GAMMA_DEF,
96 }, 94 },
97 .set = sd_setgamma, 95 .set_control = setgamma
98 .get = sd_getgamma,
99 }, 96 },
100 { 97[SHARPNESS] = {
101 { 98 {
102 .id = V4L2_CID_SHARPNESS, 99 .id = V4L2_CID_SHARPNESS,
103 .type = V4L2_CTRL_TYPE_INTEGER, 100 .type = V4L2_CTRL_TYPE_INTEGER,
@@ -105,11 +102,9 @@ static const struct ctrl sd_ctrls[] = {
105 .minimum = 0, 102 .minimum = 0,
106 .maximum = 2, 103 .maximum = 2,
107 .step = 1, 104 .step = 1,
108#define SHARPNESS_DEF 1 105 .default_value = 1,
109 .default_value = SHARPNESS_DEF,
110 }, 106 },
111 .set = sd_setsharpness, 107 .set_control = setsharpness
112 .get = sd_getsharpness,
113 }, 108 },
114}; 109};
115 110
@@ -167,6 +162,45 @@ static void mi_w(struct gspca_dev *gspca_dev,
167 reg_w(gspca_dev, 4); 162 reg_w(gspca_dev, 4);
168} 163}
169 164
165static void setbrightness(struct gspca_dev *gspca_dev)
166{
167 struct sd *sd = (struct sd *) gspca_dev;
168
169 gspca_dev->usb_buf[0] = 0x61;
170 gspca_dev->usb_buf[1] = sd->ctrls[BRIGHTNESS].val;
171 reg_w(gspca_dev, 2);
172}
173
174static void setcolors(struct gspca_dev *gspca_dev)
175{
176 struct sd *sd = (struct sd *) gspca_dev;
177 s16 val;
178
179 val = sd->ctrls[COLORS].val;
180 gspca_dev->usb_buf[0] = 0x5f;
181 gspca_dev->usb_buf[1] = val << 3;
182 gspca_dev->usb_buf[2] = ((val >> 2) & 0xf8) | 0x04;
183 reg_w(gspca_dev, 3);
184}
185
186static void setgamma(struct gspca_dev *gspca_dev)
187{
188 struct sd *sd = (struct sd *) gspca_dev;
189
190 gspca_dev->usb_buf[0] = 0x06;
191 gspca_dev->usb_buf[1] = sd->ctrls[GAMMA].val * 0x40;
192 reg_w(gspca_dev, 2);
193}
194
195static void setsharpness(struct gspca_dev *gspca_dev)
196{
197 struct sd *sd = (struct sd *) gspca_dev;
198
199 gspca_dev->usb_buf[0] = 0x67;
200 gspca_dev->usb_buf[1] = sd->ctrls[SHARPNESS].val * 4 + 3;
201 reg_w(gspca_dev, 2);
202}
203
170/* this function is called at probe time */ 204/* this function is called at probe time */
171static int sd_config(struct gspca_dev *gspca_dev, 205static int sd_config(struct gspca_dev *gspca_dev,
172 const struct usb_device_id *id) 206 const struct usb_device_id *id)
@@ -177,10 +211,7 @@ static int sd_config(struct gspca_dev *gspca_dev,
177 cam = &gspca_dev->cam; 211 cam = &gspca_dev->cam;
178 cam->cam_mode = vga_mode; 212 cam->cam_mode = vga_mode;
179 cam->nmodes = ARRAY_SIZE(vga_mode); 213 cam->nmodes = ARRAY_SIZE(vga_mode);
180 sd->brightness = BRIGHTNESS_DEF; 214 cam->ctrls = sd->ctrls;
181 sd->colors = COLOR_DEF;
182 sd->gamma = GAMMA_DEF;
183 sd->sharpness = SHARPNESS_DEF;
184 sd->quality = QUALITY_DEF; 215 sd->quality = QUALITY_DEF;
185 gspca_dev->nbalt = 9; /* use the altsetting 08 */ 216 gspca_dev->nbalt = 9; /* use the altsetting 08 */
186 return 0; 217 return 0;
@@ -223,7 +254,7 @@ static int sd_start(struct gspca_dev *gspca_dev)
223 data[5] = 0x30; /* reg 4, MI, PAS5101 : 254 data[5] = 0x30; /* reg 4, MI, PAS5101 :
224 * 0x30 for 24mhz , 0x28 for 12mhz */ 255 * 0x30 for 24mhz , 0x28 for 12mhz */
225 data[6] = 0x02; /* reg 5, H start - was 0x04 */ 256 data[6] = 0x02; /* reg 5, H start - was 0x04 */
226 data[7] = sd->gamma * 0x40; /* reg 0x06: gamma */ 257 data[7] = sd->ctrls[GAMMA].val * 0x40; /* reg 0x06: gamma */
227 data[8] = 0x01; /* reg 7, V start - was 0x03 */ 258 data[8] = 0x01; /* reg 7, V start - was 0x03 */
228/* if (h_size == 320 ) */ 259/* if (h_size == 320 ) */
229/* data[9]= 0x56; * reg 8, 24MHz, 2:1 scale down */ 260/* data[9]= 0x56; * reg 8, 24MHz, 2:1 scale down */
@@ -261,9 +292,9 @@ static int sd_start(struct gspca_dev *gspca_dev)
261 /* reg 0x5f/0x60 (LE) = saturation */ 292 /* reg 0x5f/0x60 (LE) = saturation */
262 /* h (60): xxxx x100 293 /* h (60): xxxx x100
263 * l (5f): xxxx x000 */ 294 * l (5f): xxxx x000 */
264 data[2] = sd->colors << 3; 295 data[2] = sd->ctrls[COLORS].val << 3;
265 data[3] = ((sd->colors >> 2) & 0xf8) | 0x04; 296 data[3] = ((sd->ctrls[COLORS].val >> 2) & 0xf8) | 0x04;
266 data[4] = sd->brightness; /* reg 0x61 = brightness */ 297 data[4] = sd->ctrls[BRIGHTNESS].val; /* reg 0x61 = brightness */
267 data[5] = 0x00; 298 data[5] = 0x00;
268 299
269 err_code = reg_w(gspca_dev, 6); 300 err_code = reg_w(gspca_dev, 6);
@@ -272,7 +303,7 @@ static int sd_start(struct gspca_dev *gspca_dev)
272 303
273 data[0] = 0x67; 304 data[0] = 0x67;
274/*jfm: from win trace*/ 305/*jfm: from win trace*/
275 data[1] = sd->sharpness * 4 + 3; 306 data[1] = sd->ctrls[SHARPNESS].val * 4 + 3;
276 data[2] = 0x14; 307 data[2] = 0x14;
277 err_code = reg_w(gspca_dev, 3); 308 err_code = reg_w(gspca_dev, 3);
278 if (err_code < 0) 309 if (err_code < 0)
@@ -352,93 +383,6 @@ static void sd_pkt_scan(struct gspca_dev *gspca_dev,
352 gspca_frame_add(gspca_dev, INTER_PACKET, data, len); 383 gspca_frame_add(gspca_dev, INTER_PACKET, data, len);
353} 384}
354 385
355static int sd_setbrightness(struct gspca_dev *gspca_dev, __s32 val)
356{
357 struct sd *sd = (struct sd *) gspca_dev;
358
359 sd->brightness = val;
360 if (gspca_dev->streaming) {
361 gspca_dev->usb_buf[0] = 0x61;
362 gspca_dev->usb_buf[1] = val;
363 reg_w(gspca_dev, 2);
364 }
365 return 0;
366}
367
368static int sd_getbrightness(struct gspca_dev *gspca_dev, __s32 *val)
369{
370 struct sd *sd = (struct sd *) gspca_dev;
371
372 *val = sd->brightness;
373 return 0;
374}
375
376static int sd_setcolors(struct gspca_dev *gspca_dev, __s32 val)
377{
378 struct sd *sd = (struct sd *) gspca_dev;
379
380 sd->colors = val;
381 if (gspca_dev->streaming) {
382
383 /* see sd_start */
384 gspca_dev->usb_buf[0] = 0x5f;
385 gspca_dev->usb_buf[1] = sd->colors << 3;
386 gspca_dev->usb_buf[2] = ((sd->colors >> 2) & 0xf8) | 0x04;
387 reg_w(gspca_dev, 3);
388 }
389 return 0;
390}
391
392static int sd_getcolors(struct gspca_dev *gspca_dev, __s32 *val)
393{
394 struct sd *sd = (struct sd *) gspca_dev;
395
396 *val = sd->colors;
397 return 0;
398}
399
400static int sd_setgamma(struct gspca_dev *gspca_dev, __s32 val)
401{
402 struct sd *sd = (struct sd *) gspca_dev;
403
404 sd->gamma = val;
405 if (gspca_dev->streaming) {
406 gspca_dev->usb_buf[0] = 0x06;
407 gspca_dev->usb_buf[1] = val * 0x40;
408 reg_w(gspca_dev, 2);
409 }
410 return 0;
411}
412
413static int sd_getgamma(struct gspca_dev *gspca_dev, __s32 *val)
414{
415 struct sd *sd = (struct sd *) gspca_dev;
416
417 *val = sd->gamma;
418 return 0;
419}
420
421static int sd_setsharpness(struct gspca_dev *gspca_dev, __s32 val)
422{
423 struct sd *sd = (struct sd *) gspca_dev;
424
425 sd->sharpness = val;
426 if (gspca_dev->streaming) {
427 gspca_dev->usb_buf[0] = 0x67;
428 gspca_dev->usb_buf[1] = val * 4 + 3;
429 reg_w(gspca_dev, 2);
430 }
431 return 0;
432}
433
434static int sd_getsharpness(struct gspca_dev *gspca_dev, __s32 *val)
435{
436 struct sd *sd = (struct sd *) gspca_dev;
437
438 *val = sd->sharpness;
439 return 0;
440}
441
442static int sd_set_jcomp(struct gspca_dev *gspca_dev, 386static int sd_set_jcomp(struct gspca_dev *gspca_dev,
443 struct v4l2_jpegcompression *jcomp) 387 struct v4l2_jpegcompression *jcomp)
444{ 388{
@@ -471,7 +415,7 @@ static int sd_get_jcomp(struct gspca_dev *gspca_dev,
471static const struct sd_desc sd_desc = { 415static const struct sd_desc sd_desc = {
472 .name = MODULE_NAME, 416 .name = MODULE_NAME,
473 .ctrls = sd_ctrls, 417 .ctrls = sd_ctrls,
474 .nctrls = ARRAY_SIZE(sd_ctrls), 418 .nctrls = NCTRLS,
475 .config = sd_config, 419 .config = sd_config,
476 .init = sd_init, 420 .init = sd_init,
477 .start = sd_start, 421 .start = sd_start,