mirror of
https://github.com/RPCS3/rpcs3.git
synced 2025-01-15 22:53:47 +00:00
Small cleanup
This commit is contained in:
parent
5c31037c04
commit
c88e0a0eb9
@ -193,8 +193,8 @@ class squeue_t
|
||||
|
||||
public:
|
||||
squeue_t()
|
||||
: m_sync({})
|
||||
{
|
||||
m_sync.write_relaxed({});
|
||||
}
|
||||
|
||||
u32 get_max_size() const
|
||||
@ -202,9 +202,9 @@ public:
|
||||
return sq_size;
|
||||
}
|
||||
|
||||
bool is_full() const
|
||||
bool is_full() const volatile
|
||||
{
|
||||
return m_sync.read_relaxed().count == sq_size;
|
||||
return m_sync.data.count == sq_size;
|
||||
}
|
||||
|
||||
bool push(const T& data, const std::function<bool()>& test_exit)
|
||||
|
@ -78,29 +78,29 @@ void SPUThread::InitRegs()
|
||||
ch_mfc_args = {};
|
||||
mfc_queue.clear();
|
||||
|
||||
ch_tag_mask = 0;
|
||||
ch_tag_stat.data = {};
|
||||
ch_stall_stat.data = {};
|
||||
ch_atomic_stat.data = {};
|
||||
ch_tag_mask = {};
|
||||
ch_tag_stat = {};
|
||||
ch_stall_stat = {};
|
||||
ch_atomic_stat = {};
|
||||
|
||||
ch_in_mbox.clear();
|
||||
|
||||
ch_out_mbox.data = {};
|
||||
ch_out_intr_mbox.data = {};
|
||||
ch_out_mbox = {};
|
||||
ch_out_intr_mbox = {};
|
||||
|
||||
snr_config = 0;
|
||||
snr_config = {};
|
||||
|
||||
ch_snr1.data = {};
|
||||
ch_snr2.data = {};
|
||||
ch_snr1 = {};
|
||||
ch_snr2 = {};
|
||||
|
||||
ch_event_mask = 0;
|
||||
ch_event_stat.write_relaxed(0);
|
||||
ch_event_mask = {};
|
||||
ch_event_stat = {};
|
||||
|
||||
ch_dec_start_timestamp = get_time(); // ???
|
||||
ch_dec_value = 0;
|
||||
ch_dec_value = {};
|
||||
|
||||
run_ctrl.write_relaxed(0);
|
||||
status.write_relaxed(0);
|
||||
run_ctrl = {};
|
||||
status = {};
|
||||
|
||||
int0.clear();
|
||||
int2.clear();
|
||||
|
@ -139,10 +139,7 @@ union spu_channel_t
|
||||
|
||||
atomic_t<sync_var_t> sync_var; // atomic variable
|
||||
|
||||
sync_var_t data; // unsafe direct access
|
||||
|
||||
public:
|
||||
|
||||
bool push(u32 value)
|
||||
{
|
||||
bool out_result;
|
||||
@ -205,14 +202,14 @@ public:
|
||||
sync_var.write_relaxed({ count, value });
|
||||
}
|
||||
|
||||
u32 get_value()
|
||||
u32 get_value() volatile
|
||||
{
|
||||
return sync_var.read_relaxed().value;
|
||||
return sync_var.data.value;
|
||||
}
|
||||
|
||||
u32 get_count()
|
||||
u32 get_count() volatile
|
||||
{
|
||||
return sync_var.read_relaxed().count;
|
||||
return sync_var.data.count;
|
||||
}
|
||||
};
|
||||
|
||||
@ -232,8 +229,8 @@ struct spu_channel_4_t
|
||||
public:
|
||||
void clear()
|
||||
{
|
||||
sync_var.write_relaxed({});
|
||||
value3.write_relaxed({});
|
||||
sync_var = {};
|
||||
value3 = {};
|
||||
}
|
||||
|
||||
void push_uncond(u32 value)
|
||||
@ -275,9 +272,9 @@ public:
|
||||
return out_result;
|
||||
}
|
||||
|
||||
u32 get_count()
|
||||
u32 get_count() volatile
|
||||
{
|
||||
return sync_var.read_relaxed().count;
|
||||
return sync_var.data.count;
|
||||
}
|
||||
};
|
||||
|
||||
@ -311,10 +308,10 @@ public:
|
||||
|
||||
void clear()
|
||||
{
|
||||
mask.write_relaxed(0);
|
||||
stat.write_relaxed(0);
|
||||
mask = {};
|
||||
stat = {};
|
||||
|
||||
assigned.write_relaxed(-1);
|
||||
assigned = { -1 };
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -882,28 +882,28 @@ void syncLFQueueInit(vm::ptr<CellSyncLFQueue> queue, vm::ptr<u8> buffer, u32 siz
|
||||
|
||||
if (direction == CELL_SYNC_QUEUE_ANY2ANY)
|
||||
{
|
||||
queue->pop1.write_relaxed({});
|
||||
queue->push1.write_relaxed({});
|
||||
queue->pop1 = {};
|
||||
queue->push1 = {};
|
||||
queue->m_buffer.set(queue->m_buffer.addr() | 1);
|
||||
queue->m_bs[0] = -1;
|
||||
queue->m_bs[1] = -1;
|
||||
//m_bs[2]
|
||||
//m_bs[3]
|
||||
queue->m_v1 = -1;
|
||||
queue->push2.write_relaxed({ be_t<u16>::make(-1) });
|
||||
queue->pop2.write_relaxed({ be_t<u16>::make(-1) });
|
||||
queue->push2 = { { be_t<u16>::make(-1) } };
|
||||
queue->pop2 = { { be_t<u16>::make(-1) } };
|
||||
}
|
||||
else
|
||||
{
|
||||
queue->pop1.write_relaxed({ be_t<u16>::make(0), be_t<u16>::make(0), queue->pop1.read_relaxed().m_h3, be_t<u16>::make(0) });
|
||||
queue->push1.write_relaxed({ be_t<u16>::make(0), be_t<u16>::make(0), queue->push1.read_relaxed().m_h7, be_t<u16>::make(0) });
|
||||
queue->pop1 = { { be_t<u16>::make(0), be_t<u16>::make(0), queue->pop1.read_relaxed().m_h3, be_t<u16>::make(0) } };
|
||||
queue->push1 = { { be_t<u16>::make(0), be_t<u16>::make(0), queue->push1.read_relaxed().m_h7, be_t<u16>::make(0) } };
|
||||
queue->m_bs[0] = -1; // written as u32
|
||||
queue->m_bs[1] = -1;
|
||||
queue->m_bs[2] = -1;
|
||||
queue->m_bs[3] = -1;
|
||||
queue->m_v1 = 0;
|
||||
queue->push2.write_relaxed({});
|
||||
queue->pop2.write_relaxed({});
|
||||
queue->push2 = {};
|
||||
queue->pop2 = {};
|
||||
}
|
||||
|
||||
queue->m_v2 = 0;
|
||||
|
@ -114,7 +114,7 @@ s32 sys_lwmutex_create(vm::ptr<sys_lwmutex_t> lwmutex, vm::ptr<sys_lwmutex_attri
|
||||
|
||||
std::shared_ptr<lwmutex_t> lw(new lwmutex_t(protocol, attr->name_u64));
|
||||
|
||||
lwmutex->lock_var.write_relaxed({ lwmutex::free, lwmutex::zero });
|
||||
lwmutex->lock_var = { { lwmutex::free, lwmutex::zero } };
|
||||
lwmutex->attribute = attr->recursive | attr->protocol;
|
||||
lwmutex->recursive_count = 0;
|
||||
lwmutex->sleep_queue = Emu.GetIdManager().GetNewID(lw);
|
||||
@ -575,7 +575,7 @@ s32 sys_lwcond_wait(PPUThread& CPU, vm::ptr<sys_lwcond_t> lwcond, u64 timeout)
|
||||
const be_t<u32> recursive_value = lwmutex->recursive_count;
|
||||
|
||||
// set special value
|
||||
lwmutex->owner.write_relaxed(lwmutex::reserved);
|
||||
lwmutex->owner = { lwmutex::reserved };
|
||||
lwmutex->recursive_count = 0;
|
||||
|
||||
// call the syscall
|
||||
|
@ -20,7 +20,7 @@
|
||||
|
||||
SysCallBase sys_fs("sys_fs");
|
||||
|
||||
s32 sys_fs_open(vm::ptr<const char> path, s32 flags, vm::ptr<u32> fd, u64 mode, vm::ptr<const void> arg, u64 size)
|
||||
s32 sys_fs_open(vm::ptr<const char> path, s32 flags, vm::ptr<u32> fd, u32 mode, vm::ptr<const void> arg, u64 size)
|
||||
{
|
||||
sys_fs.Warning("sys_fs_open(path=*0x%x, flags=0x%x, fd=*0x%x, arg=*0x%x, size=0x%llx)", path, flags, fd, arg, size);
|
||||
sys_fs.Warning("*** path = '%s'", path.get_ptr());
|
||||
|
@ -89,7 +89,7 @@ enum : s32
|
||||
|
||||
enum CellFsMode : s32
|
||||
{
|
||||
CELL_FS_S_IFMT = 0170000,
|
||||
CELL_FS_S_IFMT = 0170000,
|
||||
CELL_FS_S_IFDIR = 0040000, // directory
|
||||
CELL_FS_S_IFREG = 0100000, // regular
|
||||
CELL_FS_S_IFLNK = 0120000, // symbolic link
|
||||
@ -126,7 +126,7 @@ struct CellFsDirent
|
||||
|
||||
struct CellFsStat
|
||||
{
|
||||
be_t<u32> mode;
|
||||
be_t<s32> mode;
|
||||
be_t<s32> uid;
|
||||
be_t<s32> gid;
|
||||
be_t<s64> atime;
|
||||
@ -145,7 +145,7 @@ struct CellFsUtimbuf
|
||||
#pragma pack(pop)
|
||||
|
||||
// SysCalls
|
||||
s32 sys_fs_open(vm::ptr<const char> path, s32 flags, vm::ptr<u32> fd, u64 mode, vm::ptr<const void> arg, u64 size);
|
||||
s32 sys_fs_open(vm::ptr<const char> path, s32 flags, vm::ptr<u32> fd, u32 mode, vm::ptr<const void> arg, u64 size);
|
||||
s32 sys_fs_read(u32 fd, vm::ptr<void> buf, u64 nbytes, vm::ptr<u64> nread);
|
||||
s32 sys_fs_write(u32 fd, vm::ptr<const void> buf, u64 nbytes, vm::ptr<u64> nwrite);
|
||||
s32 sys_fs_close(u32 fd);
|
||||
|
@ -16,7 +16,7 @@ void lwmutex_create(sys_lwmutex_t& lwmutex, bool recursive, u32 protocol, u64 na
|
||||
{
|
||||
std::shared_ptr<lwmutex_t> mutex(new lwmutex_t(protocol, name));
|
||||
|
||||
lwmutex.lock_var.write_relaxed({ lwmutex::free, lwmutex::zero });
|
||||
lwmutex.lock_var = { { lwmutex::free, lwmutex::zero } };
|
||||
lwmutex.attribute = protocol | (recursive ? SYS_SYNC_RECURSIVE : SYS_SYNC_NOT_RECURSIVE);
|
||||
lwmutex.recursive_count = 0;
|
||||
lwmutex.sleep_queue = Emu.GetIdManager().GetNewID(mutex, TYPE_LWMUTEX);
|
||||
|
@ -315,11 +315,12 @@ s32 sys_spu_thread_group_start(u32 id)
|
||||
|
||||
spu.SetEntry(image->entry_point);
|
||||
spu.Run();
|
||||
spu.status.write_relaxed(SPU_STATUS_RUNNING);
|
||||
spu.GPR[3] = u128::from64(0, args.arg1);
|
||||
spu.GPR[4] = u128::from64(0, args.arg2);
|
||||
spu.GPR[5] = u128::from64(0, args.arg3);
|
||||
spu.GPR[6] = u128::from64(0, args.arg4);
|
||||
|
||||
spu.status.exchange(SPU_STATUS_RUNNING);
|
||||
}
|
||||
}
|
||||
|
||||
@ -518,7 +519,7 @@ s32 sys_spu_thread_group_terminate(u32 id, s32 value)
|
||||
{
|
||||
auto& spu = static_cast<SPUThread&>(*t);
|
||||
|
||||
spu.status.write_relaxed(SPU_STATUS_STOPPED);
|
||||
spu.status.exchange(SPU_STATUS_STOPPED);
|
||||
spu.FastStop();
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user