From: Alexey Tikhonov Date: Thu, 3 Oct 2024 16:40:04 +0000 (+0200) Subject: Fix krb5_crypto_us_timeofday() microseconds check X-Git-Tag: krb5-1.22-beta1~74 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=refs%2Fpull%2F1374%2Fhead;p=thirdparty%2Fkrb5.git Fix krb5_crypto_us_timeofday() microseconds check Commit a60db180211a383bd382afe729e9309acb8dcf53 mistakenly reversed the sense of the krb5_crypto_us_timeofday() conditional that enforces fowards movement of the microseconds value within a second. Moreover, the macros ts_after() and ts_incr() should not have been applied to non-timestamp values. Revert the incorrect changes. [ghudson@mit.edu: rewrote commit message] ticket: 9141 (new) tags: pullup target_version: 1.21-next --- diff --git a/src/lib/krb5/os/c_ustime.c b/src/lib/krb5/os/c_ustime.c index f69f2ea4c3..7019ea1970 100644 --- a/src/lib/krb5/os/c_ustime.c +++ b/src/lib/krb5/os/c_ustime.c @@ -106,14 +106,14 @@ krb5_crypto_us_timeofday(krb5_timestamp *seconds, krb5_int32 *microseconds) need to properly handle the case where the administrator intentionally adjusted time backwards. */ if (now.sec == ts_incr(last_time.sec, -1) || - (now.sec == last_time.sec && !ts_after(last_time.usec, now.usec))) { + (now.sec == last_time.sec && now.usec <= last_time.usec)) { /* Correct 'now' to be exactly one microsecond later than 'last_time'. Note that _because_ we perform this hack, 'now' may be _earlier_ than 'last_time', even though the system time is monotonically increasing. */ now.sec = last_time.sec; - now.usec = ts_incr(last_time.usec, 1); + now.usec = last_time.usec + 1; if (now.usec >= 1000000) { now.sec = ts_incr(now.sec, 1); now.usec = 0;