Struct StagingBelt

Source
pub struct StagingBelt { /* private fields */ }
Expand description

Staging belt is a machine that uploads data.

Internally it uses a ring-buffer of staging buffers that are sub-allocated. It has an advantage over Queue.write_buffer in a way that it returns a mutable slice, which you can fill to avoid an extra data copy.

Implementations§

Source§

impl StagingBelt

Source

pub fn new(chunk_size: BufferAddress, device: &Device) -> Self

Create a new staging belt.

The chunk_size is the unit of internal buffer allocation. It’s better when it’s big, but ideally still 1-4 times less than the total amount of data uploaded per submission.

Source

pub fn write_buffer( &mut self, target: &Buffer, offset: BufferAddress, size: BufferSize, device: &Device, ) -> BufferViewMut<'_>

Allocate the staging belt slice of size to be uploaded into the target buffer at the specified offset.

The upload will only really be scheduled at the next StagingBelt::flush call.

Source

pub fn flush(&mut self, device: &Device) -> CommandBuffer

Produce a command buffer with all the accumulated transfers.

At this point, all the partially used staging buffers are closed until the GPU is done copying the data from them.

Source

pub fn recall(&mut self) -> impl Future<Output = ()> + Send

Recall all of the closed buffers back for re-usal.

This has to be called after the command buffer produced by flush is submitted!

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.