mirror of
https://github.com/shadps4-emu/shadPS4.git
synced 2025-01-01 12:46:01 +00:00
Implement S_ABSDIFF_I32 shader instruction (#902)
This commit is contained in:
parent
ab201398b2
commit
c181102a02
|
@ -84,6 +84,8 @@ void Translator::EmitScalarAlu(const GcnInst& inst) {
|
||||||
return S_MAX_U32(false, inst);
|
return S_MAX_U32(false, inst);
|
||||||
case Opcode::S_MAX_I32:
|
case Opcode::S_MAX_I32:
|
||||||
return S_MAX_U32(true, inst);
|
return S_MAX_U32(true, inst);
|
||||||
|
case Opcode::S_ABSDIFF_I32:
|
||||||
|
return S_ABSDIFF_I32(inst);
|
||||||
case Opcode::S_WQM_B64:
|
case Opcode::S_WQM_B64:
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -563,4 +565,12 @@ void Translator::S_MIN_U32(bool is_signed, const GcnInst& inst) {
|
||||||
ir.SetScc(ir.IEqual(result, src0));
|
ir.SetScc(ir.IEqual(result, src0));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Translator::S_ABSDIFF_I32(const GcnInst& inst) {
|
||||||
|
const IR::U32 src0{GetSrc(inst.src[0])};
|
||||||
|
const IR::U32 src1{GetSrc(inst.src[1])};
|
||||||
|
const IR::U32 result{ir.IAbs(ir.ISub(src0, src1))};
|
||||||
|
SetDst(inst.dst[0], result);
|
||||||
|
ir.SetScc(ir.INotEqual(result, ir.Imm32(0)));
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace Shader::Gcn
|
} // namespace Shader::Gcn
|
||||||
|
|
|
@ -103,6 +103,7 @@ public:
|
||||||
void S_ADDK_I32(const GcnInst& inst);
|
void S_ADDK_I32(const GcnInst& inst);
|
||||||
void S_MAX_U32(bool is_signed, const GcnInst& inst);
|
void S_MAX_U32(bool is_signed, const GcnInst& inst);
|
||||||
void S_MIN_U32(bool is_signed, const GcnInst& inst);
|
void S_MIN_U32(bool is_signed, const GcnInst& inst);
|
||||||
|
void S_ABSDIFF_I32(const GcnInst& inst);
|
||||||
void S_CMPK(ConditionOp cond, bool is_signed, const GcnInst& inst);
|
void S_CMPK(ConditionOp cond, bool is_signed, const GcnInst& inst);
|
||||||
|
|
||||||
// Scalar Memory
|
// Scalar Memory
|
||||||
|
|
Loading…
Reference in a new issue