diff options
| author | 2020-05-15 02:24:42 -0300 | |
|---|---|---|
| committer | 2020-05-21 23:20:43 -0300 | |
| commit | 5d0986a53be495f2a2158968db1bc0974f0dd0d3 (patch) | |
| tree | 76b89957701a3e8cec21211b0090f8517b9338af /src/video_core/shader | |
| parent | Merge pull request #3926 from ogniK5377/keyboard-states (diff) | |
| download | yuzu-5d0986a53be495f2a2158968db1bc0974f0dd0d3.tar.gz yuzu-5d0986a53be495f2a2158968db1bc0974f0dd0d3.tar.xz yuzu-5d0986a53be495f2a2158968db1bc0974f0dd0d3.zip | |
shader/other: Implement BAR.SYNC 0x0
Trivially implement this particular case of BAR. Unless games use OpenCL
or CUDA barriers, we shouldn't hit any other case here.
Diffstat (limited to 'src/video_core/shader')
| -rw-r--r-- | src/video_core/shader/decode/other.cpp | 5 | ||||
| -rw-r--r-- | src/video_core/shader/node.h | 1 |
2 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 d4f95b18c..82ec7bb6f 100644 --- a/src/video_core/shader/decode/other.cpp +++ b/src/video_core/shader/decode/other.cpp | |||
| @@ -272,6 +272,11 @@ u32 ShaderIR::DecodeOther(NodeBlock& bb, u32 pc) { | |||
| 272 | SetRegister(bb, instr.gpr0, GetRegister(instr.gpr8)); | 272 | SetRegister(bb, instr.gpr0, GetRegister(instr.gpr8)); |
| 273 | break; | 273 | break; |
| 274 | } | 274 | } |
| 275 | case OpCode::Id::BAR: { | ||
| 276 | UNIMPLEMENTED_IF_MSG(instr.value != 0xF0A81B8000070000ULL, "BAR is not BAR.SYNC 0x0"); | ||
| 277 | bb.push_back(Operation(OperationCode::Barrier)); | ||
| 278 | break; | ||
| 279 | } | ||
| 275 | case OpCode::Id::MEMBAR: { | 280 | case OpCode::Id::MEMBAR: { |
| 276 | UNIMPLEMENTED_IF(instr.membar.type != Tegra::Shader::MembarType::GL); | 281 | UNIMPLEMENTED_IF(instr.membar.type != Tegra::Shader::MembarType::GL); |
| 277 | UNIMPLEMENTED_IF(instr.membar.unknown != Tegra::Shader::MembarUnknown::Default); | 282 | UNIMPLEMENTED_IF(instr.membar.unknown != Tegra::Shader::MembarUnknown::Default); |
diff --git a/src/video_core/shader/node.h b/src/video_core/shader/node.h index f75b62240..80aa69295 100644 --- a/src/video_core/shader/node.h +++ b/src/video_core/shader/node.h | |||
| @@ -228,6 +228,7 @@ enum class OperationCode { | |||
| 228 | ThreadId, /// () -> uint | 228 | ThreadId, /// () -> uint |
| 229 | ShuffleIndexed, /// (uint value, uint index) -> uint | 229 | ShuffleIndexed, /// (uint value, uint index) -> uint |
| 230 | 230 | ||
| 231 | Barrier, /// () -> void | ||
| 231 | MemoryBarrierGL, /// () -> void | 232 | MemoryBarrierGL, /// () -> void |
| 232 | 233 | ||
| 233 | Amount, | 234 | Amount, |