mirror of
https://github.com/citra-emu/citra-canary.git
synced 2025-01-11 17:55:28 +00:00
shader_jit_a64_compiler: Improve MAX, MIN (#7137)
This commit is contained in:
parent
80213bf88f
commit
271218b733
|
@ -548,13 +548,8 @@ void JitShader::Compile_MAX(Instruction instr) {
|
||||||
Compile_SwizzleSrc(instr, 1, instr.common.src1, SRC1);
|
Compile_SwizzleSrc(instr, 1, instr.common.src1, SRC1);
|
||||||
Compile_SwizzleSrc(instr, 2, instr.common.src2, SRC2);
|
Compile_SwizzleSrc(instr, 2, instr.common.src2, SRC2);
|
||||||
|
|
||||||
// VSCRATCH0 = Ordinal(SRC1)
|
// Equivalent to (b < a) ? a : b with associated NaN caveats
|
||||||
FCMEQ(VSCRATCH0.S4(), SRC1.S4(), SRC1.S4());
|
FCMGT(VSCRATCH0.S4(), SRC1.S4(), SRC2.S4());
|
||||||
|
|
||||||
// FMAX will always pick the NaN
|
|
||||||
FMAX(SRC1.S4(), SRC1.S4(), SRC2.S4());
|
|
||||||
|
|
||||||
// In the case of NaN, pick SRC2
|
|
||||||
BIF(SRC1.B16(), SRC2.B16(), VSCRATCH0.B16());
|
BIF(SRC1.B16(), SRC2.B16(), VSCRATCH0.B16());
|
||||||
|
|
||||||
Compile_DestEnable(instr, SRC1);
|
Compile_DestEnable(instr, SRC1);
|
||||||
|
@ -564,13 +559,8 @@ void JitShader::Compile_MIN(Instruction instr) {
|
||||||
Compile_SwizzleSrc(instr, 1, instr.common.src1, SRC1);
|
Compile_SwizzleSrc(instr, 1, instr.common.src1, SRC1);
|
||||||
Compile_SwizzleSrc(instr, 2, instr.common.src2, SRC2);
|
Compile_SwizzleSrc(instr, 2, instr.common.src2, SRC2);
|
||||||
|
|
||||||
// VSCRATCH0 = Ordinal(SRC1)
|
// Equivalent to (a < b) ? a : b with associated NaN caveats
|
||||||
FCMEQ(VSCRATCH0.S4(), SRC1.S4(), SRC1.S4());
|
FCMGT(VSCRATCH0.S4(), SRC2.S4(), SRC1.S4());
|
||||||
|
|
||||||
// FMIN will always pick the NaN
|
|
||||||
FMIN(SRC1.S4(), SRC1.S4(), SRC2.S4());
|
|
||||||
|
|
||||||
// In the case of NaN, pick SRC2
|
|
||||||
BIF(SRC1.B16(), SRC2.B16(), VSCRATCH0.B16());
|
BIF(SRC1.B16(), SRC2.B16(), VSCRATCH0.B16());
|
||||||
|
|
||||||
Compile_DestEnable(instr, SRC1);
|
Compile_DestEnable(instr, SRC1);
|
||||||
|
|
Loading…
Reference in a new issue