pub struct ComputePass<'encoder> {
pub(crate) inner: DispatchComputePass,
pub(crate) _encoder_guard: PhantomDrop<&'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: DispatchComputePass
§_encoder_guard: PhantomDrop<&'encoder ()>
This lifetime is used to protect the CommandEncoder
from being used
while the pass is alive. This needs to be PhantomDrop to prevent the lifetime
from being shortened.
Implementations§
source§impl ComputePass<'_>
impl ComputePass<'_>
sourcepub 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.
sourcepub fn set_bind_group<'a, BG>(
&mut self,
index: u32,
bind_group: BG,
offsets: &[DynamicOffset],
)
pub fn set_bind_group<'a, BG>( &mut self, index: u32, bind_group: BG, offsets: &[DynamicOffset], )
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.
sourcepub fn set_pipeline(&mut self, pipeline: &ComputePipeline)
pub fn set_pipeline(&mut self, pipeline: &ComputePipeline)
Sets the active compute pipeline.
sourcepub fn insert_debug_marker(&mut self, label: &str)
pub fn insert_debug_marker(&mut self, label: &str)
Inserts debug marker.
sourcepub 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.
sourcepub fn pop_debug_group(&mut self)
pub fn pop_debug_group(&mut self)
Stops command recording and creates debug group.
sourcepub 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.
sourcepub fn dispatch_workgroups_indirect(
&mut self,
indirect_buffer: &Buffer,
indirect_offset: BufferAddress,
)
pub fn dispatch_workgroups_indirect( &mut self, indirect_buffer: &Buffer, indirect_offset: BufferAddress, )
Dispatches compute work operations, based on the contents of the indirect_buffer
.
The structure expected in indirect_buffer
must conform to DispatchIndirectArgs
.
source§impl ComputePass<'_>
impl ComputePass<'_>
Features::PUSH_CONSTANTS
must be enabled on the device in order to call these functions.
sourcepub 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.
source§impl ComputePass<'_>
impl ComputePass<'_>
Features::TIMESTAMP_QUERY_INSIDE_PASSES
must be enabled on the device in order to call these functions.
sourcepub 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.
source§impl ComputePass<'_>
impl ComputePass<'_>
Features::PIPELINE_STATISTICS_QUERY
must be enabled on the device in order to call these functions.
sourcepub 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.
sourcepub 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§
source§impl<'encoder> Debug for ComputePass<'encoder>
impl<'encoder> Debug for ComputePass<'encoder>
source§impl Hash for ComputePass<'_>
impl Hash for ComputePass<'_>
source§impl Ord for ComputePass<'_>
impl Ord for ComputePass<'_>
source§impl PartialEq for ComputePass<'_>
impl PartialEq for ComputePass<'_>
source§impl PartialOrd for ComputePass<'_>
impl PartialOrd for ComputePass<'_>
impl Eq for ComputePass<'_>
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
§impl<Q, K> Comparable<K> for Q
impl<Q, K> Comparable<K> for Q
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.