From: Victor Stinner Date: Thu, 1 Oct 2015 06:44:03 +0000 (+0200) Subject: Fix _PyTime_AsTimevalStruct_impl() on OpenBSD X-Git-Tag: v3.6.0a1~1363 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=b7a8af20ff09efdfa6896ecaff7d036562c17897;p=python Fix _PyTime_AsTimevalStruct_impl() on OpenBSD On the x86 OpenBSD 5.8 buildbot, the integer overflow check is ignored. Copy the tv_sec variable into a Py_time_t variable instead of "simply" casting it to Py_time_t, to fix the integer overflow check. --- diff --git a/Python/pytime.c b/Python/pytime.c index 9889a3b53b..53611b1ec1 100644 --- a/Python/pytime.c +++ b/Python/pytime.c @@ -454,7 +454,7 @@ static int _PyTime_AsTimevalStruct_impl(_PyTime_t t, struct timeval *tv, _PyTime_round_t round, int raise) { - _PyTime_t secs; + _PyTime_t secs, secs2; int us; int res; @@ -467,7 +467,8 @@ _PyTime_AsTimevalStruct_impl(_PyTime_t t, struct timeval *tv, #endif tv->tv_usec = us; - if (res < 0 || (_PyTime_t)tv->tv_sec != secs) { + secs2 = (_PyTime_t)tv->tv_sec; + if (res < 0 || secs2 != secs) { if (raise) error_time_t_overflow(); return -1;