Re: [PATCH] clocksource: use clocksource_freq2mult() helper
From: John Stultz
Date: Fri Apr 08 2016 - 00:55:36 EST
On Wed, Mar 16, 2016 at 3:21 AM, Alexander Kuleshov
<kuleshovmail@xxxxxxxxx> wrote:
> which is introduced in the 7aca0c072 commit to simplify calculation of
> the mult and shift in the clocks_calc_mult_shift().
>
> Signed-off-by: Alexander Kuleshov <kuleshovmail@xxxxxxxxx>
> ---
> kernel/time/clocksource.c | 4 +---
> 1 file changed, 1 insertion(+), 3 deletions(-)
>
> diff --git a/kernel/time/clocksource.c b/kernel/time/clocksource.c
> index 56ece14..de57923 100644
> --- a/kernel/time/clocksource.c
> +++ b/kernel/time/clocksource.c
> @@ -80,9 +80,7 @@ clocks_calc_mult_shift(u32 *mult, u32 *shift, u32 from, u32 to, u32 maxsec)
> * accuracy and fits the maxsec conversion range:
> */
> for (sft = 32; sft > 0; sft--) {
> - tmp = (u64) to << sft;
> - tmp += from / 2;
> - do_div(tmp, from);
> + tmp = clocksource_freq2mult(from, sft, to);
> if ((tmp >> sftacc) == 0)
> break;
> }
I'm worried you never tested this, as its clearly broken, and keeps my
systems from booting.
clocksource_freq2mult returns a u32. In the code being removed, tmp is
a u64. So this may truncate the high bits.
Since sftacc is often 32, this causes it to exit prematurely on the
first pass through the loop.
Please do make sure to boot test what you send out. I spent some time
thinking I had broken my qemu testing setup before I realized it was
this simple looking patch.
thanks
-john