mirror of
https://github.com/RPCS3/rpcs3.git
synced 2024-11-22 02:32:36 +01:00
SPU: fix event count with ACK and mask write
This commit is contained in:
parent
1c89f8a855
commit
a776f15557
@ -5335,7 +5335,7 @@ bool spu_thread::set_ch_value(u32 ch, u32 value)
|
||||
|
||||
case SPU_WrEventMask:
|
||||
{
|
||||
get_events(value);
|
||||
get_events(value | static_cast<u32>(ch_events.load().mask));
|
||||
|
||||
if (ch_events.atomic_op([&](ch_events_t& events)
|
||||
{
|
||||
@ -5347,7 +5347,7 @@ bool spu_thread::set_ch_value(u32 ch, u32 value)
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
return !!events.count;
|
||||
}))
|
||||
{
|
||||
// Check interrupts in case count is 1
|
||||
@ -5363,7 +5363,7 @@ bool spu_thread::set_ch_value(u32 ch, u32 value)
|
||||
case SPU_WrEventAck:
|
||||
{
|
||||
// "Collect" events before final acknowledgment
|
||||
get_events(value);
|
||||
get_events(value | static_cast<u32>(ch_events.load().mask));
|
||||
|
||||
bool freeze_dec = false;
|
||||
|
||||
@ -5379,7 +5379,7 @@ bool spu_thread::set_ch_value(u32 ch, u32 value)
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
return !!events.count;
|
||||
});
|
||||
|
||||
if (!is_dec_frozen && freeze_dec)
|
||||
|
Loading…
Reference in New Issue
Block a user