Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754404AbdFWJPD (ORCPT ); Fri, 23 Jun 2017 05:15:03 -0400 Received: from ozlabs.org ([103.22.144.67]:59887 "EHLO ozlabs.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754032AbdFWJPC (ORCPT ); Fri, 23 Jun 2017 05:15:02 -0400 X-powerpc-patch-notification: thanks X-powerpc-patch-commit: d4cfb11387ee29ba4626546c676fd25c7abbbbb2 In-Reply-To: <20170527080452.GA14021@fergus.ozlabs.ibm.com> To: Paul Mackerras , linuxppc-dev@ozlabs.org From: Michael Ellerman Cc: John Stultz , linux-kernel@vger.kernel.org Subject: Re: powerpc: Convert VDSO update function to use new update_vsyscall interface Message-Id: <3wvCTJ6Yvmz9s8P@ozlabs.org> Date: Fri, 23 Jun 2017 19:15:00 +1000 (AEST) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2135 Lines: 43 On Sat, 2017-05-27 at 08:04:52 UTC, Paul Mackerras wrote: > This converts the powerpc VDSO time update function to use the new > interface introduced in commit 576094b7f0aa ("time: Introduce new > GENERIC_TIME_VSYSCALL", 2012-09-11). Where the old interface gave > us the time as of the last update in seconds and whole nanoseconds, > with the new interface we get the nanoseconds part effectively in > a binary fixed-point format with tk->tkr_mono.shift bits to the > right of the binary point. > > With the old interface, the fractional nanoseconds got truncated, > meaning that the value returned by the VDSO clock_gettime function > would have about 1ns of jitter in it compared to the value computed > by the generic timekeeping code in the kernel. > > The powerpc VDSO time functions (clock_gettime and gettimeofday) > already work in units of 2^-32 seconds, or 0.23283 ns, because that > makes it simple to split the result into seconds and fractional > seconds, and represent the fractional seconds in either microseconds > or nanoseconds. This is good enough accuracy for now, so this patch > avoids changing how the VDSO works or the interface in the VDSO data > page. > > This patch converts the powerpc update_vsyscall_old to be called > update_vsyscall and use the new interface. We convert the fractional > second to units of 2^-32 seconds without truncating to whole nanoseconds. > (There is still a conversion to whole nanoseconds for any legacy users > of the vdso_data/systemcfg stamp_xtime field.) > > In addition, this improves the accuracy of the computation of tb_to_xs > for those systems with high-frequency timebase clocks (>= 268.5 MHz) > by doing the right shift in two parts, one before the multiplication and > one after, rather than doing the right shift before the multiplication. > (We can't do all of the right shift after the multiplication unless we > use 128-bit arithmetic.) > > Signed-off-by: Paul Mackerras > Acked-by: John Stultz Applied to powerpc next-test, thanks. https://git.kernel.org/powerpc/c/d4cfb11387ee29ba4626546c676fd2 cheers