2007-02-07 14:07:31 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2005-2007, Ingo Weinhold, bonefish@users.sf.net. All rights reserved.
|
2005-01-30 16:09:06 +00:00
|
|
|
* Distributed under the terms of the MIT License.
|
|
|
|
*/
|
|
|
|
#ifndef KERNEL_UTIL_AUTO_LOCKER_H
|
|
|
|
#define KERNEL_UTIL_AUTO_LOCKER_H
|
|
|
|
|
2007-02-07 14:07:31 +00:00
|
|
|
|
2007-08-09 19:47:22 +00:00
|
|
|
#include <KernelExport.h>
|
|
|
|
|
2007-03-27 12:05:33 +00:00
|
|
|
#include <shared/AutoLocker.h>
|
2005-01-30 16:09:06 +00:00
|
|
|
|
2007-08-09 19:47:22 +00:00
|
|
|
#include <int.h>
|
|
|
|
#include <lock.h>
|
|
|
|
|
2007-02-07 14:07:31 +00:00
|
|
|
|
2005-01-30 16:09:06 +00:00
|
|
|
namespace BPrivate {
|
|
|
|
|
|
|
|
// MutexLocking
|
|
|
|
class MutexLocking {
|
|
|
|
public:
|
|
|
|
inline bool Lock(mutex *lockable)
|
|
|
|
{
|
2007-02-07 14:07:31 +00:00
|
|
|
return mutex_lock(lockable) == B_OK;
|
2005-01-30 16:09:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
inline void Unlock(mutex *lockable)
|
|
|
|
{
|
|
|
|
mutex_unlock(lockable);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
// MutexLocker
|
|
|
|
typedef AutoLocker<mutex, MutexLocking> MutexLocker;
|
|
|
|
|
|
|
|
// RecursiveLockLocking
|
|
|
|
class RecursiveLockLocking {
|
|
|
|
public:
|
|
|
|
inline bool Lock(recursive_lock *lockable)
|
|
|
|
{
|
2007-02-07 14:07:31 +00:00
|
|
|
return recursive_lock_lock(lockable) == B_OK;
|
2005-01-30 16:09:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
inline void Unlock(recursive_lock *lockable)
|
|
|
|
{
|
|
|
|
recursive_lock_unlock(lockable);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
// RecursiveLocker
|
|
|
|
typedef AutoLocker<recursive_lock, RecursiveLockLocking> RecursiveLocker;
|
|
|
|
|
2005-04-13 22:40:48 +00:00
|
|
|
// BenaphoreLocking
|
|
|
|
class BenaphoreLocking {
|
|
|
|
public:
|
|
|
|
inline bool Lock(benaphore *lockable)
|
|
|
|
{
|
|
|
|
return benaphore_lock(lockable) == B_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void Unlock(benaphore *lockable)
|
|
|
|
{
|
|
|
|
benaphore_unlock(lockable);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
// BenaphoreLocker
|
|
|
|
typedef AutoLocker<benaphore, BenaphoreLocking> BenaphoreLocker;
|
|
|
|
|
2007-08-09 19:47:22 +00:00
|
|
|
// InterruptsLocking
|
|
|
|
class InterruptsLocking {
|
|
|
|
public:
|
|
|
|
inline bool Lock(int* lockable)
|
|
|
|
{
|
|
|
|
*lockable = disable_interrupts();
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void Unlock(int* lockable)
|
|
|
|
{
|
|
|
|
restore_interrupts(*lockable);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
// InterruptsLocker
|
|
|
|
class InterruptsLocker : AutoLocker<int, InterruptsLocking> {
|
|
|
|
public:
|
|
|
|
inline InterruptsLocker(bool alreadyLocked = false,
|
|
|
|
bool lockIfNotLocked = true)
|
|
|
|
: AutoLocker<int, InterruptsLocking>(&fState, alreadyLocked,
|
|
|
|
lockIfNotLocked)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
int fState;
|
|
|
|
};
|
|
|
|
|
|
|
|
// SpinLocking
|
|
|
|
class SpinLocking {
|
|
|
|
public:
|
|
|
|
inline bool Lock(spinlock* lockable)
|
|
|
|
{
|
|
|
|
acquire_spinlock(lockable);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void Unlock(spinlock* lockable)
|
|
|
|
{
|
|
|
|
release_spinlock(lockable);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
// SpinLocker
|
|
|
|
typedef AutoLocker<spinlock, SpinLocking> SpinLocker;
|
|
|
|
|
2005-01-30 16:09:06 +00:00
|
|
|
} // namespace BPrivate
|
|
|
|
|
|
|
|
using BPrivate::AutoLocker;
|
|
|
|
using BPrivate::MutexLocker;
|
|
|
|
using BPrivate::RecursiveLocker;
|
2005-04-13 22:40:48 +00:00
|
|
|
using BPrivate::BenaphoreLocker;
|
2007-08-09 19:47:22 +00:00
|
|
|
using BPrivate::InterruptsLocker;
|
|
|
|
using BPrivate::SpinLocker;
|
2005-01-30 16:09:06 +00:00
|
|
|
|
|
|
|
#endif // KERNEL_UTIL_AUTO_LOCKER_H
|