Commit c680dd60 authored by Trent Piepho's avatar Trent Piepho Committed by Mauro Carvalho Chehab

V4L/DVB (5502): Sn9c102: more efficient register writing code

There were many places in the driver which had long sequences of constant
register initializations.  These were done with one function call per
register.  The register address and value were immediate values in the
function calls.
This is very inefficient, as each register and value take twice the space
when they are code, as each includes a push instruction to put it on
the stack.  There there is the overhead, both size and time, for a
function call for each register.  It's also quite a few lines of C code
to do this.
The patch creates a function that writes multiple registers from a list,
and a macro that makes it easy to construct a such a list as a const
static local to send to the function.
This gets rid of quite a bit of C code, and shrinks the driver by around
8k, while at the same time being more efficient.
Acked-by: default avatarLuca Risolia <luca.risolia@studio.unibo.it>
Signed-off-by: default avatarTrent Piepho <xyzzy@speakeasy.org>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@infradead.org>
parent 0ee32871
...@@ -209,27 +209,40 @@ static void sn9c102_queue_unusedframes(struct sn9c102_device* cam) ...@@ -209,27 +209,40 @@ static void sn9c102_queue_unusedframes(struct sn9c102_device* cam)
} }
/*****************************************************************************/ /*****************************************************************************/
/*
int sn9c102_write_regs(struct sn9c102_device* cam, u8* buff, u16 index) * Write a sequence of count value/register pairs. Returns -1 after the
* first failed write, or 0 for no errors.
*/
int sn9c102_write_regs(struct sn9c102_device* cam, const u8 valreg[][2],
int count)
{ {
struct usb_device* udev = cam->usbdev; struct usb_device* udev = cam->usbdev;
u8* value = cam->control_buffer; /* Needed for DMA'able memory */
int i, res; int i, res;
if (index + sizeof(buff) >= ARRAY_SIZE(cam->reg)) for (i = 0; i < count; i++) {
return -1; u8 index = valreg[i][1];
/*
* index is a u8, so it must be <256 and can't be out of range.
* If we put in a check anyway, gcc annoys us with a warning
* that our check is useless. People get all uppity when they
* see warnings in the kernel compile.
*/
*value = valreg[i][0];
res = usb_control_msg(udev, usb_sndctrlpipe(udev, 0),
0x08, 0x41, index, 0,
value, 1, SN9C102_CTRL_TIMEOUT);
if (res < 0) {
DBG(3, "Failed to write a register (value 0x%02X, "
"index 0x%02X, error %d)", *value, index, res);
return -1;
}
res = usb_control_msg(udev, usb_sndctrlpipe(udev, 0), 0x08, 0x41, cam->reg[index] = *value;
index, 0, buff, sizeof(buff),
SN9C102_CTRL_TIMEOUT*sizeof(buff));
if (res < 0) {
DBG(3, "Failed to write registers (index 0x%02X, error %d)",
index, res);
return -1;
} }
for (i = 0; i < sizeof(buff); i++)
cam->reg[index+i] = buff[i];
return 0; return 0;
} }
......
...@@ -24,14 +24,11 @@ ...@@ -24,14 +24,11 @@
static int hv7131d_init(struct sn9c102_device* cam) static int hv7131d_init(struct sn9c102_device* cam)
{ {
int err = 0; int err;
err += sn9c102_write_reg(cam, 0x00, 0x10); err = sn9c102_write_const_regs(cam, {0x00, 0x10}, {0x00, 0x11},
err += sn9c102_write_reg(cam, 0x00, 0x11); {0x00, 0x14}, {0x60, 0x17},
err += sn9c102_write_reg(cam, 0x00, 0x14); {0x0e, 0x18}, {0xf2, 0x19});
err += sn9c102_write_reg(cam, 0x60, 0x17);
err += sn9c102_write_reg(cam, 0x0e, 0x18);
err += sn9c102_write_reg(cam, 0xf2, 0x19);
err += sn9c102_i2c_write(cam, 0x01, 0x04); err += sn9c102_i2c_write(cam, 0x01, 0x04);
err += sn9c102_i2c_write(cam, 0x02, 0x00); err += sn9c102_i2c_write(cam, 0x02, 0x00);
...@@ -247,11 +244,10 @@ static struct sn9c102_sensor hv7131d = { ...@@ -247,11 +244,10 @@ static struct sn9c102_sensor hv7131d = {
int sn9c102_probe_hv7131d(struct sn9c102_device* cam) int sn9c102_probe_hv7131d(struct sn9c102_device* cam)
{ {
int r0 = 0, r1 = 0, err = 0; int r0 = 0, r1 = 0, err;
err += sn9c102_write_reg(cam, 0x01, 0x01); err = sn9c102_write_const_regs(cam, {0x01, 0x01}, {0x00, 0x01},
err += sn9c102_write_reg(cam, 0x00, 0x01); {0x28, 0x17});
err += sn9c102_write_reg(cam, 0x28, 0x17);
if (err) if (err)
return -EIO; return -EIO;
......
...@@ -27,13 +27,10 @@ static int mi0343_init(struct sn9c102_device* cam) ...@@ -27,13 +27,10 @@ static int mi0343_init(struct sn9c102_device* cam)
struct sn9c102_sensor* s = sn9c102_get_sensor(cam); struct sn9c102_sensor* s = sn9c102_get_sensor(cam);
int err = 0; int err = 0;
err += sn9c102_write_reg(cam, 0x00, 0x10); err = sn9c102_write_const_regs(cam, {0x00, 0x10}, {0x00, 0x11},
err += sn9c102_write_reg(cam, 0x00, 0x11); {0x0a, 0x14}, {0x40, 0x01},
err += sn9c102_write_reg(cam, 0x0a, 0x14); {0x20, 0x17}, {0x07, 0x18},
err += sn9c102_write_reg(cam, 0x40, 0x01); {0xa0, 0x19});
err += sn9c102_write_reg(cam, 0x20, 0x17);
err += sn9c102_write_reg(cam, 0x07, 0x18);
err += sn9c102_write_reg(cam, 0xa0, 0x19);
err += sn9c102_i2c_try_raw_write(cam, s, 4, s->i2c_slave_id, 0x0d, err += sn9c102_i2c_try_raw_write(cam, s, 4, s->i2c_slave_id, 0x0d,
0x00, 0x01, 0, 0); 0x00, 0x01, 0, 0);
...@@ -338,9 +335,9 @@ int sn9c102_probe_mi0343(struct sn9c102_device* cam) ...@@ -338,9 +335,9 @@ int sn9c102_probe_mi0343(struct sn9c102_device* cam)
u8 data[5+1]; u8 data[5+1];
int err = 0; int err = 0;
err += sn9c102_write_reg(cam, 0x01, 0x01); err = sn9c102_write_const_regs(cam, {0x01, 0x01}, {0x00, 0x01},
err += sn9c102_write_reg(cam, 0x00, 0x01); {0x28, 0x17});
err += sn9c102_write_reg(cam, 0x28, 0x17);
if (err) if (err)
return -EIO; return -EIO;
......
...@@ -27,34 +27,20 @@ static int mi0360_init(struct sn9c102_device* cam) ...@@ -27,34 +27,20 @@ static int mi0360_init(struct sn9c102_device* cam)
struct sn9c102_sensor* s = sn9c102_get_sensor(cam); struct sn9c102_sensor* s = sn9c102_get_sensor(cam);
int err = 0; int err = 0;
err += sn9c102_write_reg(cam, 0x00, 0x10); err = sn9c102_write_const_regs(cam, {0x00, 0x10}, {0x00, 0x11},
err += sn9c102_write_reg(cam, 0x00, 0x11); {0x0a, 0x14}, {0x40, 0x01},
err += sn9c102_write_reg(cam, 0x0a, 0x14); {0x20, 0x17}, {0x07, 0x18},
err += sn9c102_write_reg(cam, 0x40, 0x01); {0xa0, 0x19}, {0x02, 0x1c},
err += sn9c102_write_reg(cam, 0x20, 0x17); {0x03, 0x1d}, {0x0f, 0x1e},
err += sn9c102_write_reg(cam, 0x07, 0x18); {0x0c, 0x1f}, {0x00, 0x20},
err += sn9c102_write_reg(cam, 0xa0, 0x19); {0x10, 0x21}, {0x20, 0x22},
err += sn9c102_write_reg(cam, 0x02, 0x1c); {0x30, 0x23}, {0x40, 0x24},
err += sn9c102_write_reg(cam, 0x03, 0x1d); {0x50, 0x25}, {0x60, 0x26},
err += sn9c102_write_reg(cam, 0x0f, 0x1e); {0x70, 0x27}, {0x80, 0x28},
err += sn9c102_write_reg(cam, 0x0c, 0x1f); {0x90, 0x29}, {0xa0, 0x2a},
err += sn9c102_write_reg(cam, 0x00, 0x20); {0xb0, 0x2b}, {0xc0, 0x2c},
err += sn9c102_write_reg(cam, 0x10, 0x21); {0xd0, 0x2d}, {0xe0, 0x2e},
err += sn9c102_write_reg(cam, 0x20, 0x22); {0xf0, 0x2f}, {0xff, 0x30});
err += sn9c102_write_reg(cam, 0x30, 0x23);
err += sn9c102_write_reg(cam, 0x40, 0x24);
err += sn9c102_write_reg(cam, 0x50, 0x25);
err += sn9c102_write_reg(cam, 0x60, 0x26);
err += sn9c102_write_reg(cam, 0x70, 0x27);
err += sn9c102_write_reg(cam, 0x80, 0x28);
err += sn9c102_write_reg(cam, 0x90, 0x29);
err += sn9c102_write_reg(cam, 0xa0, 0x2a);
err += sn9c102_write_reg(cam, 0xb0, 0x2b);
err += sn9c102_write_reg(cam, 0xc0, 0x2c);
err += sn9c102_write_reg(cam, 0xd0, 0x2d);
err += sn9c102_write_reg(cam, 0xe0, 0x2e);
err += sn9c102_write_reg(cam, 0xf0, 0x2f);
err += sn9c102_write_reg(cam, 0xff, 0x30);
err += sn9c102_i2c_try_raw_write(cam, s, 4, s->i2c_slave_id, 0x0d, err += sn9c102_i2c_try_raw_write(cam, s, 4, s->i2c_slave_id, 0x0d,
0x00, 0x01, 0, 0); 0x00, 0x01, 0, 0);
...@@ -332,11 +318,10 @@ static struct sn9c102_sensor mi0360 = { ...@@ -332,11 +318,10 @@ static struct sn9c102_sensor mi0360 = {
int sn9c102_probe_mi0360(struct sn9c102_device* cam) int sn9c102_probe_mi0360(struct sn9c102_device* cam)
{ {
u8 data[5+1]; u8 data[5+1];
int err = 0; int err;
err += sn9c102_write_reg(cam, 0x01, 0x01); err = sn9c102_write_const_regs(cam, {0x01, 0x01}, {0x00, 0x01},
err += sn9c102_write_reg(cam, 0x00, 0x01); {0x28, 0x17});
err += sn9c102_write_reg(cam, 0x28, 0x17);
if (err) if (err)
return -EIO; return -EIO;
......
...@@ -29,10 +29,9 @@ static int ov7630_init(struct sn9c102_device* cam) ...@@ -29,10 +29,9 @@ static int ov7630_init(struct sn9c102_device* cam)
switch (sn9c102_get_bridge(cam)) { switch (sn9c102_get_bridge(cam)) {
case BRIDGE_SN9C101: case BRIDGE_SN9C101:
case BRIDGE_SN9C102: case BRIDGE_SN9C102:
err += sn9c102_write_reg(cam, 0x00, 0x14); err = sn9c102_write_const_regs(cam, {0x00, 0x14},
err += sn9c102_write_reg(cam, 0x60, 0x17); {0x60, 0x17}, {0x0f, 0x18},
err += sn9c102_write_reg(cam, 0x0f, 0x18); {0x50, 0x19});
err += sn9c102_write_reg(cam, 0x50, 0x19);
err += sn9c102_i2c_write(cam, 0x12, 0x8d); err += sn9c102_i2c_write(cam, 0x12, 0x8d);
err += sn9c102_i2c_write(cam, 0x12, 0x0d); err += sn9c102_i2c_write(cam, 0x12, 0x0d);
...@@ -62,42 +61,26 @@ static int ov7630_init(struct sn9c102_device* cam) ...@@ -62,42 +61,26 @@ static int ov7630_init(struct sn9c102_device* cam)
err += sn9c102_i2c_write(cam, 0x71, 0x00); err += sn9c102_i2c_write(cam, 0x71, 0x00);
err += sn9c102_i2c_write(cam, 0x74, 0x21); err += sn9c102_i2c_write(cam, 0x74, 0x21);
err += sn9c102_i2c_write(cam, 0x7d, 0xf7); err += sn9c102_i2c_write(cam, 0x7d, 0xf7);
break; break;
case BRIDGE_SN9C103: case BRIDGE_SN9C103:
err += sn9c102_write_reg(cam, 0x00, 0x02); err = sn9c102_write_const_regs(cam, {0x00, 0x02}, {0x00, 0x03},
err += sn9c102_write_reg(cam, 0x00, 0x03); {0x1a, 0x04}, {0x20, 0x05},
err += sn9c102_write_reg(cam, 0x1a, 0x04); {0x20, 0x06}, {0x20, 0x07},
err += sn9c102_write_reg(cam, 0x20, 0x05); {0x03, 0x10}, {0x0a, 0x14},
err += sn9c102_write_reg(cam, 0x20, 0x06); {0x60, 0x17}, {0x0f, 0x18},
err += sn9c102_write_reg(cam, 0x20, 0x07); {0x50, 0x19}, {0x1d, 0x1a},
err += sn9c102_write_reg(cam, 0x03, 0x10); {0x10, 0x1b}, {0x02, 0x1c},
err += sn9c102_write_reg(cam, 0x0a, 0x14); {0x03, 0x1d}, {0x0f, 0x1e},
err += sn9c102_write_reg(cam, 0x60, 0x17); {0x0c, 0x1f}, {0x00, 0x20},
err += sn9c102_write_reg(cam, 0x0f, 0x18); {0x10, 0x21}, {0x20, 0x22},
err += sn9c102_write_reg(cam, 0x50, 0x19); {0x30, 0x23}, {0x40, 0x24},
err += sn9c102_write_reg(cam, 0x1d, 0x1a); {0x50, 0x25}, {0x60, 0x26},
err += sn9c102_write_reg(cam, 0x10, 0x1b); {0x70, 0x27}, {0x80, 0x28},
err += sn9c102_write_reg(cam, 0x02, 0x1c); {0x90, 0x29}, {0xa0, 0x2a},
err += sn9c102_write_reg(cam, 0x03, 0x1d); {0xb0, 0x2b}, {0xc0, 0x2c},
err += sn9c102_write_reg(cam, 0x0f, 0x1e); {0xd0, 0x2d}, {0xe0, 0x2e},
err += sn9c102_write_reg(cam, 0x0c, 0x1f); {0xf0, 0x2f}, {0xff, 0x30});
err += sn9c102_write_reg(cam, 0x00, 0x20);
err += sn9c102_write_reg(cam, 0x10, 0x21);
err += sn9c102_write_reg(cam, 0x20, 0x22);
err += sn9c102_write_reg(cam, 0x30, 0x23);
err += sn9c102_write_reg(cam, 0x40, 0x24);
err += sn9c102_write_reg(cam, 0x50, 0x25);
err += sn9c102_write_reg(cam, 0x60, 0x26);
err += sn9c102_write_reg(cam, 0x70, 0x27);
err += sn9c102_write_reg(cam, 0x80, 0x28);
err += sn9c102_write_reg(cam, 0x90, 0x29);
err += sn9c102_write_reg(cam, 0xa0, 0x2a);
err += sn9c102_write_reg(cam, 0xb0, 0x2b);
err += sn9c102_write_reg(cam, 0xc0, 0x2c);
err += sn9c102_write_reg(cam, 0xd0, 0x2d);
err += sn9c102_write_reg(cam, 0xe0, 0x2e);
err += sn9c102_write_reg(cam, 0xf0, 0x2f);
err += sn9c102_write_reg(cam, 0xff, 0x30);
err += sn9c102_i2c_write(cam, 0x12, 0x8d); err += sn9c102_i2c_write(cam, 0x12, 0x8d);
err += sn9c102_i2c_write(cam, 0x12, 0x0d); err += sn9c102_i2c_write(cam, 0x12, 0x0d);
...@@ -425,15 +408,14 @@ int sn9c102_probe_ov7630(struct sn9c102_device* cam) ...@@ -425,15 +408,14 @@ int sn9c102_probe_ov7630(struct sn9c102_device* cam)
switch (sn9c102_get_bridge(cam)) { switch (sn9c102_get_bridge(cam)) {
case BRIDGE_SN9C101: case BRIDGE_SN9C101:
case BRIDGE_SN9C102: case BRIDGE_SN9C102:
err += sn9c102_write_reg(cam, 0x01, 0x01); err = sn9c102_write_const_regs(cam, {0x01, 0x01},
err += sn9c102_write_reg(cam, 0x00, 0x01); {0x00, 0x01}, {0x28, 0x17});
err += sn9c102_write_reg(cam, 0x28, 0x17);
break; break;
case BRIDGE_SN9C103: /* do _not_ change anything! */ case BRIDGE_SN9C103: /* do _not_ change anything! */
err += sn9c102_write_reg(cam, 0x09, 0x01); err = sn9c102_write_const_regs(cam, {0x09, 0x01},
err += sn9c102_write_reg(cam, 0x42, 0x01); {0x42, 0x01}, {0x28, 0x17},
err += sn9c102_write_reg(cam, 0x28, 0x17); {0x44, 0x02});
err += sn9c102_write_reg(cam, 0x44, 0x02);
pid = sn9c102_i2c_try_read(cam, &ov7630, 0x0a); pid = sn9c102_i2c_try_read(cam, &ov7630, 0x0a);
if (err || pid < 0) { /* try a different initialization */ if (err || pid < 0) { /* try a different initialization */
err = sn9c102_write_reg(cam, 0x01, 0x01); err = sn9c102_write_reg(cam, 0x01, 0x01);
......
...@@ -27,12 +27,9 @@ static int pas106b_init(struct sn9c102_device* cam) ...@@ -27,12 +27,9 @@ static int pas106b_init(struct sn9c102_device* cam)
{ {
int err = 0; int err = 0;
err += sn9c102_write_reg(cam, 0x00, 0x10); err = sn9c102_write_const_regs(cam, {0x00, 0x10}, {0x00, 0x11},
err += sn9c102_write_reg(cam, 0x00, 0x11); {0x00, 0x14}, {0x20, 0x17},
err += sn9c102_write_reg(cam, 0x00, 0x14); {0x20, 0x19}, {0x09, 0x18});
err += sn9c102_write_reg(cam, 0x20, 0x17);
err += sn9c102_write_reg(cam, 0x20, 0x19);
err += sn9c102_write_reg(cam, 0x09, 0x18);
err += sn9c102_i2c_write(cam, 0x02, 0x0c); err += sn9c102_i2c_write(cam, 0x02, 0x0c);
err += sn9c102_i2c_write(cam, 0x05, 0x5a); err += sn9c102_i2c_write(cam, 0x05, 0x5a);
...@@ -276,16 +273,17 @@ static struct sn9c102_sensor pas106b = { ...@@ -276,16 +273,17 @@ static struct sn9c102_sensor pas106b = {
int sn9c102_probe_pas106b(struct sn9c102_device* cam) int sn9c102_probe_pas106b(struct sn9c102_device* cam)
{ {
int r0 = 0, r1 = 0, err = 0; int r0 = 0, r1 = 0, err;
unsigned int pid = 0; unsigned int pid = 0;
/* /*
Minimal initialization to enable the I2C communication Minimal initialization to enable the I2C communication
NOTE: do NOT change the values! NOTE: do NOT change the values!
*/ */
err += sn9c102_write_reg(cam, 0x01, 0x01); /* sensor power down */ err = sn9c102_write_const_regs(cam,
err += sn9c102_write_reg(cam, 0x00, 0x01); /* sensor power on */ {0x01, 0x01}, /* sensor power down */
err += sn9c102_write_reg(cam, 0x28, 0x17); /* sensor clock at 24 MHz */ {0x00, 0x01}, /* sensor power on */
{0x28, 0x17});/* sensor clock 24 MHz */
if (err) if (err)
return -EIO; return -EIO;
......
...@@ -35,47 +35,29 @@ static int pas202bcb_init(struct sn9c102_device* cam) ...@@ -35,47 +35,29 @@ static int pas202bcb_init(struct sn9c102_device* cam)
switch (sn9c102_get_bridge(cam)) { switch (sn9c102_get_bridge(cam)) {
case BRIDGE_SN9C101: case BRIDGE_SN9C101:
case BRIDGE_SN9C102: case BRIDGE_SN9C102:
err += sn9c102_write_reg(cam, 0x00, 0x10); err = sn9c102_write_const_regs(cam, {0x00, 0x10},
err += sn9c102_write_reg(cam, 0x00, 0x11); {0x00, 0x11}, {0x00, 0x14},
err += sn9c102_write_reg(cam, 0x00, 0x14); {0x20, 0x17}, {0x30, 0x19},
err += sn9c102_write_reg(cam, 0x20, 0x17); {0x09, 0x18});
err += sn9c102_write_reg(cam, 0x30, 0x19);
err += sn9c102_write_reg(cam, 0x09, 0x18);
break; break;
case BRIDGE_SN9C103: case BRIDGE_SN9C103:
err += sn9c102_write_reg(cam, 0x00, 0x02); err = sn9c102_write_const_regs(cam, {0x00, 0x02},
err += sn9c102_write_reg(cam, 0x00, 0x03); {0x00, 0x03}, {0x1a, 0x04},
err += sn9c102_write_reg(cam, 0x1a, 0x04); {0x20, 0x05}, {0x20, 0x06},
err += sn9c102_write_reg(cam, 0x20, 0x05); {0x20, 0x07}, {0x00, 0x10},
err += sn9c102_write_reg(cam, 0x20, 0x06); {0x00, 0x11}, {0x00, 0x14},
err += sn9c102_write_reg(cam, 0x20, 0x07); {0x20, 0x17}, {0x30, 0x19},
err += sn9c102_write_reg(cam, 0x00, 0x10); {0x09, 0x18}, {0x02, 0x1c},
err += sn9c102_write_reg(cam, 0x00, 0x11); {0x03, 0x1d}, {0x0f, 0x1e},
err += sn9c102_write_reg(cam, 0x00, 0x14); {0x0c, 0x1f}, {0x00, 0x20},
err += sn9c102_write_reg(cam, 0x20, 0x17); {0x10, 0x21}, {0x20, 0x22},
err += sn9c102_write_reg(cam, 0x30, 0x19); {0x30, 0x23}, {0x40, 0x24},
err += sn9c102_write_reg(cam, 0x09, 0x18); {0x50, 0x25}, {0x60, 0x26},
err += sn9c102_write_reg(cam, 0x02, 0x1c); {0x70, 0x27}, {0x80, 0x28},
err += sn9c102_write_reg(cam, 0x03, 0x1d); {0x90, 0x29}, {0xa0, 0x2a},
err += sn9c102_write_reg(cam, 0x0f, 0x1e); {0xb0, 0x2b}, {0xc0, 0x2c},
err += sn9c102_write_reg(cam, 0x0c, 0x1f); {0xd0, 0x2d}, {0xe0, 0x2e},
err += sn9c102_write_reg(cam, 0x00, 0x20); {0xf0, 0x2f}, {0xff, 0x30});
err += sn9c102_write_reg(cam, 0x10, 0x21);
err += sn9c102_write_reg(cam, 0x20, 0x22);
err += sn9c102_write_reg(cam, 0x30, 0x23);
err += sn9c102_write_reg(cam, 0x40, 0x24);
err += sn9c102_write_reg(cam, 0x50, 0x25);
err += sn9c102_write_reg(cam, 0x60, 0x26);
err += sn9c102_write_reg(cam, 0x70, 0x27);
err += sn9c102_write_reg(cam, 0x80, 0x28);
err += sn9c102_write_reg(cam, 0x90, 0x29);
err += sn9c102_write_reg(cam, 0xa0, 0x2a);
err += sn9c102_write_reg(cam, 0xb0, 0x2b);
err += sn9c102_write_reg(cam, 0xc0, 0x2c);
err += sn9c102_write_reg(cam, 0xd0, 0x2d);
err += sn9c102_write_reg(cam, 0xe0, 0x2e);
err += sn9c102_write_reg(cam, 0xf0, 0x2f);
err += sn9c102_write_reg(cam, 0xff, 0x30);
break; break;
default: default:
break; break;
...@@ -325,15 +307,15 @@ int sn9c102_probe_pas202bcb(struct sn9c102_device* cam) ...@@ -325,15 +307,15 @@ int sn9c102_probe_pas202bcb(struct sn9c102_device* cam)
switch (sn9c102_get_bridge(cam)) { switch (sn9c102_get_bridge(cam)) {
case BRIDGE_SN9C101: case BRIDGE_SN9C101:
case BRIDGE_SN9C102: case BRIDGE_SN9C102:
err += sn9c102_write_reg(cam, 0x01, 0x01); /* power down */ err = sn9c102_write_const_regs(cam,
err += sn9c102_write_reg(cam, 0x40, 0x01); /* power on */ {0x01, 0x01}, /* power down */
err += sn9c102_write_reg(cam, 0x28, 0x17); /* clock 24 MHz */ {0x40, 0x01}, /* power on */
{0x28, 0x17});/* clock 24 MHz */
break; break;
case BRIDGE_SN9C103: /* do _not_ change anything! */ case BRIDGE_SN9C103: /* do _not_ change anything! */
err += sn9c102_write_reg(cam, 0x09, 0x01); err = sn9c102_write_const_regs(cam, {0x09, 0x01},
err += sn9c102_write_reg(cam, 0x44, 0x01); {0x44, 0x01}, {0x44, 0x02},
err += sn9c102_write_reg(cam, 0x44, 0x02); {0x29, 0x17});
err += sn9c102_write_reg(cam, 0x29, 0x17);
break; break;
default: default:
break; break;
......
...@@ -114,9 +114,17 @@ extern int sn9c102_i2c_write(struct sn9c102_device*, u8 address, u8 value); ...@@ -114,9 +114,17 @@ extern int sn9c102_i2c_write(struct sn9c102_device*, u8 address, u8 value);
extern int sn9c102_i2c_read(struct sn9c102_device*, u8 address); extern int sn9c102_i2c_read(struct sn9c102_device*, u8 address);
/* I/O on registers in the bridge. Could be used by the sensor methods too */ /* I/O on registers in the bridge. Could be used by the sensor methods too */
extern int sn9c102_write_regs(struct sn9c102_device*, u8* buff, u16 index);
extern int sn9c102_write_reg(struct sn9c102_device*, u8 value, u16 index);
extern int sn9c102_pread_reg(struct sn9c102_device*, u16 index); extern int sn9c102_pread_reg(struct sn9c102_device*, u16 index);
extern int sn9c102_write_reg(struct sn9c102_device*, u8 value, u16 index);
extern int sn9c102_write_regs(struct sn9c102_device*, const u8 valreg[][2],
int count);
/*
* Write multiple registers with constant values. For example:
* sn9c102_write_const_regs(cam, {0x00, 0x14}, {0x60, 0x17}, {0x0f, 0x18});
*/
#define sn9c102_write_const_regs(device, data...) \
({ const static u8 _data[][2] = {data}; \
sn9c102_write_regs(device, _data, ARRAY_SIZE(_data)); })
/*****************************************************************************/ /*****************************************************************************/
......
...@@ -26,14 +26,10 @@ static int tas5110c1b_init(struct sn9c102_device* cam) ...@@ -26,14 +26,10 @@ static int tas5110c1b_init(struct sn9c102_device* cam)
{ {
int err = 0; int err = 0;
err += sn9c102_write_reg(cam, 0x01, 0x01); err = sn9c102_write_const_regs(cam, {0x01, 0x01}, {0x44, 0x01},
err += sn9c102_write_reg(cam, 0x44, 0x01); {0x00, 0x10}, {0x00, 0x11},
err += sn9c102_write_reg(cam, 0x00, 0x10); {0x0a, 0x14}, {0x60, 0x17},
err += sn9c102_write_reg(cam, 0x00, 0x11); {0x06, 0x18}, {0xfb, 0x19});
err += sn9c102_write_reg(cam, 0x0a, 0x14);
err += sn9c102_write_reg(cam, 0x60, 0x17);
err += sn9c102_write_reg(cam, 0x06, 0x18);
err += sn9c102_write_reg(cam, 0xfb, 0x19);
err += sn9c102_i2c_write(cam, 0xc0, 0x80); err += sn9c102_i2c_write(cam, 0xc0, 0x80);
......
...@@ -24,14 +24,11 @@ ...@@ -24,14 +24,11 @@
static int tas5110d_init(struct sn9c102_device* cam) static int tas5110d_init(struct sn9c102_device* cam)
{ {
int err = 0; int err;
err += sn9c102_write_reg(cam, 0x01, 0x01); err = sn9c102_write_const_regs(cam, {0x01, 0x01}, {0x04, 0x01},
err += sn9c102_write_reg(cam, 0x04, 0x01); {0x0a, 0x14}, {0x60, 0x17},
err += sn9c102_write_reg(cam, 0x0a, 0x14); {0x06, 0x18}, {0xfb, 0x19});
err += sn9c102_write_reg(cam, 0x60, 0x17);
err += sn9c102_write_reg(cam, 0x06, 0x18);
err += sn9c102_write_reg(cam, 0xfb, 0x19);
err += sn9c102_i2c_write(cam, 0x9a, 0xca); err += sn9c102_i2c_write(cam, 0x9a, 0xca);
......
...@@ -24,16 +24,12 @@ ...@@ -24,16 +24,12 @@
static int tas5130d1b_init(struct sn9c102_device* cam) static int tas5130d1b_init(struct sn9c102_device* cam)
{ {
int err = 0; int err;
err += sn9c102_write_reg(cam, 0x01, 0x01); err = sn9c102_write_const_regs(cam, {0x01, 0x01}, {0x20, 0x17},
err += sn9c102_write_reg(cam, 0x20, 0x17); {0x04, 0x01}, {0x01, 0x10},
err += sn9c102_write_reg(cam, 0x04, 0x01); {0x00, 0x11}, {0x00, 0x14},
err += sn9c102_write_reg(cam, 0x01, 0x10); {0x60, 0x17}, {0x07, 0x18});
err += sn9c102_write_reg(cam, 0x00, 0x11);
err += sn9c102_write_reg(cam, 0x00, 0x14);
err += sn9c102_write_reg(cam, 0x60, 0x17);
err += sn9c102_write_reg(cam, 0x07, 0x18);
return err; return 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