Struct BufferBinding
pub struct BufferBinding<'a, B>{
pub offset: u64,
pub size: Option<NonZero<u64>>,
/* private fields */
}unstable-wgpu-27 only.Expand description
A region of a buffer made visible to shaders via a BindGroup.
§Construction
The recommended way to construct a BufferBinding is using the binding
method on a wgpu-core Buffer, which will validate the binding size
against the buffer size. A new_unchecked constructor is also provided for
cases where direct construction is necessary.
§Accessible region
wgpu_hal guarantees that shaders compiled with
ShaderModuleDescriptor::runtime_checks set to true cannot read or
write data via this binding outside the accessible region of a buffer:
-
The accessible region starts at
offset. -
For
Storagebindings, the size of the accessible region issize, which must be a multiple of 4. -
For
Uniformbindings, the size of the accessible region issizerounded up to the next multiple ofAlignments::uniform_bounds_check_alignment.
Note that this guarantee is stricter than WGSL’s requirements for
out-of-bounds accesses, as WGSL allows them to return values from
elsewhere in the buffer. But this guarantee is necessary anyway, to permit
wgpu-core to avoid clearing uninitialized regions of buffers that will
never be read by the application before they are overwritten. This
optimization consults bind group buffer binding regions to determine which
parts of which buffers shaders might observe. This optimization is only
sound if shader access is bounds-checked.
§Zero-length bindings
Some back ends cannot tolerate zero-length regions; for example, see
VUID-VkDescriptorBufferInfo-offset-00340 and
VUID-VkDescriptorBufferInfo-range-00341, or the
documentation for GLES’s glBindBufferRange. This documentation
previously stated that a BufferBinding must have offset strictly less
than the size of the buffer, but this restriction was not honored elsewhere
in the code, so has been removed. However, it remains the case that
some backends do not support zero-length bindings, so additional
logic is needed somewhere to handle this properly. See
#3170.
Fields§
§offset: u64The offset at which the bound region starts.
This must be less or equal to the size of the buffer.
size: Option<NonZero<u64>>The size of the region bound, in bytes.
If None, the region extends from offset to the end of the
buffer. Given the restrictions on offset, this means that
the size is always greater than zero.
Implementations§
§impl<'a> BufferBinding<'a, dyn DynBuffer>
impl<'a> BufferBinding<'a, dyn DynBuffer>
pub fn expect_downcast<B>(self) -> BufferBinding<'a, B>where
B: DynBuffer,
§impl<'a, B> BufferBinding<'a, B>
impl<'a, B> BufferBinding<'a, B>
pub fn new_unchecked<S>(
buffer: &'a B,
offset: u64,
size: S,
) -> BufferBinding<'a, B>
pub fn new_unchecked<S>( buffer: &'a B, offset: u64, size: S, ) -> BufferBinding<'a, B>
Construct a BufferBinding with the given contents.
When possible, use the binding method on a wgpu-core Buffer instead
of this method. Buffer::binding validates the size of the binding
against the size of the buffer.
It is more difficult to provide a validating constructor here, due to
not having direct access to the size of a DynBuffer.
SAFETY: The caller is responsible for ensuring that a binding of size
bytes starting at offset is contained within the buffer.
The S type parameter is a temporary convenience to allow callers to
pass a zero size. When the zero-size binding issue is resolved, the
argument should just match the type of the member.
TODO(https://github.com/gfx-rs/wgpu/issues/3170): remove the parameter
Trait Implementations§
§impl<B> Clone for BufferBinding<'_, B>
impl<B> Clone for BufferBinding<'_, B>
§fn clone(&self) -> BufferBinding<'_, B>
fn clone(&self) -> BufferBinding<'_, B>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreAuto Trait Implementations§
impl<'a, B> Freeze for BufferBinding<'a, B>where
B: ?Sized,
impl<'a, B> RefUnwindSafe for BufferBinding<'a, B>where
B: RefUnwindSafe + ?Sized,
impl<'a, B> Send for BufferBinding<'a, B>where
B: ?Sized,
impl<'a, B> Sync for BufferBinding<'a, B>where
B: ?Sized,
impl<'a, B> Unpin for BufferBinding<'a, B>where
B: ?Sized,
impl<'a, B> UnwindSafe for BufferBinding<'a, B>where
B: RefUnwindSafe + ?Sized,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<T> Pointable for T
impl<T> Pointable for T
§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self from the equivalent element of its
superset. Read more§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self is actually part of its subset T (and can be converted to it).§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset but without any property checks. Always succeeds.§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self to the equivalent element of its superset.