diff options
author | Russell King <rmk@dyn-67.arm.linux.org.uk> | 2009-02-12 05:12:59 -0500 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2009-02-14 04:59:21 -0500 |
commit | 8b9dbc16d4f5786c6c930ab028722e3ed7e4285b (patch) | |
tree | d6bd11034d7d31a42275577840f5eb16b432378d /arch/arm/plat-omap/include/mach | |
parent | 883992bd8f6924c9aa849f2dac381075e2e55a9d (diff) |
[ARM] omap: arrange for clock recalc methods to return the rate
linux-omap source commit 33d000c99ee393fe2042f93e8422f94976d276ce
introduces a way to "dry run" clock changes before they're committed.
However, this involves putting logic to handle this into each and
every recalc function, and unfortunately due to the caching, led to
some bugs.
Solve both of issues by making the recalc methods always return the
clock rate for the clock, which the caller decides what to do with.
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'arch/arm/plat-omap/include/mach')
-rw-r--r-- | arch/arm/plat-omap/include/mach/clock.h | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/arch/arm/plat-omap/include/mach/clock.h b/arch/arm/plat-omap/include/mach/clock.h index 0ba28462a497..7b6f6bcbff94 100644 --- a/arch/arm/plat-omap/include/mach/clock.h +++ b/arch/arm/plat-omap/include/mach/clock.h | |||
@@ -75,7 +75,7 @@ struct clk { | |||
75 | unsigned long rate; | 75 | unsigned long rate; |
76 | __u32 flags; | 76 | __u32 flags; |
77 | void __iomem *enable_reg; | 77 | void __iomem *enable_reg; |
78 | void (*recalc)(struct clk *); | 78 | unsigned long (*recalc)(struct clk *); |
79 | int (*set_rate)(struct clk *, unsigned long); | 79 | int (*set_rate)(struct clk *, unsigned long); |
80 | long (*round_rate)(struct clk *, unsigned long); | 80 | long (*round_rate)(struct clk *, unsigned long); |
81 | void (*init)(struct clk *); | 81 | void (*init)(struct clk *); |
@@ -123,7 +123,7 @@ extern void clk_reparent(struct clk *child, struct clk *parent); | |||
123 | extern void clk_unregister(struct clk *clk); | 123 | extern void clk_unregister(struct clk *clk); |
124 | extern void propagate_rate(struct clk *clk); | 124 | extern void propagate_rate(struct clk *clk); |
125 | extern void recalculate_root_clocks(void); | 125 | extern void recalculate_root_clocks(void); |
126 | extern void followparent_recalc(struct clk *clk); | 126 | extern unsigned long followparent_recalc(struct clk *clk); |
127 | extern void clk_enable_init_clocks(void); | 127 | extern void clk_enable_init_clocks(void); |
128 | #ifdef CONFIG_CPU_FREQ | 128 | #ifdef CONFIG_CPU_FREQ |
129 | extern void clk_init_cpufreq_table(struct cpufreq_frequency_table **table); | 129 | extern void clk_init_cpufreq_table(struct cpufreq_frequency_table **table); |