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

V4L/DVB (10012): m5602: Start to unify read/write sensor functions

First step into unifying the read and write sensor functions
Signed-off-by: default avatarErik Andrén <erik.andren@gmail.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent d58626c2
...@@ -80,6 +80,50 @@ int m5602_write_bridge(struct sd *sd, u8 address, u8 i2c_data) ...@@ -80,6 +80,50 @@ int m5602_write_bridge(struct sd *sd, u8 address, u8 i2c_data)
return (err < 0) ? err : 0; return (err < 0) ? err : 0;
} }
int m5602_write_sensor(struct sd *sd, const u8 address,
u8 *i2c_data, const u8 len)
{
int err, i;
u8 *p;
struct usb_device *udev = sd->gspca_dev.dev;
__u8 *buf = sd->gspca_dev.usb_buf;
/* No sensor with a data width larger than 16 bits has yet been seen */
if (len > sd->sensor->i2c_regW || !len)
return -EINVAL;
memcpy(buf, sensor_urb_skeleton,
sizeof(sensor_urb_skeleton));
buf[11] = sd->sensor->i2c_slave_id;
buf[15] = address;
/* Special case larger sensor writes */
p = buf + 16;
/* Copy a four byte write sequence for each byte to be written to */
for (i = 0; i < len; i++) {
memcpy(p, sensor_urb_skeleton + 16, 4);
p[3] = i2c_data[i];
p += 4;
PDEBUG(D_CONF, "Writing sensor register 0x%x with 0x%x",
address, i2c_data[i]);
}
/* Copy the tailer */
memcpy(p, sensor_urb_skeleton + 20, 4);
/* Set the total length */
p[3] = 0x10 + len;
err = usb_control_msg(udev, usb_sndctrlpipe(udev, 0),
0x04, 0x40, 0x19,
0x0000, buf,
20 + len * 4, M5602_URB_MSG_TIMEOUT);
return (err < 0) ? err : 0;
}
/* Dump all the registers of the m5602 bridge, /* Dump all the registers of the m5602 bridge,
unfortunately this breaks the camera until it's power cycled */ unfortunately this breaks the camera until it's power cycled */
static void m5602_dump_bridge(struct sd *sd) static void m5602_dump_bridge(struct sd *sd)
......
...@@ -104,6 +104,7 @@ static struct m5602_sensor mt9m111 = { ...@@ -104,6 +104,7 @@ static struct m5602_sensor mt9m111 = {
.name = "MT9M111", .name = "MT9M111",
.i2c_slave_id = 0xba, .i2c_slave_id = 0xba,
.i2c_regW = 2,
.probe = mt9m111_probe, .probe = mt9m111_probe,
.init = mt9m111_init, .init = mt9m111_init,
......
...@@ -153,6 +153,7 @@ int ov9650_set_auto_gain(struct gspca_dev *gspca_dev, __s32 val); ...@@ -153,6 +153,7 @@ int ov9650_set_auto_gain(struct gspca_dev *gspca_dev, __s32 val);
static struct m5602_sensor ov9650 = { static struct m5602_sensor ov9650 = {
.name = "OV9650", .name = "OV9650",
.i2c_slave_id = 0x60, .i2c_slave_id = 0x60,
.i2c_regW = 1,
.probe = ov9650_probe, .probe = ov9650_probe,
.init = ov9650_init, .init = ov9650_init,
.power_down = ov9650_power_down, .power_down = ov9650_power_down,
......
...@@ -150,6 +150,7 @@ static struct m5602_sensor po1030 = { ...@@ -150,6 +150,7 @@ static struct m5602_sensor po1030 = {
.name = "PO1030", .name = "PO1030",
.i2c_slave_id = 0xdc, .i2c_slave_id = 0xdc,
.i2c_regW = 1,
.probe = po1030_probe, .probe = po1030_probe,
.init = po1030_init, .init = po1030_init,
......
...@@ -87,6 +87,7 @@ static struct m5602_sensor s5k4aa = { ...@@ -87,6 +87,7 @@ static struct m5602_sensor s5k4aa = {
.init = s5k4aa_init, .init = s5k4aa_init,
.power_down = s5k4aa_power_down, .power_down = s5k4aa_power_down,
.i2c_slave_id = 0x5a, .i2c_slave_id = 0x5a,
.i2c_regW = 2,
.nctrls = 4, .nctrls = 4,
.ctrls = { .ctrls = {
{ {
......
...@@ -69,6 +69,7 @@ static struct m5602_sensor s5k83a = { ...@@ -69,6 +69,7 @@ static struct m5602_sensor s5k83a = {
.init = s5k83a_init, .init = s5k83a_init,
.power_down = s5k83a_power_down, .power_down = s5k83a_power_down,
.i2c_slave_id = 0x5a, .i2c_slave_id = 0x5a,
.i2c_regW = 2,
.nctrls = 5, .nctrls = 5,
.ctrls = { .ctrls = {
{ {
......
...@@ -49,6 +49,9 @@ struct m5602_sensor { ...@@ -49,6 +49,9 @@ struct m5602_sensor {
/* What i2c address the sensor is connected to */ /* What i2c address the sensor is connected to */
u8 i2c_slave_id; u8 i2c_slave_id;
/* Width of each i2c register (in bytes) */
u8 i2c_regW;
/* Probes if the sensor is connected */ /* Probes if the sensor is connected */
int (*probe)(struct sd *sd); int (*probe)(struct sd *sd);
......
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