diff options
| author | 2018-07-02 19:48:15 -0500 | |
|---|---|---|
| committer | 2018-07-02 19:48:15 -0500 | |
| commit | 6e4e0b2b41eee7309bbf3f9a92368482b5d49232 (patch) | |
| tree | ecb93e1ca902f503c84ad22a35ff47a241947c7b /src | |
| parent | Merge pull request #602 from Subv/mufu_subop (diff) | |
| download | yuzu-6e4e0b2b41eee7309bbf3f9a92368482b5d49232.tar.gz yuzu-6e4e0b2b41eee7309bbf3f9a92368482b5d49232.tar.xz yuzu-6e4e0b2b41eee7309bbf3f9a92368482b5d49232.zip | |
GPU: Implemented MUFU suboperation 8, sqrt.
Diffstat (limited to 'src')
| -rw-r--r-- | src/video_core/engines/shader_bytecode.h | 1 | ||||
| -rw-r--r-- | src/video_core/renderer_opengl/gl_shader_decompiler.cpp | 4 |
2 files changed, 5 insertions, 0 deletions
diff --git a/src/video_core/engines/shader_bytecode.h b/src/video_core/engines/shader_bytecode.h index 86fd64979..c1226a649 100644 --- a/src/video_core/engines/shader_bytecode.h +++ b/src/video_core/engines/shader_bytecode.h | |||
| @@ -166,6 +166,7 @@ enum class SubOp : u64 { | |||
| 166 | Lg2 = 0x3, | 166 | Lg2 = 0x3, |
| 167 | Rcp = 0x4, | 167 | Rcp = 0x4, |
| 168 | Rsq = 0x5, | 168 | Rsq = 0x5, |
| 169 | Sqrt = 0x8, | ||
| 169 | }; | 170 | }; |
| 170 | 171 | ||
| 171 | enum class F2iRoundingOp : u64 { | 172 | enum class F2iRoundingOp : u64 { |
diff --git a/src/video_core/renderer_opengl/gl_shader_decompiler.cpp b/src/video_core/renderer_opengl/gl_shader_decompiler.cpp index bbccf0bfd..8e5465f40 100644 --- a/src/video_core/renderer_opengl/gl_shader_decompiler.cpp +++ b/src/video_core/renderer_opengl/gl_shader_decompiler.cpp | |||
| @@ -917,6 +917,10 @@ private: | |||
| 917 | regs.SetRegisterToFloat(instr.gpr0, 0, "inversesqrt(" + op_a + ')', 1, 1, | 917 | regs.SetRegisterToFloat(instr.gpr0, 0, "inversesqrt(" + op_a + ')', 1, 1, |
| 918 | instr.alu.saturate_d); | 918 | instr.alu.saturate_d); |
| 919 | break; | 919 | break; |
| 920 | case SubOp::Sqrt: | ||
| 921 | regs.SetRegisterToFloat(instr.gpr0, 0, "sqrt(" + op_a + ')', 1, 1, | ||
| 922 | instr.alu.saturate_d); | ||
| 923 | break; | ||
| 920 | default: | 924 | default: |
| 921 | NGLOG_CRITICAL(HW_GPU, "Unhandled MUFU sub op: {0:x}", | 925 | NGLOG_CRITICAL(HW_GPU, "Unhandled MUFU sub op: {0:x}", |
| 922 | static_cast<unsigned>(instr.sub_op.Value())); | 926 | static_cast<unsigned>(instr.sub_op.Value())); |