93a10f
From 44cebf3e692053541f362b62f88f327c2c96e70e Mon Sep 17 00:00:00 2001
93a10f
From: Michael Trapp <michael.trapp@sap.com>
93a10f
Date: Tue, 2 Aug 2022 14:16:43 +0200
93a10f
Subject: libuuid: check clock value from LIBUUID_CLOCK_FILE
93a10f
93a10f
The clock value from the LIBUUID_CLOCK_FILE must be checked in
93a10f
case of an update of libuuid. If clock==CLOCK_SEQ_CONT it must
93a10f
be set to a new value.
93a10f
93a10f
Signed-off-by: Karel Zak <kzak@redhat.com>
93a10f
Upstream: http://github.com/util-linux/util-linux/commit/5d1424d85ac9e2a1369ee920038825c154ee5443
93a10f
Addresses: https://bugzilla.redhat.com/show_bug.cgi?id=2141969
93a10f
---
93a10f
 libuuid/src/gen_uuid.c | 5 +++++
93a10f
 1 file changed, 5 insertions(+)
93a10f
93a10f
diff --git a/libuuid/src/gen_uuid.c b/libuuid/src/gen_uuid.c
93a10f
index f557053f7..8dc38559f 100644
93a10f
--- a/libuuid/src/gen_uuid.c
93a10f
+++ b/libuuid/src/gen_uuid.c
93a10f
@@ -274,6 +274,11 @@ static int get_clock(uint32_t *clock_high, uint32_t *clock_low,
93a10f
 			last.tv_usec = tv2;
93a10f
 			adjustment = a;
93a10f
 		}
93a10f
+		// reset in case of reserved CLOCK_SEQ_CONT
93a10f
+		if (clock_seq == CLOCK_SEQ_CONT) {
93a10f
+			last.tv_sec = 0;
93a10f
+			last.tv_usec = 0;
93a10f
+		}
93a10f
 	}
93a10f
 
93a10f
 	if ((last.tv_sec == 0) && (last.tv_usec == 0)) {
93a10f
-- 
93a10f
2.38.1
93a10f