diff options
| author | 2018-05-29 23:10:44 -0400 | |
|---|---|---|
| committer | 2018-05-29 23:10:44 -0400 | |
| commit | 68937a662dd09e67a7558e6ab21c5f31338db2a4 (patch) | |
| tree | b376dc84787c4548a3a093f5c6da0f862d5e6884 /src | |
| parent | nvhost_ctrl: Stub out IocCtrlEventRegister. (diff) | |
| download | yuzu-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.h | 6 | ||||
| -rw-r--r-- | src/video_core/renderer_opengl/gl_shader_decompiler.cpp | 7 |
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(); |