|
|
@ -8,38 +8,36 @@ class Mutex
|
|
|
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
public:
|
|
|
|
|
|
|
|
|
|
|
|
Mutex(int kind = PTHREAD_MUTEX_DEFAULT);
|
|
|
|
enum MutexType {
|
|
|
|
|
|
|
|
Normal = PTHREAD_MUTEX_NORMAL, // no deadlock check, unlock a non-locked mutex results undefined behaviour
|
|
|
|
|
|
|
|
ErrorCheck = PTHREAD_MUTEX_ERRORCHECK, // error returned when relock or unlocking a non-locked mutex
|
|
|
|
|
|
|
|
Recursive = PTHREAD_MUTEX_RECURSIVE, // Lock counting with error handling.
|
|
|
|
|
|
|
|
Default = PTHREAD_MUTEX_DEFAULT // equals normal
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Mutex(MutexType type = MutexType::Default);
|
|
|
|
~Mutex();
|
|
|
|
~Mutex();
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
MutexType getType() const { return m_type; }
|
|
|
|
* Locks mutex. If already locked, the calling thread shall block until
|
|
|
|
pthread_mutex_t* getPThreadMutex() { return &m_mutex; }
|
|
|
|
* the mutex becomes available.
|
|
|
|
|
|
|
|
* @returns If successful, zero; otherwise, an error number.
|
|
|
|
// If already locked, the calling thread shall block until the mutex becomes available.
|
|
|
|
*/
|
|
|
|
|
|
|
|
int lock();
|
|
|
|
int lock();
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
*
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
int unlock();
|
|
|
|
int unlock();
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
// If currently locked, the call shall return immediately.
|
|
|
|
* If currently locked, the call shall return immediately.
|
|
|
|
|
|
|
|
* @returns Zero if a lock acquired. Otherwise, an error number.
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
int tryLock( const long int intervalSec = 0,
|
|
|
|
int tryLock( const long int intervalSec = 0,
|
|
|
|
const long int intervalNSec = 0 );
|
|
|
|
const long int intervalNSec = 0 );
|
|
|
|
|
|
|
|
|
|
|
|
pthread_mutex_t* getPThreadMutex();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
private:
|
|
|
|
|
|
|
|
|
|
|
|
Mutex(const Mutex& m);
|
|
|
|
Mutex(const Mutex& m);
|
|
|
|
Mutex& operator=(const Mutex& m);
|
|
|
|
Mutex& operator=(const Mutex& m);
|
|
|
|
|
|
|
|
|
|
|
|
pthread_mutex_t m_mutex;
|
|
|
|
pthread_mutex_t m_mutex;
|
|
|
|
|
|
|
|
MutexType m_type;
|
|
|
|
|
|
|
|
pthread_mutexattr_t m_attr;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
#endif // MUTEX_HPP
|
|
|
|
#endif // MUTEX_HPP
|
|
|
|