Commit f8ef3d69 authored by Tomi Valkeinen's avatar Tomi Valkeinen

OMAPDSS: DSI: Add FEAT_DSI_PLL_SELFREQDCO

Add FEAT_DSI_PLL_SELFREQDCO. OMAP5's DSI PLL has a new configuration
option that needs to be programmed depending on the PLL's output clock
frequency.
Signed-off-by: default avatarTomi Valkeinen <tomi.valkeinen@ti.com>
parent de09e455
...@@ -1671,18 +1671,22 @@ int dsi_pll_set_clock_div(struct platform_device *dsidev, ...@@ -1671,18 +1671,22 @@ int dsi_pll_set_clock_div(struct platform_device *dsidev,
BUG_ON(cinfo->fint < dsi->fint_min || cinfo->fint > dsi->fint_max); BUG_ON(cinfo->fint < dsi->fint_min || cinfo->fint > dsi->fint_max);
l = dsi_read_reg(dsidev, DSI_PLL_CONFIGURATION2);
if (dss_has_feature(FEAT_DSI_PLL_FREQSEL)) { if (dss_has_feature(FEAT_DSI_PLL_FREQSEL)) {
f = cinfo->fint < 1000000 ? 0x3 : f = cinfo->fint < 1000000 ? 0x3 :
cinfo->fint < 1250000 ? 0x4 : cinfo->fint < 1250000 ? 0x4 :
cinfo->fint < 1500000 ? 0x5 : cinfo->fint < 1500000 ? 0x5 :
cinfo->fint < 1750000 ? 0x6 : cinfo->fint < 1750000 ? 0x6 :
0x7; 0x7;
}
l = dsi_read_reg(dsidev, DSI_PLL_CONFIGURATION2);
if (dss_has_feature(FEAT_DSI_PLL_FREQSEL))
l = FLD_MOD(l, f, 4, 1); /* DSI_PLL_FREQSEL */ l = FLD_MOD(l, f, 4, 1); /* DSI_PLL_FREQSEL */
} else if (dss_has_feature(FEAT_DSI_PLL_SELFREQDCO)) {
f = cinfo->clkin4ddr < 1000000000 ? 0x2 : 0x4;
l = FLD_MOD(l, f, 4, 1); /* PLL_SELFREQDCO */
}
l = FLD_MOD(l, 1, 13, 13); /* DSI_PLL_REFEN */ l = FLD_MOD(l, 1, 13, 13); /* DSI_PLL_REFEN */
l = FLD_MOD(l, 0, 14, 14); /* DSIPHY_CLKINEN */ l = FLD_MOD(l, 0, 14, 14); /* DSIPHY_CLKINEN */
l = FLD_MOD(l, 1, 20, 20); /* DSI_HSDIVBYPASS */ l = FLD_MOD(l, 1, 20, 20); /* DSI_HSDIVBYPASS */
......
...@@ -519,6 +519,7 @@ static const enum dss_feat_id omap5_dss_feat_list[] = { ...@@ -519,6 +519,7 @@ static const enum dss_feat_id omap5_dss_feat_list[] = {
FEAT_ALPHA_FREE_ZORDER, FEAT_ALPHA_FREE_ZORDER,
FEAT_FIFO_MERGE, FEAT_FIFO_MERGE,
FEAT_BURST_2D, FEAT_BURST_2D,
FEAT_DSI_PLL_SELFREQDCO,
}; };
/* OMAP2 DSS Features */ /* OMAP2 DSS Features */
......
...@@ -65,6 +65,7 @@ enum dss_feat_id { ...@@ -65,6 +65,7 @@ enum dss_feat_id {
/* An unknown HW bug causing the normal FIFO thresholds not to work */ /* An unknown HW bug causing the normal FIFO thresholds not to work */
FEAT_OMAP3_DSI_FIFO_BUG, FEAT_OMAP3_DSI_FIFO_BUG,
FEAT_BURST_2D, FEAT_BURST_2D,
FEAT_DSI_PLL_SELFREQDCO,
}; };
/* DSS register field id */ /* DSS register field id */
......
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