summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSubv <subv2112@gmail.com>2018-07-03 02:48:15 +0200
committerSubv <subv2112@gmail.com>2018-07-03 02:48:15 +0200
commit6e4e0b2b41eee7309bbf3f9a92368482b5d49232 (patch)
treeecb93e1ca902f503c84ad22a35ff47a241947c7b
parentMerge pull request #602 from Subv/mufu_subop (diff)
downloadyuzu-6e4e0b2b41eee7309bbf3f9a92368482b5d49232.tar
yuzu-6e4e0b2b41eee7309bbf3f9a92368482b5d49232.tar.gz
yuzu-6e4e0b2b41eee7309bbf3f9a92368482b5d49232.tar.bz2
yuzu-6e4e0b2b41eee7309bbf3f9a92368482b5d49232.tar.lz
yuzu-6e4e0b2b41eee7309bbf3f9a92368482b5d49232.tar.xz
yuzu-6e4e0b2b41eee7309bbf3f9a92368482b5d49232.tar.zst
yuzu-6e4e0b2b41eee7309bbf3f9a92368482b5d49232.zip
-rw-r--r--src/video_core/engines/shader_bytecode.h1
-rw-r--r--src/video_core/renderer_opengl/gl_shader_decompiler.cpp4
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 {
Lg2 = 0x3,
Rcp = 0x4,
Rsq = 0x5,
+ Sqrt = 0x8,
};
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:
regs.SetRegisterToFloat(instr.gpr0, 0, "inversesqrt(" + op_a + ')', 1, 1,
instr.alu.saturate_d);
break;
+ case SubOp::Sqrt:
+ regs.SetRegisterToFloat(instr.gpr0, 0, "sqrt(" + op_a + ')', 1, 1,
+ instr.alu.saturate_d);
+ break;
default:
NGLOG_CRITICAL(HW_GPU, "Unhandled MUFU sub op: {0:x}",
static_cast<unsigned>(instr.sub_op.Value()));