diff options
author | Tony Wasserka <neobrainx@gmail.com> | 2015-01-26 11:52:15 +0100 |
---|---|---|
committer | Tony Wasserka <neobrainx@gmail.com> | 2015-01-26 11:52:15 +0100 |
commit | 0cf3c40aa9f57a425c3cceba9a9a02986226bb21 (patch) | |
tree | 464bf8822bd09f9cc2e6a9d23e95cacf882459d7 /src/video_core/rasterizer.cpp | |
parent | ad666ac47a03f63aa7c2b5ecfe9a7d76c6a033d2 (diff) | |
parent | ff83d23ed5a2b204a6768e853329204cb1dd1bd3 (diff) |
Merge pull request #506 from bunnei/depth-functions
GPU: Implement the remaining depth testing functions.
Diffstat (limited to 'src/video_core/rasterizer.cpp')
-rw-r--r-- | src/video_core/rasterizer.cpp | 20 |
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; |