summaryrefslogtreecommitdiffstats
path: root/src/video_core/rasterizer.cpp
diff options
context:
space:
mode:
authorbunnei <bunneidev@gmail.com>2015-01-26 05:34:14 +0100
committerbunnei <bunneidev@gmail.com>2015-01-26 05:34:14 +0100
commitff83d23ed5a2b204a6768e853329204cb1dd1bd3 (patch)
tree464bf8822bd09f9cc2e6a9d23e95cacf882459d7 /src/video_core/rasterizer.cpp
parentMerge pull request #484 from chinhodado/build (diff)
downloadyuzu-ff83d23ed5a2b204a6768e853329204cb1dd1bd3.tar
yuzu-ff83d23ed5a2b204a6768e853329204cb1dd1bd3.tar.gz
yuzu-ff83d23ed5a2b204a6768e853329204cb1dd1bd3.tar.bz2
yuzu-ff83d23ed5a2b204a6768e853329204cb1dd1bd3.tar.lz
yuzu-ff83d23ed5a2b204a6768e853329204cb1dd1bd3.tar.xz
yuzu-ff83d23ed5a2b204a6768e853329204cb1dd1bd3.tar.zst
yuzu-ff83d23ed5a2b204a6768e853329204cb1dd1bd3.zip
Diffstat (limited to '')
-rw-r--r--src/video_core/rasterizer.cpp20
1 files changed, 20 insertions, 0 deletions
diff --git a/src/video_core/rasterizer.cpp b/src/video_core/rasterizer.cpp
index 025d4e484..219a1bbb7 100644
--- a/src/video_core/rasterizer.cpp
+++ b/src/video_core/rasterizer.cpp
@@ -441,18 +441,38 @@ void ProcessTriangle(const VertexShader::OutputVertex& v0,
bool pass = false;
switch (registers.output_merger.depth_test_func) {
+ case registers.output_merger.Never:
+ pass = false;
+ break;
+
case registers.output_merger.Always:
pass = true;
break;
+ case registers.output_merger.Equal:
+ pass = z == ref_z;
+ break;
+
+ case registers.output_merger.NotEqual:
+ pass = z != ref_z;
+ break;
+
case registers.output_merger.LessThan:
pass = z < ref_z;
break;
+ case registers.output_merger.LessThanOrEqual:
+ pass = z <= ref_z;
+ break;
+
case registers.output_merger.GreaterThan:
pass = z > ref_z;
break;
+ case registers.output_merger.GreaterThanOrEqual:
+ pass = z >= ref_z;
+ break;
+
default:
LOG_ERROR(HW_GPU, "Unknown depth test function %x", registers.output_merger.depth_test_func.Value());
break;