OMAP4: clock: Add dummy clock nodes for interface clocks
authorSantosh Shilimkar <santosh.shilimkar@ti.com>
Tue, 23 Feb 2010 05:09:40 +0000 (22:09 -0700)
committerPaul Walmsley <paul@pwsan.com>
Thu, 25 Feb 2010 00:45:17 +0000 (17:45 -0700)
On OMAP4 platform the iclk control is completly under hardware control
and no software control is available.

This difference w.r.t previous OMAP's needs all the common driver
accross OMAP's , cpu_is_xxxx() checks. To avoid poulluting the
drivers dummy clock nodes are created (The autogeneration
script has been updated accordingly).

Signed-off-by: Santosh Shilimkar <santosh.shilimkar@ti.com>
Signed-off-by: Rajendra Nayak <rnayak@ti.com>
Signed-off-by: Benoit Cousson <b-cousson@ti.com>
[paul@pwsan.com: made OMAP1 dummy_ck common and edited patch to reuse that]
Signed-off-by: Paul Walmsley <paul@pwsan.com>
arch/arm/mach-omap1/clock.c
arch/arm/mach-omap1/clock_data.c
arch/arm/mach-omap2/clock.h
arch/arm/mach-omap2/clock44xx_data.c
arch/arm/plat-omap/clock.c
arch/arm/plat-omap/include/plat/clock.h

index 0ba044d80a4105f31fb4de1e111872823887e0de..e0aec1007a0de0bf02f7777e1dae6acd211e1e94 100644 (file)
@@ -38,20 +38,6 @@ struct clk *api_ck_p, *ck_dpll1_p, *ck_ref_p;
  * Omap1 specific clock functions
  *-------------------------------------------------------------------------*/
 
-static int clk_omap1_dummy_enable(struct clk *clk)
-{
-       return 0;
-}
-
-static void clk_omap1_dummy_disable(struct clk *clk)
-{
-}
-
-const struct clkops clkops_dummy = {
-       .enable         = clk_omap1_dummy_enable,
-       .disable        = clk_omap1_dummy_disable,
-};
-
 unsigned long omap1_uart_recalc(struct clk *clk)
 {
        unsigned int val = __raw_readl(clk->enable_reg);
index 8b1d14d1e38e864f118bc52e703404b0ba4ac0bf..aa8558adbf1c0416d81dd89c6c43dd5eab0424ca 100644 (file)
  * Omap1 clocks
  *-------------------------------------------------------------------------*/
 
-/* XXX is this necessary? */
-static struct clk dummy_ck = {
-       .name   = "dummy",
-       .ops    = &clkops_dummy,
-};
-
 static struct clk ck_ref = {
        .name           = "ck_ref",
        .ops            = &clkops_null,
index f77d8af585aeaf0b8c0711de350854087b58d20f..ad8a1f7c1afc7ea078bfa72fe113b5d6689c3e59 100644 (file)
@@ -127,6 +127,7 @@ void omap2_clk_print_new_rates(const char *hfclkin_ck_name,
 extern u8 cpu_mask;
 
 extern const struct clkops clkops_omap2_dflt_wait;
+extern const struct clkops clkops_dummy;
 extern const struct clkops clkops_omap2_dflt;
 
 extern struct clk_functions omap2_clk_functions;
index c0825cffdbbc396556c2e58e21c424bdde7f4e61..28b107967c861350502e920f8c9c182e3f983914 100644 (file)
@@ -2645,6 +2645,41 @@ static struct omap_clk omap44xx_clks[] = {
        CLK(NULL,       "usim_fclk",                    &usim_fclk,     CK_443X),
        CLK(NULL,       "utmi_p1_gfclk_ck",             &utmi_p1_gfclk_ck,      CK_443X),
        CLK(NULL,       "utmi_p2_gfclk_ck",             &utmi_p2_gfclk_ck,      CK_443X),
+       CLK(NULL,       "gpio1_dbck",                   &dummy_ck,      CK_443X),
+       CLK(NULL,       "gpio2_dbck",                   &dummy_ck,      CK_443X),
+       CLK(NULL,       "gpio3_dbck",                   &dummy_ck,      CK_443X),
+       CLK(NULL,       "gpio4_dbck",                   &dummy_ck,      CK_443X),
+       CLK(NULL,       "gpio5_dbck",                   &dummy_ck,      CK_443X),
+       CLK(NULL,       "gpio6_dbck",                   &dummy_ck,      CK_443X),
+       CLK(NULL,       "gpmc_ck",                      &dummy_ck,      CK_443X),
+       CLK(NULL,       "gpt1_ick",                     &dummy_ck,      CK_443X),
+       CLK(NULL,       "gpt2_ick",                     &dummy_ck,      CK_443X),
+       CLK(NULL,       "gpt3_ick",                     &dummy_ck,      CK_443X),
+       CLK(NULL,       "gpt4_ick",                     &dummy_ck,      CK_443X),
+       CLK(NULL,       "gpt5_ick",                     &dummy_ck,      CK_443X),
+       CLK(NULL,       "gpt6_ick",                     &dummy_ck,      CK_443X),
+       CLK(NULL,       "gpt7_ick",                     &dummy_ck,      CK_443X),
+       CLK(NULL,       "gpt8_ick",                     &dummy_ck,      CK_443X),
+       CLK(NULL,       "gpt9_ick",                     &dummy_ck,      CK_443X),
+       CLK(NULL,       "gpt10_ick",                    &dummy_ck,      CK_443X),
+       CLK(NULL,       "gpt11_ick",                    &dummy_ck,      CK_443X),
+       CLK("i2c_omap.1",       "ick",                          &dummy_ck,      CK_443X),
+       CLK("i2c_omap.2",       "ick",                          &dummy_ck,      CK_443X),
+       CLK("i2c_omap.3",       "ick",                          &dummy_ck,      CK_443X),
+       CLK("i2c_omap.4",       "ick",                          &dummy_ck,      CK_443X),
+       CLK("omap-mcbsp.1",     "ick",                          &dummy_ck,      CK_443X),
+       CLK("omap-mcbsp.2",     "ick",                          &dummy_ck,      CK_443X),
+       CLK("omap-mcbsp.3",     "ick",                          &dummy_ck,      CK_443X),
+       CLK("omap-mcbsp.4",     "ick",                          &dummy_ck,      CK_443X),
+       CLK("omap-mcspi.1",     "ick",                          &dummy_ck,      CK_443X),
+       CLK("omap-mcspi.2",     "ick",                          &dummy_ck,      CK_443X),
+       CLK("omap-mcspi.3",     "ick",                          &dummy_ck,      CK_443X),
+       CLK("omap-mcspi.4",     "ick",                          &dummy_ck,      CK_443X),
+       CLK(NULL,       "uart1_ick",                    &dummy_ck,      CK_443X),
+       CLK(NULL,       "uart2_ick",                    &dummy_ck,      CK_443X),
+       CLK(NULL,       "uart3_ick",                    &dummy_ck,      CK_443X),
+       CLK(NULL,       "uart4_ick",                    &dummy_ck,      CK_443X),
+       CLK("omap_wdt", "ick",                          &dummy_ck,      CK_443X),
 };
 
 int __init omap4xxx_clk_init(void)
index 6cc13e7fd89787f86eeb42ac6c33baf1fb1c5508..5261a09236919ef1b743ef2b869f182abdfb1685 100644 (file)
@@ -357,6 +357,16 @@ const struct clkops clkops_null = {
        .disable        = clkll_disable_null,
 };
 
+/*
+ * Dummy clock
+ *
+ * Used for clock aliases that are needed on some OMAPs, but not others
+ */
+struct clk dummy_ck = {
+       .name   = "dummy",
+       .ops    = &clkops_null,
+};
+
 #ifdef CONFIG_CPU_FREQ
 void clk_init_cpufreq_table(struct cpufreq_frequency_table **table)
 {
index 9b4701f1498499f1a2bbeb9b4168531b47f1c9cc..34f7fa9ad4c038e942f837772b2d14fa7de25e88 100644 (file)
@@ -186,6 +186,8 @@ extern struct clk *omap_clk_get_by_name(const char *name);
 
 extern const struct clkops clkops_null;
 
+extern struct clk dummy_ck;
+
 /* Clock flags */
 #define ENABLE_REG_32BIT       (1 << 0)        /* Use 32-bit access */
 #define CLOCK_IDLE_CONTROL     (1 << 1)