Commit 3ebd1794 authored by Jean-François Moine's avatar Jean-François Moine Committed by Mauro Carvalho Chehab

[media] gspca - sq930x: Don't register a webcam when there are USB errors

Signed-off-by: default avatarJean-François Moine <moinejf@free.fr>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent 634b4770
...@@ -687,10 +687,12 @@ static void cmos_probe(struct gspca_dev *gspca_dev) ...@@ -687,10 +687,12 @@ static void cmos_probe(struct gspca_dev *gspca_dev)
if (gspca_dev->usb_buf[0] != 0) if (gspca_dev->usb_buf[0] != 0)
break; break;
} }
if (i >= ARRAY_SIZE(probe_order)) if (i >= ARRAY_SIZE(probe_order)) {
err("Unknown sensor"); err("Unknown sensor");
else gspca_dev->usb_err = -EINVAL;
sd->sensor = probe_order[i]; return;
}
sd->sensor = probe_order[i];
} }
static void mt9v111_init(struct gspca_dev *gspca_dev) static void mt9v111_init(struct gspca_dev *gspca_dev)
...@@ -867,6 +869,9 @@ static int sd_init(struct gspca_dev *gspca_dev) ...@@ -867,6 +869,9 @@ static int sd_init(struct gspca_dev *gspca_dev)
*/ */
reg_r(gspca_dev, SQ930_CTRL_GET_DEV_INFO, 8); reg_r(gspca_dev, SQ930_CTRL_GET_DEV_INFO, 8);
if (gspca_dev->usb_err < 0)
return gspca_dev->usb_err;
/* it returns: /* it returns:
* 03 00 12 93 0b f6 c9 00 live! ultra * 03 00 12 93 0b f6 c9 00 live! ultra
* 03 00 07 93 0b f6 ca 00 live! ultra for notebook * 03 00 07 93 0b f6 ca 00 live! ultra for notebook
...@@ -905,10 +910,10 @@ static int sd_init(struct gspca_dev *gspca_dev) ...@@ -905,10 +910,10 @@ static int sd_init(struct gspca_dev *gspca_dev)
else else
cmos_probe(gspca_dev); cmos_probe(gspca_dev);
} }
if (gspca_dev->usb_err >= 0) {
PDEBUG(D_PROBE, "Sensor %s", sensor_tb[sd->sensor].name); PDEBUG(D_PROBE, "Sensor %s", sensor_tb[sd->sensor].name);
global_init(sd, 1);
global_init(sd, 1); }
return gspca_dev->usb_err; return gspca_dev->usb_err;
} }
......
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