|
@@ -1052,25 +1052,26 @@ static void update_hdmi_timings(struct hdmi_config *cfg,
|
|
|
cfg->timings.hsync_pol = cea_vesa_timings[code].hsync_pol;
|
|
|
}
|
|
|
|
|
|
-static void hdmi_compute_pll(unsigned long clkin, int phy,
|
|
|
- int n, struct hdmi_pll_info *pi)
|
|
|
+static void hdmi_compute_pll(struct omap_dss_device *dssdev, int phy,
|
|
|
+ struct hdmi_pll_info *pi)
|
|
|
{
|
|
|
- unsigned long refclk;
|
|
|
+ unsigned long clkin, refclk;
|
|
|
u32 mf;
|
|
|
|
|
|
+ clkin = dss_clk_get_rate(DSS_CLK_SYSCK) / 10000;
|
|
|
/*
|
|
|
* Input clock is predivided by N + 1
|
|
|
* out put of which is reference clk
|
|
|
*/
|
|
|
- refclk = clkin / (n + 1);
|
|
|
- pi->regn = n;
|
|
|
+ pi->regn = dssdev->clocks.hdmi.regn;
|
|
|
+ refclk = clkin / (pi->regn + 1);
|
|
|
|
|
|
/*
|
|
|
* multiplier is pixel_clk/ref_clk
|
|
|
* Multiplying by 100 to avoid fractional part removal
|
|
|
*/
|
|
|
- pi->regm = (phy * 100/(refclk))/100;
|
|
|
- pi->regm2 = 1;
|
|
|
+ pi->regm = (phy * 100 / (refclk)) / 100;
|
|
|
+ pi->regm2 = dssdev->clocks.hdmi.regm2;
|
|
|
|
|
|
/*
|
|
|
* fractional multiplier is remainder of the difference between
|
|
@@ -1078,14 +1079,14 @@ static void hdmi_compute_pll(unsigned long clkin, int phy,
|
|
|
* multiplied by 2^18(262144) divided by the reference clock
|
|
|
*/
|
|
|
mf = (phy - pi->regm * refclk) * 262144;
|
|
|
- pi->regmf = mf/(refclk);
|
|
|
+ pi->regmf = mf / (refclk);
|
|
|
|
|
|
/*
|
|
|
* Dcofreq should be set to 1 if required pixel clock
|
|
|
* is greater than 1000MHz
|
|
|
*/
|
|
|
pi->dcofreq = phy > 1000 * 100;
|
|
|
- pi->regsd = ((pi->regm * clkin / 10) / ((n + 1) * 250) + 5) / 10;
|
|
|
+ pi->regsd = ((pi->regm * clkin / 10) / ((pi->regn + 1) * 250) + 5) / 10;
|
|
|
|
|
|
DSSDBG("M = %d Mf = %d\n", pi->regm, pi->regmf);
|
|
|
DSSDBG("range = %d sd = %d\n", pi->dcofreq, pi->regsd);
|
|
@@ -1106,7 +1107,7 @@ static int hdmi_power_on(struct omap_dss_device *dssdev)
|
|
|
int r, code = 0;
|
|
|
struct hdmi_pll_info pll_data;
|
|
|
struct omap_video_timings *p;
|
|
|
- int clkin, n, phy;
|
|
|
+ unsigned long phy;
|
|
|
|
|
|
hdmi_enable_clocks(1);
|
|
|
|
|
@@ -1126,11 +1127,9 @@ static int hdmi_power_on(struct omap_dss_device *dssdev)
|
|
|
dssdev->panel.timings = cea_vesa_timings[code].timings;
|
|
|
update_hdmi_timings(&hdmi.cfg, p, code);
|
|
|
|
|
|
- clkin = 3840; /* 38.4 MHz */
|
|
|
- n = 15; /* this is a constant for our math */
|
|
|
phy = p->pixel_clock;
|
|
|
|
|
|
- hdmi_compute_pll(clkin, phy, n, &pll_data);
|
|
|
+ hdmi_compute_pll(dssdev, phy, &pll_data);
|
|
|
|
|
|
hdmi_wp_video_start(0);
|
|
|
|
|
@@ -1160,7 +1159,7 @@ static int hdmi_power_on(struct omap_dss_device *dssdev)
|
|
|
* dynamically by user. This can be moved to single location , say
|
|
|
* Boardfile.
|
|
|
*/
|
|
|
- dss_select_dispc_clk_source(OMAP_DSS_CLK_SRC_FCK);
|
|
|
+ dss_select_dispc_clk_source(dssdev->clocks.dispc.dispc_fclk_src);
|
|
|
|
|
|
/* bypass TV gamma table */
|
|
|
dispc_enable_gamma_table(0);
|