From 824da00987eaeb275ebfa18503b412f2e081a96c Mon Sep 17 00:00:00 2001 From: Jim Blandy Date: Mon, 6 Jun 2022 15:49:58 -0700 Subject: [PATCH] Don't dirty the vertex buffer for stride/rate changes on bundles. `wgpu_core::command::bundle::State::set_pipeline` marks a vertex buffer slot dirty if the pipeline's stride or step mode for that vertex buffer slot differs from what had been previously established. The effect of marking the slot dirty is to ensure that a new `SetVertexBuffer` command is inserted before the next draw command that uses that vertex buffer. However, this is unnecessary: `wgpu_hal::CommandEncoder::set_vertex_buffer` does not need to be called simply because the stride or rate has changed. --- wgpu-core/src/command/bundle.rs | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/wgpu-core/src/command/bundle.rs b/wgpu-core/src/command/bundle.rs index 6121ab8f9f..4f78a0a044 100644 --- a/wgpu-core/src/command/bundle.rs +++ b/wgpu-core/src/command/bundle.rs @@ -1203,11 +1203,8 @@ impl State { self.index.pipeline_format = index_format; for (vs, &(stride, step_mode)) in self.vertex.iter_mut().zip(vertex_strides) { - if vs.stride != stride || vs.rate != step_mode { - vs.stride = stride; - vs.rate = step_mode; - vs.is_dirty = true; - } + vs.stride = stride; + vs.rate = step_mode; } let push_constants_changed = self