#ifndef PMEMOBJ_MUTEX_HPP
#define PMEMOBJ_MUTEX_HPP
#include "libpmemobj++/detail/pexceptions.hpp"
#include "libpmemobj/thread.h"
#include "libpmemobj/tx_base.h"
namespace pmem
{
namespace obj
{
class mutex {
public:
typedef PMEMmutex *native_handle_type;
mutex()
{
PMEMobjpool *pop;
if ((pop = pmemobj_pool_by_ptr(&plock)) == nullptr)
throw lock_error(1, std::generic_category(),
"Persistent mutex not from persistent"
"memory.");
pmemobj_mutex_zero(pop, &plock);
}
~mutex() = default;
void
lock()
{
PMEMobjpool *pop = pmemobj_pool_by_ptr(this);
if (int ret = pmemobj_mutex_lock(pop, &this->plock))
throw lock_error(ret, std::system_category(),
"Failed to lock a mutex.");
}
bool
try_lock()
{
PMEMobjpool *pop = pmemobj_pool_by_ptr(this);
int ret = pmemobj_mutex_trylock(pop, &this->plock);
if (ret == 0)
return true;
else if (ret == EBUSY)
return false;
else
throw lock_error(ret, std::system_category(),
"Failed to lock a mutex.");
}
void
unlock()
{
PMEMobjpool *pop = pmemobj_pool_by_ptr(this);
(void)pmemobj_mutex_unlock(pop, &this->plock);
}
native_handle_type
native_handle() noexcept
{
return &this->plock;
}
enum pobj_tx_param
lock_type() const noexcept
{
return TX_PARAM_MUTEX;
}
mutex &operator=(const mutex &) = delete;
mutex(const mutex &) = delete;
private:
PMEMmutex plock;
};
}
}
#endif