From feb67dede698ebc8f76aaeabe5f0f2b4db785fa1 Mon Sep 17 00:00:00 2001 From: sunshineinabox Date: Thu, 4 Jul 2024 23:35:40 -0700 Subject: [PATCH] Avoid setting depth bias state when not needed. --- src/Ryujinx.Graphics.Vulkan/PipelineBase.cs | 13 ++++++-- .../PipelineDynamicState.cs | 32 +++++++++++-------- 2 files changed, 30 insertions(+), 15 deletions(-) diff --git a/src/Ryujinx.Graphics.Vulkan/PipelineBase.cs b/src/Ryujinx.Graphics.Vulkan/PipelineBase.cs index 42b129e886..e3374f8847 100644 --- a/src/Ryujinx.Graphics.Vulkan/PipelineBase.cs +++ b/src/Ryujinx.Graphics.Vulkan/PipelineBase.cs @@ -880,8 +880,17 @@ namespace Ryujinx.Graphics.Vulkan public void SetDepthBias(PolygonModeMask enables, float factor, float units, float clamp) { - bool enable = enables != 0; - DynamicState.SetDepthBias(factor, units, clamp, enable); + bool enable = (enables != 0) && (factor > 0.0f || units > 0.0f); + + if (enable) + { + DynamicState.SetDepthBias(factor, units, clamp); + } + + if (Gd.Capabilities.SupportsExtendedDynamicState2) + { + DynamicState.SetDepthBiasEnable(enable); + } _newState.DepthBiasEnable = enable; diff --git a/src/Ryujinx.Graphics.Vulkan/PipelineDynamicState.cs b/src/Ryujinx.Graphics.Vulkan/PipelineDynamicState.cs index ebc048cfd7..7733ead98c 100644 --- a/src/Ryujinx.Graphics.Vulkan/PipelineDynamicState.cs +++ b/src/Ryujinx.Graphics.Vulkan/PipelineDynamicState.cs @@ -77,9 +77,10 @@ namespace Ryujinx.Graphics.Vulkan PatchControlPoints = 1 << 13, PrimitiveRestart = 1 << 14, PrimitiveTopology = 1 << 15, + DepthBiasEnable = 1 << 16, Standard = Blend | DepthBias | Scissor | Stencil | Viewport | LineWidth, Extended = CullMode | FrontFace | DepthTestBool | DepthTestCompareOp | StencilTestEnableandStencilOp | PrimitiveTopology, - Extended2 = RasterDiscard | LogicOp | PatchControlPoints | PrimitiveRestart, + Extended2 = RasterDiscard | LogicOp | PatchControlPoints | PrimitiveRestart | DepthBiasEnable, } private DirtyFlags _dirty; @@ -93,16 +94,21 @@ namespace Ryujinx.Graphics.Vulkan _dirty |= DirtyFlags.Blend; } - public void SetDepthBias(float slopeFactor, float constantFactor, float clamp, bool enable) + public void SetDepthBias(float slopeFactor, float constantFactor, float clamp) { _depthBiasSlopeFactor = slopeFactor; _depthBiasConstantFactor = constantFactor; _depthBiasClamp = clamp; - _depthBiasEnable = enable; _dirty |= DirtyFlags.DepthBias; } + public void SetDepthBiasEnable(bool enable) + { + _depthBiasEnable = enable; + _dirty |= DirtyFlags.DepthBiasEnable; + } + public void SetScissor(int index, Rect2D scissor) { _scissors[index] = scissor; @@ -299,6 +305,11 @@ namespace Ryujinx.Graphics.Vulkan RecordDepthTestBool(gd.ExtendedDynamicStateApi, commandBuffer); } + if (_dirty.HasFlag(DirtyFlags.DepthBiasEnable)) + { + RecordDepthBiasEnable(gd.ExtendedDynamicState2Api, commandBuffer); + } + if (_dirty.HasFlag(DirtyFlags.DepthTestCompareOp)) { RecordDepthTestCompareOp(gd.ExtendedDynamicStateApi, commandBuffer); @@ -349,19 +360,14 @@ namespace Ryujinx.Graphics.Vulkan private readonly void RecordDepthBias(VulkanRenderer gd, CommandBuffer commandBuffer) { - if (gd.Capabilities.SupportsExtendedDynamicState2) - { - gd.ExtendedDynamicState2Api.CmdSetDepthBiasEnable(commandBuffer, _depthBiasEnable); - - if (!_depthBiasEnable) - { - return; - } - } - gd.Api.CmdSetDepthBias(commandBuffer, _depthBiasConstantFactor, _depthBiasClamp, _depthBiasSlopeFactor); } + private readonly void RecordDepthBiasEnable(ExtExtendedDynamicState2 gd, CommandBuffer commandBuffer) + { + gd.CmdSetDepthBiasEnable(commandBuffer, _depthBiasEnable); + } + private void RecordScissor(VulkanRenderer gd, CommandBuffer commandBuffer) { if (ScissorsCount != 0)