Update vk_swapchain
Some checks failed
Build legacy Nix package on Ubuntu / build (push) Failing after 0s
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:
parent
96cb003174
commit
09e109d6ef
1 changed files with 29 additions and 16 deletions
|
@ -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);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in a new issue