wgpu

Struct ComputePass

Source
pub struct ComputePass<'encoder> { /* private fields */ }
Expand description

In-progress recording of a compute pass.

It can be created with CommandEncoder::begin_compute_pass.

Corresponds to WebGPU GPUComputePassEncoder.

Implementations§

Source§

impl<'encoder> ComputePass<'encoder>

Source

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.

Source

pub fn set_bind_group<'a>( &mut self, index: u32, bind_group: impl Into<Option<&'a BindGroup>>, 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.

Source

pub fn set_pipeline(&mut self, pipeline: &ComputePipeline)

Sets the active compute pipeline.

Source

pub fn insert_debug_marker(&mut self, label: &str)

Inserts debug marker.

Source

pub fn push_debug_group(&mut self, label: &str)

Start record commands and group it into debug marker group.

Source

pub fn pop_debug_group(&mut self)

Stops command recording and creates debug group.

Source

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.

Source

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<'encoder> ComputePass<'encoder>

Features::PUSH_CONSTANTS must be enabled on the device in order to call these functions.

Source

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<'encoder> ComputePass<'encoder>

Features::TIMESTAMP_QUERY_INSIDE_PASSES must be enabled on the device in order to call these functions.

Source

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<'encoder> ComputePass<'encoder>

Features::PIPELINE_STATISTICS_QUERY must be enabled on the device in order to call these functions.

Source

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.

Source

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>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

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> 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> Downcast<T> for T

Source§

fn downcast(&self) -> &T

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.
Source§

impl<T> Upcast<T> for T

Source§

fn upcast(&self) -> Option<&T>

Source§

impl<T> WasmNotSend for T
where T: Send,

Source§

impl<T> WasmNotSendSync for T

Source§

impl<T> WasmNotSync for T
where T: Sync,