/* * Copyright 2008, Axel Dörfler, axeld@pinc-software.de. * Copyright 2005-2007, Ingo Weinhold, bonefish@users.sf.net. All rights reserved. * * Distributed under the terms of the MIT License. */ #ifndef KERNEL_UTIL_AUTO_LOCKER_H #define KERNEL_UTIL_AUTO_LOCKER_H #include #include #include #include #include namespace BPrivate { // MutexLocking class MutexLocking { public: inline bool Lock(mutex *lockable) { return mutex_lock(lockable) == B_OK; } inline void Unlock(mutex *lockable) { mutex_unlock(lockable); } }; // MutexLocker typedef AutoLocker MutexLocker; // RecursiveLockLocking class RecursiveLockLocking { public: inline bool Lock(recursive_lock *lockable) { return recursive_lock_lock(lockable) == B_OK; } inline void Unlock(recursive_lock *lockable) { recursive_lock_unlock(lockable); } }; // RecursiveLocker typedef AutoLocker RecursiveLocker; class ReadWriteLockReadLocking { public: inline bool Lock(rw_lock *lockable) { return rw_lock_read_lock(lockable) == B_OK; } inline void Unlock(rw_lock *lockable) { rw_lock_read_unlock(lockable); } }; class ReadWriteLockWriteLocking { public: inline bool Lock(rw_lock *lockable) { return rw_lock_write_lock(lockable) == B_OK; } inline void Unlock(rw_lock *lockable) { rw_lock_write_unlock(lockable); } }; typedef AutoLocker ReadLocker; typedef AutoLocker WriteLocker; // 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 : public AutoLocker { public: inline InterruptsLocker(bool alreadyLocked = false, bool lockIfNotLocked = true) : AutoLocker(&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 SpinLocker; // InterruptsSpinLocking class InterruptsSpinLocking { public: struct State { State(spinlock* lock) : lock(lock) { } int state; spinlock* lock; }; inline bool Lock(spinlock* lockable) { fState = disable_interrupts(); acquire_spinlock(lockable); return true; } inline void Unlock(spinlock* lockable) { release_spinlock(lockable); restore_interrupts(fState); } private: int fState; }; // InterruptsSpinLocker typedef AutoLocker InterruptsSpinLocker; // ThreadCPUPinLocking class ThreadCPUPinLocking { public: inline bool Lock(struct thread* thread) { thread_pin_to_current_cpu(thread); return true; } inline void Unlock(struct thread* thread) { thread_unpin_from_current_cpu(thread); } }; // MutexLocker typedef AutoLocker ThreadCPUPinner; } // namespace BPrivate using BPrivate::AutoLocker; using BPrivate::MutexLocker; using BPrivate::RecursiveLocker; using BPrivate::ReadLocker; using BPrivate::WriteLocker; using BPrivate::InterruptsLocker; using BPrivate::SpinLocker; using BPrivate::InterruptsSpinLocker; using BPrivate::ThreadCPUPinner; #endif // KERNEL_UTIL_AUTO_LOCKER_H