mirror of
https://github.com/RPCS3/rpcs3.git
synced 2025-01-07 03:58:09 +00:00
vm: implement vm::atomic_op, fetch_op helpers
Can help to reduce lambda depth hell a little.
This commit is contained in:
parent
c4c6dc19a5
commit
5227e65808
@ -1751,7 +1751,7 @@ s32 cellSpursSetMaxContention(vm::ptr<CellSpurs> spurs, u32 wid, u32 maxContenti
|
||||
maxContention = CELL_SPURS_MAX_SPU;
|
||||
}
|
||||
|
||||
vm::light_op(spurs->wklMaxContention[wid % CELL_SPURS_MAX_WORKLOAD], [&](atomic_t<u8>& value)
|
||||
vm::atomic_op(spurs->wklMaxContention[wid % CELL_SPURS_MAX_WORKLOAD], [&](u8& value)
|
||||
{
|
||||
value &= wid < CELL_SPURS_MAX_WORKLOAD ? 0xF0 : 0x0F;
|
||||
value |= wid < CELL_SPURS_MAX_WORKLOAD ? maxContention : maxContention << 4;
|
||||
@ -2321,9 +2321,11 @@ s32 _spurs::add_workload(ppu_thread& ppu, vm::ptr<CellSpurs> spurs, vm::ptr<u32>
|
||||
|
||||
u32 wnum;
|
||||
const u32 wmax = spurs->flags1 & SF1_32_WORKLOADS ? CELL_SPURS_MAX_WORKLOAD2 : CELL_SPURS_MAX_WORKLOAD; // TODO: check if can be changed
|
||||
vm::light_op(spurs->wklEnabled, [&](atomic_be_t<u32>& value)
|
||||
|
||||
vm::fetch_op(spurs->wklEnabled, [&](be_t<u32>& value)
|
||||
{
|
||||
wnum = std::countl_one<u32>(value); // found empty position
|
||||
|
||||
if (wnum < wmax)
|
||||
{
|
||||
value |= (0x80000000 >> wnum); // set workload bit
|
||||
@ -2404,16 +2406,13 @@ s32 _spurs::add_workload(ppu_thread& ppu, vm::ptr<CellSpurs> spurs, vm::ptr<u32>
|
||||
spurs->wklIdleSpuCountOrReadyCount2[wnum] = 0;
|
||||
}
|
||||
|
||||
vm::light_op(spurs->wklMaxContention[index], [&](atomic_t<u8>& data)
|
||||
{
|
||||
data.atomic_op([&](u8& v)
|
||||
vm::atomic_op(spurs->wklMaxContention[index], [&](u8& v)
|
||||
{
|
||||
v &= (wnum <= 15 ? ~0xf : ~0xf0);
|
||||
v |= (maxContention > 8 ? 8 : maxContention) << 4;
|
||||
});
|
||||
});
|
||||
|
||||
vm::light_op<true>((wnum <= 15 ? spurs->wklSignal1 : spurs->wklSignal2), [&](atomic_be_t<u16>& data)
|
||||
vm::atomic_op<true>((wnum <= 15 ? spurs->wklSignal1 : spurs->wklSignal2), [&](be_t<u16>& data)
|
||||
{
|
||||
data &= ~(0x8000 >> index);
|
||||
});
|
||||
@ -2581,9 +2580,7 @@ s32 cellSpursWaitForWorkloadShutdown(ppu_thread& ppu, vm::ptr<CellSpurs> spurs,
|
||||
|
||||
auto& info = spurs->wklSyncInfo(wid);
|
||||
|
||||
const bool ok = vm::light_op(info.x28, [](atomic_be_t<u32>& state)
|
||||
{
|
||||
return state.fetch_op([](be_t<u32>& val)
|
||||
const auto [_old0, ok] = vm::fetch_op(info.x28, [](be_t<u32>& val)
|
||||
{
|
||||
if (val)
|
||||
{
|
||||
@ -2592,7 +2589,6 @@ s32 cellSpursWaitForWorkloadShutdown(ppu_thread& ppu, vm::ptr<CellSpurs> spurs,
|
||||
|
||||
val = 2;
|
||||
return true;
|
||||
}).second;
|
||||
});
|
||||
|
||||
if (!ok)
|
||||
@ -2600,9 +2596,7 @@ s32 cellSpursWaitForWorkloadShutdown(ppu_thread& ppu, vm::ptr<CellSpurs> spurs,
|
||||
return CELL_SPURS_POLICY_MODULE_ERROR_STAT;
|
||||
}
|
||||
|
||||
const bool wait_sema = vm::light_op<true>(spurs->wklEvent(wid), [](atomic_t<u8>& event)
|
||||
{
|
||||
return event.fetch_op([](u8& event)
|
||||
const auto [_old1, wait_sema] = vm::fetch_op<true>(spurs->wklEvent(wid), [](u8& event)
|
||||
{
|
||||
if ((event & 1) == 0 || (event & 0x22) == 0x2)
|
||||
{
|
||||
@ -2611,7 +2605,6 @@ s32 cellSpursWaitForWorkloadShutdown(ppu_thread& ppu, vm::ptr<CellSpurs> spurs,
|
||||
}
|
||||
|
||||
return false;
|
||||
}).second;
|
||||
});
|
||||
|
||||
if (wait_sema)
|
||||
@ -2926,13 +2919,9 @@ s32 cellSpursReadyCountAdd(ppu_thread& ppu, vm::ptr<CellSpurs> spurs, u32 wid, v
|
||||
return CELL_SPURS_POLICY_MODULE_ERROR_STAT;
|
||||
}
|
||||
|
||||
*old = vm::light_op(spurs->readyCount(wid), [&](atomic_t<u8>& v)
|
||||
*old = vm::fetch_op(spurs->readyCount(wid), [&](u8& val)
|
||||
{
|
||||
return v.fetch_op([&](u8& val)
|
||||
{
|
||||
const s32 _new = val + value;
|
||||
val = static_cast<u8>(std::clamp<s32>(_new, 0, 255));
|
||||
});
|
||||
val = static_cast<u8>(std::clamp<s32>(val + static_cast<u32>(value), 0, 255));
|
||||
});
|
||||
|
||||
return CELL_OK;
|
||||
|
@ -426,4 +426,22 @@ namespace vm
|
||||
return result;
|
||||
}
|
||||
}
|
||||
|
||||
template <bool Ack = false, typename T, typename F>
|
||||
SAFE_BUFFERS inline auto atomic_op(T& data, F op)
|
||||
{
|
||||
return light_op<Ack, T>(data, [&](T& data)
|
||||
{
|
||||
return data.atomic_op(op);
|
||||
});
|
||||
}
|
||||
|
||||
template <bool Ack = false, typename T, typename F>
|
||||
SAFE_BUFFERS inline auto fetch_op(T& data, F op)
|
||||
{
|
||||
return light_op<Ack, T>(data, [&](T& data)
|
||||
{
|
||||
return data.fetch_op(op);
|
||||
});
|
||||
}
|
||||
} // namespace vm
|
||||
|
Loading…
Reference in New Issue
Block a user