提交 cc043428 编写于 作者: H Hans de Goede 提交者: Mauro Carvalho Chehab

V4L/DVB (9685): gspca: Correct restart of webcams in spca501.

Currently the spca501 driver only works the first time used, then the cam needs
to be unplugged or the driver reloaded, this is because currently the data
which should be send each time the stream is started is send only once.
Likewise currently the data to initialize the cam is send from the probe
function, and thus will not get send after a suspend/resume.
This patch fixes this by sending both at the right time.
Signed-off-by: NHans de Goede <hdegoede@redhat.com>
Signed-off-by: NJean-Francois Moine <moinejf@free.fr>
Signed-off-by: NMauro Carvalho Chehab <mchehab@redhat.com>
上级 dff369aa
...@@ -1930,6 +1930,14 @@ static int sd_config(struct gspca_dev *gspca_dev, ...@@ -1930,6 +1930,14 @@ static int sd_config(struct gspca_dev *gspca_dev,
sd->contrast = sd_ctrls[MY_CONTRAST].qctrl.default_value; sd->contrast = sd_ctrls[MY_CONTRAST].qctrl.default_value;
sd->colors = sd_ctrls[MY_COLOR].qctrl.default_value; sd->colors = sd_ctrls[MY_COLOR].qctrl.default_value;
return 0;
}
/* this function is called at probe and resume time */
static int sd_init(struct gspca_dev *gspca_dev)
{
struct sd *sd = (struct sd *) gspca_dev;
switch (sd->subtype) { switch (sd->subtype) {
case Arowana300KCMOSCamera: case Arowana300KCMOSCamera:
case SmileIntlCamera: case SmileIntlCamera:
...@@ -1948,15 +1956,17 @@ static int sd_config(struct gspca_dev *gspca_dev, ...@@ -1948,15 +1956,17 @@ static int sd_config(struct gspca_dev *gspca_dev,
goto error; goto error;
break; break;
} }
PDEBUG(D_STREAM, "Initializing SPCA501 finished");
return 0; return 0;
error: error:
return -EINVAL; return -EINVAL;
} }
/* this function is called at probe and resume time */ static int sd_start(struct gspca_dev *gspca_dev)
static int sd_init(struct gspca_dev *gspca_dev)
{ {
struct sd *sd = (struct sd *) gspca_dev; struct sd *sd = (struct sd *) gspca_dev;
struct usb_device *dev = gspca_dev->dev;
int mode;
switch (sd->subtype) { switch (sd->subtype) {
case ThreeComHomeConnectLite: case ThreeComHomeConnectLite:
...@@ -1976,14 +1986,6 @@ static int sd_init(struct gspca_dev *gspca_dev) ...@@ -1976,14 +1986,6 @@ static int sd_init(struct gspca_dev *gspca_dev)
/* Generic 501 open data */ /* Generic 501 open data */
write_vector(gspca_dev, spca501_open_data); write_vector(gspca_dev, spca501_open_data);
} }
PDEBUG(D_STREAM, "Initializing SPCA501 finished");
return 0;
}
static int sd_start(struct gspca_dev *gspca_dev)
{
struct usb_device *dev = gspca_dev->dev;
int mode;
/* memorize the wanted pixel format */ /* memorize the wanted pixel format */
mode = gspca_dev->cam.cam_mode[(int) gspca_dev->curr_mode].priv; mode = gspca_dev->cam.cam_mode[(int) gspca_dev->curr_mode].priv;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册