pub struct ComputePass<'encoder> {
pub(crate) inner: ComputePassInner,
pub(crate) encoder_guard: PhantomData<&'encoder ()>,
}
Expand description
In-progress recording of a compute pass.
It can be created with CommandEncoder::begin_compute_pass
.
Corresponds to WebGPU GPUComputePassEncoder
.
Fields§
§inner: ComputePassInner
§encoder_guard: PhantomData<&'encoder ()>
Implementations§
§impl<'encoder> ComputePass<'encoder>
impl<'encoder> ComputePass<'encoder>
pub fn forget_lifetime(self) -> ComputePass<'static>
pub fn forget_lifetime(self) -> ComputePass<'static>
Drops the lifetime relationship to the parent command encoder, making usage of the encoder while this pass is recorded a run-time error instead.
Attention: As long as the compute pass has not been ended, any mutating operation on the parent command encoder will cause a run-time error and invalidate it! By default, the lifetime constraint prevents this, but it can be useful to handle this at run time, such as when storing the pass and encoder in the same data structure.
This operation has no effect on pass recording.
It’s a safe operation, since CommandEncoder
is in a locked state as long as the pass is active
regardless of the lifetime constraint or its absence.
pub fn set_bind_group(
&mut self,
index: u32,
bind_group: &BindGroup,
offsets: &[u32]
)
pub fn set_bind_group( &mut self, index: u32, bind_group: &BindGroup, offsets: &[u32] )
Sets the active bind group for a given bind group index. The bind group layout
in the active pipeline when the dispatch()
function is called must match the layout of this bind group.
If the bind group have dynamic offsets, provide them in the binding order.
These offsets have to be aligned to Limits::min_uniform_buffer_offset_alignment
or Limits::min_storage_buffer_offset_alignment
appropriately.
pub fn set_pipeline(&mut self, pipeline: &ComputePipeline)
pub fn set_pipeline(&mut self, pipeline: &ComputePipeline)
Sets the active compute pipeline.
pub fn insert_debug_marker(&mut self, label: &str)
pub fn insert_debug_marker(&mut self, label: &str)
Inserts debug marker.
pub fn push_debug_group(&mut self, label: &str)
pub fn push_debug_group(&mut self, label: &str)
Start record commands and group it into debug marker group.
pub fn pop_debug_group(&mut self)
pub fn pop_debug_group(&mut self)
Stops command recording and creates debug group.
pub fn dispatch_workgroups(&mut self, x: u32, y: u32, z: u32)
pub fn dispatch_workgroups(&mut self, x: u32, y: u32, z: u32)
Dispatches compute work operations.
x
, y
and z
denote the number of work groups to dispatch in each dimension.
pub fn dispatch_workgroups_indirect(
&mut self,
indirect_buffer: &Buffer,
indirect_offset: u64
)
pub fn dispatch_workgroups_indirect( &mut self, indirect_buffer: &Buffer, indirect_offset: u64 )
Dispatches compute work operations, based on the contents of the indirect_buffer
.
The structure expected in indirect_buffer
must conform to DispatchIndirectArgs
.
§impl<'encoder> ComputePass<'encoder>
impl<'encoder> ComputePass<'encoder>
Features::PUSH_CONSTANTS
must be enabled on the device in order to call these functions.
pub fn set_push_constants(&mut self, offset: u32, data: &[u8])
pub fn set_push_constants(&mut self, offset: u32, data: &[u8])
Set push constant data for subsequent dispatch calls.
Write the bytes in data
at offset offset
within push constant
storage. Both offset
and the length of data
must be
multiples of PUSH_CONSTANT_ALIGNMENT
, which is always 4.
For example, if offset
is 4
and data
is eight bytes long, this
call will write data
to bytes 4..12
of push constant storage.
§impl<'encoder> ComputePass<'encoder>
impl<'encoder> ComputePass<'encoder>
Features::TIMESTAMP_QUERY_INSIDE_PASSES
must be enabled on the device in order to call these functions.
pub fn write_timestamp(&mut self, query_set: &QuerySet, query_index: u32)
pub fn write_timestamp(&mut self, query_set: &QuerySet, query_index: u32)
Issue a timestamp command at this point in the queue. The timestamp will be written to the specified query set, at the specified index.
Must be multiplied by Queue::get_timestamp_period
to get
the value in nanoseconds. Absolute values have no meaning,
but timestamps can be subtracted to get the time it takes
for a string of operations to complete.
§impl<'encoder> ComputePass<'encoder>
impl<'encoder> ComputePass<'encoder>
Features::PIPELINE_STATISTICS_QUERY
must be enabled on the device in order to call these functions.
pub fn begin_pipeline_statistics_query(
&mut self,
query_set: &QuerySet,
query_index: u32
)
pub fn begin_pipeline_statistics_query( &mut self, query_set: &QuerySet, query_index: u32 )
Start a pipeline statistics query on this compute pass. It can be ended with
end_pipeline_statistics_query
. Pipeline statistics queries may not be nested.
pub fn end_pipeline_statistics_query(&mut self)
pub fn end_pipeline_statistics_query(&mut self)
End the pipeline statistics query on this compute pass. It can be started with
begin_pipeline_statistics_query
. Pipeline statistics queries may not be nested.
Trait Implementations§
Auto Trait Implementations§
impl<'encoder> Freeze for ComputePass<'encoder>
impl<'encoder> !RefUnwindSafe for ComputePass<'encoder>
impl<'encoder> Send for ComputePass<'encoder>
impl<'encoder> Sync for ComputePass<'encoder>
impl<'encoder> Unpin for ComputePass<'encoder>
impl<'encoder> !UnwindSafe for ComputePass<'encoder>
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> CheckedAs for T
impl<T> CheckedAs for T
source§fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
fn checked_as<Dst>(self) -> Option<Dst>where
T: CheckedCast<Dst>,
source§impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
impl<Src, Dst> CheckedCastFrom<Src> for Dstwhere
Src: CheckedCast<Dst>,
source§fn checked_cast_from(src: Src) -> Option<Dst>
fn checked_cast_from(src: Src) -> Option<Dst>
§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 moresource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request