Commit edbfbdb3 authored by Erik Andrén's avatar Erik Andrén Committed by Mauro Carvalho Chehab

V4L/DVB (10018): gspca - m5602 - ov9650: Use generic read_sensor function

Toggle read sensor sequence depending on type of sensor. Check that no
more than max width of a sensor is read.
Signed-off-by: default avatarErik Andrén <erik.andren@gmail.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent e7a7f510
...@@ -85,9 +85,14 @@ int m5602_read_sensor(struct sd *sd, const u8 address, ...@@ -85,9 +85,14 @@ int m5602_read_sensor(struct sd *sd, const u8 address,
{ {
int err, i; int err, i;
if (!len || len > sd->sensor->i2c_regW)
return -EINVAL;
do { do {
err = m5602_read_bridge(sd, M5602_XB_I2C_STATUS, i2c_data); err = m5602_read_bridge(sd, M5602_XB_I2C_STATUS, i2c_data);
} while ((*i2c_data & I2C_BUSY) && !err); } while ((*i2c_data & I2C_BUSY) && !err);
if (err < 0)
goto out;
err = m5602_write_bridge(sd, M5602_XB_I2C_DEV_ADDR, err = m5602_write_bridge(sd, M5602_XB_I2C_DEV_ADDR,
sd->sensor->i2c_slave_id); sd->sensor->i2c_slave_id);
...@@ -98,13 +103,19 @@ int m5602_read_sensor(struct sd *sd, const u8 address, ...@@ -98,13 +103,19 @@ int m5602_read_sensor(struct sd *sd, const u8 address,
if (err < 0) if (err < 0)
goto out; goto out;
err = m5602_write_bridge(sd, M5602_XB_I2C_CTRL, 0x10 + len); if (sd->sensor->i2c_regW == 1) {
if (err < 0) err = m5602_write_bridge(sd, M5602_XB_I2C_CTRL, len);
goto out; if (err < 0)
goto out;
err = m5602_write_bridge(sd, M5602_XB_I2C_CTRL, 0x08); err = m5602_write_bridge(sd, M5602_XB_I2C_CTRL, 0x08);
if (err < 0) if (err < 0)
goto out; goto out;
} else {
err = m5602_write_bridge(sd, M5602_XB_I2C_CTRL, 0x18 + len);
if (err < 0)
goto out;
}
for (i = 0; (i < len) && !err; i++) { for (i = 0; (i < len) && !err; i++) {
err = m5602_read_bridge(sd, M5602_XB_I2C_DATA, &(i2c_data[i])); err = m5602_read_bridge(sd, M5602_XB_I2C_DATA, &(i2c_data[i]));
......
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