Bug 181175

Summary: [WTF] Add clock_gettime based monotonicallyIncreasingTime implementation for Linux and BSDs
Product: WebKit Reporter: Yusuke Suzuki <ysuzuki>
Component: New BugsAssignee: Yusuke Suzuki <ysuzuki>
Status: RESOLVED FIXED    
Severity: Normal CC: annulen, benjamin, cdumez, cgarcia, clopez, cmarcelo, darin, dbates, ews-watchlist, mark.lam, mcatanzaro, saam, sam, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
Attachments:
Description Flags
Patch mcatanzaro: review+

Yusuke Suzuki
Reported 2017-12-27 06:29:26 PST
[WTF] Add clock_gettime based monotonicallyIncreasingTime implementation for Linux and BSDs
Attachments
Patch (1.41 KB, patch)
2017-12-27 06:30 PST, Yusuke Suzuki
mcatanzaro: review+
Yusuke Suzuki
Comment 1 2017-12-27 06:30:44 PST
Konstantin Tokarev
Comment 2 2017-12-27 06:42:08 PST
Comment on attachment 330214 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=330214&action=review > Source/WTF/wtf/CurrentTime.cpp:277 > +} FYI, Qt's implementation of monotonic clock timer uses more sofisticated check, see https://code.woboq.org/qt5/qtbase/src/corelib/kernel/qelapsedtimer_unix.cpp.html#65 and from line 115. On Linux, it always assumes monotonic clock to be present, on other systems it checks values of macros and, if needed, what sysconf(_SC_MONOTONIC_CLOCK) returns
Konstantin Tokarev
Comment 3 2017-12-27 07:10:10 PST
Here is a version of that file under LGPL 2 (so that portions could be imported if needed): http://code.qt.io/cgit/qt/qtbase.git/tree/src/corelib/tools/qelapsedtimer_unix.cpp?h=5.6
Yusuke Suzuki
Comment 4 2017-12-27 08:12:02 PST
Comment on attachment 330214 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=330214&action=review >> Source/WTF/wtf/CurrentTime.cpp:277 >> +} > > FYI, Qt's implementation of monotonic clock timer uses more sofisticated check, see https://code.woboq.org/qt5/qtbase/src/corelib/kernel/qelapsedtimer_unix.cpp.html#65 and from line 115. On Linux, it always assumes monotonic clock to be present, on other systems it checks values of macros and, if needed, what sysconf(_SC_MONOTONIC_CLOCK) returns But actually, are there any Linux/FreeBSD/OpenBSD/NetBSD environments that do not support monotonic clock? For example, libcxx assumes that supported environments have this monotonic clock[1]. And if it fails, it simply crashes. [1]: https://github.com/llvm-mirror/libcxx/blob/master/src/chrono.cpp#L220-L227
Michael Catanzaro
Comment 5 2017-12-27 09:14:08 PST
Comment on attachment 330214 [details] Patch This seems fine to me, since you've ensured that it only affects JSCOnly. GTK and WPE will be happy that they continue using g_get_monotonic_time, since WebKit events rely on WebKit's monotonic time matching GLib's. (It should be the same under the hood -- CLOCK_MONOTONIC -- either way, but continuing to use g_get_monotonic_time seems preferable.)
Konstantin Tokarev
Comment 6 2017-12-27 09:18:34 PST
>libcxx assumes that supported environments have this monotonic clock[1]. And if it fails, it simply crashes. Cool. But at least it checks that CLOCK_MONOTONIC is defined,
Konstantin Tokarev
Comment 7 2017-12-27 16:49:37 PST
>But actually, are there any Linux/FreeBSD/OpenBSD/NetBSD environments that do not support monotonic clock? It seems like no, there aren't
Konstantin Tokarev
Comment 8 2017-12-27 16:57:18 PST
Comment on attachment 330214 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=330214&action=review >>> Source/WTF/wtf/CurrentTime.cpp:277 >>> +} >> >> FYI, Qt's implementation of monotonic clock timer uses more sofisticated check, see https://code.woboq.org/qt5/qtbase/src/corelib/kernel/qelapsedtimer_unix.cpp.html#65 and from line 115. On Linux, it always assumes monotonic clock to be present, on other systems it checks values of macros and, if needed, what sysconf(_SC_MONOTONIC_CLOCK) returns > > But actually, are there any Linux/FreeBSD/OpenBSD/NetBSD environments that do not support monotonic clock? > For example, libcxx assumes that supported environments have this monotonic clock[1]. And if it fails, it simply crashes. > > [1]: https://github.com/llvm-mirror/libcxx/blob/master/src/chrono.cpp#L220-L227 Interestingly, it seems like on Linux CLOCK_MONOTONIC isn't really monotonic, but can be affected by adjtime(3) and NTP. There is additional CLOCK_MONOTONIC_RAW which is available since Linux 2.6.28, which is truly monotonic. Neither Qt nor GLib attempt to use it in their monotonic time wrappers
Carlos Alberto Lopez Perez
Comment 9 2017-12-27 17:11:14 PST
(In reply to Konstantin Tokarev from comment #8) > > Interestingly, it seems like on Linux CLOCK_MONOTONIC isn't really > monotonic, but can be affected by adjtime(3) and NTP. There is additional > CLOCK_MONOTONIC_RAW which is available since Linux 2.6.28, which is truly > monotonic. Neither Qt nor GLib attempt to use it in their monotonic time > wrappers I think both are really monotonic, the difference is that the first is affected by time frequency adjustments via adjtime() (aka: the speed of a second), meanwhile the second doesn't gets affected by that. https://stackoverflow.com/a/14270415
Konstantin Tokarev
Comment 10 2017-12-27 17:44:36 PST
Comment on attachment 330214 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=330214&action=review > Source/WTF/wtf/CurrentTime.cpp:276 > + return static_cast<double>(ts.tv_sec) + ts.tv_nsec * 1.0e9; This code has a bug, it should either be static_cast<double>(ts.tv_sec) + ts.tv_nsec / 1.0e9 or static_cast<double>(ts.tv_sec) * 1.0e9 + ts.tv_nsec I would prefer the former as it will result in numbers of smaller order
Yusuke Suzuki
Comment 11 2017-12-28 06:13:55 PST
Comment on attachment 330214 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=330214&action=review >> Source/WTF/wtf/CurrentTime.cpp:276 >> + return static_cast<double>(ts.tv_sec) + ts.tv_nsec * 1.0e9; > > This code has a bug, it should either be > > static_cast<double>(ts.tv_sec) + ts.tv_nsec / 1.0e9 > > or > > static_cast<double>(ts.tv_sec) * 1.0e9 + ts.tv_nsec > > I would prefer the former as it will result in numbers of smaller order Oops, fixed. double should be in seconds. The former is fine.
Yusuke Suzuki
Comment 12 2017-12-28 06:17:12 PST
Radar WebKit Bug Importer
Comment 13 2018-01-02 13:18:38 PST
Radar WebKit Bug Importer
Comment 14 2018-01-02 13:18:44 PST
Darin Adler
Comment 15 2018-01-05 12:32:36 PST
Comment on attachment 330214 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=330214&action=review >>> Source/WTF/wtf/CurrentTime.cpp:276 >>> + return static_cast<double>(ts.tv_sec) + ts.tv_nsec * 1.0e9; >> >> This code has a bug, it should either be >> >> static_cast<double>(ts.tv_sec) + ts.tv_nsec / 1.0e9 >> >> or >> >> static_cast<double>(ts.tv_sec) * 1.0e9 + ts.tv_nsec >> >> I would prefer the former as it will result in numbers of smaller order > > Oops, fixed. double should be in seconds. The former is fine. I would have suggested 1.0e-9 instead of switching from multiplication to division.
Note You need to log in before you can comment on or make changes to this bug.