Commit 7f9c65ea authored by Brad Love's avatar Brad Love Committed by Greg Kroah-Hartman

media: cx25840: Use subdev host data for PLL override

commit 3ee9bc12 upstream.

The cx25840 driver currently configures 885, 887, and 888 using
default divisors for each chip. This check to see if the cx23885
driver has passed the cx25840 a non-default clock rate for a
specific chip. If a cx23885 board has left clk_freq at 0, the
clock default values will be used to configure the PLLs.

This patch only has effect on 888 boards who set clk_freq to 25M.
Signed-off-by: default avatarBrad Love <brad@nextdimension.cc>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@s-opensource.com>
Cc: Ben Hutchings <ben.hutchings@codethink.co.uk>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 99b6d2c3
...@@ -467,8 +467,13 @@ static void cx23885_initialize(struct i2c_client *client) ...@@ -467,8 +467,13 @@ static void cx23885_initialize(struct i2c_client *client)
{ {
DEFINE_WAIT(wait); DEFINE_WAIT(wait);
struct cx25840_state *state = to_state(i2c_get_clientdata(client)); struct cx25840_state *state = to_state(i2c_get_clientdata(client));
u32 clk_freq = 0;
struct workqueue_struct *q; struct workqueue_struct *q;
/* cx23885 sets hostdata to clk_freq pointer */
if (v4l2_get_subdev_hostdata(&state->sd))
clk_freq = *((u32 *)v4l2_get_subdev_hostdata(&state->sd));
/* /*
* Come out of digital power down * Come out of digital power down
* The CX23888, at least, needs this, otherwise registers aside from * The CX23888, at least, needs this, otherwise registers aside from
...@@ -504,8 +509,13 @@ static void cx23885_initialize(struct i2c_client *client) ...@@ -504,8 +509,13 @@ static void cx23885_initialize(struct i2c_client *client)
* 50.0 MHz * (0xb + 0xe8ba26/0x2000000)/4 = 5 * 28.636363 MHz * 50.0 MHz * (0xb + 0xe8ba26/0x2000000)/4 = 5 * 28.636363 MHz
* 572.73 MHz before post divide * 572.73 MHz before post divide
*/ */
/* HVR1850 or 50MHz xtal */ if (clk_freq == 25000000) {
cx25840_write(client, 0x2, 0x71); /* 888/ImpactVCBe or 25Mhz xtal */
; /* nothing to do */
} else {
/* HVR1850 or 50MHz xtal */
cx25840_write(client, 0x2, 0x71);
}
cx25840_write4(client, 0x11c, 0x01d1744c); cx25840_write4(client, 0x11c, 0x01d1744c);
cx25840_write4(client, 0x118, 0x00000416); cx25840_write4(client, 0x118, 0x00000416);
cx25840_write4(client, 0x404, 0x0010253e); cx25840_write4(client, 0x404, 0x0010253e);
...@@ -548,9 +558,15 @@ static void cx23885_initialize(struct i2c_client *client) ...@@ -548,9 +558,15 @@ static void cx23885_initialize(struct i2c_client *client)
/* HVR1850 */ /* HVR1850 */
switch (state->id) { switch (state->id) {
case CX23888_AV: case CX23888_AV:
/* 888/HVR1250 specific */ if (clk_freq == 25000000) {
cx25840_write4(client, 0x10c, 0x13333333); /* 888/ImpactVCBe or 25MHz xtal */
cx25840_write4(client, 0x108, 0x00000515); cx25840_write4(client, 0x10c, 0x01b6db7b);
cx25840_write4(client, 0x108, 0x00000512);
} else {
/* 888/HVR1250 or 50MHz xtal */
cx25840_write4(client, 0x10c, 0x13333333);
cx25840_write4(client, 0x108, 0x00000515);
}
break; break;
default: default:
cx25840_write4(client, 0x10c, 0x002be2c9); cx25840_write4(client, 0x10c, 0x002be2c9);
...@@ -577,7 +593,7 @@ static void cx23885_initialize(struct i2c_client *client) ...@@ -577,7 +593,7 @@ static void cx23885_initialize(struct i2c_client *client)
* 368.64 MHz before post divide * 368.64 MHz before post divide
* 122.88 MHz / 0xa = 12.288 MHz * 122.88 MHz / 0xa = 12.288 MHz
*/ */
/* HVR1850 or 50MHz xtal */ /* HVR1850 or 50MHz xtal or 25MHz xtal */
cx25840_write4(client, 0x114, 0x017dbf48); cx25840_write4(client, 0x114, 0x017dbf48);
cx25840_write4(client, 0x110, 0x000a030e); cx25840_write4(client, 0x110, 0x000a030e);
break; break;
......
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