|
|
12089cc |
From a97ad0c4b447a132a322cedc3a5f7fa4cab4b304 Mon Sep 17 00:00:00 2001
|
|
|
12089cc |
From: Miroslav Lichvar <mlichvar@redhat.com>
|
|
|
12089cc |
Date: Thu, 1 Aug 2013 19:31:35 +0200
|
|
|
12089cc |
Subject: [PATCH] ntp: Make periodic RTC update more reliable
|
|
|
12089cc |
|
|
|
12089cc |
The current code requires that the scheduled update of the RTC happens
|
|
|
12089cc |
in the closest tick to the half of the second. This seems to be
|
|
|
12089cc |
difficult to achieve reliably. The scheduled work may be missing the
|
|
|
12089cc |
target time by a tick or two and be constantly rescheduled every second.
|
|
|
12089cc |
|
|
|
12089cc |
Relax the limit to 10 ticks. As a typical RTC drifts in the 11-minute
|
|
|
12089cc |
update interval by several milliseconds, this shouldn't affect the
|
|
|
12089cc |
overall accuracy of the RTC much.
|
|
|
12089cc |
|
|
|
12089cc |
Signed-off-by: Miroslav Lichvar <mlichvar@redhat.com>
|
|
|
12089cc |
Signed-off-by: John Stultz <john.stultz@linaro.org>
|
|
|
12089cc |
---
|
|
|
12089cc |
kernel/time/ntp.c | 3 ++-
|
|
|
12089cc |
1 file changed, 2 insertions(+), 1 deletion(-)
|
|
|
12089cc |
|
|
|
12089cc |
diff --git a/kernel/time/ntp.c b/kernel/time/ntp.c
|
|
|
12089cc |
index 8f5b3b9..ab1fa7c 100644
|
|
|
12089cc |
--- a/kernel/time/ntp.c
|
|
|
12089cc |
+++ b/kernel/time/ntp.c
|
|
|
12089cc |
@@ -475,6 +475,7 @@ static void sync_cmos_clock(struct work_struct *work)
|
|
|
12089cc |
* called as close as possible to 500 ms before the new second starts.
|
|
|
12089cc |
* This code is run on a timer. If the clock is set, that timer
|
|
|
12089cc |
* may not expire at the correct time. Thus, we adjust...
|
|
|
12089cc |
+ * We want the clock to be within a couple of ticks from the target.
|
|
|
12089cc |
*/
|
|
|
12089cc |
if (!ntp_synced()) {
|
|
|
12089cc |
/*
|
|
|
12089cc |
@@ -485,7 +486,7 @@ static void sync_cmos_clock(struct work_struct *work)
|
|
|
12089cc |
}
|
|
|
12089cc |
|
|
|
12089cc |
getnstimeofday(&now;;
|
|
|
12089cc |
- if (abs(now.tv_nsec - (NSEC_PER_SEC / 2)) <= tick_nsec / 2) {
|
|
|
12089cc |
+ if (abs(now.tv_nsec - (NSEC_PER_SEC / 2)) <= tick_nsec * 5) {
|
|
|
12089cc |
struct timespec adjust = now;
|
|
|
12089cc |
|
|
|
12089cc |
fail = -ENODEV;
|
|
|
12089cc |
--
|
|
|
12089cc |
1.7.9.5
|
|
|
12089cc |
|