OMAP: DSS2: improve DSS clk src selection
authorTomi Valkeinen <tomi.valkeinen@nokia.com>
Fri, 8 Jan 2010 16:00:36 +0000 (18:00 +0200)
committerTomi Valkeinen <tomi.valkeinen@nokia.com>
Mon, 15 Feb 2010 13:14:40 +0000 (15:14 +0200)
dss_select_clk_source() was rather confusing. Selecting the source with
enums is much clearer.

The clk source selection is also stored into memory, so that we know what
is the selected source, even when clocks are off. This is important during
setup, as we need to what clocks to turn on before the clocks are turned
on.

Signed-off-by: Tomi Valkeinen <tomi.valkeinen@nokia.com>
drivers/video/omap2/dss/dpi.c
drivers/video/omap2/dss/dsi.c
drivers/video/omap2/dss/dss.c
drivers/video/omap2/dss/dss.h

index 69ce31ae2a2fe4d8037db48667eaf187f8ecd6ea..c5091ed12a7d5825cff4728ad92bc13fdb00de3c 100644 (file)
@@ -57,7 +57,7 @@ static int dpi_set_dsi_clk(bool is_tft, unsigned long pck_req,
        if (r)
                return r;
 
-       dss_select_clk_source(0, 1);
+       dss_select_dispc_clk_source(DSS_SRC_DSI1_PLL_FCLK);
 
        r = dispc_set_clock_div(&dispc_cinfo);
        if (r)
@@ -238,7 +238,7 @@ static void dpi_display_disable(struct omap_dss_device *dssdev)
        dispc_enable_lcd_out(0);
 
 #ifdef CONFIG_OMAP2_DSS_USE_DSI_PLL
-       dss_select_clk_source(0, 0);
+       dss_select_dispc_clk_source(DSS_SRC_DSS1_ALWON_FCLK);
        dsi_pll_uninit();
        dss_clk_disable(DSS_CLK_FCK2);
 #endif
index 036f4221e3df001b4a224931df55d001d3d75d4f..4fdb628427e0944ad06ef8e3683f4df8592e6cbc 100644 (file)
@@ -3203,7 +3203,8 @@ static int dsi_display_init_dsi(struct omap_dss_device *dssdev)
        if (r)
                goto err1;
 
-       dss_select_clk_source(true, true);
+       dss_select_dispc_clk_source(DSS_SRC_DSI1_PLL_FCLK);
+       dss_select_dsi_clk_source(DSS_SRC_DSI2_PLL_FCLK);
 
        DSSDBG("PLL OK\n");
 
@@ -3247,7 +3248,8 @@ err4:
 err3:
        dsi_complexio_uninit();
 err2:
-       dss_select_clk_source(false, false);
+       dss_select_dispc_clk_source(DSS_SRC_DSS1_ALWON_FCLK);
+       dss_select_dsi_clk_source(DSS_SRC_DSS1_ALWON_FCLK);
 err1:
        dsi_pll_uninit();
 err0:
@@ -3259,7 +3261,8 @@ static void dsi_display_uninit_dsi(struct omap_dss_device *dssdev)
        if (dssdev->driver->disable)
                dssdev->driver->disable(dssdev);
 
-       dss_select_clk_source(false, false);
+       dss_select_dispc_clk_source(DSS_SRC_DSS1_ALWON_FCLK);
+       dss_select_dsi_clk_source(DSS_SRC_DSS1_ALWON_FCLK);
        dsi_complexio_uninit();
        dsi_pll_uninit();
 }
index 0a26b7d84d4187a58bd6325801c389e177b22f39..8254a4232a536d3c844214e165bd67507d94c943 100644 (file)
@@ -68,6 +68,9 @@ static struct {
        struct dss_clock_info cache_dss_cinfo;
        struct dispc_clock_info cache_dispc_cinfo;
 
+       enum dss_clk_source dsi_clk_source;
+       enum dss_clk_source dispc_clk_source;
+
        u32             ctx[DSS_SZ_REGS / sizeof(u32)];
 } dss;
 
@@ -247,23 +250,42 @@ void dss_dump_regs(struct seq_file *s)
 #undef DUMPREG
 }
 
-void dss_select_clk_source(bool dsi, bool dispc)
+void dss_select_dispc_clk_source(enum dss_clk_source clk_src)
+{
+       int b;
+
+       BUG_ON(clk_src != DSS_SRC_DSI1_PLL_FCLK &&
+                       clk_src != DSS_SRC_DSS1_ALWON_FCLK);
+
+       b = clk_src == DSS_SRC_DSS1_ALWON_FCLK ? 0 : 1;
+
+       REG_FLD_MOD(DSS_CONTROL, b, 0, 0);      /* DISPC_CLK_SWITCH */
+
+       dss.dispc_clk_source = clk_src;
+}
+
+void dss_select_dsi_clk_source(enum dss_clk_source clk_src)
 {
-       u32 r;
-       r = dss_read_reg(DSS_CONTROL);
-       r = FLD_MOD(r, dsi, 1, 1);      /* DSI_CLK_SWITCH */
-       r = FLD_MOD(r, dispc, 0, 0);    /* DISPC_CLK_SWITCH */
-       dss_write_reg(DSS_CONTROL, r);
+       int b;
+
+       BUG_ON(clk_src != DSS_SRC_DSI2_PLL_FCLK &&
+                       clk_src != DSS_SRC_DSS1_ALWON_FCLK);
+
+       b = clk_src == DSS_SRC_DSS1_ALWON_FCLK ? 0 : 1;
+
+       REG_FLD_MOD(DSS_CONTROL, b, 1, 1);      /* DSI_CLK_SWITCH */
+
+       dss.dsi_clk_source = clk_src;
 }
 
-int dss_get_dsi_clk_source(void)
+enum dss_clk_source dss_get_dispc_clk_source(void)
 {
-       return FLD_GET(dss_read_reg(DSS_CONTROL), 1, 1);
+       return dss.dispc_clk_source;
 }
 
-int dss_get_dispc_clk_source(void)
+enum dss_clk_source dss_get_dsi_clk_source(void)
 {
-       return FLD_GET(dss_read_reg(DSS_CONTROL), 0, 0);
+       return dss.dsi_clk_source;
 }
 
 /* calculate clock rates using dividers in cinfo */
index 41145af36353cc642c6cce55824dce997d72f767..3713dc69825977a1a3859d3430e395d5808fd5c3 100644 (file)
@@ -119,6 +119,12 @@ enum dss_clock {
        DSS_CLK_96M     = 1 << 4,
 };
 
+enum dss_clk_source {
+       DSS_SRC_DSI1_PLL_FCLK,
+       DSS_SRC_DSI2_PLL_FCLK,
+       DSS_SRC_DSS1_ALWON_FCLK,
+};
+
 struct dss_clock_info {
        /* rates that we get with dividers below */
        unsigned long fck;
@@ -219,9 +225,11 @@ void dss_sdi_init(u8 datapairs);
 int dss_sdi_enable(void);
 void dss_sdi_disable(void);
 
-void dss_select_clk_source(bool dsi, bool dispc);
-int dss_get_dsi_clk_source(void);
-int dss_get_dispc_clk_source(void);
+void dss_select_dispc_clk_source(enum dss_clk_source clk_src);
+void dss_select_dsi_clk_source(enum dss_clk_source clk_src);
+enum dss_clk_source dss_get_dispc_clk_source(void);
+enum dss_clk_source dss_get_dsi_clk_source(void);
+
 void dss_set_venc_output(enum omap_dss_venc_type type);
 void dss_set_dac_pwrdn_bgz(bool enable);