|
@@ -43,8 +43,6 @@
|
|
#include <asm/pcic.h>
|
|
#include <asm/pcic.h>
|
|
#include <asm/of_device.h>
|
|
#include <asm/of_device.h>
|
|
|
|
|
|
-extern unsigned long wall_jiffies;
|
|
|
|
-
|
|
|
|
DEFINE_SPINLOCK(rtc_lock);
|
|
DEFINE_SPINLOCK(rtc_lock);
|
|
enum sparc_clock_type sp_clock_typ;
|
|
enum sparc_clock_type sp_clock_typ;
|
|
DEFINE_SPINLOCK(mostek_lock);
|
|
DEFINE_SPINLOCK(mostek_lock);
|
|
@@ -449,7 +447,7 @@ unsigned long long sched_clock(void)
|
|
|
|
|
|
/* Ok, my cute asm atomicity trick doesn't work anymore.
|
|
/* Ok, my cute asm atomicity trick doesn't work anymore.
|
|
* There are just too many variables that need to be protected
|
|
* There are just too many variables that need to be protected
|
|
- * now (both members of xtime, wall_jiffies, et al.)
|
|
|
|
|
|
+ * now (both members of xtime, et al.)
|
|
*/
|
|
*/
|
|
void do_gettimeofday(struct timeval *tv)
|
|
void do_gettimeofday(struct timeval *tv)
|
|
{
|
|
{
|
|
@@ -459,26 +457,17 @@ void do_gettimeofday(struct timeval *tv)
|
|
unsigned long max_ntp_tick = tick_usec - tickadj;
|
|
unsigned long max_ntp_tick = tick_usec - tickadj;
|
|
|
|
|
|
do {
|
|
do {
|
|
- unsigned long lost;
|
|
|
|
-
|
|
|
|
seq = read_seqbegin_irqsave(&xtime_lock, flags);
|
|
seq = read_seqbegin_irqsave(&xtime_lock, flags);
|
|
usec = do_gettimeoffset();
|
|
usec = do_gettimeoffset();
|
|
- lost = jiffies - wall_jiffies;
|
|
|
|
|
|
|
|
/*
|
|
/*
|
|
* If time_adjust is negative then NTP is slowing the clock
|
|
* If time_adjust is negative then NTP is slowing the clock
|
|
* so make sure not to go into next possible interval.
|
|
* so make sure not to go into next possible interval.
|
|
* Better to lose some accuracy than have time go backwards..
|
|
* Better to lose some accuracy than have time go backwards..
|
|
*/
|
|
*/
|
|
- if (unlikely(time_adjust < 0)) {
|
|
|
|
|
|
+ if (unlikely(time_adjust < 0))
|
|
usec = min(usec, max_ntp_tick);
|
|
usec = min(usec, max_ntp_tick);
|
|
|
|
|
|
- if (lost)
|
|
|
|
- usec += lost * max_ntp_tick;
|
|
|
|
- }
|
|
|
|
- else if (unlikely(lost))
|
|
|
|
- usec += lost * tick_usec;
|
|
|
|
-
|
|
|
|
sec = xtime.tv_sec;
|
|
sec = xtime.tv_sec;
|
|
usec += (xtime.tv_nsec / 1000);
|
|
usec += (xtime.tv_nsec / 1000);
|
|
} while (read_seqretry_irqrestore(&xtime_lock, seq, flags));
|
|
} while (read_seqretry_irqrestore(&xtime_lock, seq, flags));
|
|
@@ -521,8 +510,7 @@ static int sbus_do_settimeofday(struct timespec *tv)
|
|
* wall time. Discover what correction gettimeofday() would have
|
|
* wall time. Discover what correction gettimeofday() would have
|
|
* made, and then undo it!
|
|
* made, and then undo it!
|
|
*/
|
|
*/
|
|
- nsec -= 1000 * (do_gettimeoffset() +
|
|
|
|
- (jiffies - wall_jiffies) * (USEC_PER_SEC / HZ));
|
|
|
|
|
|
+ nsec -= 1000 * do_gettimeoffset();
|
|
|
|
|
|
wtm_sec = wall_to_monotonic.tv_sec + (xtime.tv_sec - sec);
|
|
wtm_sec = wall_to_monotonic.tv_sec + (xtime.tv_sec - sec);
|
|
wtm_nsec = wall_to_monotonic.tv_nsec + (xtime.tv_nsec - nsec);
|
|
wtm_nsec = wall_to_monotonic.tv_nsec + (xtime.tv_nsec - nsec);
|