From owner-freebsd-hackers@FreeBSD.ORG Tue Apr 28 17:56:04 2015 Return-Path: Delivered-To: freebsd-hackers@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by hub.freebsd.org (Postfix) with ESMTPS id E27F1BE1 for ; Tue, 28 Apr 2015 17:56:04 +0000 (UTC) Received: from relay.mailchannels.net (tkt-001-i373.relay.mailchannels.net [174.136.5.175]) by mx1.freebsd.org (Postfix) with ESMTP id D0B7F100E for ; Tue, 28 Apr 2015 17:56:03 +0000 (UTC) X-Sender-Id: duocircle|x-authuser|hippie Received: from smtp5.ore.mailhop.org (ip-10-220-9-73.us-west-2.compute.internal [10.220.9.73]) by relay.mailchannels.net (Postfix) with ESMTPA id 2A2C81D132B; Tue, 28 Apr 2015 15:34:18 +0000 (UTC) X-Sender-Id: duocircle|x-authuser|hippie Received: from smtp5.ore.mailhop.org (smtp5.ore.mailhop.org [10.45.8.167]) (using TLSv1 with cipher DHE-RSA-AES256-SHA) by 0.0.0.0:2500 (trex/5.4.8); Tue, 28 Apr 2015 15:34:18 +0000 X-MC-Relay: Neutral X-MailChannels-SenderId: duocircle|x-authuser|hippie X-MailChannels-Auth-Id: duocircle X-MC-Loop-Signature: 1430235258232:3816386999 X-MC-Ingress-Time: 1430235258232 Received: from c-73-34-117-227.hsd1.co.comcast.net ([73.34.117.227] helo=ilsoft.org) by smtp5.ore.mailhop.org with esmtpsa (TLSv1.2:DHE-RSA-AES256-GCM-SHA384:256) (Exim 4.82) (envelope-from ) id 1Yn7WZ-0001Ji-B4; Tue, 28 Apr 2015 15:34:15 +0000 Received: from revolution.hippie.lan (revolution.hippie.lan [172.22.42.240]) by ilsoft.org (8.14.9/8.14.9) with ESMTP id t3SFYC7p047062; Tue, 28 Apr 2015 09:34:12 -0600 (MDT) (envelope-from ian@freebsd.org) X-Mail-Handler: DuoCircle Outbound SMTP X-Originating-IP: 73.34.117.227 X-Report-Abuse-To: abuse@duocircle.com (see https://support.duocircle.com/support/solutions/articles/5000540958-duocircle-standard-smtp-abuse-information for abuse reporting information) X-MHO-User: U2FsdGVkX1/ckI7zVFHfy6qLo4qJLq+P Message-ID: <1430235252.1157.37.camel@freebsd.org> Subject: Re: System clock always unsynced From: Ian Lepore To: Christian Weisgerber Cc: freebsd-hackers@freebsd.org Date: Tue, 28 Apr 2015 09:34:12 -0600 In-Reply-To: <20150428115741.GA68174@lorvorc.mips.inka.de> References: <1430177037.1157.23.camel@freebsd.org> <20150428115741.GA68174@lorvorc.mips.inka.de> Content-Type: text/plain; charset="us-ascii" X-Mailer: Evolution 3.12.10 FreeBSD GNOME Team Port Mime-Version: 1.0 Content-Transfer-Encoding: 7bit X-AuthUser: hippie X-BeenThere: freebsd-hackers@freebsd.org X-Mailman-Version: 2.1.20 Precedence: list List-Id: Technical Discussions relating to FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 28 Apr 2015 17:56:05 -0000 On Tue, 2015-04-28 at 13:57 +0200, Christian Weisgerber wrote: > Ian Lepore: > > > > Okay, let me rephrase this since the first two replies completely > > > missed the point. This is an API programming question. How is the > > > poorly documented ntp_adjtime() API to be used so the system clock > > > will lose the STA_UNSYNC status and switch from TIME_ERROR to TIME_OK > > > as clock state? > > > > It requires a call to ntp_adjtime() with the MOD_STATUS bit set in > > ntv.modes and the STA_UNSYNC bit clear in ntv.status. > > Well, yes. You omitted the crucial piece of information, but I > think I have figured it out from reading kern_ntptime.c: The > STA_UNSYNC value is _read_ by the kernel and (mostly) _set_ by > userland. It is ntpd that is supposed to clear STA_UNSYNC to signal > the kernel that the time is synchronized. > > The ntp_adjtime(2) man page doesn't say anything how STA_UNSYNC is > used and I had naturally assumed that it was the kernel that cleared > STA_UNSYNC to let ntpd know (that the offsets had been applied or > whatever). > I'm not sure why you "naturally" assumed it was the kernel's responsibility to clear that bit when all the kernel is doing is following ntpd's instructions on how to steer the clock. It's ntpd (or some other external entity) that knows the relationship between current system time and some other authorative source of time. The missing documentation you're looking for is probably RFC 1589. The ntp_adjtime manpage probably should mention it. -- Ian