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