summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/video_core/shader/decode/conversion.cpp15
1 files changed, 13 insertions, 2 deletions
diff --git a/src/video_core/shader/decode/conversion.cpp b/src/video_core/shader/decode/conversion.cpp
index 32facd6ba..0eeb75559 100644
--- a/src/video_core/shader/decode/conversion.cpp
+++ b/src/video_core/shader/decode/conversion.cpp
@@ -63,12 +63,11 @@ u32 ShaderIR::DecodeConversion(NodeBlock& bb, u32 pc) {
63 case OpCode::Id::I2F_R: 63 case OpCode::Id::I2F_R:
64 case OpCode::Id::I2F_C: 64 case OpCode::Id::I2F_C:
65 case OpCode::Id::I2F_IMM: { 65 case OpCode::Id::I2F_IMM: {
66 UNIMPLEMENTED_IF(instr.conversion.int_src.selector != 0);
67 UNIMPLEMENTED_IF(instr.conversion.dst_size == Register::Size::Long); 66 UNIMPLEMENTED_IF(instr.conversion.dst_size == Register::Size::Long);
68 UNIMPLEMENTED_IF_MSG(instr.generates_cc, 67 UNIMPLEMENTED_IF_MSG(instr.generates_cc,
69 "Condition codes generation in I2F is not implemented"); 68 "Condition codes generation in I2F is not implemented");
70 69
71 Node value = [&]() { 70 Node value = [&] {
72 switch (opcode->get().GetId()) { 71 switch (opcode->get().GetId()) {
73 case OpCode::Id::I2F_R: 72 case OpCode::Id::I2F_R:
74 return GetRegister(instr.gpr20); 73 return GetRegister(instr.gpr20);
@@ -81,7 +80,19 @@ u32 ShaderIR::DecodeConversion(NodeBlock& bb, u32 pc) {
81 return Immediate(0); 80 return Immediate(0);
82 } 81 }
83 }(); 82 }();
83
84 const bool input_signed = instr.conversion.is_input_signed; 84 const bool input_signed = instr.conversion.is_input_signed;
85
86 if (instr.conversion.src_size == Register::Size::Byte) {
87 const u32 offset = static_cast<u32>(instr.conversion.int_src.selector) * 8;
88 if (offset > 0) {
89 value = SignedOperation(OperationCode::ILogicalShiftRight, input_signed,
90 std::move(value), Immediate(offset));
91 }
92 } else {
93 UNIMPLEMENTED_IF(instr.conversion.int_src.selector != 0);
94 }
95
85 value = ConvertIntegerSize(value, instr.conversion.src_size, input_signed); 96 value = ConvertIntegerSize(value, instr.conversion.src_size, input_signed);
86 value = GetOperandAbsNegInteger(value, instr.conversion.abs_a, false, input_signed); 97 value = GetOperandAbsNegInteger(value, instr.conversion.abs_a, false, input_signed);
87 value = SignedOperation(OperationCode::FCastInteger, input_signed, PRECISE, value); 98 value = SignedOperation(OperationCode::FCastInteger, input_signed, PRECISE, value);