All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] clk: scmi: Fix the rounding of clock rate
@ 2018-07-27 14:01 ` Amit Daniel Kachhap
  0 siblings, 0 replies; 21+ messages in thread
From: Amit Daniel Kachhap @ 2018-07-27 14:01 UTC (permalink / raw)
  To: linux-arm-kernel
  Cc: Sudeep Holla, Michael Turquette, Stephen Boyd, linux-clk,
	linux-kernel, Amit Daniel Kachhap

This fix rounds the clock rate properly by using quotient and not
remainder in the calculation. This issue was found while testing HDMI
in the Juno platform.

Signed-off-by: Amit Daniel Kachhap <amit.kachhap@arm.com>
---
 drivers/clk/clk-scmi.c | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)

diff --git a/drivers/clk/clk-scmi.c b/drivers/clk/clk-scmi.c
index bb2a6f2..a985bf5 100644
--- a/drivers/clk/clk-scmi.c
+++ b/drivers/clk/clk-scmi.c
@@ -38,7 +38,6 @@ static unsigned long scmi_clk_recalc_rate(struct clk_hw *hw,
 static long scmi_clk_round_rate(struct clk_hw *hw, unsigned long rate,
 				unsigned long *parent_rate)
 {
-	int step;
 	u64 fmin, fmax, ftmp;
 	struct scmi_clk *clk = to_scmi_clk(hw);
 
@@ -60,9 +59,9 @@ static long scmi_clk_round_rate(struct clk_hw *hw, unsigned long rate,
 
 	ftmp = rate - fmin;
 	ftmp += clk->info->range.step_size - 1; /* to round up */
-	step = do_div(ftmp, clk->info->range.step_size);
+	do_div(ftmp, clk->info->range.step_size);
 
-	return step * clk->info->range.step_size + fmin;
+	return ftmp * clk->info->range.step_size + fmin;
 }
 
 static int scmi_clk_set_rate(struct clk_hw *hw, unsigned long rate,
-- 
2.7.4


^ permalink raw reply related	[flat|nested] 21+ messages in thread

end of thread, other threads:[~2018-08-02 20:50 UTC | newest]

Thread overview: 21+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2018-07-27 14:01 [PATCH] clk: scmi: Fix the rounding of clock rate Amit Daniel Kachhap
2018-07-27 14:01 ` Amit Daniel Kachhap
2018-07-27 16:37 ` Stephen Boyd
2018-07-27 16:37   ` Stephen Boyd
2018-07-27 16:37   ` Stephen Boyd
2018-07-30  5:33   ` Amit Daniel Kachhap
2018-07-30  5:33     ` Amit Daniel Kachhap
2018-07-30 11:40     ` Sudeep Holla
2018-07-30 11:40       ` Sudeep Holla
2018-07-30 16:26       ` Stephen Boyd
2018-07-30 16:26         ` Stephen Boyd
2018-07-30 16:26         ` Stephen Boyd
2018-07-31  5:55         ` Amit Daniel Kachhap
2018-07-31  5:55           ` Amit Daniel Kachhap
2018-08-02 20:50           ` Stephen Boyd
2018-08-02 20:50             ` Stephen Boyd
2018-08-02 20:50             ` Stephen Boyd
2018-07-31  5:21       ` Amit Daniel Kachhap
2018-07-31  5:21         ` Amit Daniel Kachhap
2018-07-30 11:36 ` Sudeep Holla
2018-07-30 11:36   ` Sudeep Holla

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.