Commit c948c5e3 authored by Andrew Morton's avatar Andrew Morton Committed by Linus Torvalds

[PATCH] alpha: fix do_settimeofday() for new API

parent 99f2577a
...@@ -445,12 +445,15 @@ do_gettimeofday(struct timeval *tv) ...@@ -445,12 +445,15 @@ do_gettimeofday(struct timeval *tv)
tv->tv_usec = usec; tv->tv_usec = usec;
} }
void int
do_settimeofday(struct timeval *tv) do_settimeofday(struct timespec *tv)
{ {
unsigned long delta_usec; unsigned long delta_nsec;
long sec, usec; long sec, nsec;
if ((unsigned long)tv->tv_nsec >= NSEC_PER_SEC)
return -EINVAL;
write_seqlock_irq(&xtime_lock); write_seqlock_irq(&xtime_lock);
/* The offset that is added into time in do_gettimeofday above /* The offset that is added into time in do_gettimeofday above
...@@ -458,31 +461,33 @@ do_settimeofday(struct timeval *tv) ...@@ -458,31 +461,33 @@ do_settimeofday(struct timeval *tv)
time. Without this, a full-tick error is possible. */ time. Without this, a full-tick error is possible. */
#ifdef CONFIG_SMP #ifdef CONFIG_SMP
delta_usec = (jiffies - wall_jiffies) * (1000000 / HZ); delta_nsec = (jiffies - wall_jiffies) * (NSEC_PER_SEC / HZ);
#else #else
delta_usec = rpcc() - state.last_time; delta_nsec = rpcc() - state.last_time;
delta_usec = (delta_usec * state.scaled_ticks_per_cycle delta_nsec = (delta_nsec * state.scaled_ticks_per_cycle
+ state.partial_tick + state.partial_tick
+ ((jiffies - wall_jiffies) << FIX_SHIFT)) * 15625; + ((jiffies - wall_jiffies) << FIX_SHIFT)) * 15625;
delta_usec = ((delta_usec / ((1UL << (FIX_SHIFT-6-1)) * HZ)) + 1) / 2; delta_nsec = ((delta_nsec / ((1UL << (FIX_SHIFT-6-1)) * HZ)) + 1) / 2;
delta_nsec *= 1000;
#endif #endif
sec = tv->tv_sec; sec = tv->tv_sec;
usec = tv->tv_usec; nsec = tv->tv_nsec;
usec -= delta_usec; nsec -= delta_nsec;
if (usec < 0) { if (nsec < 0) {
usec += 1000000; nsec += NSEC_PER_SEC;
sec -= 1; sec -= 1;
} }
xtime.tv_sec = sec; xtime.tv_sec = sec;
xtime.tv_nsec = (usec / 1000); xtime.tv_nsec = nsec;
time_adjust = 0; /* stop active adjtime() */ time_adjust = 0; /* stop active adjtime() */
time_status |= STA_UNSYNC; time_status |= STA_UNSYNC;
time_maxerror = NTP_PHASE_LIMIT; time_maxerror = NTP_PHASE_LIMIT;
time_esterror = NTP_PHASE_LIMIT; time_esterror = NTP_PHASE_LIMIT;
write_sequnlock_irq(&xtime_lock); write_sequnlock_irq(&xtime_lock);
return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment