Commit dc6a43e4 authored by Roman Zippel's avatar Roman Zippel Committed by Linus Torvalds

[PATCH] ntp: add time_freq to tick length

This adds the frequency part to ntp_update_frequency().
Signed-off-by: default avatarRoman Zippel <zippel@linux-m68k.org>
Cc: john stultz <johnstul@us.ibm.com>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent ab8783b6
...@@ -37,8 +37,7 @@ long time_tolerance = MAXFREQ; /* frequency tolerance (ppm) */ ...@@ -37,8 +37,7 @@ long time_tolerance = MAXFREQ; /* frequency tolerance (ppm) */
long time_precision = 1; /* clock precision (us) */ long time_precision = 1; /* clock precision (us) */
long time_maxerror = NTP_PHASE_LIMIT; /* maximum error (us) */ long time_maxerror = NTP_PHASE_LIMIT; /* maximum error (us) */
long time_esterror = NTP_PHASE_LIMIT; /* estimated error (us) */ long time_esterror = NTP_PHASE_LIMIT; /* estimated error (us) */
long time_freq = (((NSEC_PER_SEC + HZ/2) % HZ - HZ/2) << SHIFT_USEC) / NSEC_PER_USEC; long time_freq; /* frequency offset (scaled ppm)*/
/* frequency offset (scaled ppm)*/
long time_reftime; /* time at last adjustment (s) */ long time_reftime; /* time at last adjustment (s) */
long time_adjust; long time_adjust;
long time_next_adjust; long time_next_adjust;
...@@ -67,6 +66,7 @@ void ntp_update_frequency(void) ...@@ -67,6 +66,7 @@ void ntp_update_frequency(void)
{ {
tick_length_base = (u64)(tick_usec * NSEC_PER_USEC * USER_HZ) << TICK_LENGTH_SHIFT; tick_length_base = (u64)(tick_usec * NSEC_PER_USEC * USER_HZ) << TICK_LENGTH_SHIFT;
tick_length_base += (s64)CLOCK_TICK_ADJUST << TICK_LENGTH_SHIFT; tick_length_base += (s64)CLOCK_TICK_ADJUST << TICK_LENGTH_SHIFT;
tick_length_base += ((s64)time_freq * NSEC_PER_USEC) << (TICK_LENGTH_SHIFT - SHIFT_USEC);
do_div(tick_length_base, HZ); do_div(tick_length_base, HZ);
...@@ -163,8 +163,6 @@ void second_overflow(void) ...@@ -163,8 +163,6 @@ void second_overflow(void)
* Compute the frequency estimate and additional phase adjustment due * Compute the frequency estimate and additional phase adjustment due
* to frequency error for the next second. * to frequency error for the next second.
*/ */
ltemp = time_freq;
time_adj += shift_right(ltemp,(SHIFT_USEC + SHIFT_HZ - SHIFT_SCALE));
#if HZ == 100 #if HZ == 100
/* /*
...@@ -389,7 +387,7 @@ int do_adjtimex(struct timex *txc) ...@@ -389,7 +387,7 @@ int do_adjtimex(struct timex *txc)
if (txc->modes & ADJ_TICK) if (txc->modes & ADJ_TICK)
tick_usec = txc->tick; tick_usec = txc->tick;
if (txc->modes & ADJ_TICK) if (txc->modes & (ADJ_TICK|ADJ_FREQUENCY|ADJ_OFFSET))
ntp_update_frequency(); ntp_update_frequency();
} /* txc->modes */ } /* txc->modes */
leave: if ((time_status & (STA_UNSYNC|STA_CLOCKERR)) != 0) leave: if ((time_status & (STA_UNSYNC|STA_CLOCKERR)) != 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