2006-03-25 00:46:40 +03:00
|
|
|
/*
|
|
|
|
* Copyright 2006, Haiku, Inc. All Rights Reserved.
|
|
|
|
* Distributed under the terms of the MIT License.
|
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* Axel Dörfler, axeld@pinc-software.de
|
|
|
|
*/
|
|
|
|
#ifndef LOCK_H
|
|
|
|
#define LOCK_H
|
|
|
|
|
|
|
|
|
|
|
|
#include <OS.h>
|
|
|
|
|
|
|
|
|
2022-03-28 21:10:59 +03:00
|
|
|
struct lock {
|
2006-03-25 00:46:40 +03:00
|
|
|
sem_id sem;
|
2013-11-06 03:03:07 +04:00
|
|
|
int32 count;
|
2022-03-28 21:10:59 +03:00
|
|
|
};
|
2006-03-25 00:46:40 +03:00
|
|
|
|
|
|
|
|
|
|
|
static inline status_t
|
|
|
|
init_lock(struct lock *lock, const char *name)
|
|
|
|
{
|
|
|
|
lock->sem = create_sem(0, name);
|
|
|
|
lock->count = 0;
|
|
|
|
|
|
|
|
return lock->sem < B_OK ? lock->sem : B_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static inline void
|
|
|
|
uninit_lock(struct lock *lock)
|
|
|
|
{
|
|
|
|
delete_sem(lock->sem);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static inline status_t
|
|
|
|
acquire_lock(struct lock *lock)
|
|
|
|
{
|
|
|
|
if (atomic_add(&lock->count, 1) > 0)
|
|
|
|
return acquire_sem(lock->sem);
|
|
|
|
|
|
|
|
return B_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static inline status_t
|
|
|
|
release_lock(struct lock *lock)
|
|
|
|
{
|
|
|
|
if (atomic_add(&lock->count, -1) > 1)
|
|
|
|
return release_sem(lock->sem);
|
|
|
|
|
|
|
|
return B_OK;
|
|
|
|
}
|
|
|
|
|
2006-05-14 18:30:25 +04:00
|
|
|
|
|
|
|
class Autolock {
|
|
|
|
public:
|
|
|
|
Autolock(struct lock &lock)
|
|
|
|
:
|
|
|
|
fLock(&lock)
|
|
|
|
{
|
|
|
|
fStatus = acquire_lock(fLock);
|
|
|
|
}
|
|
|
|
|
|
|
|
~Autolock()
|
|
|
|
{
|
|
|
|
if (fStatus == B_OK)
|
|
|
|
release_lock(fLock);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
2010-02-09 01:50:38 +03:00
|
|
|
IsLocked() const
|
2006-05-14 18:30:25 +04:00
|
|
|
{
|
|
|
|
return fStatus == B_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
status_t fStatus;
|
|
|
|
struct lock *fLock;
|
|
|
|
};
|
|
|
|
|
2006-03-25 00:46:40 +03:00
|
|
|
#endif /* LOCK_H */
|