From a36929536514d2d8215a037e0f111376ca61103d Mon Sep 17 00:00:00 2001 From: teoxoy <28601907+teoxoy@users.noreply.github.com> Date: Thu, 2 Mar 2023 23:01:41 +0100 Subject: [PATCH] change type of `bytes_per_row` and `rows_per_image` (members of `ImageDataLayout`) from `Option` to `Option` --- CHANGELOG.md | 1 + deno_webgpu/src/command_encoder.rs | 9 +++--- deno_webgpu/src/queue.rs | 6 ++-- wgpu-core/src/command/clear.rs | 4 +-- wgpu-core/src/command/transfer.rs | 4 +-- wgpu-core/src/device/queue.rs | 29 ++++++++----------- wgpu-hal/examples/halmark/main.rs | 6 ++-- wgpu-hal/src/dx12/command.rs | 17 +++++------ wgpu-hal/src/gles/queue.rs | 12 ++++---- wgpu-hal/src/metal/command.rs | 14 +++------ wgpu-hal/src/vulkan/command.rs | 4 +-- wgpu-types/src/lib.rs | 4 +-- wgpu/examples/bunnymark/main.rs | 2 +- wgpu/examples/capture/main.rs | 5 +--- wgpu/examples/cube/main.rs | 2 +- wgpu/examples/framework.rs | 4 +-- wgpu/examples/mipmap/main.rs | 4 +-- wgpu/examples/texture-arrays/main.rs | 8 ++--- wgpu/src/backend/web.rs | 8 ++--- wgpu/src/util/device.rs | 10 ++----- wgpu/tests/common/image.rs | 7 ++--- wgpu/tests/external_texture.rs | 4 +-- wgpu/tests/queue_transfer.rs | 6 ++-- wgpu/tests/shader_primitive_index/mod.rs | 3 +- wgpu/tests/shader_view_format/mod.rs | 3 +- wgpu/tests/texture_bounds.rs | 3 +- wgpu/tests/write_texture.rs | 17 +++++------ wgpu/tests/zero_init_texture_after_discard.rs | 4 +-- 28 files changed, 80 insertions(+), 120 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index da5ac74ff3..343247a35a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -74,6 +74,7 @@ By @teoxoy in [#3436](https://github.com/gfx-rs/wgpu/pull/3436) - Change type of `mip_level_count` and `array_layer_count` (members of `TextureViewDescriptor` and `ImageSubresourceRange`) from `Option` to `Option`. By @teoxoy in [#3445](https://github.com/gfx-rs/wgpu/pull/3445) - All `fxhash` dependencies have been replaced with `rustc-hash`. By @james7132 in [#3502](https://github.com/gfx-rs/wgpu/pull/3502) +- Change type of `bytes_per_row` and `rows_per_image` (members of `ImageDataLayout`) from `Option` to `Option`. By @teoxoy in [#3529](https://github.com/gfx-rs/wgpu/pull/3529) ### Changes diff --git a/deno_webgpu/src/command_encoder.rs b/deno_webgpu/src/command_encoder.rs index 8d06af887c..5fc472c6cd 100644 --- a/deno_webgpu/src/command_encoder.rs +++ b/deno_webgpu/src/command_encoder.rs @@ -8,7 +8,6 @@ use deno_core::ResourceId; use serde::Deserialize; use std::borrow::Cow; use std::cell::RefCell; -use std::num::NonZeroU32; use super::error::WebGpuResult; @@ -272,8 +271,8 @@ pub fn op_webgpu_command_encoder_copy_buffer_to_texture( buffer: source_buffer_resource.0, layout: wgpu_types::ImageDataLayout { offset: source.offset, - bytes_per_row: NonZeroU32::new(source.bytes_per_row.unwrap_or(0)), - rows_per_image: NonZeroU32::new(source.rows_per_image.unwrap_or(0)), + bytes_per_row: source.bytes_per_row, + rows_per_image: source.rows_per_image, }, }; let destination = wgpu_core::command::ImageCopyTexture { @@ -320,8 +319,8 @@ pub fn op_webgpu_command_encoder_copy_texture_to_buffer( buffer: destination_buffer_resource.0, layout: wgpu_types::ImageDataLayout { offset: destination.offset, - bytes_per_row: NonZeroU32::new(destination.bytes_per_row.unwrap_or(0)), - rows_per_image: NonZeroU32::new(destination.rows_per_image.unwrap_or(0)), + bytes_per_row: destination.bytes_per_row, + rows_per_image: destination.rows_per_image, }, }; gfx_ok!(command_encoder => instance.command_encoder_copy_texture_to_buffer( diff --git a/deno_webgpu/src/queue.rs b/deno_webgpu/src/queue.rs index 5e310ae99c..98cf437364 100644 --- a/deno_webgpu/src/queue.rs +++ b/deno_webgpu/src/queue.rs @@ -1,7 +1,5 @@ // Copyright 2018-2023 the Deno authors. All rights reserved. MIT license. -use std::num::NonZeroU32; - use deno_core::error::AnyError; use deno_core::op; use deno_core::OpState; @@ -54,8 +52,8 @@ impl From for wgpu_types::ImageDataLayout { fn from(layout: GpuImageDataLayout) -> Self { wgpu_types::ImageDataLayout { offset: layout.offset, - bytes_per_row: NonZeroU32::new(layout.bytes_per_row.unwrap_or(0)), - rows_per_image: NonZeroU32::new(layout.rows_per_image.unwrap_or(0)), + bytes_per_row: layout.bytes_per_row, + rows_per_image: layout.rows_per_image, } } } diff --git a/wgpu-core/src/command/clear.rs b/wgpu-core/src/command/clear.rs index 2784577a10..b63392f7ae 100644 --- a/wgpu-core/src/command/clear.rs +++ b/wgpu-core/src/command/clear.rs @@ -1,4 +1,4 @@ -use std::{num::NonZeroU32, ops::Range}; +use std::ops::Range; #[cfg(feature = "trace")] use crate::device::trace::Command as TraceCommand; @@ -363,7 +363,7 @@ fn clear_texture_via_buffer_copies( zero_buffer_copy_regions.push(hal::BufferTextureCopy { buffer_layout: wgt::ImageDataLayout { offset: 0, - bytes_per_row: NonZeroU32::new(bytes_per_row), + bytes_per_row: Some(bytes_per_row), rows_per_image: None, }, texture_base: hal::TextureCopyBase { diff --git a/wgpu-core/src/command/transfer.rs b/wgpu-core/src/command/transfer.rs index eca45ab70e..44aac3fa08 100644 --- a/wgpu-core/src/command/transfer.rs +++ b/wgpu-core/src/command/transfer.rs @@ -264,7 +264,7 @@ pub(crate) fn validate_linear_texture_data( let bytes_in_last_row = width_in_blocks * block_size; let bytes_per_row = if let Some(bytes_per_row) = layout.bytes_per_row { - let bytes_per_row = bytes_per_row.get() as BufferAddress; + let bytes_per_row = bytes_per_row as BufferAddress; if bytes_per_row < bytes_in_last_row { return Err(TransferError::InvalidBytesPerRow); } @@ -276,7 +276,7 @@ pub(crate) fn validate_linear_texture_data( 0 }; let block_rows_per_image = if let Some(rows_per_image) = layout.rows_per_image { - let rows_per_image = rows_per_image.get() as BufferAddress; + let rows_per_image = rows_per_image as BufferAddress; if rows_per_image < height_in_blocks { return Err(TransferError::InvalidRowsPerImage); } diff --git a/wgpu-core/src/device/queue.rs b/wgpu-core/src/device/queue.rs index d8f51ba553..0bcad61f8f 100644 --- a/wgpu-core/src/device/queue.rs +++ b/wgpu-core/src/device/queue.rs @@ -18,7 +18,7 @@ use crate::{ use hal::{CommandEncoder as _, Device as _, Queue as _}; use parking_lot::Mutex; use smallvec::SmallVec; -use std::{iter, mem, num::NonZeroU32, ptr}; +use std::{iter, mem, ptr}; use thiserror::Error; /// Number of command buffers that we generate from the same pool @@ -649,15 +649,12 @@ impl Global { let width_blocks = size.width / block_width; let height_blocks = size.height / block_height; - let block_rows_per_image = match data_layout.rows_per_image { - Some(rows_per_image) => rows_per_image.get(), - None => { - // doesn't really matter because we need this only if we copy - // more than one layer, and then we validate for this being not - // None - size.height - } - }; + let block_rows_per_image = data_layout.rows_per_image.unwrap_or( + // doesn't really matter because we need this only if we copy + // more than one layer, and then we validate for this being not + // None + size.height, + ); let block_size = dst .desc @@ -738,11 +735,9 @@ impl Global { .as_raw() .ok_or(TransferError::InvalidTexture(destination.texture))?; - let bytes_per_row = if let Some(bytes_per_row) = data_layout.bytes_per_row { - bytes_per_row.get() - } else { - width_blocks * block_size - }; + let bytes_per_row = data_layout + .bytes_per_row + .unwrap_or(width_blocks * block_size); // Platform validation requires that the staging buffer always be // freed, even if an error occurs. All paths from here must call @@ -796,8 +791,8 @@ impl Global { offset: rel_array_layer as u64 * block_rows_per_image as u64 * stage_bytes_per_row as u64, - bytes_per_row: NonZeroU32::new(stage_bytes_per_row), - rows_per_image: NonZeroU32::new(block_rows_per_image), + bytes_per_row: Some(stage_bytes_per_row), + rows_per_image: Some(block_rows_per_image), }, texture_base, size: hal_copy_size, diff --git a/wgpu-hal/examples/halmark/main.rs b/wgpu-hal/examples/halmark/main.rs index b9c2453d74..b4f25c9179 100644 --- a/wgpu-hal/examples/halmark/main.rs +++ b/wgpu-hal/examples/halmark/main.rs @@ -9,9 +9,7 @@ use raw_window_handle::{HasRawDisplayHandle, HasRawWindowHandle}; use std::{ borrow::{Borrow, Cow}, - iter, mem, - num::NonZeroU32, - ptr, + iter, mem, ptr, time::Instant, }; @@ -328,7 +326,7 @@ impl Example { let copy = hal::BufferTextureCopy { buffer_layout: wgt::ImageDataLayout { offset: 0, - bytes_per_row: NonZeroU32::new(4), + bytes_per_row: Some(4), rows_per_image: None, }, texture_base: hal::TextureCopyBase { diff --git a/wgpu-hal/src/dx12/command.rs b/wgpu-hal/src/dx12/command.rs index bf25b77c31..c634110154 100644 --- a/wgpu-hal/src/dx12/command.rs +++ b/wgpu-hal/src/dx12/command.rs @@ -33,19 +33,16 @@ impl crate::BufferTextureCopy { Height: self .buffer_layout .rows_per_image - .map_or(self.size.height, |count| count.get() * block_height), + .map_or(self.size.height, |count| count * block_height), Depth: self.size.depth, RowPitch: { - let actual = match self.buffer_layout.bytes_per_row { - Some(count) => count.get(), + let actual = self.buffer_layout.bytes_per_row.unwrap_or_else(|| { // this may happen for single-line updates - None => { - let block_size = format - .block_size(Some(self.texture_base.aspect.map())) - .unwrap(); - (self.size.width / block_width) * block_size - } - }; + let block_size = format + .block_size(Some(self.texture_base.aspect.map())) + .unwrap(); + (self.size.width / block_width) * block_size + }); crate::auxil::align_to(actual, d3d12_ty::D3D12_TEXTURE_DATA_PITCH_ALIGNMENT) }, }, diff --git a/wgpu-hal/src/gles/queue.rs b/wgpu-hal/src/gles/queue.rs index 499a4c9358..633c9b41ed 100644 --- a/wgpu-hal/src/gles/queue.rs +++ b/wgpu-hal/src/gles/queue.rs @@ -597,11 +597,11 @@ impl super::Queue { let row_texels = copy .buffer_layout .bytes_per_row - .map_or(0, |bpr| block_width * bpr.get() / block_size); + .map_or(0, |bpr| block_width * bpr / block_size); let column_texels = copy .buffer_layout .rows_per_image - .map_or(0, |rpi| block_height * rpi.get()); + .map_or(0, |rpi| block_height * rpi); unsafe { gl.bind_texture(dst_target, Some(dst)) }; unsafe { gl.pixel_store_i32(glow::UNPACK_ROW_LENGTH, row_texels as i32) }; @@ -711,13 +711,13 @@ impl super::Queue { let bytes_per_row = copy .buffer_layout .bytes_per_row - .map_or(copy.size.width * block_size, |bpr| bpr.get()); + .unwrap_or(copy.size.width * block_size); let minimum_rows_per_image = (copy.size.height + block_height - 1) / block_height; let rows_per_image = copy .buffer_layout .rows_per_image - .map_or(minimum_rows_per_image, |rpi| rpi.get()); + .unwrap_or(minimum_rows_per_image); let bytes_per_image = bytes_per_row * rows_per_image; let minimum_bytes_per_image = bytes_per_row * minimum_rows_per_image; @@ -819,11 +819,11 @@ impl super::Queue { let row_texels = copy .buffer_layout .bytes_per_row - .map_or(copy.size.width, |bpr| bpr.get() / block_size); + .map_or(copy.size.width, |bpr| bpr / block_size); let column_texels = copy .buffer_layout .rows_per_image - .map_or(copy.size.height, |bpr| bpr.get()); + .unwrap_or(copy.size.height); unsafe { gl.bind_framebuffer(glow::READ_FRAMEBUFFER, Some(self.copy_fbo)) }; diff --git a/wgpu-hal/src/metal/command.rs b/wgpu-hal/src/metal/command.rs index 25e355a32b..95bb6e1507 100644 --- a/wgpu-hal/src/metal/command.rs +++ b/wgpu-hal/src/metal/command.rs @@ -223,14 +223,11 @@ impl crate::CommandEncoder for super::CommandEncoder { .texture_base .max_copy_size(&dst.copy_size) .min(©.size); - let bytes_per_row = copy - .buffer_layout - .bytes_per_row - .map_or(0, |v| v.get() as u64); + let bytes_per_row = copy.buffer_layout.bytes_per_row.unwrap_or(0) as u64; let image_byte_stride = if extent.depth > 1 { copy.buffer_layout .rows_per_image - .map_or(0, |v| v.get() as u64 * bytes_per_row) + .map_or(0, |v| v as u64 * bytes_per_row) } else { // Don't pass a stride when updating a single layer, otherwise metal validation // fails when updating a subset of the image due to the stride being larger than @@ -269,14 +266,11 @@ impl crate::CommandEncoder for super::CommandEncoder { .texture_base .max_copy_size(&src.copy_size) .min(©.size); - let bytes_per_row = copy - .buffer_layout - .bytes_per_row - .map_or(0, |v| v.get() as u64); + let bytes_per_row = copy.buffer_layout.bytes_per_row.unwrap_or(0) as u64; let bytes_per_image = copy .buffer_layout .rows_per_image - .map_or(0, |v| v.get() as u64 * bytes_per_row); + .map_or(0, |v| v as u64 * bytes_per_row); encoder.copy_from_texture_to_buffer( &src.raw, copy.texture_base.array_layer as u64, diff --git a/wgpu-hal/src/vulkan/command.rs b/wgpu-hal/src/vulkan/command.rs index 29c7d86473..f6c871026c 100644 --- a/wgpu-hal/src/vulkan/command.rs +++ b/wgpu-hal/src/vulkan/command.rs @@ -25,12 +25,12 @@ impl super::Texture { let block_size = format .block_size(Some(r.texture_base.aspect.map())) .unwrap(); - block_width * (bpr.get() / block_size) + block_width * (bpr / block_size) }), buffer_image_height: r .buffer_layout .rows_per_image - .map_or(0, |rpi| rpi.get() * block_height), + .map_or(0, |rpi| rpi * block_height), image_subresource, image_offset, image_extent: conv::map_copy_extent(&extent), diff --git a/wgpu-types/src/lib.rs b/wgpu-types/src/lib.rs index 7541dc54d0..38fecda515 100644 --- a/wgpu-types/src/lib.rs +++ b/wgpu-types/src/lib.rs @@ -5177,7 +5177,7 @@ pub struct ImageDataLayout { /// [CEcbtt]: ../wgpu/struct.CommandEncoder.html#method.copy_buffer_to_texture /// [CEcttb]: ../wgpu/struct.CommandEncoder.html#method.copy_texture_to_buffer /// [Qwt]: ../wgpu/struct.Queue.html#method.write_texture - pub bytes_per_row: Option, + pub bytes_per_row: Option, /// "Rows" that make up a single "image". /// /// A row is one row of pixels or of compressed blocks in the x direction. @@ -5187,7 +5187,7 @@ pub struct ImageDataLayout { /// The amount of rows per image may be larger than the actual amount of rows of data. /// /// Required if there are multiple images (i.e. the depth is more than one). - pub rows_per_image: Option, + pub rows_per_image: Option, } /// Specific type of a buffer binding. diff --git a/wgpu/examples/bunnymark/main.rs b/wgpu/examples/bunnymark/main.rs index 4c82aa2041..9af73c8180 100644 --- a/wgpu/examples/bunnymark/main.rs +++ b/wgpu/examples/bunnymark/main.rs @@ -159,7 +159,7 @@ impl framework::Example for Example { &buf, wgpu::ImageDataLayout { offset: 0, - bytes_per_row: std::num::NonZeroU32::new(info.width * 4), + bytes_per_row: Some(info.width * 4), rows_per_image: None, }, size, diff --git a/wgpu/examples/capture/main.rs b/wgpu/examples/capture/main.rs index 8fe95a06ad..252777355a 100644 --- a/wgpu/examples/capture/main.rs +++ b/wgpu/examples/capture/main.rs @@ -113,10 +113,7 @@ async fn create_red_image_with_dimensions( buffer: &output_buffer, layout: wgpu::ImageDataLayout { offset: 0, - bytes_per_row: Some( - std::num::NonZeroU32::new(buffer_dimensions.padded_bytes_per_row as u32) - .unwrap(), - ), + bytes_per_row: Some(buffer_dimensions.padded_bytes_per_row as u32), rows_per_image: None, }, }, diff --git a/wgpu/examples/cube/main.rs b/wgpu/examples/cube/main.rs index 4cf1871faa..2f1acae027 100644 --- a/wgpu/examples/cube/main.rs +++ b/wgpu/examples/cube/main.rs @@ -210,7 +210,7 @@ impl framework::Example for Example { &texels, wgpu::ImageDataLayout { offset: 0, - bytes_per_row: Some(std::num::NonZeroU32::new(size).unwrap()), + bytes_per_row: Some(size), rows_per_image: None, }, texture_extent, diff --git a/wgpu/examples/framework.rs b/wgpu/examples/framework.rs index b08fc10364..2e5e25283a 100644 --- a/wgpu/examples/framework.rs +++ b/wgpu/examples/framework.rs @@ -504,7 +504,7 @@ pub struct FrameworkRefTest { #[cfg(test)] #[allow(dead_code)] pub fn test(mut params: FrameworkRefTest) { - use std::{mem, num::NonZeroU32}; + use std::mem; assert_eq!(params.width % 64, 0, "width needs to be aligned 64"); @@ -592,7 +592,7 @@ pub fn test(mut params: FrameworkRefTest) { buffer: &dst_buffer, layout: wgpu::ImageDataLayout { offset: 0, - bytes_per_row: NonZeroU32::new(params.width * 4), + bytes_per_row: Some(params.width * 4), rows_per_image: None, }, }, diff --git a/wgpu/examples/mipmap/main.rs b/wgpu/examples/mipmap/main.rs index 9e3cbdee2b..12b9e201a5 100644 --- a/wgpu/examples/mipmap/main.rs +++ b/wgpu/examples/mipmap/main.rs @@ -2,7 +2,7 @@ mod framework; use bytemuck::{Pod, Zeroable}; -use std::{borrow::Cow, f32::consts, mem, num::NonZeroU32}; +use std::{borrow::Cow, f32::consts, mem}; use wgpu::util::DeviceExt; const TEXTURE_FORMAT: wgpu::TextureFormat = wgpu::TextureFormat::Rgba8UnormSrgb; @@ -247,7 +247,7 @@ impl framework::Example for Example { buffer: &temp_buf, layout: wgpu::ImageDataLayout { offset: 0, - bytes_per_row: Some(NonZeroU32::new(4 * size).unwrap()), + bytes_per_row: Some(4 * size), rows_per_image: None, }, }, diff --git a/wgpu/examples/texture-arrays/main.rs b/wgpu/examples/texture-arrays/main.rs index 1d6d2be21e..6d3fb56b12 100644 --- a/wgpu/examples/texture-arrays/main.rs +++ b/wgpu/examples/texture-arrays/main.rs @@ -197,7 +197,7 @@ impl framework::Example for Example { &red_texture_data, wgpu::ImageDataLayout { offset: 0, - bytes_per_row: Some(NonZeroU32::new(4).unwrap()), + bytes_per_row: Some(4), rows_per_image: None, }, wgpu::Extent3d::default(), @@ -207,7 +207,7 @@ impl framework::Example for Example { &green_texture_data, wgpu::ImageDataLayout { offset: 0, - bytes_per_row: Some(NonZeroU32::new(4).unwrap()), + bytes_per_row: Some(4), rows_per_image: None, }, wgpu::Extent3d::default(), @@ -217,7 +217,7 @@ impl framework::Example for Example { &blue_texture_data, wgpu::ImageDataLayout { offset: 0, - bytes_per_row: Some(NonZeroU32::new(4).unwrap()), + bytes_per_row: Some(4), rows_per_image: None, }, wgpu::Extent3d::default(), @@ -227,7 +227,7 @@ impl framework::Example for Example { &white_texture_data, wgpu::ImageDataLayout { offset: 0, - bytes_per_row: Some(NonZeroU32::new(4).unwrap()), + bytes_per_row: Some(4), rows_per_image: None, }, wgpu::Extent3d::default(), diff --git a/wgpu/src/backend/web.rs b/wgpu/src/backend/web.rs index 9ccf174570..f42e133e87 100644 --- a/wgpu/src/backend/web.rs +++ b/wgpu/src/backend/web.rs @@ -460,10 +460,10 @@ fn map_buffer_copy_view(view: crate::ImageCopyBuffer) -> web_sys::GpuImageCopyBu let buffer = &<::BufferId>::from(view.buffer.id).0; let mut mapped = web_sys::GpuImageCopyBuffer::new(buffer); if let Some(bytes_per_row) = view.layout.bytes_per_row { - mapped.bytes_per_row(bytes_per_row.get()); + mapped.bytes_per_row(bytes_per_row); } if let Some(rows_per_image) = view.layout.rows_per_image { - mapped.rows_per_image(rows_per_image.get()); + mapped.rows_per_image(rows_per_image); } mapped.offset(view.layout.offset as f64); mapped @@ -2369,10 +2369,10 @@ impl crate::context::Context for Context { ) { let mut mapped_data_layout = web_sys::GpuImageDataLayout::new(); if let Some(bytes_per_row) = data_layout.bytes_per_row { - mapped_data_layout.bytes_per_row(bytes_per_row.get()); + mapped_data_layout.bytes_per_row(bytes_per_row); } if let Some(rows_per_image) = data_layout.rows_per_image { - mapped_data_layout.rows_per_image(rows_per_image.get()); + mapped_data_layout.rows_per_image(rows_per_image); } mapped_data_layout.offset(data_layout.offset as f64); diff --git a/wgpu/src/util/device.rs b/wgpu/src/util/device.rs index 01dcaf1717..2d6f0ed7fe 100644 --- a/wgpu/src/util/device.rs +++ b/wgpu/src/util/device.rs @@ -1,5 +1,3 @@ -use std::num::NonZeroU32; - /// Describes a [Buffer](crate::Buffer) when allocating. #[derive(Clone, Debug, PartialEq, Eq, Hash)] pub struct BufferInitDescriptor<'a> { @@ -132,12 +130,8 @@ impl DeviceExt for crate::Device { &data[binary_offset..end_offset], crate::ImageDataLayout { offset: 0, - bytes_per_row: Some( - NonZeroU32::new(bytes_per_row).expect("invalid bytes per row"), - ), - rows_per_image: Some( - NonZeroU32::new(height_blocks).expect("invalid height"), - ), + bytes_per_row: Some(bytes_per_row), + rows_per_image: Some(height_blocks), }, mip_physical, ); diff --git a/wgpu/tests/common/image.rs b/wgpu/tests/common/image.rs index aeff3da5fa..f3c9df6baf 100644 --- a/wgpu/tests/common/image.rs +++ b/wgpu/tests/common/image.rs @@ -2,7 +2,6 @@ use std::{ borrow::Cow, ffi::{OsStr, OsString}, io, - num::NonZeroU32, path::Path, str::FromStr, }; @@ -282,10 +281,8 @@ fn copy_texture_to_buffer_with_aspect( }, layout: ImageDataLayout { offset: 0, - bytes_per_row: Some( - NonZeroU32::new((texture.width() / block_width) * block_size).unwrap(), - ), - rows_per_image: Some(NonZeroU32::new(texture.height() / block_height).unwrap()), + bytes_per_row: Some((texture.width() / block_width) * block_size), + rows_per_image: Some(texture.height() / block_height), }, }, texture diff --git a/wgpu/tests/external_texture.rs b/wgpu/tests/external_texture.rs index 2bb2ec21bb..b40dc337e4 100644 --- a/wgpu/tests/external_texture.rs +++ b/wgpu/tests/external_texture.rs @@ -1,7 +1,5 @@ #![cfg(all(target_arch = "wasm32", not(target_os = "emscripten")))] -use std::num::NonZeroU32; - use crate::common::{fail_if, initialize_test, TestParameters}; use wasm_bindgen::JsCast; use wasm_bindgen_test::*; @@ -314,7 +312,7 @@ async fn image_bitmap_import() { buffer: &readback_buffer, layout: wgpu::ImageDataLayout { offset: 0, - bytes_per_row: Some(NonZeroU32::new(256).unwrap()), + bytes_per_row: Some(256), rows_per_image: None, }, }, diff --git a/wgpu/tests/queue_transfer.rs b/wgpu/tests/queue_transfer.rs index 62740cf7d2..7145087667 100644 --- a/wgpu/tests/queue_transfer.rs +++ b/wgpu/tests/queue_transfer.rs @@ -1,7 +1,5 @@ //! Tests for buffer copy validation. -use std::num::NonZeroU32; - use crate::common::{fail, initialize_test, TestParameters}; use wasm_bindgen_test::*; @@ -37,9 +35,9 @@ fn queue_write_texture_overflow() { &data, wgpu::ImageDataLayout { offset: 0, - bytes_per_row: NonZeroU32::new(879161360), + bytes_per_row: Some(879161360), //bytes_per_image: 4294967295, - rows_per_image: NonZeroU32::new(4294967295 / 879161360), + rows_per_image: Some(4294967295 / 879161360), }, wgpu::Extent3d { width: 3056263286, diff --git a/wgpu/tests/shader_primitive_index/mod.rs b/wgpu/tests/shader_primitive_index/mod.rs index 086bc181d9..c10a842cc8 100644 --- a/wgpu/tests/shader_primitive_index/mod.rs +++ b/wgpu/tests/shader_primitive_index/mod.rs @@ -1,5 +1,4 @@ use crate::common::{initialize_test, TestParameters, TestingContext}; -use std::num::NonZeroU32; use wasm_bindgen_test::*; use wgpu::util::{align_to, DeviceExt}; @@ -230,7 +229,7 @@ fn capture_rgba_u8_texture( buffer: &output_buffer, layout: wgpu::ImageDataLayout { offset: 0, - bytes_per_row: NonZeroU32::new(bytes_per_row), + bytes_per_row: Some(bytes_per_row), rows_per_image: None, }, }, diff --git a/wgpu/tests/shader_view_format/mod.rs b/wgpu/tests/shader_view_format/mod.rs index f82f8851cf..045198f1bc 100644 --- a/wgpu/tests/shader_view_format/mod.rs +++ b/wgpu/tests/shader_view_format/mod.rs @@ -1,5 +1,4 @@ use crate::common::{image::calc_difference, initialize_test, TestParameters, TestingContext}; -use std::num::NonZeroU32; use wgpu::{util::DeviceExt, DownlevelFlags, Limits, TextureFormat}; #[test] @@ -166,7 +165,7 @@ fn reinterpret( buffer: &read_buffer, layout: wgpu::ImageDataLayout { offset: 0, - bytes_per_row: NonZeroU32::new(wgpu::COPY_BYTES_PER_ROW_ALIGNMENT), + bytes_per_row: Some(wgpu::COPY_BYTES_PER_ROW_ALIGNMENT), rows_per_image: None, }, }, diff --git a/wgpu/tests/texture_bounds.rs b/wgpu/tests/texture_bounds.rs index 3bdb9f23e7..ea6b2a18bf 100644 --- a/wgpu/tests/texture_bounds.rs +++ b/wgpu/tests/texture_bounds.rs @@ -1,7 +1,6 @@ //! Tests for texture copy bounds checks. use crate::common::{fail_if, initialize_test, TestParameters}; -use std::num::NonZeroU32; use wasm_bindgen_test::*; #[test] @@ -112,6 +111,6 @@ const BUFFER_SIZE: u32 = TEXTURE_SIZE.width * TEXTURE_SIZE.height * BYTES_PER_PI const BUFFER_COPY_LAYOUT: wgpu::ImageDataLayout = wgpu::ImageDataLayout { offset: 0, - bytes_per_row: NonZeroU32::new(TEXTURE_SIZE.width * BYTES_PER_PIXEL), + bytes_per_row: Some(TEXTURE_SIZE.width * BYTES_PER_PIXEL), rows_per_image: None, }; diff --git a/wgpu/tests/write_texture.rs b/wgpu/tests/write_texture.rs index 1c6ea203f3..b6fe787616 100644 --- a/wgpu/tests/write_texture.rs +++ b/wgpu/tests/write_texture.rs @@ -2,7 +2,6 @@ use crate::common::{initialize_test, TestParameters}; -use std::num::NonZeroU32; use wasm_bindgen_test::*; #[test] @@ -39,8 +38,8 @@ fn write_texture_subset_2d() { bytemuck::cast_slice(&data), wgpu::ImageDataLayout { offset: 0, - bytes_per_row: std::num::NonZeroU32::new(size), - rows_per_image: std::num::NonZeroU32::new(size), + bytes_per_row: Some(size), + rows_per_image: Some(size), }, wgpu::Extent3d { width: size, @@ -73,8 +72,8 @@ fn write_texture_subset_2d() { buffer: &read_buffer, layout: wgpu::ImageDataLayout { offset: 0, - bytes_per_row: NonZeroU32::new(size), - rows_per_image: NonZeroU32::new(size), + bytes_per_row: Some(size), + rows_per_image: Some(size), }, }, wgpu::Extent3d { @@ -135,8 +134,8 @@ fn write_texture_subset_3d() { bytemuck::cast_slice(&data), wgpu::ImageDataLayout { offset: 0, - bytes_per_row: std::num::NonZeroU32::new(size), - rows_per_image: std::num::NonZeroU32::new(size), + bytes_per_row: Some(size), + rows_per_image: Some(size), }, wgpu::Extent3d { width: size, @@ -169,8 +168,8 @@ fn write_texture_subset_3d() { buffer: &read_buffer, layout: wgpu::ImageDataLayout { offset: 0, - bytes_per_row: NonZeroU32::new(size), - rows_per_image: NonZeroU32::new(size), + bytes_per_row: Some(size), + rows_per_image: Some(size), }, }, wgpu::Extent3d { diff --git a/wgpu/tests/zero_init_texture_after_discard.rs b/wgpu/tests/zero_init_texture_after_discard.rs index a10e606d63..eda28ff954 100644 --- a/wgpu/tests/zero_init_texture_after_discard.rs +++ b/wgpu/tests/zero_init_texture_after_discard.rs @@ -1,5 +1,3 @@ -use std::num::NonZeroU32; - use crate::common::{image::ReadbackBuffers, initialize_test, TestParameters, TestingContext}; use wasm_bindgen_test::*; use wgpu::*; @@ -184,7 +182,7 @@ impl<'ctx> TestCase<'ctx> { &data, ImageDataLayout { offset: 0, - bytes_per_row: NonZeroU32::new(bytes_per_row), + bytes_per_row: Some(bytes_per_row), rows_per_image: None, }, texture.size(),