diff options
| author | Victor Stinner <victor.stinner@gmail.com> | 2017-10-24 16:53:32 -0700 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2017-10-24 16:53:32 -0700 | 
| commit | 850a18e03e8f8309bc8c39adc6e7d51a4568cd9a (patch) | |
| tree | 56455b89cb152566734d1fc5de5c70029c3baa70 /Include/pythread.h | |
| parent | 3557b05c5a7dfd7d97ddfd3b79aefd53d25e5132 (diff) | |
| download | cpython-git-850a18e03e8f8309bc8c39adc6e7d51a4568cd9a.tar.gz | |
bpo-30768: Recompute timeout on interrupted lock (GH-4103)
Fix the pthread+semaphore implementation of
PyThread_acquire_lock_timed() when called with timeout > 0 and
intr_flag=0: recompute the timeout if sem_timedwait() is interrupted
by a signal (EINTR).
See also the PEP 475.
The pthread implementation of PyThread_acquire_lock() now fails with
a fatal error if the timeout is larger than PY_TIMEOUT_MAX, as done
in the Windows implementation.
The check prevents any risk of overflow in PyThread_acquire_lock().
Add also PY_DWORD_MAX constant.
Diffstat (limited to 'Include/pythread.h')
| -rw-r--r-- | Include/pythread.h | 21 | 
1 files changed, 14 insertions, 7 deletions
| diff --git a/Include/pythread.h b/Include/pythread.h index d6674685f2..eb61033b2d 100644 --- a/Include/pythread.h +++ b/Include/pythread.h @@ -42,16 +42,23 @@ PyAPI_FUNC(int) PyThread_acquire_lock(PyThread_type_lock, int);     and floating-point numbers allowed.  */  #define PY_TIMEOUT_T long long -#define PY_TIMEOUT_MAX PY_LLONG_MAX -/* In the NT API, the timeout is a DWORD and is expressed in milliseconds */ -#if defined (NT_THREADS) -#if 0xFFFFFFFFLL * 1000 < PY_TIMEOUT_MAX -#undef PY_TIMEOUT_MAX -#define PY_TIMEOUT_MAX (0xFFFFFFFFLL * 1000) -#endif +#if defined(_POSIX_THREADS) +   /* PyThread_acquire_lock_timed() uses _PyTime_FromNanoseconds(us * 1000), +      convert microseconds to nanoseconds. */ +#  define PY_TIMEOUT_MAX (PY_LLONG_MAX / 1000) +#elif defined (NT_THREADS) +   /* In the NT API, the timeout is a DWORD and is expressed in milliseconds */ +#  if 0xFFFFFFFFLL * 1000 < PY_LLONG_MAX +#    define PY_TIMEOUT_MAX (0xFFFFFFFFLL * 1000) +#  else +#    define PY_TIMEOUT_MAX PY_LLONG_MAX +#  endif +#else +#  define PY_TIMEOUT_MAX PY_LLONG_MAX  #endif +  /* If microseconds == 0, the call is non-blocking: it returns immediately     even when the lock can't be acquired.     If microseconds > 0, the call waits up to the specified duration. | 
