Vulkan: Restrict feedback loop detection to AMD Radeon RX GPUs + Qualcomm SoCs

This commit is contained in:
KeatonTheBot 2025-04-18 18:10:18 -05:00
parent 0e810e1e96
commit d46a6bfed5

View file

@ -1,6 +1,7 @@
using Ryujinx.Common.Memory;
using Silk.NET.Vulkan;
using Silk.NET.Vulkan.Extensions.EXT;
using System;
namespace Ryujinx.Graphics.Vulkan
{
@ -27,6 +28,7 @@ namespace Ryujinx.Graphics.Vulkan
public uint ViewportsCount;
public Array16<Viewport> Viewports;
[Flags]
private enum DirtyFlags
{
None = 0,
@ -146,7 +148,7 @@ namespace Ryujinx.Graphics.Vulkan
if (_dirty.HasFlag(DirtyFlags.FeedbackLoop) && gd.Capabilities.SupportsDynamicAttachmentFeedbackLoop)
{
RecordFeedbackLoop(gd.DynamicFeedbackLoopApi, commandBuffer);
RecordFeedbackLoop(gd.DynamicFeedbackLoopApi, commandBuffer, gd);
}
_dirty = DirtyFlags.None;
@ -188,7 +190,10 @@ namespace Ryujinx.Graphics.Vulkan
}
}
private readonly void RecordFeedbackLoop(ExtAttachmentFeedbackLoopDynamicState api, CommandBuffer commandBuffer)
private readonly void RecordFeedbackLoop(ExtAttachmentFeedbackLoopDynamicState api, CommandBuffer commandBuffer, VulkanRenderer gd)
{
// AMD Radeon RX GPUs + Qualcomm SoCs only
if ((gd.Vendor == Vendor.Amd && gd.GpuRenderer.Contains("RX")) || gd.Vendor == Vendor.Qualcomm)
{
ImageAspectFlags aspects = (_feedbackLoopAspects & FeedbackLoopAspects.Color) != 0 ? ImageAspectFlags.ColorBit : 0;
@ -201,3 +206,4 @@ namespace Ryujinx.Graphics.Vulkan
}
}
}
}