mirror of
https://github.com/openssl/openssl.git
synced 2025-03-31 20:10:45 +08:00
Round up nano secs when converting OSSL_TIME to struct timeval
struct timeval doesn't support nanosecs but OSSL_TIME does. We round up any nanosecs to ensure that a non-zero input always results in a non-zero output. This fixes a quic-client fuzzer hang. Fixes #22437 Reviewed-by: Hugo Landau <hlandau@openssl.org> Reviewed-by: Tomas Mraz <tomas@openssl.org> (Merged from https://github.com/openssl/openssl/pull/22440)
This commit is contained in:
parent
055f3dd140
commit
c239bc9e96
@ -45,6 +45,13 @@ typedef struct {
|
||||
#define ossl_us2time(us) ossl_ticks2time((us) * OSSL_TIME_US)
|
||||
#define ossl_time2us(t) (ossl_time2ticks(t) / OSSL_TIME_US)
|
||||
|
||||
/*
|
||||
* Arithmetic operations on times.
|
||||
* These operations are saturating, in that an overflow or underflow returns
|
||||
* the largest or smallest value respectively.
|
||||
*/
|
||||
OSSL_SAFE_MATH_UNSIGNED(time, uint64_t)
|
||||
|
||||
/* Convert a tick count into a time */
|
||||
static ossl_unused ossl_inline
|
||||
OSSL_TIME ossl_ticks2time(uint64_t ticks)
|
||||
@ -84,6 +91,15 @@ static ossl_unused ossl_inline
|
||||
struct timeval ossl_time_to_timeval(OSSL_TIME t)
|
||||
{
|
||||
struct timeval tv;
|
||||
int err = 0;
|
||||
|
||||
/*
|
||||
* Round up any nano secs which struct timeval doesn't support. Ensures that
|
||||
* we never return a zero time if the input time is non zero
|
||||
*/
|
||||
t.t = safe_add_time(t.t, OSSL_TIME_US - 1, &err);
|
||||
if (err)
|
||||
t = ossl_time_infinite();
|
||||
|
||||
#ifdef _WIN32
|
||||
tv.tv_sec = (long int)(t.t / OSSL_TIME_SECOND);
|
||||
@ -151,13 +167,6 @@ int ossl_time_is_infinite(OSSL_TIME t)
|
||||
return ossl_time_compare(t, ossl_time_infinite()) == 0;
|
||||
}
|
||||
|
||||
/*
|
||||
* Arithmetic operations on times.
|
||||
* These operations are saturating, in that an overflow or underflow returns
|
||||
* the largest or smallest value respectively.
|
||||
*/
|
||||
OSSL_SAFE_MATH_UNSIGNED(time, uint64_t)
|
||||
|
||||
static ossl_unused ossl_inline
|
||||
OSSL_TIME ossl_time_add(OSSL_TIME a, OSSL_TIME b)
|
||||
{
|
||||
|
Loading…
x
Reference in New Issue
Block a user