diff options
author | Andy Walls <awalls@radix.net> | 2008-12-20 21:48:57 -0500 |
---|---|---|
committer | Andy Walls <awalls@radix.net> | 2008-12-20 21:48:57 -0500 |
commit | bce583f51a7c7b70a1d1f922d5bf816df4f5766b (patch) | |
tree | 9c41f50c70e7f1e036013dac6effe1e06808b03a /linux/drivers/media/video/cx18/cx18-av-core.c | |
parent | 51b7994a471b5bdb5d68cfd1af7743c3faa91268 (diff) | |
download | mediapointer-dvb-s2-bce583f51a7c7b70a1d1f922d5bf816df4f5766b.tar.gz mediapointer-dvb-s2-bce583f51a7c7b70a1d1f922d5bf816df4f5766b.tar.bz2 |
cx18: Use a consistent crystal value for computing all PLL parameters
From: Andy Walls <awalls@radix.net>
Use a consistent crystal value of 28.636360 MHz for computing all PLL
parameters so clocks don't have relative error due to assumed crystal
value mismatches. Also aimed to have all PLLs run their VOCs at close to
400 MHz to minimze the error of these PLLs as frequency synthesizers. Also
set the VDCLK and AIMCLK PLLs to sane values before the APU and CPU firmware
are loaded. Also fixed I2S Master clock dividers.
Many thanks to Mike Bradley and Jeff Campbell for reporting this problem and
suggesting the solution, researching and experimenting, and performing
extensive testing to support their suggested solution.
Reported-by: Jeff Campbell <jac1dlists@gmail.com>
Reported-by: Mike Bradley <mike.bradley@incanetworks.com>
Priority: normal
Signed-off-by: Andy Walls <awalls@radix.net>
Diffstat (limited to 'linux/drivers/media/video/cx18/cx18-av-core.c')
-rw-r--r-- | linux/drivers/media/video/cx18/cx18-av-core.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/linux/drivers/media/video/cx18/cx18-av-core.c b/linux/drivers/media/video/cx18/cx18-av-core.c index 40ea6fde6..0b1c84b4d 100644 --- a/linux/drivers/media/video/cx18/cx18-av-core.c +++ b/linux/drivers/media/video/cx18/cx18-av-core.c @@ -271,7 +271,7 @@ void cx18_av_std_setup(struct cx18 *cx) if (pll_post) { int fin, fsc, pll; - pll = (28636364L * ((((u64)pll_int) << 25) + pll_frac)) >> 25; + pll = (28636360L * ((((u64)pll_int) << 25) + pll_frac)) >> 25; pll /= pll_post; CX18_DEBUG_INFO("PLL = %d.%06d MHz\n", pll / 1000000, pll % 1000000); |