From 2ac009ba236d128b05ea8600fac4fc2d3e4e0ffe Mon Sep 17 00:00:00 2001 From: teoxoy <28601907+teoxoy@users.noreply.github.com> Date: Thu, 27 Jul 2023 13:42:18 +0200 Subject: [PATCH] Revert "Make shader write&read storage buffers match non readonly layouts (#3893)" This reverts commit 17143c149c13ea5af36909ef6033e776cecad28c. --- wgpu-core/src/validation.rs | 71 +------------------------------------ 1 file changed, 1 insertion(+), 70 deletions(-) diff --git a/wgpu-core/src/validation.rs b/wgpu-core/src/validation.rs index 771adba731..83cb90530a 100644 --- a/wgpu-core/src/validation.rs +++ b/wgpu-core/src/validation.rs @@ -409,7 +409,7 @@ impl Resource { ) } }; - if !address_space_matches(self.class, class) { + if self.class != class { return Err(BindingError::WrongAddressSpace { binding: class, shader: self.class, @@ -1237,72 +1237,3 @@ impl Interface { Ok(outputs) } } - -fn address_space_matches(shader: naga::AddressSpace, binding: naga::AddressSpace) -> bool { - match (shader, binding) { - ( - naga::AddressSpace::Storage { - access: access_shader, - }, - naga::AddressSpace::Storage { - access: access_pipeline, - }, - ) => { - // Allow read- and write-only usages to match read-write layouts: - (access_shader & access_pipeline) == access_shader - } - (a, b) => a == b, - } -} - -#[cfg(test)] -mod test { - use super::address_space_matches; - - #[test] - fn address_space_matches_correctly() { - assert!(address_space_matches( - naga::AddressSpace::Uniform, - naga::AddressSpace::Uniform - )); - - assert!(!address_space_matches( - naga::AddressSpace::Uniform, - naga::AddressSpace::Storage { - access: naga::StorageAccess::LOAD - } - )); - - let test_cases = [ - (naga::StorageAccess::LOAD, naga::StorageAccess::LOAD, true), - (naga::StorageAccess::STORE, naga::StorageAccess::LOAD, false), - (naga::StorageAccess::LOAD, naga::StorageAccess::STORE, false), - (naga::StorageAccess::STORE, naga::StorageAccess::STORE, true), - ( - naga::StorageAccess::LOAD | naga::StorageAccess::STORE, - naga::StorageAccess::LOAD | naga::StorageAccess::STORE, - true, - ), - ( - naga::StorageAccess::STORE, - naga::StorageAccess::LOAD | naga::StorageAccess::STORE, - true, - ), - ( - naga::StorageAccess::LOAD, - naga::StorageAccess::LOAD | naga::StorageAccess::STORE, - true, - ), - ]; - - for (shader, binding, expect_match) in test_cases { - assert_eq!( - expect_match, - address_space_matches( - naga::AddressSpace::Storage { access: shader }, - naga::AddressSpace::Storage { access: binding } - ) - ); - } - } -}