Intel(R) Threading Building Blocks Doxygen Documentation
version 4.2.3
|
Classes | |
class | tbb::null_mutex |
A mutex which does nothing. More... | |
class | tbb::null_rw_mutex |
A rw mutex which does nothing. More... | |
class | tbb::queuing_mutex |
Queuing mutex with local-only spinning. More... | |
class | tbb::queuing_rw_mutex |
Queuing reader-writer mutex with local-only spinning. More... | |
class | tbb::spin_mutex |
A lock that occupies a single byte. More... | |
class | tbb::spin_rw_mutex_v3 |
Fast, unfair, spinning reader-writer lock with backoff and writer-preference. More... | |
Macros | |
#define | __TBB_DECL_ATOMIC(T) |
Primary template for atomic. More... | |
Typedefs | |
typedef interface7::internal::padded_mutex< spin_mutex, false > | tbb::speculative_spin_mutex |
A cross-platform spin mutex with speculative lock acquisition. More... | |
typedef interface7::internal::padded_mutex< tbb::spin_rw_mutex, true > | tbb::interface8::speculative_spin_rw_mutex |
A cross-platform spin reader/writer mutex with speculative lock acquisition. More... | |
#define __TBB_DECL_ATOMIC | ( | T | ) |
Primary template for atomic.
See the Reference for details.
A cross-platform spin mutex with speculative lock acquisition.
On platforms with proper HW support, this lock may speculatively execute its critical sections, using HW mechanisms to detect real data races and ensure atomicity of the critical sections. In particular, it uses Intel(R) Transactional Synchronization Extensions (Intel(R) TSX). Without such HW support, it behaves like a spin_mutex. It should be used for locking short critical sections where the lock is contended but the data it protects are not. If zero-initialized, the mutex is considered unheld.
Definition at line 205 of file spin_mutex.h.
typedef interface7::internal::padded_mutex<tbb::spin_rw_mutex,true> tbb::interface8::speculative_spin_rw_mutex |
A cross-platform spin reader/writer mutex with speculative lock acquisition.
On platforms with proper HW support, this lock may speculatively execute its critical sections, using HW mechanisms to detect real data races and ensure atomicity of the critical sections. In particular, it uses Intel(R) Transactional Synchronization Extensions (Intel(R) TSX). Without such HW support, it behaves like a spin_rw_mutex. It should be used for locking short critical sections where the lock is contended but the data it protects are not.
Definition at line 245 of file spin_rw_mutex.h.