aboutsummaryrefslogtreecommitdiff
path: root/Ryujinx.Graphics.Vulkan/PipelineDynamicState.cs
diff options
context:
space:
mode:
authorTSR Berry <20988865+TSRBerry@users.noreply.github.com>2023-04-08 01:22:00 +0200
committerMary <thog@protonmail.com>2023-04-27 23:51:14 +0200
commitcee712105850ac3385cd0091a923438167433f9f (patch)
tree4a5274b21d8b7f938c0d0ce18736d3f2993b11b1 /Ryujinx.Graphics.Vulkan/PipelineDynamicState.cs
parentcd124bda587ef09668a971fa1cac1c3f0cfc9f21 (diff)
Move solution and projects to src
Diffstat (limited to 'Ryujinx.Graphics.Vulkan/PipelineDynamicState.cs')
-rw-r--r--Ryujinx.Graphics.Vulkan/PipelineDynamicState.cs170
1 files changed, 0 insertions, 170 deletions
diff --git a/Ryujinx.Graphics.Vulkan/PipelineDynamicState.cs b/Ryujinx.Graphics.Vulkan/PipelineDynamicState.cs
deleted file mode 100644
index 42ea022a..00000000
--- a/Ryujinx.Graphics.Vulkan/PipelineDynamicState.cs
+++ /dev/null
@@ -1,170 +0,0 @@
-using Ryujinx.Common.Memory;
-using Silk.NET.Vulkan;
-
-namespace Ryujinx.Graphics.Vulkan
-{
- struct PipelineDynamicState
- {
- private float _depthBiasSlopeFactor;
- private float _depthBiasConstantFactor;
- private float _depthBiasClamp;
-
- public int ScissorsCount;
- private Array16<Rect2D> _scissors;
-
- private uint _backCompareMask;
- private uint _backWriteMask;
- private uint _backReference;
- private uint _frontCompareMask;
- private uint _frontWriteMask;
- private uint _frontReference;
-
- private Array4<float> _blendConstants;
-
- public uint ViewportsCount;
- public Array16<Viewport> Viewports;
-
- private enum DirtyFlags
- {
- None = 0,
- Blend = 1 << 0,
- DepthBias = 1 << 1,
- Scissor = 1 << 2,
- Stencil = 1 << 3,
- Viewport = 1 << 4,
- All = Blend | DepthBias | Scissor | Stencil | Viewport
- }
-
- private DirtyFlags _dirty;
-
- public void SetBlendConstants(float r, float g, float b, float a)
- {
- _blendConstants[0] = r;
- _blendConstants[1] = g;
- _blendConstants[2] = b;
- _blendConstants[3] = a;
-
- _dirty |= DirtyFlags.Blend;
- }
-
- public void SetDepthBias(float slopeFactor, float constantFactor, float clamp)
- {
- _depthBiasSlopeFactor = slopeFactor;
- _depthBiasConstantFactor = constantFactor;
- _depthBiasClamp = clamp;
-
- _dirty |= DirtyFlags.DepthBias;
- }
-
- public void SetScissor(int index, Rect2D scissor)
- {
- _scissors[index] = scissor;
-
- _dirty |= DirtyFlags.Scissor;
- }
-
- public void SetStencilMasks(
- uint backCompareMask,
- uint backWriteMask,
- uint backReference,
- uint frontCompareMask,
- uint frontWriteMask,
- uint frontReference)
- {
- _backCompareMask = backCompareMask;
- _backWriteMask = backWriteMask;
- _backReference = backReference;
- _frontCompareMask = frontCompareMask;
- _frontWriteMask = frontWriteMask;
- _frontReference = frontReference;
-
- _dirty |= DirtyFlags.Stencil;
- }
-
- public void SetViewport(int index, Viewport viewport)
- {
- Viewports[index] = viewport;
-
- _dirty |= DirtyFlags.Viewport;
- }
-
- public void SetViewports(ref Array16<Viewport> viewports, uint viewportsCount)
- {
- Viewports = viewports;
- ViewportsCount = viewportsCount;
-
- if (ViewportsCount != 0)
- {
- _dirty |= DirtyFlags.Viewport;
- }
- }
-
- public void ForceAllDirty()
- {
- _dirty = DirtyFlags.All;
- }
-
- public void ReplayIfDirty(Vk api, CommandBuffer commandBuffer)
- {
- if (_dirty.HasFlag(DirtyFlags.Blend))
- {
- RecordBlend(api, commandBuffer);
- }
-
- if (_dirty.HasFlag(DirtyFlags.DepthBias))
- {
- RecordDepthBias(api, commandBuffer);
- }
-
- if (_dirty.HasFlag(DirtyFlags.Scissor))
- {
- RecordScissor(api, commandBuffer);
- }
-
- if (_dirty.HasFlag(DirtyFlags.Stencil))
- {
- RecordStencilMasks(api, commandBuffer);
- }
-
- if (_dirty.HasFlag(DirtyFlags.Viewport))
- {
- RecordViewport(api, commandBuffer);
- }
-
- _dirty = DirtyFlags.None;
- }
-
- private void RecordBlend(Vk api, CommandBuffer commandBuffer)
- {
- api.CmdSetBlendConstants(commandBuffer, _blendConstants.AsSpan());
- }
-
- private void RecordDepthBias(Vk api, CommandBuffer commandBuffer)
- {
- api.CmdSetDepthBias(commandBuffer, _depthBiasConstantFactor, _depthBiasClamp, _depthBiasSlopeFactor);
- }
-
- private void RecordScissor(Vk api, CommandBuffer commandBuffer)
- {
- api.CmdSetScissor(commandBuffer, 0, (uint)ScissorsCount, _scissors.AsSpan());
- }
-
- private void RecordStencilMasks(Vk api, CommandBuffer commandBuffer)
- {
- api.CmdSetStencilCompareMask(commandBuffer, StencilFaceFlags.FaceBackBit, _backCompareMask);
- api.CmdSetStencilWriteMask(commandBuffer, StencilFaceFlags.FaceBackBit, _backWriteMask);
- api.CmdSetStencilReference(commandBuffer, StencilFaceFlags.FaceBackBit, _backReference);
- api.CmdSetStencilCompareMask(commandBuffer, StencilFaceFlags.FaceFrontBit, _frontCompareMask);
- api.CmdSetStencilWriteMask(commandBuffer, StencilFaceFlags.FaceFrontBit, _frontWriteMask);
- api.CmdSetStencilReference(commandBuffer, StencilFaceFlags.FaceFrontBit, _frontReference);
- }
-
- private void RecordViewport(Vk api, CommandBuffer commandBuffer)
- {
- if (ViewportsCount != 0)
- {
- api.CmdSetViewport(commandBuffer, 0, ViewportsCount, Viewports.AsSpan());
- }
- }
- }
-}