Commit 2f18c4d8 authored by Tomi Valkeinen's avatar Tomi Valkeinen

OMAP: DSS2: improve DSS clk src selection

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: default avatarTomi Valkeinen <tomi.valkeinen@nokia.com>
parent b63c97f5
...@@ -57,7 +57,7 @@ static int dpi_set_dsi_clk(bool is_tft, unsigned long pck_req, ...@@ -57,7 +57,7 @@ static int dpi_set_dsi_clk(bool is_tft, unsigned long pck_req,
if (r) if (r)
return 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); r = dispc_set_clock_div(&dispc_cinfo);
if (r) if (r)
...@@ -238,7 +238,7 @@ static void dpi_display_disable(struct omap_dss_device *dssdev) ...@@ -238,7 +238,7 @@ static void dpi_display_disable(struct omap_dss_device *dssdev)
dispc_enable_lcd_out(0); dispc_enable_lcd_out(0);
#ifdef CONFIG_OMAP2_DSS_USE_DSI_PLL #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(); dsi_pll_uninit();
dss_clk_disable(DSS_CLK_FCK2); dss_clk_disable(DSS_CLK_FCK2);
#endif #endif
......
...@@ -3203,7 +3203,8 @@ static int dsi_display_init_dsi(struct omap_dss_device *dssdev) ...@@ -3203,7 +3203,8 @@ static int dsi_display_init_dsi(struct omap_dss_device *dssdev)
if (r) if (r)
goto err1; 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"); DSSDBG("PLL OK\n");
...@@ -3247,7 +3248,8 @@ static int dsi_display_init_dsi(struct omap_dss_device *dssdev) ...@@ -3247,7 +3248,8 @@ static int dsi_display_init_dsi(struct omap_dss_device *dssdev)
err3: err3:
dsi_complexio_uninit(); dsi_complexio_uninit();
err2: 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: err1:
dsi_pll_uninit(); dsi_pll_uninit();
err0: err0:
...@@ -3259,7 +3261,8 @@ static void dsi_display_uninit_dsi(struct omap_dss_device *dssdev) ...@@ -3259,7 +3261,8 @@ static void dsi_display_uninit_dsi(struct omap_dss_device *dssdev)
if (dssdev->driver->disable) if (dssdev->driver->disable)
dssdev->driver->disable(dssdev); 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_complexio_uninit();
dsi_pll_uninit(); dsi_pll_uninit();
} }
......
...@@ -68,6 +68,9 @@ static struct { ...@@ -68,6 +68,9 @@ static struct {
struct dss_clock_info cache_dss_cinfo; struct dss_clock_info cache_dss_cinfo;
struct dispc_clock_info cache_dispc_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)]; u32 ctx[DSS_SZ_REGS / sizeof(u32)];
} dss; } dss;
...@@ -247,23 +250,42 @@ void dss_dump_regs(struct seq_file *s) ...@@ -247,23 +250,42 @@ void dss_dump_regs(struct seq_file *s)
#undef DUMPREG #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; int b;
r = dss_read_reg(DSS_CONTROL);
r = FLD_MOD(r, dsi, 1, 1); /* DSI_CLK_SWITCH */ BUG_ON(clk_src != DSS_SRC_DSI2_PLL_FCLK &&
r = FLD_MOD(r, dispc, 0, 0); /* DISPC_CLK_SWITCH */ clk_src != DSS_SRC_DSS1_ALWON_FCLK);
dss_write_reg(DSS_CONTROL, r);
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 */ /* calculate clock rates using dividers in cinfo */
......
...@@ -119,6 +119,12 @@ enum dss_clock { ...@@ -119,6 +119,12 @@ enum dss_clock {
DSS_CLK_96M = 1 << 4, 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 { struct dss_clock_info {
/* rates that we get with dividers below */ /* rates that we get with dividers below */
unsigned long fck; unsigned long fck;
...@@ -219,9 +225,11 @@ void dss_sdi_init(u8 datapairs); ...@@ -219,9 +225,11 @@ void dss_sdi_init(u8 datapairs);
int dss_sdi_enable(void); int dss_sdi_enable(void);
void dss_sdi_disable(void); void dss_sdi_disable(void);
void dss_select_clk_source(bool dsi, bool dispc); void dss_select_dispc_clk_source(enum dss_clk_source clk_src);
int dss_get_dsi_clk_source(void); void dss_select_dsi_clk_source(enum dss_clk_source clk_src);
int dss_get_dispc_clk_source(void); 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_venc_output(enum omap_dss_venc_type type);
void dss_set_dac_pwrdn_bgz(bool enable); void dss_set_dac_pwrdn_bgz(bool enable);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment