From: Heikki Krogerus Date: Mon, 2 Feb 2015 13:37:04 +0000 (+0200) Subject: clk: fractional-divider: support for divider bypassing X-Git-Tag: firefly_0821_release~176^2~1909^2~41 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=6b54783620bcfaff37ad41e957d29c326211cc18;p=firefly-linux-kernel-4.4.55.git clk: fractional-divider: support for divider bypassing If the divider or multiplier values are 0 in the register, bypassing the divider and returning the parent clock rate in clk_fd_recalc_rate(). Signed-off-by: Heikki Krogerus Reviewed-by: Stephen Boyd Signed-off-by: Michael Turquette [mturquette@linaro.org: fixed commitlog typo] --- diff --git a/drivers/clk/clk-fractional-divider.c b/drivers/clk/clk-fractional-divider.c index 82a59d0086cc..6aa72d9d79ba 100644 --- a/drivers/clk/clk-fractional-divider.c +++ b/drivers/clk/clk-fractional-divider.c @@ -36,6 +36,9 @@ static unsigned long clk_fd_recalc_rate(struct clk_hw *hw, m = (val & fd->mmask) >> fd->mshift; n = (val & fd->nmask) >> fd->nshift; + if (!n || !m) + return parent_rate; + ret = (u64)parent_rate * m; do_div(ret, n);