From 358031af7c149ee3a88e658ca33b011a77158cba Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Thu, 12 Jan 2023 11:49:45 +0100 Subject: [PATCH 1/2] Fix typo in comment --- crates/fj-viewer/src/graphics/renderer.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/crates/fj-viewer/src/graphics/renderer.rs b/crates/fj-viewer/src/graphics/renderer.rs index 9fc32f477..b5a3d2348 100644 --- a/crates/fj-viewer/src/graphics/renderer.rs +++ b/crates/fj-viewer/src/graphics/renderer.rs @@ -251,7 +251,7 @@ impl Renderer { Ok(surface_texture) => surface_texture, Err(wgpu::SurfaceError::Timeout) => { // I'm seeing this all the time now (as in, multiple times per - // microsecond), which `PresentMode::AutoVsync`. Not sure what's + // microsecond), with `PresentMode::AutoVsync`. Not sure what's // going on, but for now, it works to just ignore it. // // Issues for reference: From ea86ad5a369c5d4b6e98864c470fa7c02afbab24 Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Thu, 12 Jan 2023 13:57:00 +0100 Subject: [PATCH 2/2] Fix wgpu validation error wgpu would fail after the window had been minimized and was un-minimized again after a while, because `Gui::update` would run many times while minimized, but `Gui::prepare_draw` wouldn't. That would lead to `end_frame` not being called for a long time, which in turn would lead to egui accumulating output. After that went on for a while, and `prepare_draw` was called again, there would be too much output for the index buffer to handle. --- crates/fj-viewer/src/gui.rs | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/crates/fj-viewer/src/gui.rs b/crates/fj-viewer/src/gui.rs index 752b76e27..b3afd90d9 100644 --- a/crates/fj-viewer/src/gui.rs +++ b/crates/fj-viewer/src/gui.rs @@ -34,6 +34,7 @@ pub struct Gui { context: egui::Context, renderer: egui_wgpu::Renderer, options: Options, + egui_output: Option, } impl Gui { @@ -71,6 +72,7 @@ impl Gui { context, renderer, options: Options::default(), + egui_output: None, } } @@ -270,6 +272,15 @@ impl Gui { }); } + // Even though the output is not used here, `end_frame` must be called + // at the end of this function. If we don't, and we get into a situation + // where `update` is called, but `prepare_draw` isn't for a while, the + // context will keep accumulating output. + // + // That might end up being too much output to handle. This can lead to + // a crash, because a index/vertex buffer gets too full. + self.egui_output = Some(self.context.end_frame()); + new_model_path } @@ -280,7 +291,9 @@ impl Gui { encoder: &mut wgpu::CommandEncoder, screen_descriptor: &egui_wgpu::renderer::ScreenDescriptor, ) -> Vec { - let egui_output = self.context.end_frame(); + let Some(egui_output) = self.egui_output.take() else { + return Vec::new() + }; let clipped_primitives = self.context.tessellate(egui_output.shapes); for (id, image_delta) in &egui_output.textures_delta.set {