summaryrefslogtreecommitdiffstats
path: root/src/video_core/rasterizer.cpp
diff options
context:
space:
mode:
authorTony Wasserka <neobrainx@gmail.com>2015-01-26 11:52:15 +0100
committerTony Wasserka <neobrainx@gmail.com>2015-01-26 11:52:15 +0100
commit0cf3c40aa9f57a425c3cceba9a9a02986226bb21 (patch)
tree464bf8822bd09f9cc2e6a9d23e95cacf882459d7 /src/video_core/rasterizer.cpp
parentMerge pull request #484 from chinhodado/build (diff)
parentGPU: Implement the remaining depth testing functions. (diff)
downloadyuzu-0cf3c40aa9f57a425c3cceba9a9a02986226bb21.tar
yuzu-0cf3c40aa9f57a425c3cceba9a9a02986226bb21.tar.gz
yuzu-0cf3c40aa9f57a425c3cceba9a9a02986226bb21.tar.bz2
yuzu-0cf3c40aa9f57a425c3cceba9a9a02986226bb21.tar.lz
yuzu-0cf3c40aa9f57a425c3cceba9a9a02986226bb21.tar.xz
yuzu-0cf3c40aa9f57a425c3cceba9a9a02986226bb21.tar.zst
yuzu-0cf3c40aa9f57a425c3cceba9a9a02986226bb21.zip
Diffstat (limited to 'src/video_core/rasterizer.cpp')
-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;