Commit b4a5916e authored by Tomas Winkler's avatar Tomas Winkler Committed by Greg Kroah-Hartman

staging/easycap: revamp inputset population code

make inputset population to be more compact and readable

Cc: Mike Thomas <rmthomas@sciolus.org>
Signed-off-by: default avatarTomas Winkler <tomas.winkler@intel.com>
Reviewed-by: default avatarDan Carpenter <error27@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent e03da5e2
...@@ -3177,6 +3177,8 @@ static int easycap_usb_probe(struct usb_interface *pusb_interface, ...@@ -3177,6 +3177,8 @@ static int easycap_usb_probe(struct usb_interface *pusb_interface,
u16 mask; u16 mask;
s32 value; s32 value;
struct easycap_format *peasycap_format; struct easycap_format *peasycap_format;
int fmtidx;
struct inputset *inputset;
/*vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv*/ /*vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv*/
#ifdef EASYCAP_IS_VIDEODEV_CLIENT #ifdef EASYCAP_IS_VIDEODEV_CLIENT
struct v4l2_device *pv4l2_device; struct v4l2_device *pv4l2_device;
...@@ -3345,116 +3347,87 @@ static int easycap_usb_probe(struct usb_interface *pusb_interface, ...@@ -3345,116 +3347,87 @@ static int easycap_usb_probe(struct usb_interface *pusb_interface,
* ... AND POPULATE easycap.inputset[] * ... AND POPULATE easycap.inputset[]
*/ */
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
/* FIXME: maybe we just use memset 0 */
inputset = peasycap->inputset;
for (k = 0; k < INPUT_MANY; k++) { for (k = 0; k < INPUT_MANY; k++) {
peasycap->inputset[k].input_ok = 0; inputset[k].input_ok = 0;
peasycap->inputset[k].standard_offset_ok = 0; inputset[k].standard_offset_ok = 0;
peasycap->inputset[k].format_offset_ok = 0; inputset[k].format_offset_ok = 0;
peasycap->inputset[k].brightness_ok = 0; inputset[k].brightness_ok = 0;
peasycap->inputset[k].contrast_ok = 0; inputset[k].contrast_ok = 0;
peasycap->inputset[k].saturation_ok = 0; inputset[k].saturation_ok = 0;
peasycap->inputset[k].hue_ok = 0; inputset[k].hue_ok = 0;
} }
if (true == peasycap->ntsc) {
i = 0; fmtidx = peasycap->ntsc ? NTSC_M : PAL_BGHIN;
m = 0; m = 0;
mask = 0; mask = 0;
while (0xFFFF != easycap_standard[i].mask) { for (i = 0; 0xFFFF != easycap_standard[i].mask; i++) {
if (NTSC_M == easycap_standard[i]. if (fmtidx == easycap_standard[i].v4l2_standard.index) {
v4l2_standard.index) { m++;
m++; for (k = 0; k < INPUT_MANY; k++)
for (k = 0; k < INPUT_MANY; k++) { inputset[k].standard_offset = i;
peasycap->inputset[k].
standard_offset = i;
}
mask = easycap_standard[i].mask;
}
i++;
}
} else {
i = 0;
m = 0;
mask = 0;
while (0xFFFF != easycap_standard[i].mask) {
if (PAL_BGHIN == easycap_standard[i].
v4l2_standard.index) {
m++;
for (k = 0; k < INPUT_MANY; k++) {
peasycap->inputset[k].
standard_offset = i;
}
mask = easycap_standard[i].mask; mask = easycap_standard[i].mask;
}
i++;
} }
} }
if (1 != m) { if (1 != m) {
SAM("MISTAKE: easycap.inputset[].standard_offset " SAM("ERROR: "
"unpopulated, %i=m\n", m); "inputset->standard_offset unpopulated, %i=m\n", m);
return -ENOENT; return -ENOENT;
} }
peasycap_format = &easycap_format[0]; peasycap_format = &easycap_format[0];
i = 0;
m = 0; m = 0;
while (0 != peasycap_format->v4l2_format.fmt.pix.width) { for (i = 0; peasycap_format->v4l2_format.fmt.pix.width; i++) {
struct v4l2_pix_format *pix =
&peasycap_format->v4l2_format.fmt.pix;
if (((peasycap_format->mask & 0x0F) == (mask & 0x0F)) && if (((peasycap_format->mask & 0x0F) == (mask & 0x0F)) &&
(peasycap_format-> pix->field == V4L2_FIELD_NONE &&
v4l2_format.fmt.pix.field == pix->pixelformat == V4L2_PIX_FMT_UYVY &&
V4L2_FIELD_NONE) && pix->width == 640 && pix->height == 480) {
(peasycap_format->
v4l2_format.fmt.pix.pixelformat ==
V4L2_PIX_FMT_UYVY) &&
(peasycap_format->
v4l2_format.fmt.pix.width ==
640) &&
(peasycap_format->
v4l2_format.fmt.pix.height == 480)) {
m++; m++;
for (k = 0; k < INPUT_MANY; k++) for (k = 0; k < INPUT_MANY; k++)
peasycap->inputset[k].format_offset = i; inputset[k].format_offset = i;
break; break;
} }
peasycap_format++; peasycap_format++;
i++;
} }
if (1 != m) { if (1 != m) {
SAM("MISTAKE: easycap.inputset[].format_offset unpopulated\n"); SAM("ERROR: inputset[]->format_offset unpopulated\n");
return -ENOENT; return -ENOENT;
} }
i = 0;
m = 0; m = 0;
while (0xFFFFFFFF != easycap_control[i].id) { for (i = 0; 0xFFFFFFFF != easycap_control[i].id; i++) {
value = easycap_control[i].default_value; value = easycap_control[i].default_value;
if (V4L2_CID_BRIGHTNESS == easycap_control[i].id) { if (V4L2_CID_BRIGHTNESS == easycap_control[i].id) {
m++; m++;
for (k = 0; k < INPUT_MANY; k++) for (k = 0; k < INPUT_MANY; k++)
peasycap->inputset[k].brightness = value; inputset[k].brightness = value;
} else if (V4L2_CID_CONTRAST == easycap_control[i].id) { } else if (V4L2_CID_CONTRAST == easycap_control[i].id) {
m++; m++;
for (k = 0; k < INPUT_MANY; k++) for (k = 0; k < INPUT_MANY; k++)
peasycap->inputset[k].contrast = value; inputset[k].contrast = value;
} else if (V4L2_CID_SATURATION == easycap_control[i].id) { } else if (V4L2_CID_SATURATION == easycap_control[i].id) {
m++; m++;
for (k = 0; k < INPUT_MANY; k++) for (k = 0; k < INPUT_MANY; k++)
peasycap->inputset[k].saturation = value; inputset[k].saturation = value;
} else if (V4L2_CID_HUE == easycap_control[i].id) { } else if (V4L2_CID_HUE == easycap_control[i].id) {
m++; m++;
for (k = 0; k < INPUT_MANY; k++) for (k = 0; k < INPUT_MANY; k++)
peasycap->inputset[k].hue = value; inputset[k].hue = value;
} }
i++;
} }
if (4 != m) { if (4 != m) {
SAM("MISTAKE: easycap.inputset[].brightness,... " SAM("ERROR: inputset[]->brightness underpopulated\n");
"underpopulated\n");
return -ENOENT; return -ENOENT;
} }
for (k = 0; k < INPUT_MANY; k++) for (k = 0; k < INPUT_MANY; k++)
peasycap->inputset[k].input = k; inputset[k].input = k;
JOM(4, "populated easycap.inputset[]\n"); JOM(4, "populated inputset[]\n");
JOM(4, "finished initialization\n"); JOM(4, "finished initialization\n");
} else { } else {
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment