From: Sakari Ailus Date: Thu, 26 Apr 2012 14:21:30 +0000 (-0300) Subject: [media] smiapp: Round minimum pre_pll up rather than down in ip_clk_freq check X-Git-Tag: firefly_0821_release~3680^2~275^2~2069 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=6f367993988720c86e863bb64db8a62a002d6d9d;p=firefly-linux-kernel-4.4.55.git [media] smiapp: Round minimum pre_pll up rather than down in ip_clk_freq check The pre_pll divisor must be such that ext_clk / pre_pll divisor does not result in a frequency that is greater than pll_ip_clk_freq. Fix this. Signed-off-by: Sakari Ailus Signed-off-by: Mauro Carvalho Chehab --- diff --git a/drivers/media/video/smiapp-pll.c b/drivers/media/video/smiapp-pll.c index a416e27a4282..a2e41a21dc65 100644 --- a/drivers/media/video/smiapp-pll.c +++ b/drivers/media/video/smiapp-pll.c @@ -124,8 +124,9 @@ int smiapp_pll_calculate(struct device *dev, struct smiapp_pll_limits *limits, limits->min_pll_ip_freq_hz)); limits->min_pre_pll_clk_div = max_t(uint16_t, limits->min_pre_pll_clk_div, - clk_div_even(pll->ext_clk_freq_hz / - limits->max_pll_ip_freq_hz)); + clk_div_even_up( + DIV_ROUND_UP(pll->ext_clk_freq_hz, + limits->max_pll_ip_freq_hz))); dev_dbg(dev, "pre-pll check: min / max pre_pll_clk_div: %d / %d\n", limits->min_pre_pll_clk_div, limits->max_pre_pll_clk_div);