spin_lock: Use std::call_once
This commit is contained in:
parent
f9e6a3df5c
commit
d5c2b473a8
2 changed files with 10 additions and 18 deletions
|
@ -3,6 +3,8 @@
|
|||
* SPDX-License-Identifier: 0BSD
|
||||
*/
|
||||
|
||||
#include <mutex>
|
||||
|
||||
#include <oaknut/code_block.hpp>
|
||||
#include <oaknut/oaknut.hpp>
|
||||
|
||||
|
@ -43,11 +45,11 @@ struct SpinLockImpl {
|
|||
oaknut::CodeBlock mem;
|
||||
oaknut::CodeGenerator code;
|
||||
|
||||
bool initialized = false;
|
||||
void (*lock)(volatile int*);
|
||||
void (*unlock)(volatile int*);
|
||||
};
|
||||
|
||||
std::once_flag flag;
|
||||
SpinLockImpl impl;
|
||||
|
||||
SpinLockImpl::SpinLockImpl()
|
||||
|
@ -66,23 +68,17 @@ void SpinLockImpl::Initialize() {
|
|||
code.RET();
|
||||
|
||||
mem.protect();
|
||||
|
||||
initialized = true;
|
||||
}
|
||||
|
||||
} // namespace
|
||||
|
||||
void SpinLock::Lock() {
|
||||
if (!impl.initialized) [[unlikely]] {
|
||||
impl.Initialize();
|
||||
}
|
||||
std::call_once(flag, &SpinLockImpl::Initialize, impl);
|
||||
impl.lock(&storage);
|
||||
}
|
||||
|
||||
void SpinLock::Unlock() {
|
||||
if (!impl.initialized) [[unlikely]] {
|
||||
impl.Initialize();
|
||||
}
|
||||
std::call_once(flag, &SpinLockImpl::Initialize, impl);
|
||||
impl.unlock(&storage);
|
||||
}
|
||||
|
||||
|
|
|
@ -3,6 +3,8 @@
|
|||
* SPDX-License-Identifier: 0BSD
|
||||
*/
|
||||
|
||||
#include <mutex>
|
||||
|
||||
#include <xbyak/xbyak.h>
|
||||
|
||||
#include "dynarmic/backend/x64/abi.h"
|
||||
|
@ -38,11 +40,11 @@ struct SpinLockImpl {
|
|||
|
||||
Xbyak::CodeGenerator code;
|
||||
|
||||
bool initialized = false;
|
||||
void (*lock)(volatile int*);
|
||||
void (*unlock)(volatile int*);
|
||||
};
|
||||
|
||||
std::once_flag flag;
|
||||
SpinLockImpl impl;
|
||||
|
||||
void SpinLockImpl::Initialize() {
|
||||
|
@ -57,23 +59,17 @@ void SpinLockImpl::Initialize() {
|
|||
unlock = code.getCurr<void (*)(volatile int*)>();
|
||||
EmitSpinLockUnlock(code, ABI_PARAM1, code.eax);
|
||||
code.ret();
|
||||
|
||||
initialized = true;
|
||||
}
|
||||
|
||||
} // namespace
|
||||
|
||||
void SpinLock::Lock() {
|
||||
if (!impl.initialized) [[unlikely]] {
|
||||
impl.Initialize();
|
||||
}
|
||||
std::call_once(flag, &SpinLockImpl::Initialize, impl);
|
||||
impl.lock(&storage);
|
||||
}
|
||||
|
||||
void SpinLock::Unlock() {
|
||||
if (!impl.initialized) [[unlikely]] {
|
||||
impl.Initialize();
|
||||
}
|
||||
std::call_once(flag, &SpinLockImpl::Initialize, impl);
|
||||
impl.unlock(&storage);
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue