diff options
Diffstat (limited to 'arch/arm/mach-omap2/clock24xx.c')
-rw-r--r-- | arch/arm/mach-omap2/clock24xx.c | 46 |
1 files changed, 23 insertions, 23 deletions
diff --git a/arch/arm/mach-omap2/clock24xx.c b/arch/arm/mach-omap2/clock24xx.c index 615b511c68c9..ece32d8acba4 100644 --- a/arch/arm/mach-omap2/clock24xx.c +++ b/arch/arm/mach-omap2/clock24xx.c | |||
@@ -1,15 +1,15 @@ | |||
1 | /* | 1 | /* |
2 | * linux/arch/arm/mach-omap2/clock.c | 2 | * linux/arch/arm/mach-omap2/clock.c |
3 | * | 3 | * |
4 | * Copyright (C) 2005 Texas Instruments Inc. | 4 | * Copyright (C) 2005-2008 Texas Instruments, Inc. |
5 | * Richard Woodruff <r-woodruff2@ti.com> | 5 | * Copyright (C) 2004-2008 Nokia Corporation |
6 | * Created for OMAP2. | ||
7 | * | 6 | * |
8 | * Cleaned up and modified to use omap shared clock framework by | 7 | * Contacts: |
9 | * Tony Lindgren <tony@atomide.com> | 8 | * Richard Woodruff <r-woodruff2@ti.com> |
9 | * Paul Walmsley | ||
10 | * | 10 | * |
11 | * Based on omap1 clock.c, Copyright (C) 2004 - 2005 Nokia corporation | 11 | * Based on earlier work by Tuukka Tikkanen, Tony Lindgren, |
12 | * Written by Tuukka Tikkanen <tuukka.tikkanen@elektrobit.com> | 12 | * Gordon McNutt and RidgeRun, Inc. |
13 | * | 13 | * |
14 | * This program is free software; you can redistribute it and/or modify | 14 | * This program is free software; you can redistribute it and/or modify |
15 | * it under the terms of the GNU General Public License version 2 as | 15 | * it under the terms of the GNU General Public License version 2 as |
@@ -60,6 +60,21 @@ static struct clk *sclk; | |||
60 | * Omap24xx specific clock functions | 60 | * Omap24xx specific clock functions |
61 | *-------------------------------------------------------------------------*/ | 61 | *-------------------------------------------------------------------------*/ |
62 | 62 | ||
63 | /* This actually returns the rate of core_ck, not dpll_ck. */ | ||
64 | static u32 omap2_get_dpll_rate_24xx(struct clk *tclk) | ||
65 | { | ||
66 | long long dpll_clk; | ||
67 | u8 amult; | ||
68 | |||
69 | dpll_clk = omap2_get_dpll_rate(tclk); | ||
70 | |||
71 | amult = cm_read_mod_reg(PLL_MOD, CM_CLKSEL2); | ||
72 | amult &= OMAP24XX_CORE_CLK_SRC_MASK; | ||
73 | dpll_clk *= amult; | ||
74 | |||
75 | return dpll_clk; | ||
76 | } | ||
77 | |||
63 | static int omap2_enable_osc_ck(struct clk *clk) | 78 | static int omap2_enable_osc_ck(struct clk *clk) |
64 | { | 79 | { |
65 | u32 pcc; | 80 | u32 pcc; |
@@ -94,21 +109,6 @@ static void omap2_sys_clk_recalc(struct clk * clk) | |||
94 | } | 109 | } |
95 | #endif /* OLD_CK */ | 110 | #endif /* OLD_CK */ |
96 | 111 | ||
97 | /* This actually returns the rate of core_ck, not dpll_ck. */ | ||
98 | static u32 omap2_get_dpll_rate_24xx(struct clk *tclk) | ||
99 | { | ||
100 | long long dpll_clk; | ||
101 | u8 amult; | ||
102 | |||
103 | dpll_clk = omap2_get_dpll_rate(tclk); | ||
104 | |||
105 | amult = cm_read_mod_reg(PLL_MOD, CM_CLKSEL2); | ||
106 | amult &= OMAP24XX_CORE_CLK_SRC_MASK; | ||
107 | dpll_clk *= amult; | ||
108 | |||
109 | return dpll_clk; | ||
110 | } | ||
111 | |||
112 | /* Enable an APLL if off */ | 112 | /* Enable an APLL if off */ |
113 | static int omap2_clk_fixed_enable(struct clk *clk) | 113 | static int omap2_clk_fixed_enable(struct clk *clk) |
114 | { | 114 | { |
@@ -333,7 +333,7 @@ static int omap2_select_table_rate(struct clk *clk, unsigned long rate) | |||
333 | 333 | ||
334 | if (!found_speed) { | 334 | if (!found_speed) { |
335 | printk(KERN_INFO "Could not set MPU rate to %luMHz\n", | 335 | printk(KERN_INFO "Could not set MPU rate to %luMHz\n", |
336 | rate / 1000000); | 336 | rate / 1000000); |
337 | return -EINVAL; | 337 | return -EINVAL; |
338 | } | 338 | } |
339 | 339 | ||