mirror of
https://github.com/shadps4-emu/shadPS4.git
synced 2025-01-04 06:06:00 +00:00
shader_recompiler: Exclude non-float results from output modifiers. (#1016)
This commit is contained in:
parent
8811cc5cc6
commit
a18419dd73
|
@ -281,12 +281,15 @@ template IR::F64 Translator::GetSrc64<IR::F64>(const InstOperand&);
|
||||||
|
|
||||||
void Translator::SetDst(const InstOperand& operand, const IR::U32F32& value) {
|
void Translator::SetDst(const InstOperand& operand, const IR::U32F32& value) {
|
||||||
IR::U32F32 result = value;
|
IR::U32F32 result = value;
|
||||||
if (operand.output_modifier.multiplier != 0.f) {
|
if (value.Type() == IR::Type::F32) {
|
||||||
result = ir.FPMul(result, ir.Imm32(operand.output_modifier.multiplier));
|
if (operand.output_modifier.multiplier != 0.f) {
|
||||||
}
|
result = ir.FPMul(result, ir.Imm32(operand.output_modifier.multiplier));
|
||||||
if (operand.output_modifier.clamp) {
|
}
|
||||||
result = ir.FPSaturate(value);
|
if (operand.output_modifier.clamp) {
|
||||||
|
result = ir.FPSaturate(value);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (operand.field) {
|
switch (operand.field) {
|
||||||
case OperandField::ScalarGPR:
|
case OperandField::ScalarGPR:
|
||||||
return ir.SetScalarReg(IR::ScalarReg(operand.code), result);
|
return ir.SetScalarReg(IR::ScalarReg(operand.code), result);
|
||||||
|
|
|
@ -569,8 +569,7 @@ void Translator::V_ADDC_U32(const GcnInst& inst) {
|
||||||
const IR::U32 scarry = IR::U32{ir.Select(carry, ir.Imm32(1), ir.Imm32(0))};
|
const IR::U32 scarry = IR::U32{ir.Select(carry, ir.Imm32(1), ir.Imm32(0))};
|
||||||
const IR::U32 result = ir.IAdd(ir.IAdd(src0, src1), scarry);
|
const IR::U32 result = ir.IAdd(ir.IAdd(src0, src1), scarry);
|
||||||
|
|
||||||
const IR::VectorReg dst_reg{inst.dst[0].code};
|
SetDst(inst.dst[0], result);
|
||||||
ir.SetVectorReg(dst_reg, result);
|
|
||||||
|
|
||||||
const IR::U1 less_src0 = ir.ILessThan(result, src0, false);
|
const IR::U1 less_src0 = ir.ILessThan(result, src0, false);
|
||||||
const IR::U1 less_src1 = ir.ILessThan(result, src1, false);
|
const IR::U1 less_src1 = ir.ILessThan(result, src1, false);
|
||||||
|
|
Loading…
Reference in a new issue