Commit 89fc4eb9 authored by Hans Verkuil's avatar Hans Verkuil Committed by Mauro Carvalho Chehab

V4L/DVB (5993): cx25840: resetting also requires reloading the firmware

Resetting without reloading the firmware is not enough. Sometimes the
firmware is 'stuck' and needs to be reloaded.
Signed-off-by: default avatarHans Verkuil <hverkuil@xs4all.nl>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@infradead.org>
parent 94104aa2
...@@ -179,7 +179,7 @@ static void cx25836_initialize(struct i2c_client *client) ...@@ -179,7 +179,7 @@ static void cx25836_initialize(struct i2c_client *client)
cx25840_and_or(client, 0x15b, ~0x1e, 0x10); cx25840_and_or(client, 0x15b, ~0x1e, 0x10);
} }
static void cx25840_initialize(struct i2c_client *client, int loadfw) static void cx25840_initialize(struct i2c_client *client)
{ {
struct cx25840_state *state = i2c_get_clientdata(client); struct cx25840_state *state = i2c_get_clientdata(client);
...@@ -197,8 +197,7 @@ static void cx25840_initialize(struct i2c_client *client, int loadfw) ...@@ -197,8 +197,7 @@ static void cx25840_initialize(struct i2c_client *client, int loadfw)
cx25840_write(client, 0x13c, 0x01); cx25840_write(client, 0x13c, 0x01);
cx25840_write(client, 0x13c, 0x00); cx25840_write(client, 0x13c, 0x00);
/* 5. */ /* 5. */
if (loadfw) cx25840_loadfw(client);
cx25840_loadfw(client);
/* 6. */ /* 6. */
cx25840_write(client, 0x115, 0x8c); cx25840_write(client, 0x115, 0x8c);
cx25840_write(client, 0x116, 0x07); cx25840_write(client, 0x116, 0x07);
...@@ -638,7 +637,7 @@ static int cx25840_command(struct i2c_client *client, unsigned int cmd, ...@@ -638,7 +637,7 @@ static int cx25840_command(struct i2c_client *client, unsigned int cmd,
if (state->is_cx25836) if (state->is_cx25836)
cx25836_initialize(client); cx25836_initialize(client);
else else
cx25840_initialize(client, 1); cx25840_initialize(client);
} }
switch (cmd) { switch (cmd) {
...@@ -841,7 +840,7 @@ static int cx25840_command(struct i2c_client *client, unsigned int cmd, ...@@ -841,7 +840,7 @@ static int cx25840_command(struct i2c_client *client, unsigned int cmd,
if (state->is_cx25836) if (state->is_cx25836)
cx25836_initialize(client); cx25836_initialize(client);
else else
cx25840_initialize(client, 0); cx25840_initialize(client);
break; break;
case VIDIOC_G_CHIP_IDENT: case VIDIOC_G_CHIP_IDENT:
......
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