On Tue, Oct 16, 2007 at 10:35:52PM +0900, Hidetoshi Seto wrote:
> > [3/9] ia64_cputime_to_nsec.patch
>
> We need to define the type of cputime_t.
> It is clear that the unit should be better than msec.
> IBM arches defined it as usec.
>
> On ia64, since the value of ar.itc is source of sched_clock(),
> there are enough parameters to convert cycles to nsecs.
>
> Then, how long time we can save in u64?
>
> 0x 1 0000 0000 0000 0000 in hex
> 18446744073 709 551 616 in decimal
> if in nsec, it will overflow after 213503 days, 584 years.
> if in usec, x1000 above.
>
> It seems enough even in nsec.
>
> So I practically make it in nsec.
> If there is situation which this definition is not acceptable,
> it would be better to have an option to switch the unit between
> nsec and usec.
>
> Thanks,
> H.Seto
>
> Signed-off-by: Hidetoshi Seto <[EMAIL PROTECTED]>
>
> ---
> arch/ia64/ia32/elfcore32.h | 5 +++
> include/asm-ia64/cputime.h | 64
> +++++++++++++++++++++++++++++----------------
> 2 files changed, 47 insertions(+), 22 deletions(-)
>
> Index: linux-2.6.23/include/asm-ia64/cputime.h
> ===================================================================
> --- linux-2.6.23.orig/include/asm-ia64/cputime.h
> +++ linux-2.6.23/include/asm-ia64/cputime.h
> @@ -7,6 +7,10 @@
> #ifndef __IA64_CPUTIME_H
> #define __IA64_CPUTIME_H
>
> +/*
> + * If we have CONFIG_VIRT_CPU_ACCOUNTING, we measure cpu time in nsec.
> + * Otherwise we measure cpu time in jiffies using the generic definitions.
> + */
> #ifndef CONFIG_VIRT_CPU_ACCOUNTING
> #include <asm-generic/cputime.h>
> #else
> @@ -36,47 +40,63 @@
> #define cputime_to_cputime64(__ct) (__ct)
>
> /*
> - * Convert cputime <-> jiffies
> + * Convert cputime <-> jiffies (HZ)
> */
> -#define cputime_to_jiffies(__ct) (__ct)
> -#define jiffies_to_cputime(__jif) (__jif)
> -#define cputime64_to_jiffies64(__ct) (__ct)
> -#define jiffies64_to_cputime64(__jif) (__jif)
> +#define cputime_to_jiffies(__ct) ((__ct) * HZ / NSEC_PER_SEC)
> +#define jiffies_to_cputime(__jif) ((__jif) * NSEC_PER_SEC / HZ)
> +#define cputime64_to_jiffies64(__ct) ((__ct) * HZ / NSEC_PER_SEC)
> +#define jiffies64_to_cputime64(__jif) ((__jif) * NSEC_PER_SEC / HZ)
It looks like cputime64_to_jiffies64 and cputime_to_jiffies will
overflow at (((2^64 -1) / HZ) + 1) ns. In the case where HZ is 1000,
this means it will overflow at (584/1000) years or about 213 days.
Similarly for cputime_to_clock_t(). Is this a problem?
>
> /*
> * Convert cputime <-> milliseconds
> */
> -#define cputime_to_msecs(__ct) jiffies_to_msecs(__ct)
> -#define msecs_to_cputime(__msecs) msecs_to_jiffies(__msecs)
> +#define cputime_to_msecs(__ct) ((__ct) / NSEC_PER_MSEC)
> +#define msecs_to_cputime(__msecs) ((__msecs) * NSEC_PER_MSEC)
>
> /*
> * Convert cputime <-> seconds
> */
> -#define cputime_to_secs(__ct) ((__ct) / HZ)
> -#define secs_to_cputime(__secs) ((__secs) * HZ)
> -
> -/*
> - * Convert cputime <-> timespec
> - */
> -#define timespec_to_cputime(__val) timespec_to_jiffies(__val)
> -#define cputime_to_timespec(__ct,__val) jiffies_to_timespec(__ct,__val)
> +#define cputime_to_secs(__ct) ((__ct) / NSEC_PER_SEC)
> +#define secs_to_cputime(__secs) ((__secs) * NSEC_PER_SEC)
>
> /*
> - * Convert cputime <-> timeval
> + * Convert cputime <-> timespec (nsec)
> */
> -#define timeval_to_cputime(__val) timeval_to_jiffies(__val)
> -#define cputime_to_timeval(__ct,__val) jiffies_to_timeval(__ct,__val)
> +static inline cputime_t timespec_to_cputime(struct timespec *val)
> +{
> + cputime_t ret = val->tv_sec * NSEC_PER_SEC;
> + return (ret + val->tv_nsec);
> +}
> +static inline void cputime_to_timespec(const cputime_t ct, struct timespec
> *val)
> +{
> + val->tv_sec = ct / NSEC_PER_SEC;
> + val->tv_nsec = ct % NSEC_PER_SEC;
> +}
> +
> +/*
> + * Convert cputime <-> timeval (msec)
> + */
> +static inline cputime_t timeval_to_cputime(struct timeval *val)
> +{
> + cputime_t ret = val->tv_sec * NSEC_PER_SEC;
> + return (ret + val->tv_usec * NSEC_PER_USEC);
> +}
> +static inline void cputime_to_timeval(const cputime_t ct, struct timeval
> *val)
> +{
> + val->tv_sec = ct / NSEC_PER_SEC;
> + val->tv_usec = (ct % NSEC_PER_SEC) / NSEC_PER_USEC;
> +}
>
> /*
> - * Convert cputime <-> clock
> + * Convert cputime <-> clock (USER_HZ)
> */
> -#define cputime_to_clock_t(__ct) jiffies_to_clock_t(__ct)
> -#define clock_t_to_cputime(__x) clock_t_to_jiffies(__x)
> +#define cputime_to_clock_t(__ct) ((__ct) * USER_HZ / NSEC_PER_SEC)
> +#define clock_t_to_cputime(__x) ((__x) * NSEC_PER_SEC / USER_HZ)
>
> /*
> * Convert cputime64 to clock.
> */
> -#define cputime64_to_clock_t(__ct) jiffies_64_to_clock_t(__ct)
> +#define cputime64_to_clock_t(__ct) cputime_to_clock_t((cputime_t)__ct)
>
> #endif /* CONFIG_VIRT_CPU_ACCOUNTING */
> #endif /* __IA64_CPUTIME_H */
> Index: linux-2.6.23/arch/ia64/ia32/elfcore32.h
> ===================================================================
> --- linux-2.6.23.orig/arch/ia64/ia32/elfcore32.h
> +++ linux-2.6.23/arch/ia64/ia32/elfcore32.h
> @@ -30,7 +30,12 @@
> int si_errno; /* errno */
> };
>
> +#ifdef CONFIG_VIRT_CPU_ACCOUNTING
> +#define cputime_to_timeval(a,b) \
> + do { (b)->tv_usec = 0; (b)->tv_sec = (a)/NSEC_PER_SEC; } while(0)
> +#else
> #define jiffies_to_timeval(a,b) do { (b)->tv_usec = 0; (b)->tv_sec = (a)/HZ;
> }while(0)
> +#endif
>
> struct elf_prstatus
> {
>
>
> -
> To unsubscribe from this list: send the line "unsubscribe linux-ia64" in
> the body of a message to [EMAIL PROTECTED]
> More majordomo info at http://vger.kernel.org/majordomo-info.html
--
Horms
H: http://www.vergenet.net/~horms/
W: http://www.valinux.co.jp/en/
-
To unsubscribe from this list: send the line "unsubscribe linux-ia64" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at http://vger.kernel.org/majordomo-info.html