Hello.

Tony Breeds wrote:

> With these functions implemented we cooperate better with the generic
> timekeeping code.  This obsoletes the need for the timer sysdev as a bonus.

    Aha, I'm seeing it's not merged to mainline yet!  And this can't be merged 
to -rt patch either, beucase -rt alsready has read_persistent_clock() 
implemented since around 2.6.18-rt...

> Signed-off-by: Tony Breeds <[EMAIL PROTECTED]>

> ---

> Patch set updated to powerpc/for-2.6.24

> * Compile tested for arch/powerpc/configs/*_defconfig
> * Booted on pSeries, iSeries, Cell and PS3

>  arch/powerpc/Kconfig         |    3 +
>  arch/powerpc/kernel/time.c   |   85 ++++++++++-------------------------
>  arch/powerpc/sysdev/Makefile |    5 --
>  arch/powerpc/sysdev/timer.c  |   81 ---------------------------------
>  4 files changed, 29 insertions(+), 145 deletions(-)
> 
> Index: working/arch/powerpc/Kconfig
> ===================================================================
> --- working.orig/arch/powerpc/Kconfig
> +++ working/arch/powerpc/Kconfig
> @@ -21,6 +21,9 @@ config MMU
>       bool
>       default y
>  
> +config GENERIC_CMOS_UPDATE
> +     def_bool y
> +
>  config GENERIC_HARDIRQS
>       bool
>       default y
> Index: working/arch/powerpc/kernel/time.c
> ===================================================================
> --- working.orig/arch/powerpc/kernel/time.c
> +++ working/arch/powerpc/kernel/time.c
> @@ -881,12 +837,35 @@ void __init generic_calibrate_decr(void)
>  #endif
>  }
>  
> -unsigned long get_boot_time(void)
> +int update_persistent_clock(struct timespec now)
>  {
>       struct rtc_time tm;
>  
> -     if (ppc_md.get_boot_time)
> -             return ppc_md.get_boot_time();
> +     if (!ppc_md.set_rtc_time)
> +             return 0;
> +
> +     to_tm(now.tv_sec + 1 + timezone_offset, &tm);
> +     tm.tm_year -= 1900;
> +     tm.tm_mon -= 1;
> +
> +     return ppc_md.set_rtc_time(&tm);
> +}
> +
> +unsigned long read_persistent_clock(void)
> +{
> +     struct rtc_time tm;
> +     static int first = 1;
> +
> +     /* XXX this is a litle fragile but will work okay in the short term */
> +     if (first) {
> +             first = 0;
> +             if (ppc_md.time_init)
> +                     timezone_offset = ppc_md.time_init();
> +
> +             /* get_boot_time() isn't guaranteed to be safe to call late */
> +             if (ppc_md.get_boot_time)
> +                     return ppc_md.get_boot_time() -timezone_offset;
> +     }

    This looks incomplete.

> @@ -898,14 +877,10 @@ unsigned long get_boot_time(void)
>  void __init time_init(void)
>  {
>       unsigned long flags;
> -     unsigned long tm = 0;
>       struct div_result res;
>       u64 scale, x;
>       unsigned shift;
>  
> -        if (ppc_md.time_init != NULL)
> -                timezone_offset = ppc_md.time_init();
> -
>       if (__USE_RTC()) {
>               /* 601 processor: dec counts down by 128 every 128ns */
>               ppc_tb_freq = 1000000000;
> @@ -980,19 +955,14 @@ void __init time_init(void)
>       /* Save the current timebase to pretty up CONFIG_PRINTK_TIME */
>       boot_tb = get_tb_or_rtc();
>  
> -     tm = get_boot_time();
> -
>       write_seqlock_irqsave(&xtime_lock, flags);

    Is there any sense of grabbing xtime_lock in time_init() when you've 
implemented read_persistent_clock()?

>  
>       /* If platform provided a timezone (pmac), we correct the time */
>          if (timezone_offset) {
>               sys_tz.tz_minuteswest = -timezone_offset / 60;
>               sys_tz.tz_dsttime = 0;
> -             tm -= timezone_offset;
>          }
>  
> -     xtime.tv_sec = tm;
> -     xtime.tv_nsec = 0;

    Huh? The 'xtime' should now be set by the *generic* timekeeping code using 
read_persistent_clock() -- or else what's the point to implement the function? 
:-/

> @@ -1010,9 +980,6 @@ void __init time_init(void)
>  
>       time_freq = 0;
>  
> -     last_rtc_update = xtime.tv_sec;
> -     set_normalized_timespec(&wall_to_monotonic,
> -                             -xtime.tv_sec, -xtime.tv_nsec);
>       write_sequnlock_irqrestore(&xtime_lock, flags);

    That 'xtime_lock' grabbing should be gone with this patch, and is not. NAK.

WBR, Sergei
_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@ozlabs.org
https://ozlabs.org/mailman/listinfo/linuxppc-dev

Reply via email to