diff options
author | Ryo Nakamura <upa@haeena.net> | 2022-12-11 13:23:41 +0900 |
---|---|---|
committer | Ryo Nakamura <upa@haeena.net> | 2022-12-11 13:23:41 +0900 |
commit | d27db01d8d427b9a3ade4e82e73dba1bb3802781 (patch) | |
tree | a1d7c690413449d14ed411f2f7b63d729620e777 /src/atomic.h | |
parent | 45cde99a85269315b9f56b1523223e90973c7bd1 (diff) |
use pthread_cleanup to acquire and release lock
In chunk_prepare(), if multiple threads wait for acquiring f->lock,
and then pthread_cancel() is called, the waiting threads are never
canceled because pthread_mutex_lock() is not a cancellation point.
So, use pthread_cleanup_push/pop to release the lock.
Diffstat (limited to 'src/atomic.h')
-rw-r--r-- | src/atomic.h | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/src/atomic.h b/src/atomic.h index e0e735d..cdbd21e 100644 --- a/src/atomic.h +++ b/src/atomic.h @@ -55,4 +55,17 @@ static inline void lock_release(lock *l) } } +static inline void lock_release_via_cleanup(void *l) +{ + lock_release(l); +} + +#define LOCK_ACQUIRE_THREAD(l) \ + lock_acquire(l); \ + pthread_cleanup_push(lock_release_via_cleanup, l) + + +#define LOCK_RELEASE_THREAD(l) \ + pthread_cleanup_pop(1) + #endif /* _ATOMIC_H_ */ |