diff options
author | Marc Kleine-Budde <mkl@pengutronix.de> | 2013-11-25 16:15:21 -0500 |
---|---|---|
committer | Shawn Guo <shawn.guo@linaro.org> | 2013-12-30 20:36:30 -0500 |
commit | 10471fa3c779e6a1f5fafafc4ab86f1119bb90e0 (patch) | |
tree | 136d35ce087b8ec366632158e2ff1a35ceac7050 /arch/arm/mach-imx | |
parent | a594790368a89165b92d7146aac2223b5a37637e (diff) |
ARM i.MX5: set CAN peripheral clock to 24 MHz parent
This patch sets the parent of CAN peripheral clock (a.k.a. CPI clock) to the
lp_apm clock, which has a rate of 24 MHz.
In the CAN world a base clock with multiple of 8 MHz is suited best for all CIA
recommented bit rates. Without this patch the CAN peripheral clock on i.MX53
has a rate of 66.666 MHz which produces quite large bit rate errors.
Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
Signed-off-by: Shawn Guo <shawn.guo@linaro.org>
Diffstat (limited to 'arch/arm/mach-imx')
-rw-r--r-- | arch/arm/mach-imx/clk-imx51-imx53.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/arch/arm/mach-imx/clk-imx51-imx53.c b/arch/arm/mach-imx/clk-imx51-imx53.c index e349fd5aab9b..dff5ca921d00 100644 --- a/arch/arm/mach-imx/clk-imx51-imx53.c +++ b/arch/arm/mach-imx/clk-imx51-imx53.c | |||
@@ -584,6 +584,9 @@ static void __init mx53_clocks_init(struct device_node *np) | |||
584 | clk_set_rate(clk[IMX5_CLK_ESDHC_A_PODF], 200000000); | 584 | clk_set_rate(clk[IMX5_CLK_ESDHC_A_PODF], 200000000); |
585 | clk_set_rate(clk[IMX5_CLK_ESDHC_B_PODF], 200000000); | 585 | clk_set_rate(clk[IMX5_CLK_ESDHC_B_PODF], 200000000); |
586 | 586 | ||
587 | /* move can bus clk to 24MHz */ | ||
588 | clk_set_parent(clk[IMX5_CLK_CAN_SEL], clk[IMX5_CLK_LP_APM]); | ||
589 | |||
587 | clk_prepare_enable(clk[IMX5_CLK_IIM_GATE]); | 590 | clk_prepare_enable(clk[IMX5_CLK_IIM_GATE]); |
588 | imx_print_silicon_rev("i.MX53", mx53_revision()); | 591 | imx_print_silicon_rev("i.MX53", mx53_revision()); |
589 | clk_disable_unprepare(clk[IMX5_CLK_IIM_GATE]); | 592 | clk_disable_unprepare(clk[IMX5_CLK_IIM_GATE]); |