From a7a39d6fc4a3c331f1f0a3c74ed50ef5938d5a23 Mon Sep 17 00:00:00 2001 From: dtzxporter Date: Thu, 18 Jan 2024 11:34:02 -0500 Subject: [PATCH 1/2] Make sure to copy all of the buffers into the resource array for dx12. Fixes #5088. Even though we're telling DX12 that the maximum frame latency should be our non-padded value, the swap chain may request any of the buffers allocated to it. --- wgpu-hal/src/dx12/mod.rs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/wgpu-hal/src/dx12/mod.rs b/wgpu-hal/src/dx12/mod.rs index af8d5a8c01..85ed066cdb 100644 --- a/wgpu-hal/src/dx12/mod.rs +++ b/wgpu-hal/src/dx12/mod.rs @@ -805,8 +805,8 @@ impl crate::Surface for Surface { unsafe { swap_chain.SetMaximumFrameLatency(config.maximum_frame_latency) }; let waitable = unsafe { swap_chain.GetFrameLatencyWaitableObject() }; - let mut resources = Vec::with_capacity(config.maximum_frame_latency as usize); - for i in 0..config.maximum_frame_latency { + let mut resources = Vec::with_capacity(swap_chain_buffer as usize); + for i in 0..swap_chain_buffer { let mut resource = d3d12::Resource::null(); unsafe { swap_chain.GetBuffer(i, &d3d12_ty::ID3D12Resource::uuidof(), resource.mut_void()) From 95fe93854371791c7fffba582f2370bf067479e9 Mon Sep 17 00:00:00 2001 From: dtzxporter Date: Thu, 18 Jan 2024 17:14:56 -0500 Subject: [PATCH 2/2] Up the maximum frame latency on the DX12 backend to allow a larger range. --- wgpu-hal/src/dx12/mod.rs | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/wgpu-hal/src/dx12/mod.rs b/wgpu-hal/src/dx12/mod.rs index 85ed066cdb..b4a3fca0ed 100644 --- a/wgpu-hal/src/dx12/mod.rs +++ b/wgpu-hal/src/dx12/mod.rs @@ -660,10 +660,14 @@ impl crate::Surface for Surface { let non_srgb_format = auxil::dxgi::conv::map_texture_format_nosrgb(config.format); + // The range for `SetMaximumFrameLatency` is 1-16 so the maximum latency requested should be 15 because we add 1. + // https://learn.microsoft.com/en-us/windows/win32/api/dxgi/nf-dxgi-idxgidevice1-setmaximumframelatency + debug_assert!(config.maximum_frame_latency <= 15); + // Nvidia recommends to use 1-2 more buffers than the maximum latency // https://developer.nvidia.com/blog/advanced-api-performance-swap-chains/ // For high latency extra buffers seems excessive, so go with a minimum of 3 and beyond that add 1. - let swap_chain_buffer = (config.maximum_frame_latency + 1).min(3); + let swap_chain_buffer = (config.maximum_frame_latency + 1).min(16); let swap_chain = match self.swap_chain.write().take() { //Note: this path doesn't properly re-initialize all of the things