renderer_vulkan: Fix present related validation errors. (#2169)

This commit is contained in:
squidbus 2025-01-17 00:16:03 -08:00 committed by GitHub
parent 1e5b316ac4
commit 1d3427780a
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
6 changed files with 28 additions and 9 deletions

View file

@ -687,8 +687,6 @@ void RenderDrawData(ImDrawData& draw_data, vk::CommandBuffer command_buffer,
vk::DescriptorSet desc_set[1]{pcmd->TextureId->descriptor_set}; vk::DescriptorSet desc_set[1]{pcmd->TextureId->descriptor_set};
command_buffer.bindDescriptorSets(vk::PipelineBindPoint::eGraphics, command_buffer.bindDescriptorSets(vk::PipelineBindPoint::eGraphics,
bd->pipeline_layout, 0, {desc_set}, {}); bd->pipeline_layout, 0, {desc_set}, {});
command_buffer.setColorBlendEnableEXT(
0, {pcmd->TextureId->disable_blend ? vk::False : vk::True});
// Draw // Draw
command_buffer.drawIndexed(pcmd->ElemCount, 1, pcmd->IdxOffset + global_idx_offset, command_buffer.drawIndexed(pcmd->ElemCount, 1, pcmd->IdxOffset + global_idx_offset,
@ -1058,10 +1056,9 @@ static void CreatePipeline(vk::Device device, const vk::AllocationCallbacks* all
.pAttachments = color_attachment, .pAttachments = color_attachment,
}; };
vk::DynamicState dynamic_states[3]{ vk::DynamicState dynamic_states[2]{
vk::DynamicState::eViewport, vk::DynamicState::eViewport,
vk::DynamicState::eScissor, vk::DynamicState::eScissor,
vk::DynamicState::eColorBlendEnableEXT,
}; };
vk::PipelineDynamicStateCreateInfo dynamic_state{ vk::PipelineDynamicStateCreateInfo dynamic_state{
.dynamicStateCount = (uint32_t)IM_ARRAYSIZE(dynamic_states), .dynamicStateCount = (uint32_t)IM_ARRAYSIZE(dynamic_states),

View file

@ -13,7 +13,6 @@ struct ImDrawData;
namespace ImGui { namespace ImGui {
struct Texture { struct Texture {
vk::DescriptorSet descriptor_set{nullptr}; vk::DescriptorSet descriptor_set{nullptr};
bool disable_blend{false};
}; };
} // namespace ImGui } // namespace ImGui

View file

@ -270,6 +270,7 @@ bool Instance::CreateDevice() {
legacy_vertex_attributes = add_extension(VK_EXT_LEGACY_VERTEX_ATTRIBUTES_EXTENSION_NAME); legacy_vertex_attributes = add_extension(VK_EXT_LEGACY_VERTEX_ATTRIBUTES_EXTENSION_NAME);
image_load_store_lod = add_extension(VK_AMD_SHADER_IMAGE_LOAD_STORE_LOD_EXTENSION_NAME); image_load_store_lod = add_extension(VK_AMD_SHADER_IMAGE_LOAD_STORE_LOD_EXTENSION_NAME);
amd_gcn_shader = add_extension(VK_AMD_GCN_SHADER_EXTENSION_NAME); amd_gcn_shader = add_extension(VK_AMD_GCN_SHADER_EXTENSION_NAME);
add_extension(VK_KHR_SWAPCHAIN_MUTABLE_FORMAT_EXTENSION_NAME);
// These extensions are promoted by Vulkan 1.3, but for greater compatibility we use Vulkan 1.2 // These extensions are promoted by Vulkan 1.3, but for greater compatibility we use Vulkan 1.2
// with extensions. // with extensions.
@ -383,7 +384,6 @@ bool Instance::CreateDevice() {
.extendedDynamicState = true, .extendedDynamicState = true,
}, },
vk::PhysicalDeviceExtendedDynamicState3FeaturesEXT{ vk::PhysicalDeviceExtendedDynamicState3FeaturesEXT{
.extendedDynamicState3ColorBlendEnable = true,
.extendedDynamicState3ColorWriteMask = true, .extendedDynamicState3ColorWriteMask = true,
}, },
vk::PhysicalDeviceDepthClipControlFeaturesEXT{ vk::PhysicalDeviceDepthClipControlFeaturesEXT{

View file

@ -380,7 +380,7 @@ void Presenter::RecreateFrame(Frame* frame, u32 width, u32 height) {
const vk::ImageViewCreateInfo view_info = { const vk::ImageViewCreateInfo view_info = {
.image = frame->image, .image = frame->image,
.viewType = vk::ImageViewType::e2D, .viewType = vk::ImageViewType::e2D,
.format = FormatToUnorm(format), .format = swapchain.GetViewFormat(),
.subresourceRange{ .subresourceRange{
.aspectMask = vk::ImageAspectFlagBits::eColor, .aspectMask = vk::ImageAspectFlagBits::eColor,
.baseMipLevel = 0, .baseMipLevel = 0,
@ -397,7 +397,6 @@ void Presenter::RecreateFrame(Frame* frame, u32 width, u32 height) {
frame->height = height; frame->height = height;
frame->imgui_texture = ImGui::Vulkan::AddTexture(view, vk::ImageLayout::eShaderReadOnlyOptimal); frame->imgui_texture = ImGui::Vulkan::AddTexture(view, vk::ImageLayout::eShaderReadOnlyOptimal);
frame->imgui_texture->disable_blend = true;
} }
Frame* Presenter::PrepareLastFrame() { Frame* Presenter::PrepareLastFrame() {
@ -615,6 +614,13 @@ Frame* Presenter::PrepareFrameInternal(VideoCore::ImageId image_id, bool is_eop)
VideoCore::ImageViewInfo info{}; VideoCore::ImageViewInfo info{};
info.format = image.info.pixel_format; info.format = image.info.pixel_format;
// Exclude alpha from output frame to avoid blending with UI.
info.mapping = vk::ComponentMapping{
.r = vk::ComponentSwizzle::eIdentity,
.g = vk::ComponentSwizzle::eIdentity,
.b = vk::ComponentSwizzle::eIdentity,
.a = vk::ComponentSwizzle::eOne,
};
if (auto view = image.FindView(info)) { if (auto view = image.FindView(info)) {
image_info.imageView = *texture_cache.GetImageView(view).image_view; image_info.imageView = *texture_cache.GetImageView(view).image_view;
} else { } else {

View file

@ -17,7 +17,7 @@ Swapchain::Swapchain(const Instance& instance_, const Frontend::WindowSDL& windo
FindPresentFormat(); FindPresentFormat();
Create(window.GetWidth(), window.GetHeight()); Create(window.GetWidth(), window.GetHeight());
ImGui::Core::Initialize(instance, window, image_count, surface_format.format); ImGui::Core::Initialize(instance, window, image_count, view_format);
} }
Swapchain::~Swapchain() { Swapchain::~Swapchain() {
@ -57,7 +57,17 @@ void Swapchain::Create(u32 width_, u32 height_) {
const u32 queue_family_indices_count = exclusive ? 1u : 2u; const u32 queue_family_indices_count = exclusive ? 1u : 2u;
const vk::SharingMode sharing_mode = const vk::SharingMode sharing_mode =
exclusive ? vk::SharingMode::eExclusive : vk::SharingMode::eConcurrent; exclusive ? vk::SharingMode::eExclusive : vk::SharingMode::eConcurrent;
const vk::Format view_formats[2] = {
surface_format.format,
view_format,
};
const vk::ImageFormatListCreateInfo format_list = {
.viewFormatCount = 2,
.pViewFormats = view_formats,
};
const vk::SwapchainCreateInfoKHR swapchain_info = { const vk::SwapchainCreateInfoKHR swapchain_info = {
.pNext = &format_list,
.flags = vk::SwapchainCreateFlagBitsKHR::eMutableFormat,
.surface = surface, .surface = surface,
.minImageCount = image_count, .minImageCount = image_count,
.imageFormat = surface_format.format, .imageFormat = surface_format.format,
@ -149,6 +159,7 @@ void Swapchain::FindPresentFormat() {
if (formats[0].format == vk::Format::eUndefined) { if (formats[0].format == vk::Format::eUndefined) {
surface_format.format = vk::Format::eR8G8B8A8Srgb; surface_format.format = vk::Format::eR8G8B8A8Srgb;
surface_format.colorSpace = vk::ColorSpaceKHR::eSrgbNonlinear; surface_format.colorSpace = vk::ColorSpaceKHR::eSrgbNonlinear;
view_format = FormatToUnorm(surface_format.format);
return; return;
} }
@ -161,6 +172,7 @@ void Swapchain::FindPresentFormat() {
surface_format.format = format; surface_format.format = format;
surface_format.colorSpace = sformat.colorSpace; surface_format.colorSpace = sformat.colorSpace;
view_format = FormatToUnorm(surface_format.format);
return; return;
} }

View file

@ -61,6 +61,10 @@ public:
return surface_format; return surface_format;
} }
vk::Format GetViewFormat() const {
return view_format;
}
vk::SwapchainKHR GetHandle() const { vk::SwapchainKHR GetHandle() const {
return swapchain; return swapchain;
} }
@ -114,6 +118,7 @@ private:
vk::SwapchainKHR swapchain{}; vk::SwapchainKHR swapchain{};
vk::SurfaceKHR surface{}; vk::SurfaceKHR surface{};
vk::SurfaceFormatKHR surface_format; vk::SurfaceFormatKHR surface_format;
vk::Format view_format;
vk::Extent2D extent; vk::Extent2D extent;
vk::SurfaceTransformFlagBitsKHR transform; vk::SurfaceTransformFlagBitsKHR transform;
vk::CompositeAlphaFlagBitsKHR composite_alpha; vk::CompositeAlphaFlagBitsKHR composite_alpha;