]> www.pilppa.org Git - linux-2.6-omap-h63xx.git/blobdiff - arch/arm/mach-omap2/clock24xx.c
OMAP2/3 clock: use clk->prcm_mod for all struct clk register addressing
[linux-2.6-omap-h63xx.git] / arch / arm / mach-omap2 / clock24xx.c
index a97d89d470aea20670f1343b98eb0ccc6cc195fe..a54f10f92cd436bbd504301976d288abacb978b6 100644 (file)
@@ -201,7 +201,8 @@ static int omap2_reprogram_dpllcore(struct clk *clk, unsigned long rate)
                if (!dd)
                        goto dpll_exit;
 
-               tmpset.cm_clksel1_pll = __raw_readl(dd->mult_div1_reg);
+               tmpset.cm_clksel1_pll = cm_read_mod_reg(clk->prcm_mod,
+                                                       dd->mult_div1_reg);
                tmpset.cm_clksel1_pll &= ~(dd->mult_mask |
                                           dd->div1_mask);
                div = ((curr_prcm_set->xtal_speed / 1000000) - 1);
@@ -500,39 +501,6 @@ static int __init omap2_clk_arch_init(void)
 }
 arch_initcall(omap2_clk_arch_init);
 
-static u32 prm_base;
-static u32 cm_base;
-
-/*
- * Since we share clock data for 242x and 243x, we need to rewrite some
- * some register base offsets. Assume offset is at prm_base if flagged,
- * else assume it's cm_base.
- */
-static inline void omap2_clk_check_reg(u32 flags, void __iomem **reg)
-{
-       u32 tmp = (__force u32)*reg;
-
-       if ((tmp >> 24) != 0)
-               return;
-
-       if (flags & OFFSET_GR_MOD)
-               tmp += prm_base;
-       else
-               tmp += cm_base;
-
-       *reg = (__force void __iomem *)tmp;
-}
-
-static void __init omap2_clk_rewrite_base(struct clk *clk)
-{
-       omap2_clk_check_reg(clk->flags, &clk->clksel_reg);
-       omap2_clk_check_reg(clk->flags, &clk->enable_reg);
-       if (clk->dpll_data) {
-               omap2_clk_check_reg(0, &clk->dpll_data->mult_div1_reg);
-               omap2_clk_check_reg(0, &clk->dpll_data->idlest_reg);
-       }
-}
-
 int __init omap2_clk_init(void)
 {
        struct prcm_config *prcm;
@@ -544,12 +512,6 @@ int __init omap2_clk_init(void)
        else if (cpu_is_omap2430())
                cpu_mask = RATE_IN_243X;
 
-       for (clkp = onchip_24xx_clks;
-            clkp < onchip_24xx_clks + ARRAY_SIZE(onchip_24xx_clks);
-            clkp++) {
-                       omap2_clk_rewrite_base(*clkp);
-       }
-
        clk_init(&omap2_clk_functions);
 
        omap2_osc_clk_recalc(&osc_ck);
@@ -603,9 +565,3 @@ int __init omap2_clk_init(void)
 
        return 0;
 }
-
-void __init omap2_set_globals_clock24xx(struct omap_globals *omap2_globals)
-{
-       prm_base = (__force u32)omap2_globals->prm;
-       cm_base = (__force u32)omap2_globals->cm;
-}