diff options
author | Yuri Kunde Schlesner <yuriks@yuriks.net> | 2015-08-24 06:46:58 +0200 |
---|---|---|
committer | Yuri Kunde Schlesner <yuriks@yuriks.net> | 2015-08-24 06:46:58 +0200 |
commit | 082b74fa241ba71f27b2e3fdf756824a0467f7f4 (patch) | |
tree | 4bc4da888d196924e300d4f853855ac6d55fafa9 /src/video_core/shader/shader_interpreter.cpp | |
parent | Shader JIT: Add name to second scratch register (XMM4) (diff) | |
download | yuzu-082b74fa241ba71f27b2e3fdf756824a0467f7f4.tar yuzu-082b74fa241ba71f27b2e3fdf756824a0467f7f4.tar.gz yuzu-082b74fa241ba71f27b2e3fdf756824a0467f7f4.tar.bz2 yuzu-082b74fa241ba71f27b2e3fdf756824a0467f7f4.tar.lz yuzu-082b74fa241ba71f27b2e3fdf756824a0467f7f4.tar.xz yuzu-082b74fa241ba71f27b2e3fdf756824a0467f7f4.tar.zst yuzu-082b74fa241ba71f27b2e3fdf756824a0467f7f4.zip |
Diffstat (limited to 'src/video_core/shader/shader_interpreter.cpp')
-rw-r--r-- | src/video_core/shader/shader_interpreter.cpp | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/src/video_core/shader/shader_interpreter.cpp b/src/video_core/shader/shader_interpreter.cpp index ae5a30441..69e4efa68 100644 --- a/src/video_core/shader/shader_interpreter.cpp +++ b/src/video_core/shader/shader_interpreter.cpp @@ -177,7 +177,10 @@ void RunInterpreter(UnitState<Debug>& state) { if (!swizzle.DestComponentEnabled(i)) continue; - dest[i] = std::max(src1[i], src2[i]); + // NOTE: Exact form required to match NaN semantics to hardware: + // max(0, NaN) -> NaN + // max(NaN, 0) -> 0 + dest[i] = (src1[i] > src2[i]) ? src1[i] : src2[i]; } Record<DebugDataRecord::DEST_OUT>(state.debug, iteration, dest); break; @@ -190,7 +193,10 @@ void RunInterpreter(UnitState<Debug>& state) { if (!swizzle.DestComponentEnabled(i)) continue; - dest[i] = std::min(src1[i], src2[i]); + // NOTE: Exact form required to match NaN semantics to hardware: + // min(0, NaN) -> NaN + // min(NaN, 0) -> 0 + dest[i] = (src1[i] < src2[i]) ? src1[i] : src2[i]; } Record<DebugDataRecord::DEST_OUT>(state.debug, iteration, dest); break; |