|
@@ -42,12 +42,13 @@ long time_esterror = NTP_PHASE_LIMIT; /* estimated error (us) */
|
|
|
long time_freq; /* frequency offset (scaled ppm)*/
|
|
|
static long time_reftime; /* time at last adjustment (s) */
|
|
|
long time_adjust;
|
|
|
+static long ntp_tick_adj;
|
|
|
|
|
|
static void ntp_update_frequency(void)
|
|
|
{
|
|
|
u64 second_length = (u64)(tick_usec * NSEC_PER_USEC * USER_HZ)
|
|
|
<< TICK_LENGTH_SHIFT;
|
|
|
- second_length += (s64)CLOCK_TICK_ADJUST << TICK_LENGTH_SHIFT;
|
|
|
+ second_length += (s64)ntp_tick_adj << TICK_LENGTH_SHIFT;
|
|
|
second_length += (s64)time_freq << (TICK_LENGTH_SHIFT - SHIFT_NSEC);
|
|
|
|
|
|
tick_length_base = second_length;
|
|
@@ -342,14 +343,16 @@ int do_adjtimex(struct timex *txc)
|
|
|
freq_adj = shift_right(freq_adj, time_constant * 2 +
|
|
|
(SHIFT_PLL + 2) * 2 - SHIFT_NSEC);
|
|
|
if (mtemp >= MINSEC && (time_status & STA_FLL || mtemp > MAXSEC)) {
|
|
|
+ u64 utemp64;
|
|
|
temp64 = time_offset << (SHIFT_NSEC - SHIFT_FLL);
|
|
|
if (time_offset < 0) {
|
|
|
- temp64 = -temp64;
|
|
|
- do_div(temp64, mtemp);
|
|
|
- freq_adj -= temp64;
|
|
|
+ utemp64 = -temp64;
|
|
|
+ do_div(utemp64, mtemp);
|
|
|
+ freq_adj -= utemp64;
|
|
|
} else {
|
|
|
- do_div(temp64, mtemp);
|
|
|
- freq_adj += temp64;
|
|
|
+ utemp64 = temp64;
|
|
|
+ do_div(utemp64, mtemp);
|
|
|
+ freq_adj += utemp64;
|
|
|
}
|
|
|
}
|
|
|
freq_adj += time_freq;
|
|
@@ -400,3 +403,11 @@ leave: if ((time_status & (STA_UNSYNC|STA_CLOCKERR)) != 0)
|
|
|
notify_cmos_timer();
|
|
|
return(result);
|
|
|
}
|
|
|
+
|
|
|
+static int __init ntp_tick_adj_setup(char *str)
|
|
|
+{
|
|
|
+ ntp_tick_adj = simple_strtol(str, NULL, 0);
|
|
|
+ return 1;
|
|
|
+}
|
|
|
+
|
|
|
+__setup("ntp_tick_adj=", ntp_tick_adj_setup);
|