Update vk_swapchain
Some checks failed
Build legacy Nix package on Ubuntu / build (push) Failing after 0s

- Refactor drop swapchain
- Fix crash when re-create swapchain
This commit is contained in:
Florian RICHER 2024-11-15 12:38:14 +01:00
parent 96cb003174
commit 09e109d6ef

View file

@ -1,7 +1,7 @@
use crate::vulkan::{VkSurface, LOG_TARGET}; use crate::vulkan::{VkSurface, LOG_TARGET};
use ash::prelude::VkResult; use ash::prelude::VkResult;
use ash::vk; use ash::vk;
use ash::vk::{Extent2D, PresentModeKHR, SurfaceFormatKHR, SurfaceTransformFlagsKHR, SwapchainKHR}; use ash::vk::{Extent2D, PresentModeKHR, SurfaceFormatKHR, SurfaceTransformFlagsKHR, SwapchainCreateInfoKHR, SwapchainKHR};
pub struct VkSwapchain { pub struct VkSwapchain {
swapchain_loader: ash::khr::swapchain::Device, swapchain_loader: ash::khr::swapchain::Device,
@ -35,7 +35,24 @@ impl VkSwapchain {
} }
pub fn create_swapchain(&mut self, surface: &VkSurface) -> VkResult<()> { pub fn create_swapchain(&mut self, surface: &VkSurface) -> VkResult<()> {
let swapchain_create_info = vk::SwapchainCreateInfoKHR::default() let mut swapchain_create_info = self.create_swapchain_info(surface);
if let Some(old_swapchain) = self.swapchain {
swapchain_create_info.old_swapchain = old_swapchain;
}
let swapchain = unsafe {
self.swapchain_loader.create_swapchain(&swapchain_create_info, None)?
};
log::debug!(target: LOG_TARGET, "Swapchain created : {swapchain_create_info:#?}");
self.swapchain = Some(swapchain);
Ok(())
}
fn create_swapchain_info(&self, surface: &VkSurface) -> SwapchainCreateInfoKHR {
SwapchainCreateInfoKHR::default()
.surface(surface.surface) .surface(surface.surface)
.min_image_count(self.desired_image_count) .min_image_count(self.desired_image_count)
.image_color_space(self.surface_format.color_space) .image_color_space(self.surface_format.color_space)
@ -47,25 +64,21 @@ impl VkSwapchain {
.composite_alpha(vk::CompositeAlphaFlagsKHR::OPAQUE) .composite_alpha(vk::CompositeAlphaFlagsKHR::OPAQUE)
.present_mode(self.present_mode) .present_mode(self.present_mode)
.clipped(true) .clipped(true)
.image_array_layers(1); .image_array_layers(1)
}
let swapchain = unsafe { fn drop_current_swapchain(&mut self) {
self.swapchain_loader.create_swapchain(&swapchain_create_info, None)? if let Some(swapchain) = self.swapchain {
}; unsafe {
log::debug!(target: LOG_TARGET, "Swapchain created : {swapchain_create_info:#?}"); self.swapchain_loader.destroy_swapchain(swapchain, None);
self.swapchain = None;
self.swapchain = Some(swapchain); }
}
Ok(())
} }
} }
impl Drop for VkSwapchain { impl Drop for VkSwapchain {
fn drop(&mut self) { fn drop(&mut self) {
if let Some(swapchain) = self.swapchain { self.drop_current_swapchain()
unsafe {
self.swapchain_loader.destroy_swapchain(swapchain, None);
}
}
} }
} }