Re: [PATCH 1/2] Add round_jiffies_up and related routines

From: Tejun Heo
Date: Tue Nov 04 2008 - 22:34:10 EST


Alan Stern wrote:
> This patch (as1158) adds round_jiffies_up() and friends. These
> routines work like the analogous round_jiffies() functions, except
> that they will never round down.
>
> The new routines will be useful for timeouts where we don't care
> exactly when the timer expires, provided it doesn't expire too soon.
>
> Signed-off-by: Alan Stern <stern@xxxxxxxxxxxxxxxxxxx>

Heh... I have exactly the same patches but mines were named
round_up_jiffies().

> + unsigned long j0 = jiffies;
> +
> + barrier(); /* Prevent the compiler from aliasing j0 and jiffies */
> + return round_jiffies_common(j + j0, cpu, false) - j0;

jiffies is volatile. No need for explicit barrier, but this part is
necessary for correct operation as if jiffies go up by two the
calculation will wrap and the returned value will be very large. I
think this fix deserves a separate patch and proper explanation.

Thanks.

--
tejun
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/