summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorGravatar bunnei2018-05-29 23:10:44 -0400
committerGravatar bunnei2018-05-29 23:10:44 -0400
commit68937a662dd09e67a7558e6ab21c5f31338db2a4 (patch)
treeb376dc84787c4548a3a093f5c6da0f862d5e6884 /src
parentnvhost_ctrl: Stub out IocCtrlEventRegister. (diff)
downloadyuzu-68937a662dd09e67a7558e6ab21c5f31338db2a4.tar.gz
yuzu-68937a662dd09e67a7558e6ab21c5f31338db2a4.tar.xz
yuzu-68937a662dd09e67a7558e6ab21c5f31338db2a4.zip
gl_shader_decompiler: Partially implement F2F_R instruction.
Diffstat (limited to 'src')
-rw-r--r--src/video_core/engines/shader_bytecode.h6
-rw-r--r--src/video_core/renderer_opengl/gl_shader_decompiler.cpp7
2 files changed, 9 insertions, 4 deletions
diff --git a/src/video_core/engines/shader_bytecode.h b/src/video_core/engines/shader_bytecode.h
index d75de85e2..198a470c0 100644
--- a/src/video_core/engines/shader_bytecode.h
+++ b/src/video_core/engines/shader_bytecode.h
@@ -456,9 +456,9 @@ private:
456 INST("00011110--------", Id::FMUL32_IMM, Type::Arithmetic, "FMUL32_IMM"), 456 INST("00011110--------", Id::FMUL32_IMM, Type::Arithmetic, "FMUL32_IMM"),
457 INST("0101000010000---", Id::MUFU, Type::Arithmetic, "MUFU"), 457 INST("0101000010000---", Id::MUFU, Type::Arithmetic, "MUFU"),
458 INST("0101110010010---", Id::RRO, Type::Arithmetic, "RRO"), 458 INST("0101110010010---", Id::RRO, Type::Arithmetic, "RRO"),
459 INST("0100110010101---", Id::F2F_C, Type::Arithmetic, "F2F_C"), 459 INST("0100110010101---", Id::F2F_C, Type::Conversion, "F2F_C"),
460 INST("0101110010101---", Id::F2F_R, Type::Arithmetic, "F2F_R"), 460 INST("0101110010101---", Id::F2F_R, Type::Conversion, "F2F_R"),
461 INST("0011100-10101---", Id::F2F_IMM, Type::Arithmetic, "F2F_IMM"), 461 INST("0011100-10101---", Id::F2F_IMM, Type::Conversion, "F2F_IMM"),
462 INST("0100110010110---", Id::F2I_C, Type::Arithmetic, "F2I_C"), 462 INST("0100110010110---", Id::F2I_C, Type::Arithmetic, "F2I_C"),
463 INST("0101110010110---", Id::F2I_R, Type::Arithmetic, "F2I_R"), 463 INST("0101110010110---", Id::F2I_R, Type::Arithmetic, "F2I_R"),
464 INST("0011100-10110---", Id::F2I_IMM, Type::Arithmetic, "F2I_IMM"), 464 INST("0011100-10110---", Id::F2I_IMM, Type::Arithmetic, "F2I_IMM"),
diff --git a/src/video_core/renderer_opengl/gl_shader_decompiler.cpp b/src/video_core/renderer_opengl/gl_shader_decompiler.cpp
index 75822e750..c17bd7d2c 100644
--- a/src/video_core/renderer_opengl/gl_shader_decompiler.cpp
+++ b/src/video_core/renderer_opengl/gl_shader_decompiler.cpp
@@ -834,13 +834,14 @@ private:
834 } 834 }
835 case OpCode::Type::Conversion: { 835 case OpCode::Type::Conversion: {
836 ASSERT_MSG(instr.conversion.size == Register::Size::Word, "Unimplemented"); 836 ASSERT_MSG(instr.conversion.size == Register::Size::Word, "Unimplemented");
837 ASSERT_MSG(!instr.conversion.selector, "Unimplemented");
838 ASSERT_MSG(!instr.conversion.negate_a, "Unimplemented"); 837 ASSERT_MSG(!instr.conversion.negate_a, "Unimplemented");
839 ASSERT_MSG(!instr.conversion.saturate_a, "Unimplemented"); 838 ASSERT_MSG(!instr.conversion.saturate_a, "Unimplemented");
840 839
841 switch (opcode->GetId()) { 840 switch (opcode->GetId()) {
842 case OpCode::Id::I2I_R: 841 case OpCode::Id::I2I_R:
843 case OpCode::Id::I2F_R: { 842 case OpCode::Id::I2F_R: {
843 ASSERT_MSG(!instr.conversion.selector, "Unimplemented");
844
844 std::string op_a = 845 std::string op_a =
845 regs.GetRegisterAsInteger(instr.gpr20, 0, instr.conversion.is_signed); 846 regs.GetRegisterAsInteger(instr.gpr20, 0, instr.conversion.is_signed);
846 847
@@ -851,6 +852,10 @@ private:
851 regs.SetRegisterToInteger(instr.gpr0, instr.conversion.is_signed, 0, op_a, 1, 1); 852 regs.SetRegisterToInteger(instr.gpr0, instr.conversion.is_signed, 0, op_a, 1, 1);
852 break; 853 break;
853 } 854 }
855 case OpCode::Id::F2F_R: {
856 regs.SetRegisterToFloat(instr.gpr0, 0, regs.GetRegisterAsFloat(instr.gpr20), 1, 1);
857 break;
858 }
854 default: { 859 default: {
855 NGLOG_CRITICAL(HW_GPU, "Unhandled conversion instruction: {}", opcode->GetName()); 860 NGLOG_CRITICAL(HW_GPU, "Unhandled conversion instruction: {}", opcode->GetName());
856 UNREACHABLE(); 861 UNREACHABLE();