summaryrefslogtreecommitdiffstats
path: root/src/video_core/renderer_vulkan
diff options
context:
space:
mode:
authorbunnei <bunneidev@gmail.com>2020-05-26 20:40:13 +0200
committerGitHub <noreply@github.com>2020-05-26 20:40:13 +0200
commit508242c2671713239c66461125696db1a69bd163 (patch)
tree07d495dd12545f1860a83f099c288b9637e76e67 /src/video_core/renderer_vulkan
parentMerge pull request #3980 from ReinUsesLisp/red-op (diff)
parentshader/other: Implement BAR.SYNC 0x0 (diff)
downloadyuzu-508242c2671713239c66461125696db1a69bd163.tar
yuzu-508242c2671713239c66461125696db1a69bd163.tar.gz
yuzu-508242c2671713239c66461125696db1a69bd163.tar.bz2
yuzu-508242c2671713239c66461125696db1a69bd163.tar.lz
yuzu-508242c2671713239c66461125696db1a69bd163.tar.xz
yuzu-508242c2671713239c66461125696db1a69bd163.tar.zst
yuzu-508242c2671713239c66461125696db1a69bd163.zip
Diffstat (limited to 'src/video_core/renderer_vulkan')
-rw-r--r--src/video_core/renderer_vulkan/vk_shader_decompiler.cpp17
1 files changed, 17 insertions, 0 deletions
diff --git a/src/video_core/renderer_vulkan/vk_shader_decompiler.cpp b/src/video_core/renderer_vulkan/vk_shader_decompiler.cpp
index b8169d832..890f34a2c 100644
--- a/src/video_core/renderer_vulkan/vk_shader_decompiler.cpp
+++ b/src/video_core/renderer_vulkan/vk_shader_decompiler.cpp
@@ -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));