Re: [RFC][PATCH 1/4] add jiffies_to_nsecs() helper and fix up size of usecs

From: Nishanth Aravamudan
Date: Thu Jul 14 2005 - 16:04:24 EST


On 14.07.2005 [13:54:47 -0700], Dave Hansen wrote:
> On Thu, 2005-07-14 at 13:28 -0700, Nishanth Aravamudan wrote:
> > +static inline u64 jiffies_to_nsecs(const unsigned long j)
> > +{
> > +#if HZ <= NSEC_PER_SEC && !(NSEC_PER_SEC % HZ)
> > + return (NSEC_PER_SEC / HZ) * (u64)j;
> > +#elif HZ > NSEC_PER_SEC && !(HZ % NSEC_PER_SEC)
> > + return ((u64)j + (HZ / NSEC_PER_SEC) - 1)/(HZ / NSEC_PER_SEC);
> > +#else
> > + return ((u64)j * NSEC_PER_SEC) / HZ;
> > +#endif
> > +}
>
> That might look a little better something like:
>
> static inline u64 jiffies_to_nsecs(const unsigned long __j)
> {
> u64 j = __j;
>
> if (HZ <= NSEC_PER_SEC && !(NSEC_PER_SEC % HZ))
> return (NSEC_PER_SEC / HZ) * j;
> else if (HZ > NSEC_PER_SEC && !(HZ % NSEC_PER_SEC))
> return (j + (HZ / NSEC_PER_SEC) - 1)/(HZ / NSEC_PER_SEC);
> else
> return (j * NSEC_PER_SEC) / HZ;
> }
>
> Compilers are smart :)

Well, I was trying to keep it similar to the other conversion functions.
I guess the compiler can evaluate the conditional full of constants at
compile-time regardless of whether it is #if or if ().

I can make these changes if others would like them as well.

Thanks,
Nish
-
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/