2015-08-02 04:15:49 +02:00
|
|
|
#include "stdafx.h"
|
|
|
|
|
#include "Emu/System.h"
|
2016-03-21 20:42:14 +01:00
|
|
|
#include "Emu/Cell/PPUModule.h"
|
2015-08-02 04:15:49 +02:00
|
|
|
|
|
|
|
|
#include "sysPrxForUser.h"
|
|
|
|
|
|
2016-04-25 12:49:12 +02:00
|
|
|
#include "Emu/Memory/wait_engine.h"
|
|
|
|
|
|
2016-03-21 20:42:14 +01:00
|
|
|
extern _log::channel sysPrxForUser;
|
2015-08-02 04:15:49 +02:00
|
|
|
|
|
|
|
|
void sys_spinlock_initialize(vm::ptr<atomic_be_t<u32>> lock)
|
|
|
|
|
{
|
2016-01-12 22:57:16 +01:00
|
|
|
sysPrxForUser.trace("sys_spinlock_initialize(lock=*0x%x)", lock);
|
2015-08-02 04:15:49 +02:00
|
|
|
|
|
|
|
|
lock->exchange(0);
|
|
|
|
|
}
|
|
|
|
|
|
2016-04-25 12:49:12 +02:00
|
|
|
void sys_spinlock_lock(vm::ptr<atomic_be_t<u32>> lock)
|
2015-08-02 04:15:49 +02:00
|
|
|
{
|
2016-01-12 22:57:16 +01:00
|
|
|
sysPrxForUser.trace("sys_spinlock_lock(lock=*0x%x)", lock);
|
2015-08-02 04:15:49 +02:00
|
|
|
|
|
|
|
|
// prx: exchange with 0xabadcafe, repeat until exchanged with 0
|
2016-04-25 12:49:12 +02:00
|
|
|
vm::wait_op(lock.addr(), 4, WRAP_EXPR(!lock->exchange(0xabadcafe)));
|
2015-08-02 04:15:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
s32 sys_spinlock_trylock(vm::ptr<atomic_be_t<u32>> lock)
|
|
|
|
|
{
|
2016-01-12 22:57:16 +01:00
|
|
|
sysPrxForUser.trace("sys_spinlock_trylock(lock=*0x%x)", lock);
|
2015-08-02 04:15:49 +02:00
|
|
|
|
2015-09-15 18:23:17 +02:00
|
|
|
if (lock->exchange(0xabadcafe))
|
2015-08-02 04:15:49 +02:00
|
|
|
{
|
|
|
|
|
return CELL_EBUSY;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return CELL_OK;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void sys_spinlock_unlock(vm::ptr<atomic_be_t<u32>> lock)
|
|
|
|
|
{
|
2016-01-12 22:57:16 +01:00
|
|
|
sysPrxForUser.trace("sys_spinlock_unlock(lock=*0x%x)", lock);
|
2015-08-02 04:15:49 +02:00
|
|
|
|
|
|
|
|
lock->exchange(0);
|
|
|
|
|
|
|
|
|
|
vm::notify_at(lock.addr(), 4);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void sysPrxForUser_sys_spinlock_init()
|
|
|
|
|
{
|
|
|
|
|
REG_FUNC(sysPrxForUser, sys_spinlock_initialize);
|
|
|
|
|
REG_FUNC(sysPrxForUser, sys_spinlock_lock);
|
|
|
|
|
REG_FUNC(sysPrxForUser, sys_spinlock_trylock);
|
|
|
|
|
REG_FUNC(sysPrxForUser, sys_spinlock_unlock);
|
|
|
|
|
}
|