mirror of
https://github.com/GreemDev/Ryujinx
synced 2024-12-13 03:29:56 +01:00
Fix stencil clears
This commit is contained in:
parent
05189c7749
commit
a264d9273d
2 changed files with 1 additions and 4 deletions
|
@ -309,7 +309,7 @@ namespace Ryujinx.Graphics.Metal
|
||||||
// Save current state
|
// Save current state
|
||||||
_pipeline.SaveState();
|
_pipeline.SaveState();
|
||||||
|
|
||||||
const int ClearDepthBufferSize = 4;
|
const int ClearDepthBufferSize = 16;
|
||||||
|
|
||||||
using var buffer = _renderer.BufferManager.ReserveOrCreate(_pipeline.Cbs, ClearDepthBufferSize);
|
using var buffer = _renderer.BufferManager.ReserveOrCreate(_pipeline.Cbs, ClearDepthBufferSize);
|
||||||
buffer.Holder.SetDataUnchecked(buffer.Offset, new ReadOnlySpan<float>(ref depthValue));
|
buffer.Holder.SetDataUnchecked(buffer.Offset, new ReadOnlySpan<float>(ref depthValue));
|
||||||
|
@ -328,7 +328,6 @@ namespace Ryujinx.Graphics.Metal
|
||||||
|
|
||||||
_pipeline.SetProgram(_programDepthStencilClear);
|
_pipeline.SetProgram(_programDepthStencilClear);
|
||||||
_pipeline.SetFaceCulling(false, Face.Front);
|
_pipeline.SetFaceCulling(false, Face.Front);
|
||||||
_pipeline.SetDepthTest(new DepthTestDescriptor(false, false, CompareOp.Always));
|
|
||||||
_pipeline.SetPrimitiveTopology(PrimitiveTopology.TriangleStrip);
|
_pipeline.SetPrimitiveTopology(PrimitiveTopology.TriangleStrip);
|
||||||
_pipeline.SetViewports(viewports);
|
_pipeline.SetViewports(viewports);
|
||||||
_pipeline.SetDepthTest(new DepthTestDescriptor(true, depthMask, CompareOp.Always));
|
_pipeline.SetDepthTest(new DepthTestDescriptor(true, depthMask, CompareOp.Always));
|
||||||
|
|
|
@ -8,7 +8,6 @@ struct VertexOut {
|
||||||
|
|
||||||
struct FragmentOut {
|
struct FragmentOut {
|
||||||
float depth [[depth(any)]];
|
float depth [[depth(any)]];
|
||||||
uint stencil [[stencil]];
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct ClearDepth {
|
struct ClearDepth {
|
||||||
|
@ -38,7 +37,6 @@ fragment FragmentOut fragmentMain(VertexOut in [[stage_in]],
|
||||||
FragmentOut out;
|
FragmentOut out;
|
||||||
|
|
||||||
out.depth = constant_buffers.clear_depth->data;
|
out.depth = constant_buffers.clear_depth->data;
|
||||||
// out.stencil = stencil_clear;
|
|
||||||
|
|
||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue