mirror of
https://github.com/Atmosphere-NX/Atmosphere
synced 2025-01-26 08:52:51 +00:00
46 lines
1 KiB
C++
46 lines
1 KiB
C++
|
#include <mesosphere/threading/KCriticalSection.hpp>
|
||
|
#include <mesosphere/threading/KScheduler.hpp>
|
||
|
#include <mesosphere/core/KCoreContext.hpp>
|
||
|
|
||
|
namespace mesosphere
|
||
|
{
|
||
|
|
||
|
bool KCriticalSection::try_lock()
|
||
|
{
|
||
|
KThread *curThread = KCoreContext::GetCurrentInstance().GetCurrentThread();
|
||
|
if (curThread == lockingThread) {
|
||
|
++lockCount;
|
||
|
return true;
|
||
|
} else if (KInterruptSpinLock<false>::try_lock()) {
|
||
|
lockingThread = curThread;
|
||
|
lockCount = 1;
|
||
|
return true;
|
||
|
} else {
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void KCriticalSection::lock()
|
||
|
{
|
||
|
KThread *curThread = KCoreContext::GetCurrentInstance().GetCurrentThread();
|
||
|
if (curThread == lockingThread) {
|
||
|
++lockCount;
|
||
|
} else {
|
||
|
KInterruptSpinLock<false>::lock();
|
||
|
lockingThread = curThread;
|
||
|
lockCount = 1;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
void KCriticalSection::unlock()
|
||
|
{
|
||
|
if (--lockCount == 0) {
|
||
|
lockingThread = nullptr;
|
||
|
KScheduler::HandleCriticalSectionLeave();
|
||
|
} else {
|
||
|
KInterruptSpinLock<false>::unlock();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|