]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
time-util: fall back to CLOCK_MONOTONIC if CLOCK_BOOTTIME unsupported 2843/head
authorLubomir Rintel <lkundrak@v3.sk>
Tue, 15 Mar 2016 11:43:33 +0000 (12:43 +0100)
committerLubomir Rintel <lkundrak@v3.sk>
Tue, 15 Mar 2016 11:43:33 +0000 (12:43 +0100)
It was added in 2.6.39, and causes an assertion to fail when running in mock
hosted on 2.6.23-based RHEL-6:

Assertion 'clock_gettime(map_clock_id(clock_id), &ts) == 0' failed at systemd/src/basic/time-util.c:70, function now(). Aborting.

src/basic/time-util.c

index 7ca764abeb0bda412a9c27b05c0fdbad98d4426a..c16460a198e5ceb13c6676212cb6dda98575c076 100644 (file)
@@ -47,12 +47,15 @@ static clockid_t map_clock_id(clockid_t c) {
         /* Some more exotic archs (s390, ppc, …) lack the "ALARM" flavour of the clocks. Thus, clock_gettime() will
          * fail for them. Since they are essentially the same as their non-ALARM pendants (their only difference is
          * when timers are set on them), let's just map them accordingly. This way, we can get the correct time even on
-         * those archs. */
+         * those archs.
+         *
+         * Also, older kernels don't support CLOCK_BOOTTIME: fall back to CLOCK_MONOTONIC. */
 
         switch (c) {
 
+        case CLOCK_BOOTTIME:
         case CLOCK_BOOTTIME_ALARM:
-                return CLOCK_BOOTTIME;
+                return clock_boottime_or_monotonic ();
 
         case CLOCK_REALTIME_ALARM:
                 return CLOCK_REALTIME;