2014-03-13 17:11:16 +01:00
|
|
|
#include "stdafx.h"
|
2014-06-17 17:44:03 +02:00
|
|
|
#include "Utilities/Log.h"
|
2014-06-02 19:27:24 +02:00
|
|
|
#include "Emu/Memory/Memory.h"
|
|
|
|
|
#include "Emu/System.h"
|
|
|
|
|
#include "Emu/Cell/PPUThread.h"
|
2014-03-13 17:11:16 +01:00
|
|
|
#include "Emu/SysCalls/SysCalls.h"
|
|
|
|
|
#include "Emu/SysCalls/lv2/SC_Spinlock.h"
|
|
|
|
|
|
|
|
|
|
SysCallBase sys_spinlock("sys_spinlock");
|
|
|
|
|
|
|
|
|
|
void sys_spinlock_initialize(mem_ptr_t<spinlock> lock)
|
|
|
|
|
{
|
|
|
|
|
sys_spinlock.Log("sys_spinlock_initialize(lock_addr=0x%x)", lock.GetAddr());
|
|
|
|
|
|
|
|
|
|
lock->mutex.initialize();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void sys_spinlock_lock(mem_ptr_t<spinlock> lock)
|
|
|
|
|
{
|
|
|
|
|
sys_spinlock.Log("sys_spinlock_lock(lock_addr=0x%x)", lock.GetAddr());
|
|
|
|
|
|
|
|
|
|
be_t<u32> tid = GetCurrentPPUThread().GetId();
|
|
|
|
|
switch (lock->mutex.lock(tid))
|
|
|
|
|
{
|
2014-06-27 15:26:46 +02:00
|
|
|
case SMR_ABORT: LOG_WARNING(HLE, "sys_spinlock_lock(0x%x) aborted", lock.GetAddr()); break;
|
|
|
|
|
case SMR_DEADLOCK: LOG_ERROR(HLE, "sys_spinlock_lock(0x%x) reached deadlock", lock.GetAddr()); break; // ???
|
2014-03-13 17:11:16 +01:00
|
|
|
default: break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int sys_spinlock_trylock(mem_ptr_t<spinlock> lock)
|
|
|
|
|
{
|
|
|
|
|
sys_spinlock.Log("sys_spinlock_trylock(lock_addr=0x%x)", lock.GetAddr());
|
|
|
|
|
|
|
|
|
|
be_t<u32> tid = GetCurrentPPUThread().GetId();
|
|
|
|
|
switch (lock->mutex.trylock(tid))
|
|
|
|
|
{
|
|
|
|
|
case SMR_FAILED: return CELL_EBUSY;
|
2014-06-27 15:26:46 +02:00
|
|
|
case SMR_ABORT: LOG_WARNING(HLE, "sys_spinlock_trylock(0x%x) aborted", lock.GetAddr()); break;
|
|
|
|
|
case SMR_DEADLOCK: LOG_ERROR(HLE, "sys_spinlock_trylock(0x%x) reached deadlock", lock.GetAddr()); break;
|
2014-03-13 17:11:16 +01:00
|
|
|
default: break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return CELL_OK;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void sys_spinlock_unlock(mem_ptr_t<spinlock> lock)
|
|
|
|
|
{
|
|
|
|
|
sys_spinlock.Log("sys_spinlock_unlock(lock_addr=0x%x)", lock.GetAddr());
|
|
|
|
|
|
2014-03-27 16:40:58 +01:00
|
|
|
while(true)
|
2014-03-13 17:11:16 +01:00
|
|
|
{
|
2014-03-27 16:40:58 +01:00
|
|
|
if (lock->mutex.unlock(lock->mutex.GetOwner()) != SMR_PERMITTED)
|
|
|
|
|
break;
|
2014-03-13 17:11:16 +01:00
|
|
|
}
|
|
|
|
|
}
|