2020-12-05 13:08:24 +01:00
|
|
|
#include "stdafx.h"
|
2016-03-21 22:42:14 +03:00
|
|
|
#include "Emu/Cell/PPUModule.h"
|
2015-08-02 05:15:49 +03:00
|
|
|
|
|
|
|
|
#include "sysPrxForUser.h"
|
|
|
|
|
|
2020-01-31 12:01:17 +03:00
|
|
|
LOG_CHANNEL(sysPrxForUser);
|
2015-08-02 05:15:49 +03:00
|
|
|
|
|
|
|
|
void sys_spinlock_initialize(vm::ptr<atomic_be_t<u32>> lock)
|
|
|
|
|
{
|
2016-01-13 00:57:16 +03:00
|
|
|
sysPrxForUser.trace("sys_spinlock_initialize(lock=*0x%x)", lock);
|
2015-08-02 05:15:49 +03:00
|
|
|
|
2017-02-22 13:10:55 +03:00
|
|
|
if (*lock)
|
|
|
|
|
{
|
|
|
|
|
*lock = 0;
|
|
|
|
|
}
|
2015-08-02 05:15:49 +03:00
|
|
|
}
|
|
|
|
|
|
2018-10-11 01:17:19 +03:00
|
|
|
error_code sys_spinlock_lock(ppu_thread& ppu, vm::ptr<atomic_be_t<u32>> lock)
|
2015-08-02 05:15:49 +03:00
|
|
|
{
|
2016-01-13 00:57:16 +03:00
|
|
|
sysPrxForUser.trace("sys_spinlock_lock(lock=*0x%x)", lock);
|
2015-08-02 05:15:49 +03:00
|
|
|
|
2017-02-22 13:10:55 +03:00
|
|
|
// Try to exchange with 0xabadcafe, repeat until exchanged with 0
|
|
|
|
|
while (*lock || lock->exchange(0xabadcafe))
|
|
|
|
|
{
|
2018-10-11 01:17:19 +03:00
|
|
|
if (ppu.test_stopped())
|
|
|
|
|
{
|
2022-07-05 14:12:21 +03:00
|
|
|
ppu.state += cpu_flag::again;
|
|
|
|
|
return {};
|
2018-10-11 01:17:19 +03:00
|
|
|
}
|
2017-02-22 13:10:55 +03:00
|
|
|
}
|
2018-10-11 01:17:19 +03:00
|
|
|
|
2020-03-22 10:35:35 +02:00
|
|
|
return CELL_OK;
|
2015-08-02 05:15:49 +03:00
|
|
|
}
|
|
|
|
|
|
2020-07-16 12:14:57 +02:00
|
|
|
error_code sys_spinlock_trylock(vm::ptr<atomic_be_t<u32>> lock)
|
2015-08-02 05:15:49 +03:00
|
|
|
{
|
2016-01-13 00:57:16 +03:00
|
|
|
sysPrxForUser.trace("sys_spinlock_trylock(lock=*0x%x)", lock);
|
2015-08-02 05:15:49 +03:00
|
|
|
|
2017-02-22 13:10:55 +03:00
|
|
|
if (*lock || lock->exchange(0xabadcafe))
|
2015-08-02 05:15:49 +03:00
|
|
|
{
|
2020-07-16 19:51:44 +02:00
|
|
|
return not_an_error(CELL_EBUSY);
|
2015-08-02 05:15:49 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return CELL_OK;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void sys_spinlock_unlock(vm::ptr<atomic_be_t<u32>> lock)
|
|
|
|
|
{
|
2016-01-13 00:57:16 +03:00
|
|
|
sysPrxForUser.trace("sys_spinlock_unlock(lock=*0x%x)", lock);
|
2015-08-02 05:15:49 +03:00
|
|
|
|
2017-02-22 13:10:55 +03:00
|
|
|
*lock = 0;
|
2015-08-02 05:15:49 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
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);
|
|
|
|
|
}
|