Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

parking_lot.c should use _PyTime_GetMonotonicClock() when available #112606

Closed
Tracked by #108219
colesbury opened this issue Dec 1, 2023 · 3 comments
Closed
Tracked by #108219

parking_lot.c should use _PyTime_GetMonotonicClock() when available #112606

colesbury opened this issue Dec 1, 2023 · 3 comments
Assignees
Labels
3.13 bugs and security fixes topic-free-threading type-bug An unexpected behavior, bug, or error

Comments

@colesbury
Copy link
Contributor

colesbury commented Dec 1, 2023

Bug report

The _PySemaphore_PlatformWait function in parking_lot.c has three implementations:

  • WaitForSingleObjectEx (for Windows)
  • sem_timedwait (Linux and most other POSIX platforms)
  • pthread_cond_timedwait (macOS and possibly other platforms that don't have sem_timedwait)

We should follow the pattern used in thread_pthread.h where we prefer functions that support CLOCK_MONOTONIC. These are sem_clockwait and pthread_cond_timedwait after setting pthread_condattr_setclock.

Additionally, we should use _PyTime_AsTimespec_clamp instead of _PyTime_AsTimespec (we don't want to raise errors in these code paths).

Note that:

  1. Windows doesn't need any changes because WaitForSingleObjectEx isn't relative to any specific clock -- it just takes a timeout for N milliseconds in the future
  2. macOS doesn't support pthread_condattr_setclock, so we're stuck with the system clock on macOS. It's not clear to me if we use the pthread_cond_timedwait for any other OS.

Linked PRs

@mattprodani
Copy link
Contributor

mattprodani commented Dec 4, 2023

Splitting into two PRs for sem_timedwait and pthread_cond_timedwait implementations. Working on finishing up the condvar implementation to share fields that initialize the proper pthread_condattr_t from thread_pthread.h as per notes.

@vstinner
Copy link
Member

vstinner commented Dec 6, 2023

As someone writes a fix for the mutex, ping me, I can review it ;-)

erlend-aasland pushed a commit that referenced this issue Jan 30, 2024
…when available (#112616)

Add a configure define for HAVE_PTHREAD_COND_TIMEDWAIT_RELATIVE_NP and
replaces pthread_cond_timedwait() with pthread_cond_timedwait_relative_np()
for relative time when supported in semaphore waiting logic.
aisk pushed a commit to aisk/cpython that referenced this issue Feb 11, 2024
aisk pushed a commit to aisk/cpython that referenced this issue Feb 11, 2024
…lot.c when available (python#112616)

Add a configure define for HAVE_PTHREAD_COND_TIMEDWAIT_RELATIVE_NP and
replaces pthread_cond_timedwait() with pthread_cond_timedwait_relative_np()
for relative time when supported in semaphore waiting logic.
Glyphack pushed a commit to Glyphack/cpython that referenced this issue Sep 2, 2024
@colesbury
Copy link
Contributor Author

Closing this as the relevant PRs landed a while ago.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
3.13 bugs and security fixes topic-free-threading type-bug An unexpected behavior, bug, or error
Projects
None yet
Development

No branches or pull requests

3 participants