From 29dbd02e6b223a85bd8a048bb3c4e4caaba7bbff Mon Sep 17 00:00:00 2001 From: Erich Gubler Date: Tue, 12 Nov 2024 10:54:41 -0500 Subject: [PATCH] fix: allow non-filterable float on derived BGLs for texture binding usage w/ no sampler --- CHANGELOG.md | 1 + wgpu-core/src/validation.rs | 18 +++++++++++++----- 2 files changed, 14 insertions(+), 5 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index afaa5737af2..4c9ddbd5a5e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -119,6 +119,7 @@ By @ErichDonGubler in [#6456](https://github.com/gfx-rs/wgpu/pull/6456), [#6148] #### General - Handle query set creation failure as an internal error that loses the `Device`, rather than panicking. By @ErichDonGubler in [#6505](https://github.com/gfx-rs/wgpu/pull/6505). +- Allow non-filterable float on texture bindings never used with samplers when using a derived bind group layout. By @ErichDonGubler in [#6531](https://github.com/gfx-rs/wgpu/pull/6531/). #### Naga diff --git a/wgpu-core/src/validation.rs b/wgpu-core/src/validation.rs index 13cf443d483..68a9288e001 100644 --- a/wgpu-core/src/validation.rs +++ b/wgpu-core/src/validation.rs @@ -497,7 +497,10 @@ impl Resource { Ok(()) } - fn derive_binding_type(&self) -> Result { + fn derive_binding_type( + &self, + is_reffed_by_sampler_in_entrypoint: bool, + ) -> Result { Ok(match self.ty { ResourceType::Buffer { size } => BindingType::Buffer { ty: match self.class { @@ -531,9 +534,9 @@ impl Resource { match class { naga::ImageClass::Sampled { multi, kind } => BindingType::Texture { sample_type: match kind { - naga::ScalarKind::Float => { - wgt::TextureSampleType::Float { filterable: true } - } + naga::ScalarKind::Float => wgt::TextureSampleType::Float { + filterable: is_reffed_by_sampler_in_entrypoint, + }, naga::ScalarKind::Sint => wgt::TextureSampleType::Sint, naga::ScalarKind::Uint => wgt::TextureSampleType::Uint, naga::ScalarKind::AbstractInt @@ -1009,7 +1012,12 @@ impl Interface { break 'err Err(BindingError::Missing); }; - let ty = match res.derive_binding_type() { + let ty = match res.derive_binding_type( + entry_point + .sampling_pairs + .iter() + .any(|&(im, _samp)| im == handle), + ) { Ok(ty) => ty, Err(error) => break 'err Err(error), };