forked from suyu/suyu
GPU: Implement the FADD32I shader instruction.
This commit is contained in:
parent
3417f46dd5
commit
c1ae841f47
2 changed files with 32 additions and 0 deletions
|
@ -283,6 +283,13 @@ union Instruction {
|
||||||
BitField<56, 1, u64> negate_a;
|
BitField<56, 1, u64> negate_a;
|
||||||
} iadd32i;
|
} iadd32i;
|
||||||
|
|
||||||
|
union {
|
||||||
|
BitField<53, 1, u64> negate_b;
|
||||||
|
BitField<54, 1, u64> abs_a;
|
||||||
|
BitField<56, 1, u64> negate_a;
|
||||||
|
BitField<57, 1, u64> abs_b;
|
||||||
|
} fadd32i;
|
||||||
|
|
||||||
union {
|
union {
|
||||||
BitField<20, 8, u64> shift_position;
|
BitField<20, 8, u64> shift_position;
|
||||||
BitField<28, 8, u64> shift_length;
|
BitField<28, 8, u64> shift_length;
|
||||||
|
@ -473,6 +480,7 @@ public:
|
||||||
FADD_C,
|
FADD_C,
|
||||||
FADD_R,
|
FADD_R,
|
||||||
FADD_IMM,
|
FADD_IMM,
|
||||||
|
FADD32I,
|
||||||
FMUL_C,
|
FMUL_C,
|
||||||
FMUL_R,
|
FMUL_R,
|
||||||
FMUL_IMM,
|
FMUL_IMM,
|
||||||
|
@ -672,6 +680,7 @@ private:
|
||||||
INST("0100110001011---", Id::FADD_C, Type::Arithmetic, "FADD_C"),
|
INST("0100110001011---", Id::FADD_C, Type::Arithmetic, "FADD_C"),
|
||||||
INST("0101110001011---", Id::FADD_R, Type::Arithmetic, "FADD_R"),
|
INST("0101110001011---", Id::FADD_R, Type::Arithmetic, "FADD_R"),
|
||||||
INST("0011100-01011---", Id::FADD_IMM, Type::Arithmetic, "FADD_IMM"),
|
INST("0011100-01011---", Id::FADD_IMM, Type::Arithmetic, "FADD_IMM"),
|
||||||
|
INST("000010----------", Id::FADD32I, Type::ArithmeticImmediate, "FADD32I"),
|
||||||
INST("0100110001101---", Id::FMUL_C, Type::Arithmetic, "FMUL_C"),
|
INST("0100110001101---", Id::FMUL_C, Type::Arithmetic, "FMUL_C"),
|
||||||
INST("0101110001101---", Id::FMUL_R, Type::Arithmetic, "FMUL_R"),
|
INST("0101110001101---", Id::FMUL_R, Type::Arithmetic, "FMUL_R"),
|
||||||
INST("0011100-01101---", Id::FMUL_IMM, Type::Arithmetic, "FMUL_IMM"),
|
INST("0011100-01101---", Id::FMUL_IMM, Type::Arithmetic, "FMUL_IMM"),
|
||||||
|
|
|
@ -968,6 +968,29 @@ private:
|
||||||
regs.GetRegisterAsFloat(instr.gpr8) + " * " + GetImmediate32(instr), 1, 1);
|
regs.GetRegisterAsFloat(instr.gpr8) + " * " + GetImmediate32(instr), 1, 1);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case OpCode::Id::FADD32I: {
|
||||||
|
std::string op_a = regs.GetRegisterAsFloat(instr.gpr8);
|
||||||
|
std::string op_b = GetImmediate32(instr);
|
||||||
|
|
||||||
|
if (instr.fadd32i.abs_a) {
|
||||||
|
op_a = "abs(" + op_a + ')';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (instr.fadd32i.negate_a) {
|
||||||
|
op_a = "-(" + op_a + ')';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (instr.fadd32i.abs_b) {
|
||||||
|
op_b = "abs(" + op_b + ')';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (instr.fadd32i.negate_b) {
|
||||||
|
op_b = "-(" + op_b + ')';
|
||||||
|
}
|
||||||
|
|
||||||
|
regs.SetRegisterToFloat(instr.gpr0, 0, op_a + " + " + op_b, 1, 1);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue