From b5b8640049aeb9b6363c3df17af01b40a56bdeaa Mon Sep 17 00:00:00 2001 From: Connor Fitzgerald Date: Fri, 25 Feb 2022 17:27:26 -0500 Subject: [PATCH] Wrap all validation logs with catch_unwinds --- wgpu-hal/src/dx12/instance.rs | 4 +++- wgpu-hal/src/gles/egl.rs | 18 ++++++++++-------- wgpu-hal/src/vulkan/instance.rs | 32 +++++++++++++++++++++----------- 3 files changed, 34 insertions(+), 20 deletions(-) diff --git a/wgpu-hal/src/dx12/instance.rs b/wgpu-hal/src/dx12/instance.rs index e430d48d3d..235786bd0f 100644 --- a/wgpu-hal/src/dx12/instance.rs +++ b/wgpu-hal/src/dx12/instance.rs @@ -58,7 +58,9 @@ unsafe extern "system" fn output_debug_string_handler( return excpt::EXCEPTION_CONTINUE_SEARCH; } - log::log!(level, "{}", message); + let _ = std::panic::catch_unwind(|| { + log::log!(level, "{}", message); + }); if cfg!(debug_assertions) && level == log::Level::Error { // Panicking behind FFI is UB, so we just exit. diff --git a/wgpu-hal/src/gles/egl.rs b/wgpu-hal/src/gles/egl.rs index 1c3f545a87..a35d48980b 100644 --- a/wgpu-hal/src/gles/egl.rs +++ b/wgpu-hal/src/gles/egl.rs @@ -262,14 +262,16 @@ fn gl_debug_message_callback(source: u32, gltype: u32, id: u32, severity: u32, m _ => unreachable!(), }; - log::log!( - log_severity, - "GLES: [{}/{}] ID {} : {}", - source_str, - type_str, - id, - message - ); + let _ = std::panic::catch_unwind(|| { + log::log!( + log_severity, + "GLES: [{}/{}] ID {} : {}", + source_str, + type_str, + id, + message + ); + }); if cfg!(debug_assertions) && log_severity == log::Level::Error { std::process::exit(1); diff --git a/wgpu-hal/src/vulkan/instance.rs b/wgpu-hal/src/vulkan/instance.rs index 3cc304307a..f6f5195356 100644 --- a/wgpu-hal/src/vulkan/instance.rs +++ b/wgpu-hal/src/vulkan/instance.rs @@ -44,14 +44,16 @@ unsafe extern "system" fn debug_utils_messenger_callback( CStr::from_ptr(cd.p_message).to_string_lossy() }; - log::log!( - level, - "{:?} [{} (0x{:x})]\n\t{}", - message_type, - message_id_name, - cd.message_id_number, - message, - ); + let _ = std::panic::catch_unwind(|| { + log::log!( + level, + "{:?} [{} (0x{:x})]\n\t{}", + message_type, + message_id_name, + cd.message_id_number, + message, + ); + }); if cd.queue_label_count != 0 { let labels = slice::from_raw_parts(cd.p_queue_labels, cd.queue_label_count as usize); @@ -64,7 +66,10 @@ unsafe extern "system" fn debug_utils_messenger_callback( .map(|lbl| CStr::from_ptr(lbl).to_string_lossy()) }) .collect::>(); - log::log!(level, "\tqueues: {}", names.join(", ")); + + let _ = std::panic::catch_unwind(|| { + log::log!(level, "\tqueues: {}", names.join(", ")); + }); } if cd.cmd_buf_label_count != 0 { @@ -78,7 +83,10 @@ unsafe extern "system" fn debug_utils_messenger_callback( .map(|lbl| CStr::from_ptr(lbl).to_string_lossy()) }) .collect::>(); - log::log!(level, "\tcommand buffers: {}", names.join(", ")); + + let _ = std::panic::catch_unwind(|| { + log::log!(level, "\tcommand buffers: {}", names.join(", ")); + }); } if cd.object_count != 0 { @@ -99,7 +107,9 @@ unsafe extern "system" fn debug_utils_messenger_callback( ) }) .collect::>(); - log::log!(level, "\tobjects: {}", names.join(", ")); + let _ = std::panic::catch_unwind(|| { + log::log!(level, "\tobjects: {}", names.join(", ")); + }); } // uncommenting this is useful for tests