|
|
|
@ -2199,6 +2199,22 @@ private:
|
|
|
|
|
return {OpSubgroupReadInvocationKHR(t_float, value, index), Type::Float};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Expression Barrier(Operation) {
|
|
|
|
|
if (!ir.IsDecompiled()) {
|
|
|
|
|
LOG_ERROR(Render_Vulkan, "OpBarrier used by shader is not decompiled");
|
|
|
|
|
return {};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const auto scope = spv::Scope::Workgroup;
|
|
|
|
|
const auto memory = spv::Scope::Workgroup;
|
|
|
|
|
const auto semantics =
|
|
|
|
|
spv::MemorySemanticsMask::WorkgroupMemory | spv::MemorySemanticsMask::AcquireRelease;
|
|
|
|
|
OpControlBarrier(Constant(t_uint, static_cast<u32>(scope)),
|
|
|
|
|
Constant(t_uint, static_cast<u32>(memory)),
|
|
|
|
|
Constant(t_uint, static_cast<u32>(semantics)));
|
|
|
|
|
return {};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Expression MemoryBarrierGL(Operation) {
|
|
|
|
|
const auto scope = spv::Scope::Device;
|
|
|
|
|
const auto semantics =
|
|
|
|
@ -2664,6 +2680,7 @@ private:
|
|
|
|
|
&SPIRVDecompiler::ThreadMask<4>, // Lt
|
|
|
|
|
&SPIRVDecompiler::ShuffleIndexed,
|
|
|
|
|
|
|
|
|
|
&SPIRVDecompiler::Barrier,
|
|
|
|
|
&SPIRVDecompiler::MemoryBarrierGL,
|
|
|
|
|
};
|
|
|
|
|
static_assert(operation_decompilers.size() == static_cast<std::size_t>(OperationCode::Amount));
|
|
|
|
|