pub trait CommandEncoder: WasmNotSendSync + Debug {
type A: Api;
Show 48 methods
// Required methods
unsafe fn begin_encoding(
&mut self,
label: Label<'_>,
) -> Result<(), DeviceError>;
unsafe fn discard_encoding(&mut self);
unsafe fn end_encoding(
&mut self,
) -> Result<<Self::A as Api>::CommandBuffer, DeviceError>;
unsafe fn reset_all<I>(&mut self, command_buffers: I)
where I: Iterator<Item = <Self::A as Api>::CommandBuffer>;
unsafe fn transition_buffers<'a, T>(&mut self, barriers: T)
where T: Iterator<Item = BufferBarrier<'a, <Self::A as Api>::Buffer>>;
unsafe fn transition_textures<'a, T>(&mut self, barriers: T)
where T: Iterator<Item = TextureBarrier<'a, <Self::A as Api>::Texture>>;
unsafe fn clear_buffer(
&mut self,
buffer: &<Self::A as Api>::Buffer,
range: MemoryRange,
);
unsafe fn copy_buffer_to_buffer<T>(
&mut self,
src: &<Self::A as Api>::Buffer,
dst: &<Self::A as Api>::Buffer,
regions: T,
)
where T: Iterator<Item = BufferCopy>;
unsafe fn copy_texture_to_texture<T>(
&mut self,
src: &<Self::A as Api>::Texture,
src_usage: TextureUses,
dst: &<Self::A as Api>::Texture,
regions: T,
)
where T: Iterator<Item = TextureCopy>;
unsafe fn copy_buffer_to_texture<T>(
&mut self,
src: &<Self::A as Api>::Buffer,
dst: &<Self::A as Api>::Texture,
regions: T,
)
where T: Iterator<Item = BufferTextureCopy>;
unsafe fn copy_texture_to_buffer<T>(
&mut self,
src: &<Self::A as Api>::Texture,
src_usage: TextureUses,
dst: &<Self::A as Api>::Buffer,
regions: T,
)
where T: Iterator<Item = BufferTextureCopy>;
unsafe fn copy_acceleration_structure_to_acceleration_structure(
&mut self,
src: &<Self::A as Api>::AccelerationStructure,
dst: &<Self::A as Api>::AccelerationStructure,
copy: AccelerationStructureCopy,
);
unsafe fn set_bind_group(
&mut self,
layout: &<Self::A as Api>::PipelineLayout,
index: u32,
group: &<Self::A as Api>::BindGroup,
dynamic_offsets: &[DynamicOffset],
);
unsafe fn set_push_constants(
&mut self,
layout: &<Self::A as Api>::PipelineLayout,
stages: ShaderStages,
offset_bytes: u32,
data: &[u32],
);
unsafe fn insert_debug_marker(&mut self, label: &str);
unsafe fn begin_debug_marker(&mut self, group_label: &str);
unsafe fn end_debug_marker(&mut self);
unsafe fn begin_query(
&mut self,
set: &<Self::A as Api>::QuerySet,
index: u32,
);
unsafe fn end_query(&mut self, set: &<Self::A as Api>::QuerySet, index: u32);
unsafe fn write_timestamp(
&mut self,
set: &<Self::A as Api>::QuerySet,
index: u32,
);
unsafe fn reset_queries(
&mut self,
set: &<Self::A as Api>::QuerySet,
range: Range<u32>,
);
unsafe fn copy_query_results(
&mut self,
set: &<Self::A as Api>::QuerySet,
range: Range<u32>,
buffer: &<Self::A as Api>::Buffer,
offset: BufferAddress,
stride: BufferSize,
);
unsafe fn begin_render_pass(
&mut self,
desc: &RenderPassDescriptor<'_, <Self::A as Api>::QuerySet, <Self::A as Api>::TextureView>,
) -> Result<(), DeviceError>;
unsafe fn end_render_pass(&mut self);
unsafe fn set_render_pipeline(
&mut self,
pipeline: &<Self::A as Api>::RenderPipeline,
);
unsafe fn set_index_buffer<'a>(
&mut self,
binding: BufferBinding<'a, <Self::A as Api>::Buffer>,
format: IndexFormat,
);
unsafe fn set_vertex_buffer<'a>(
&mut self,
index: u32,
binding: BufferBinding<'a, <Self::A as Api>::Buffer>,
);
unsafe fn set_viewport(&mut self, rect: &Rect<f32>, depth_range: Range<f32>);
unsafe fn set_scissor_rect(&mut self, rect: &Rect<u32>);
unsafe fn set_stencil_reference(&mut self, value: u32);
unsafe fn set_blend_constants(&mut self, color: &[f32; 4]);
unsafe fn draw(
&mut self,
first_vertex: u32,
vertex_count: u32,
first_instance: u32,
instance_count: u32,
);
unsafe fn draw_indexed(
&mut self,
first_index: u32,
index_count: u32,
base_vertex: i32,
first_instance: u32,
instance_count: u32,
);
unsafe fn draw_indirect(
&mut self,
buffer: &<Self::A as Api>::Buffer,
offset: BufferAddress,
draw_count: u32,
);
unsafe fn draw_indexed_indirect(
&mut self,
buffer: &<Self::A as Api>::Buffer,
offset: BufferAddress,
draw_count: u32,
);
unsafe fn draw_indirect_count(
&mut self,
buffer: &<Self::A as Api>::Buffer,
offset: BufferAddress,
count_buffer: &<Self::A as Api>::Buffer,
count_offset: BufferAddress,
max_count: u32,
);
unsafe fn draw_indexed_indirect_count(
&mut self,
buffer: &<Self::A as Api>::Buffer,
offset: BufferAddress,
count_buffer: &<Self::A as Api>::Buffer,
count_offset: BufferAddress,
max_count: u32,
);
unsafe fn draw_mesh_tasks(
&mut self,
group_count_x: u32,
group_count_y: u32,
group_count_z: u32,
);
unsafe fn draw_mesh_tasks_indirect(
&mut self,
buffer: &<Self::A as Api>::Buffer,
offset: BufferAddress,
draw_count: u32,
);
unsafe fn draw_mesh_tasks_indirect_count(
&mut self,
buffer: &<Self::A as Api>::Buffer,
offset: BufferAddress,
count_buffer: &<Self::A as Api>::Buffer,
count_offset: BufferAddress,
max_count: u32,
);
unsafe fn begin_compute_pass(
&mut self,
desc: &ComputePassDescriptor<'_, <Self::A as Api>::QuerySet>,
);
unsafe fn end_compute_pass(&mut self);
unsafe fn set_compute_pipeline(
&mut self,
pipeline: &<Self::A as Api>::ComputePipeline,
);
unsafe fn dispatch(&mut self, count: [u32; 3]);
unsafe fn dispatch_indirect(
&mut self,
buffer: &<Self::A as Api>::Buffer,
offset: BufferAddress,
);
unsafe fn build_acceleration_structures<'a, T>(
&mut self,
descriptor_count: u32,
descriptors: T,
)
where Self::A: 'a,
T: IntoIterator<Item = BuildAccelerationStructureDescriptor<'a, <Self::A as Api>::Buffer, <Self::A as Api>::AccelerationStructure>>;
unsafe fn place_acceleration_structure_barrier(
&mut self,
barrier: AccelerationStructureBarrier,
);
unsafe fn read_acceleration_structure_compact_size(
&mut self,
acceleration_structure: &<Self::A as Api>::AccelerationStructure,
buf: &<Self::A as Api>::Buffer,
);
}Expand description
Encoder and allocation pool for CommandBuffers.
A CommandEncoder not only constructs CommandBuffers but also
acts as the allocation pool that owns the buffers’ underlying
storage. Thus, CommandBuffers must not outlive the
CommandEncoder that created them.
The life cycle of a CommandBuffer is as follows:
-
Call
Device::create_command_encoderto create a newCommandEncoder, in the “closed” state. -
Call
begin_encodingon a closedCommandEncoderto begin recording commands. This puts theCommandEncoderin the “recording” state. -
Call methods like
copy_buffer_to_buffer,begin_render_pass, etc. on a “recording”CommandEncoderto add commands to the list. (If an error occurs, you must calldiscard_encoding; see below.) -
Call
end_encodingon a recordingCommandEncoderto close the encoder and construct a freshCommandBufferconsisting of the list of commands recorded up to that point. -
Call
discard_encodingon a recordingCommandEncoderto drop the commands recorded thus far and close the encoder. This is the only safe thing to do on aCommandEncoderif an error has occurred while recording commands. -
Call
reset_allon a closedCommandEncoder, passing all the liveCommandBuffersbuilt from it. All theCommandBuffers are destroyed, and their resources are freed.
§Safety
-
The
CommandEncodermust be in the states described above to make the given calls. -
A
CommandBufferthat has been submitted for execution on the GPU must live until its execution is complete. -
A
CommandBuffermust not outlive theCommandEncoderthat built it.
It is the user’s responsibility to meet this requirements. This
allows CommandEncoder implementations to keep their state
tracking to a minimum.
Required Associated Types§
Required Methods§
Sourceunsafe fn begin_encoding(&mut self, label: Label<'_>) -> Result<(), DeviceError>
unsafe fn begin_encoding(&mut self, label: Label<'_>) -> Result<(), DeviceError>
Begin encoding a new command buffer.
This puts this CommandEncoder in the “recording” state.
§Safety
This CommandEncoder must be in the “closed” state.
Sourceunsafe fn discard_encoding(&mut self)
unsafe fn discard_encoding(&mut self)
Discard the command list under construction.
If an error has occurred while recording commands, this is the only safe thing to do with the encoder.
This puts this CommandEncoder in the “closed” state.
§Safety
This CommandEncoder must be in the “recording” state.
Callers must not assume that implementations of this function are idempotent, and thus should not call it multiple times in a row.
Sourceunsafe fn end_encoding(
&mut self,
) -> Result<<Self::A as Api>::CommandBuffer, DeviceError>
unsafe fn end_encoding( &mut self, ) -> Result<<Self::A as Api>::CommandBuffer, DeviceError>
Return a fresh CommandBuffer holding the recorded commands.
The returned CommandBuffer holds all the commands recorded
on this CommandEncoder since the last call to
begin_encoding.
This puts this CommandEncoder in the “closed” state.
§Safety
This CommandEncoder must be in the “recording” state.
The returned CommandBuffer must not outlive this
CommandEncoder. Implementations are allowed to build
CommandBuffers that depend on storage owned by this
CommandEncoder.
Sourceunsafe fn reset_all<I>(&mut self, command_buffers: I)
unsafe fn reset_all<I>(&mut self, command_buffers: I)
Reclaim all resources belonging to this CommandEncoder.
§Safety
This CommandEncoder must be in the “closed” state.
The command_buffers iterator must produce all the live
CommandBuffers built using this CommandEncoder — that
is, every extant CommandBuffer returned from end_encoding.
unsafe fn transition_buffers<'a, T>(&mut self, barriers: T)
unsafe fn transition_textures<'a, T>(&mut self, barriers: T)
unsafe fn clear_buffer( &mut self, buffer: &<Self::A as Api>::Buffer, range: MemoryRange, )
unsafe fn copy_buffer_to_buffer<T>(
&mut self,
src: &<Self::A as Api>::Buffer,
dst: &<Self::A as Api>::Buffer,
regions: T,
)where
T: Iterator<Item = BufferCopy>,
Sourceunsafe fn copy_texture_to_texture<T>(
&mut self,
src: &<Self::A as Api>::Texture,
src_usage: TextureUses,
dst: &<Self::A as Api>::Texture,
regions: T,
)where
T: Iterator<Item = TextureCopy>,
unsafe fn copy_texture_to_texture<T>(
&mut self,
src: &<Self::A as Api>::Texture,
src_usage: TextureUses,
dst: &<Self::A as Api>::Texture,
regions: T,
)where
T: Iterator<Item = TextureCopy>,
Copy from one texture to another.
Works with a single array layer.
Note: dst current usage has to be wgt::TextureUses::COPY_DST.
Note: the copy extent is in physical size (rounded to the block size)
Sourceunsafe fn copy_buffer_to_texture<T>(
&mut self,
src: &<Self::A as Api>::Buffer,
dst: &<Self::A as Api>::Texture,
regions: T,
)where
T: Iterator<Item = BufferTextureCopy>,
unsafe fn copy_buffer_to_texture<T>(
&mut self,
src: &<Self::A as Api>::Buffer,
dst: &<Self::A as Api>::Texture,
regions: T,
)where
T: Iterator<Item = BufferTextureCopy>,
Copy from buffer to texture.
Works with a single array layer.
Note: dst current usage has to be wgt::TextureUses::COPY_DST.
Note: the copy extent is in physical size (rounded to the block size)
Sourceunsafe fn copy_texture_to_buffer<T>(
&mut self,
src: &<Self::A as Api>::Texture,
src_usage: TextureUses,
dst: &<Self::A as Api>::Buffer,
regions: T,
)where
T: Iterator<Item = BufferTextureCopy>,
unsafe fn copy_texture_to_buffer<T>(
&mut self,
src: &<Self::A as Api>::Texture,
src_usage: TextureUses,
dst: &<Self::A as Api>::Buffer,
regions: T,
)where
T: Iterator<Item = BufferTextureCopy>,
Copy from texture to buffer. Works with a single array layer. Note: the copy extent is in physical size (rounded to the block size)
unsafe fn copy_acceleration_structure_to_acceleration_structure( &mut self, src: &<Self::A as Api>::AccelerationStructure, dst: &<Self::A as Api>::AccelerationStructure, copy: AccelerationStructureCopy, )
Sourceunsafe fn set_bind_group(
&mut self,
layout: &<Self::A as Api>::PipelineLayout,
index: u32,
group: &<Self::A as Api>::BindGroup,
dynamic_offsets: &[DynamicOffset],
)
unsafe fn set_bind_group( &mut self, layout: &<Self::A as Api>::PipelineLayout, index: u32, group: &<Self::A as Api>::BindGroup, dynamic_offsets: &[DynamicOffset], )
Sets the bind group at index to group.
If this is not the first call to set_bind_group within the current
render or compute pass:
-
If
layoutcontainsnbind group layouts, then any previously set bind groups at indicesnor higher are cleared. -
If the first
mbind group layouts oflayoutare equal to those of the previously passed layout, but no more, then any previously set bind groups at indicesmor higher are cleared.
It follows from the above that passing the same layout as before doesn’t clear any bind groups.
§Safety
-
This
CommandEncodermust be within a render or compute pass. -
indexmust be the valid index of some bind group layout inlayout. Call this the “relevant bind group layout”. -
The layout of
groupmust be equal to the relevant bind group layout. -
The length of
dynamic_offsetsmust match the number of buffer bindings with dynamic offsets in the relevant bind group layout. -
If those buffer bindings are ordered by increasing
bindingnumber and paired with elements fromdynamic_offsets, then each offset must be a valid offset for the binding’s corresponding buffer ingroup.
Sourceunsafe fn set_push_constants(
&mut self,
layout: &<Self::A as Api>::PipelineLayout,
stages: ShaderStages,
offset_bytes: u32,
data: &[u32],
)
unsafe fn set_push_constants( &mut self, layout: &<Self::A as Api>::PipelineLayout, stages: ShaderStages, offset_bytes: u32, data: &[u32], )
Sets a range in push constant data.
IMPORTANT: while the data is passed as words, the offset is in bytes!
§Safety
offset_bytesmust be a multiple of 4.- The range of push constants written must be valid for the pipeline layout at draw time.
unsafe fn insert_debug_marker(&mut self, label: &str)
unsafe fn begin_debug_marker(&mut self, group_label: &str)
unsafe fn end_debug_marker(&mut self)
Sourceunsafe fn begin_query(&mut self, set: &<Self::A as Api>::QuerySet, index: u32)
unsafe fn begin_query(&mut self, set: &<Self::A as Api>::QuerySet, index: u32)
§Safety:
- If
setis an occlusion query set, it must be the same one as used in theRenderPassDescriptor::occlusion_query_setparameter.
Sourceunsafe fn end_query(&mut self, set: &<Self::A as Api>::QuerySet, index: u32)
unsafe fn end_query(&mut self, set: &<Self::A as Api>::QuerySet, index: u32)
§Safety:
- If
setis an occlusion query set, it must be the same one as used in theRenderPassDescriptor::occlusion_query_setparameter.
unsafe fn write_timestamp( &mut self, set: &<Self::A as Api>::QuerySet, index: u32, )
unsafe fn reset_queries( &mut self, set: &<Self::A as Api>::QuerySet, range: Range<u32>, )
unsafe fn copy_query_results( &mut self, set: &<Self::A as Api>::QuerySet, range: Range<u32>, buffer: &<Self::A as Api>::Buffer, offset: BufferAddress, stride: BufferSize, )
Sourceunsafe fn begin_render_pass(
&mut self,
desc: &RenderPassDescriptor<'_, <Self::A as Api>::QuerySet, <Self::A as Api>::TextureView>,
) -> Result<(), DeviceError>
unsafe fn begin_render_pass( &mut self, desc: &RenderPassDescriptor<'_, <Self::A as Api>::QuerySet, <Self::A as Api>::TextureView>, ) -> Result<(), DeviceError>
Begin a new render pass, clearing all active bindings.
This clears any bindings established by the following calls:
set_bind_groupset_push_constantsbegin_queryset_render_pipelineset_index_bufferset_vertex_buffer
§Safety
-
All prior calls to
begin_render_passon thisCommandEncodermust have been followed by a call toend_render_pass. -
All prior calls to
begin_compute_passon thisCommandEncodermust have been followed by a call toend_compute_pass.
Sourceunsafe fn end_render_pass(&mut self)
unsafe fn end_render_pass(&mut self)
End the current render pass.
§Safety
- There must have been a prior call to
begin_render_passon thisCommandEncoderthat has not been followed by a call toend_render_pass.
unsafe fn set_render_pipeline( &mut self, pipeline: &<Self::A as Api>::RenderPipeline, )
unsafe fn set_index_buffer<'a>( &mut self, binding: BufferBinding<'a, <Self::A as Api>::Buffer>, format: IndexFormat, )
unsafe fn set_vertex_buffer<'a>( &mut self, index: u32, binding: BufferBinding<'a, <Self::A as Api>::Buffer>, )
unsafe fn set_viewport(&mut self, rect: &Rect<f32>, depth_range: Range<f32>)
unsafe fn set_scissor_rect(&mut self, rect: &Rect<u32>)
unsafe fn set_stencil_reference(&mut self, value: u32)
unsafe fn set_blend_constants(&mut self, color: &[f32; 4])
unsafe fn draw( &mut self, first_vertex: u32, vertex_count: u32, first_instance: u32, instance_count: u32, )
unsafe fn draw_indexed( &mut self, first_index: u32, index_count: u32, base_vertex: i32, first_instance: u32, instance_count: u32, )
unsafe fn draw_indirect( &mut self, buffer: &<Self::A as Api>::Buffer, offset: BufferAddress, draw_count: u32, )
unsafe fn draw_indexed_indirect( &mut self, buffer: &<Self::A as Api>::Buffer, offset: BufferAddress, draw_count: u32, )
unsafe fn draw_indirect_count( &mut self, buffer: &<Self::A as Api>::Buffer, offset: BufferAddress, count_buffer: &<Self::A as Api>::Buffer, count_offset: BufferAddress, max_count: u32, )
unsafe fn draw_indexed_indirect_count( &mut self, buffer: &<Self::A as Api>::Buffer, offset: BufferAddress, count_buffer: &<Self::A as Api>::Buffer, count_offset: BufferAddress, max_count: u32, )
unsafe fn draw_mesh_tasks( &mut self, group_count_x: u32, group_count_y: u32, group_count_z: u32, )
unsafe fn draw_mesh_tasks_indirect( &mut self, buffer: &<Self::A as Api>::Buffer, offset: BufferAddress, draw_count: u32, )
unsafe fn draw_mesh_tasks_indirect_count( &mut self, buffer: &<Self::A as Api>::Buffer, offset: BufferAddress, count_buffer: &<Self::A as Api>::Buffer, count_offset: BufferAddress, max_count: u32, )
Sourceunsafe fn begin_compute_pass(
&mut self,
desc: &ComputePassDescriptor<'_, <Self::A as Api>::QuerySet>,
)
unsafe fn begin_compute_pass( &mut self, desc: &ComputePassDescriptor<'_, <Self::A as Api>::QuerySet>, )
Begin a new compute pass, clearing all active bindings.
This clears any bindings established by the following calls:
§Safety
-
All prior calls to
begin_render_passon thisCommandEncodermust have been followed by a call toend_render_pass. -
All prior calls to
begin_compute_passon thisCommandEncodermust have been followed by a call toend_compute_pass.
Sourceunsafe fn end_compute_pass(&mut self)
unsafe fn end_compute_pass(&mut self)
End the current compute pass.
§Safety
- There must have been a prior call to
begin_compute_passon thisCommandEncoderthat has not been followed by a call toend_compute_pass.
unsafe fn set_compute_pipeline( &mut self, pipeline: &<Self::A as Api>::ComputePipeline, )
unsafe fn dispatch(&mut self, count: [u32; 3])
unsafe fn dispatch_indirect( &mut self, buffer: &<Self::A as Api>::Buffer, offset: BufferAddress, )
Sourceunsafe fn build_acceleration_structures<'a, T>(
&mut self,
descriptor_count: u32,
descriptors: T,
)where
Self::A: 'a,
T: IntoIterator<Item = BuildAccelerationStructureDescriptor<'a, <Self::A as Api>::Buffer, <Self::A as Api>::AccelerationStructure>>,
unsafe fn build_acceleration_structures<'a, T>(
&mut self,
descriptor_count: u32,
descriptors: T,
)where
Self::A: 'a,
T: IntoIterator<Item = BuildAccelerationStructureDescriptor<'a, <Self::A as Api>::Buffer, <Self::A as Api>::AccelerationStructure>>,
To get the required sizes for the buffer allocations use get_acceleration_structure_build_sizes per descriptor
All buffers must be synchronized externally
All buffer regions, which are written to may only be passed once per function call,
with the exception of updates in the same descriptor.
Consequences of this limitation:
- scratch buffers need to be unique
- a tlas can’t be build in the same call with a blas it contains
unsafe fn place_acceleration_structure_barrier( &mut self, barrier: AccelerationStructureBarrier, )
unsafe fn read_acceleration_structure_compact_size( &mut self, acceleration_structure: &<Self::A as Api>::AccelerationStructure, buf: &<Self::A as Api>::Buffer, )
Dyn Compatibility§
This trait is not dyn compatible.
In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.