diff options
author | 2024-03-29 14:29:31 +0100 | |
---|---|---|
committer | 2024-03-29 14:29:31 +0100 | |
commit | 5f1eb43161d70b4ef157aae1ebc2b5fb25eb5b27 (patch) | |
tree | 9e266da4bc18dd34229cb2c58efe8529ba8fe3b4 /wgpu/src/buffer.rs | |
parent | 0a97b9e37ae115bb0db33193c8a6b62590a3cd2c (diff) | |
download | iced-5f1eb43161d70b4ef157aae1ebc2b5fb25eb5b27.tar.gz iced-5f1eb43161d70b4ef157aae1ebc2b5fb25eb5b27.tar.bz2 iced-5f1eb43161d70b4ef157aae1ebc2b5fb25eb5b27.zip |
Split big `Buffer` writes into multiple chunks
Diffstat (limited to 'wgpu/src/buffer.rs')
-rw-r--r-- | wgpu/src/buffer.rs | 42 |
1 files changed, 34 insertions, 8 deletions
diff --git a/wgpu/src/buffer.rs b/wgpu/src/buffer.rs index f8828d46..c9d6b828 100644 --- a/wgpu/src/buffer.rs +++ b/wgpu/src/buffer.rs @@ -1,6 +1,8 @@ use std::marker::PhantomData; use std::ops::RangeBounds; +pub const MAX_WRITE_SIZE: usize = 1024 * 100; + #[derive(Debug)] pub struct Buffer<T> { label: &'static str, @@ -69,14 +71,38 @@ impl<T: bytemuck::Pod> Buffer<T> { ) -> usize { let bytes: &[u8] = bytemuck::cast_slice(contents); - belt.write_buffer( - encoder, - &self.raw, - offset as u64, - (bytes.len() as u64).try_into().expect("Non-empty write"), - device, - ) - .copy_from_slice(bytes); + if bytes.len() <= MAX_WRITE_SIZE { + belt.write_buffer( + encoder, + &self.raw, + offset as u64, + (bytes.len() as u64).try_into().expect("Non-empty write"), + device, + ) + .copy_from_slice(bytes); + } else { + let mut bytes_written = 0; + + let bytes_per_chunk = (bytes.len().min(MAX_WRITE_SIZE) as u64) + .try_into() + .expect("Non-empty write"); + + while bytes_written < bytes.len() { + belt.write_buffer( + encoder, + &self.raw, + (offset + bytes_written) as u64, + bytes_per_chunk, + device, + ) + .copy_from_slice( + &bytes[bytes_written + ..bytes_written + bytes_per_chunk.get() as usize], + ); + + bytes_written += bytes_per_chunk.get() as usize; + } + } self.offsets.push(offset as u64); |