From c094e625d0e8cc2d52e2dba91dc8d5292ac220ed Mon Sep 17 00:00:00 2001 From: Teodor Tanasoaia <28601907+teoxoy@users.noreply.github.com> Date: Fri, 19 Jan 2024 22:42:19 +0100 Subject: [PATCH] [d3d12] use plane 1 for stencil only views (#5100) * [d3d12] use plane 1 for stencil only views * add test * skip stencil only view creation on WebGL --- tests/tests/root.rs | 1 + tests/tests/texture_view_creation.rs | 65 ++++++++++++++++++++++++++++ wgpu-hal/src/dx12/view.rs | 1 + 3 files changed, 67 insertions(+) create mode 100644 tests/tests/texture_view_creation.rs diff --git a/tests/tests/root.rs b/tests/tests/root.rs index e3f116b0c7..f886c0f9eb 100644 --- a/tests/tests/root.rs +++ b/tests/tests/root.rs @@ -34,6 +34,7 @@ mod shader; mod shader_primitive_index; mod shader_view_format; mod texture_bounds; +mod texture_view_creation; mod transfer; mod vertex_indices; mod write_texture; diff --git a/tests/tests/texture_view_creation.rs b/tests/tests/texture_view_creation.rs new file mode 100644 index 0000000000..eeede4c26f --- /dev/null +++ b/tests/tests/texture_view_creation.rs @@ -0,0 +1,65 @@ +use wgpu::*; +use wgpu_test::{gpu_test, FailureCase, GpuTestConfiguration, TestParameters}; + +#[gpu_test] +static STENCIL_ONLY_VIEW_CREATION: GpuTestConfiguration = GpuTestConfiguration::new() + .parameters( + TestParameters::default() + .skip(FailureCase::webgl2()) // WebGL doesn't have stencil only views + .limits(wgpu::Limits::downlevel_defaults()), + ) + .run_async(|ctx| async move { + for format in [TextureFormat::Stencil8, TextureFormat::Depth24PlusStencil8] { + let texture = ctx.device.create_texture(&TextureDescriptor { + label: None, + size: Extent3d { + width: 256, + height: 256, + depth_or_array_layers: 1, + }, + mip_level_count: 1, + sample_count: 1, + dimension: TextureDimension::D2, + format, + usage: TextureUsages::COPY_DST + | TextureUsages::COPY_SRC + | TextureUsages::TEXTURE_BINDING, + view_formats: &[], + }); + let _view = texture.create_view(&TextureViewDescriptor { + aspect: TextureAspect::StencilOnly, + ..Default::default() + }); + } + }); + +#[gpu_test] +static DEPTH_ONLY_VIEW_CREATION: GpuTestConfiguration = + GpuTestConfiguration::new().run_async(|ctx| async move { + for format in [ + TextureFormat::Depth16Unorm, + TextureFormat::Depth24Plus, + TextureFormat::Depth24PlusStencil8, + ] { + let texture = ctx.device.create_texture(&TextureDescriptor { + label: None, + size: Extent3d { + width: 256, + height: 256, + depth_or_array_layers: 1, + }, + mip_level_count: 1, + sample_count: 1, + dimension: TextureDimension::D2, + format, + usage: TextureUsages::COPY_DST + | TextureUsages::COPY_SRC + | TextureUsages::TEXTURE_BINDING, + view_formats: &[], + }); + let _view = texture.create_view(&TextureViewDescriptor { + aspect: TextureAspect::DepthOnly, + ..Default::default() + }); + } + }); diff --git a/wgpu-hal/src/dx12/view.rs b/wgpu-hal/src/dx12/view.rs index 6cbad7bd1d..ae8e5814a8 100644 --- a/wgpu-hal/src/dx12/view.rs +++ b/wgpu-hal/src/dx12/view.rs @@ -36,6 +36,7 @@ impl crate::TextureViewDescriptor<'_> { fn aspects_to_plane(aspects: crate::FormatAspects) -> u32 { match aspects { + crate::FormatAspects::STENCIL => 1, crate::FormatAspects::PLANE_1 => 1, crate::FormatAspects::PLANE_2 => 2, _ => 0,