]> pilppa.com Git - linux-2.6-omap-h63xx.git/commitdiff
omap2 clock: vlynq_fck recalc should be clksel, not followparent
authorPaul Walmsley <paul@pwsan.com>
Thu, 2 Aug 2007 18:10:06 +0000 (12:10 -0600)
committerTony Lindgren <tony@atomide.com>
Fri, 10 Aug 2007 09:34:56 +0000 (02:34 -0700)
vlynq_fck is a clksel clock, so its rate is equal to its parent's
rate, divided by whichever divisor is selected.  But its definition in
clock.h specifies omap2_followparent_recalc() as its rate calculation
code, which sets the clock's rate to that of its parent without
accounting for any divisor.  Fix to use omap2_clksel_recalc() instead.
omap2_clksel_recalc() is also missing the appropriate special case to
divide the vlynq_fck rate down; add this in.

Signed-off-by: Paul Walmsley <paul@pwsan.com>
Signed-off-by: Tony Lindgren <tony@atomide.com>
arch/arm/mach-omap2/clock.c
arch/arm/mach-omap2/clock.h

index 94e31a986974d494fc47e73d0bf79e0aa9f1f7e1..ff7a65ecf9172e53ebb3018d82ad054eedbf45a3 100644 (file)
 
 #undef DEBUG
 
+/* CM_CLKSEL1_CORE.CLKSEL_VLYNQ options (2420) */
+#define CLKSEL_VLYNQ_96MHZ             0
+#define CLKSEL_VLYNQ_CORECLK_16                0x10
+
 /* SET_PERFORMANCE_LEVEL PARAMETERS */
 #define PRCM_HALF_SPEED                1
 #define PRCM_FULL_SPEED                2
@@ -358,6 +362,12 @@ static void omap2_clksel_recalc(struct clk * clk)
                return;
        }
 
+       if ((clk == &vlynq_fck) && cpu_is_omap2420() &&
+           (clksel1_core & OMAP2420_CLKSEL_VLYNQ_MASK) == CLKSEL_VLYNQ_96MHZ) {
+               clk->rate = func_96m_ck.rate;
+               return;
+       }
+
        if (!fixed) {
                div = omap2_clksel_get_divisor(clk);
                if (div == 0)
index eda904a8a4ae74cd6d8d97ef4e6c35b46baae2e9..dd6e1d9129db4e0658a3f510d3f29f2bf5b8e07f 100644 (file)
@@ -1824,7 +1824,7 @@ static struct clk vlynq_fck = {
        .enable_reg     = OMAP_CM_REGADDR(CORE_MOD, CM_FCLKEN1),
        .enable_bit     = OMAP2420_EN_VLYNQ_SHIFT,
        .src_offset     = 15,
-       .recalc         = &omap2_followparent_recalc,
+       .recalc         = &omap2_clksel_recalc,
 };
 
 static struct clk sdrc_ick = {