|
|
@ -280,6 +280,10 @@ static ResultCode ArbitrateLock(Handle holding_thread_handle, VAddr mutex_addr, |
|
|
"requesting_current_thread_handle=0x{:08X}", |
|
|
"requesting_current_thread_handle=0x{:08X}", |
|
|
holding_thread_handle, mutex_addr, requesting_thread_handle); |
|
|
holding_thread_handle, mutex_addr, requesting_thread_handle); |
|
|
|
|
|
|
|
|
|
|
|
if (Memory::IsKernelVirtualAddress(mutex_addr)) { |
|
|
|
|
|
return ERR_INVALID_ADDRESS_STATE; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
auto& handle_table = Core::System::GetInstance().Kernel().HandleTable(); |
|
|
auto& handle_table = Core::System::GetInstance().Kernel().HandleTable(); |
|
|
return Mutex::TryAcquire(handle_table, mutex_addr, holding_thread_handle, |
|
|
return Mutex::TryAcquire(handle_table, mutex_addr, holding_thread_handle, |
|
|
requesting_thread_handle); |
|
|
requesting_thread_handle); |
|
|
@ -289,6 +293,10 @@ static ResultCode ArbitrateLock(Handle holding_thread_handle, VAddr mutex_addr, |
|
|
static ResultCode ArbitrateUnlock(VAddr mutex_addr) { |
|
|
static ResultCode ArbitrateUnlock(VAddr mutex_addr) { |
|
|
LOG_TRACE(Kernel_SVC, "called mutex_addr=0x{:X}", mutex_addr); |
|
|
LOG_TRACE(Kernel_SVC, "called mutex_addr=0x{:X}", mutex_addr); |
|
|
|
|
|
|
|
|
|
|
|
if (Memory::IsKernelVirtualAddress(mutex_addr)) { |
|
|
|
|
|
return ERR_INVALID_ADDRESS_STATE; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
return Mutex::Release(mutex_addr); |
|
|
return Mutex::Release(mutex_addr); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|