V4L/DVB (13143): gspca_ov519 cleanup sensor detection

gspca_ov519 cleanup sensor detection

Signed-off-by: Hans de Goede <hdegoede@redhat.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
This commit is contained in:
Hans de Goede 2009-10-11 07:41:46 -03:00 committed by Mauro Carvalho Chehab
parent d76f975c57
commit 229bb7dc51
1 changed files with 23 additions and 32 deletions

View File

@ -416,6 +416,7 @@ static const struct v4l2_pix_format ov511_sif_mode[] = {
/* I2C ADDRESSES */
#define OV7xx0_SID 0x42
#define OV_HIRES_SID 0x60 /* OV9xxx / OV2xxx / OV3xxx */
#define OV8xx0_SID 0xa0
#define OV6xx0_SID 0xc0
@ -1423,13 +1424,18 @@ static inline int ov51x_restart(struct sd *sd)
return 0;
}
static int ov51x_set_slave_ids(struct sd *sd, __u8 slave);
/* This does an initial reset of an OmniVision sensor and ensures that I2C
* is synchronized. Returns <0 on failure.
*/
static int init_ov_sensor(struct sd *sd)
static int init_ov_sensor(struct sd *sd, __u8 slave)
{
int i;
if (ov51x_set_slave_ids(sd, slave) < 0)
return -EIO;
/* Reset the sensor */
if (i2c_w(sd, 0x12, 0x80) < 0)
return -EIO;
@ -1996,46 +2002,31 @@ static int sd_config(struct gspca_dev *gspca_dev,
ov51x_led_control(sd, 0); /* turn LED off */
/* Test for 76xx */
if (ov51x_set_slave_ids(sd, OV7xx0_SID) < 0)
goto error;
/* The OV519 must be more aggressive about sensor detection since
* I2C write will never fail if the sensor is not present. We have
* to try to initialize the sensor to detect its presence */
if (init_ov_sensor(sd) >= 0) {
/* Test for 76xx */
if (init_ov_sensor(sd, OV7xx0_SID) >= 0) {
if (ov7xx0_configure(sd) < 0) {
PDEBUG(D_ERR, "Failed to configure OV7xx0");
goto error;
}
} else {
/* Test for 6xx0 */
if (ov51x_set_slave_ids(sd, OV6xx0_SID) < 0)
/* Test for 6xx0 */
} else if (init_ov_sensor(sd, OV6xx0_SID) >= 0) {
if (ov6xx0_configure(sd) < 0) {
PDEBUG(D_ERR, "Failed to configure OV6xx0");
goto error;
if (init_ov_sensor(sd) >= 0) {
if (ov6xx0_configure(sd) < 0) {
PDEBUG(D_ERR, "Failed to configure OV6xx0");
goto error;
}
} else {
/* Test for 8xx0 */
if (ov51x_set_slave_ids(sd, OV8xx0_SID) < 0)
goto error;
if (init_ov_sensor(sd) < 0) {
PDEBUG(D_ERR,
"Can't determine sensor slave IDs");
goto error;
}
if (ov8xx0_configure(sd) < 0) {
PDEBUG(D_ERR,
"Failed to configure OV8xx0 sensor");
goto error;
}
}
/* Test for 8xx0 */
} else if (init_ov_sensor(sd, OV8xx0_SID) >= 0) {
if (ov8xx0_configure(sd) < 0) {
PDEBUG(D_ERR, "Failed to configure OV8xx0");
goto error;
}
} else {
PDEBUG(D_ERR, "Can't determine sensor slave IDs");
goto error;
}
cam = &gspca_dev->cam;