From 85738221cbfb319d4f7ff6312a7a9640b6bc1d32 Mon Sep 17 00:00:00 2001 From: Nicolas Silva Date: Tue, 9 Jan 2024 15:25:17 +0100 Subject: [PATCH] Don't crash if a texture is destroyed before queue submission --- wgpu-core/src/command/memory_init.rs | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/wgpu-core/src/command/memory_init.rs b/wgpu-core/src/command/memory_init.rs index 81456ece0a..3bfc71f4f7 100644 --- a/wgpu-core/src/command/memory_init.rs +++ b/wgpu-core/src/command/memory_init.rs @@ -11,7 +11,9 @@ use crate::{ FastHashMap, }; -use super::{clear::clear_texture, BakedCommands, DestroyedBufferError, DestroyedTextureError}; +use super::{ + clear::clear_texture, BakedCommands, ClearError, DestroyedBufferError, DestroyedTextureError, +}; /// Surface that was discarded by `StoreOp::Discard` of a preceding renderpass. /// Any read access to this surface needs to be preceded by a texture initialization. @@ -301,15 +303,26 @@ impl BakedCommands { // TODO: Could we attempt some range collapsing here? for range in ranges.drain(..) { - clear_texture( + let clear_result = clear_texture( &texture_use.texture, range, &mut self.encoder, &mut device_tracker.textures, &device.alignments, device.zero_buffer.as_ref().unwrap(), - ) - .unwrap(); + ); + + // A Texture can be destroyed between the command recording + // and now, this is out of our control so we have to handle + // it gracefully. + if let Err(ClearError::InvalidTexture(id)) = clear_result { + return Err(DestroyedTextureError(id)); + } + + // Other errors are unexpected. + if let Err(error) = clear_result { + panic!("{error}"); + } } }