diff options
author | bunnei <bunneidev@gmail.com> | 2020-05-26 20:40:13 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-05-26 20:40:13 +0200 |
commit | 508242c2671713239c66461125696db1a69bd163 (patch) | |
tree | 07d495dd12545f1860a83f099c288b9637e76e67 /src/video_core/renderer_vulkan | |
parent | Merge pull request #3980 from ReinUsesLisp/red-op (diff) | |
parent | shader/other: Implement BAR.SYNC 0x0 (diff) | |
download | yuzu-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.cpp | 17 |
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)); |