summaryrefslogtreecommitdiff
path: root/src/video_core/shader/decode
diff options
context:
space:
mode:
authorGravatar ReinUsesLisp2019-12-09 21:46:12 -0300
committerGravatar ReinUsesLisp2019-12-10 16:45:03 -0300
commit425a254fa24d7179124b4544ffeb2b1fe4fa99dc (patch)
treeffe458cdf75e70e072eab574051c72d0c4c837dc /src/video_core/shader/decode
parentMerge pull request #3208 from ReinUsesLisp/vk-shader-decompiler (diff)
downloadyuzu-425a254fa24d7179124b4544ffeb2b1fe4fa99dc.tar.gz
yuzu-425a254fa24d7179124b4544ffeb2b1fe4fa99dc.tar.xz
yuzu-425a254fa24d7179124b4544ffeb2b1fe4fa99dc.zip
shader: Implement MEMBAR.GL
Implement using memoryBarrier in GLSL and OpMemoryBarrier on SPIR-V.
Diffstat (limited to 'src/video_core/shader/decode')
-rw-r--r--src/video_core/shader/decode/other.cpp6
1 files changed, 6 insertions, 0 deletions
diff --git a/src/video_core/shader/decode/other.cpp b/src/video_core/shader/decode/other.cpp
index 5c802886b..7321698b2 100644
--- a/src/video_core/shader/decode/other.cpp
+++ b/src/video_core/shader/decode/other.cpp
@@ -257,6 +257,12 @@ u32 ShaderIR::DecodeOther(NodeBlock& bb, u32 pc) {
257 SetRegister(bb, instr.gpr0, GetRegister(instr.gpr8)); 257 SetRegister(bb, instr.gpr0, GetRegister(instr.gpr8));
258 break; 258 break;
259 } 259 }
260 case OpCode::Id::MEMBAR: {
261 UNIMPLEMENTED_IF(instr.membar.type != Tegra::Shader::MembarType::GL);
262 UNIMPLEMENTED_IF(instr.membar.unknown != Tegra::Shader::MembarUnknown::Default);
263 bb.push_back(Operation(OperationCode::MemoryBarrierGL));
264 break;
265 }
260 case OpCode::Id::DEPBAR: { 266 case OpCode::Id::DEPBAR: {
261 LOG_DEBUG(HW_GPU, "DEPBAR instruction is stubbed"); 267 LOG_DEBUG(HW_GPU, "DEPBAR instruction is stubbed");
262 break; 268 break;