pub struct ComputePipeline { /* private fields */ }
Expand description

A pipeline object that describes to the Vulkan implementation how it should perform compute operations.

The template parameter contains the descriptor set to use with this pipeline.

Pass an optional Arc to a PipelineCache to enable pipeline caching. The vulkan implementation will handle the PipelineCache and check if it is available. Check the documentation of the PipelineCache for more information.

Implementations§

source§

impl ComputePipeline

source

pub fn new<Css, F>( device: Arc<Device>, shader: EntryPoint<'_>, specialization_constants: &Css, cache: Option<Arc<PipelineCache>>, func: F ) -> Result<Arc<ComputePipeline>, ComputePipelineCreationError>where Css: SpecializationConstants, F: FnOnce(&mut [DescriptorSetLayoutCreateInfo]),

Builds a new ComputePipeline.

func is a closure that is given a mutable reference to the inferred descriptor set definitions. This can be used to make changes to the layout before it’s created, for example to add dynamic buffers or immutable samplers.

source

pub fn with_pipeline_layout<Css>( device: Arc<Device>, shader: EntryPoint<'_>, specialization_constants: &Css, layout: Arc<PipelineLayout>, cache: Option<Arc<PipelineCache>> ) -> Result<Arc<ComputePipeline>, ComputePipelineCreationError>where Css: SpecializationConstants,

Builds a new ComputePipeline with a specific pipeline layout.

An error will be returned if the pipeline layout isn’t a superset of what the shader uses.

source

pub unsafe fn with_unchecked_pipeline_layout<Css>( device: Arc<Device>, shader: EntryPoint<'_>, specialization_constants: &Css, layout: Arc<PipelineLayout>, cache: Option<Arc<PipelineCache>> ) -> Result<Arc<ComputePipeline>, ComputePipelineCreationError>where Css: SpecializationConstants,

Same as with_pipeline_layout, but doesn’t check whether the pipeline layout is a superset of what the shader expects.

source

pub fn device(&self) -> &Arc<Device>

Returns the Device this compute pipeline was created with.

Trait Implementations§

source§

impl Debug for ComputePipeline

source§

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

Formats the value using the given formatter. Read more
source§

impl DeviceOwned for ComputePipeline

source§

fn device(&self) -> &Arc<Device>

Returns the device that owns Self.
source§

impl Drop for ComputePipeline

source§

fn drop(&mut self)

Executes the destructor for this type. Read more
source§

impl Hash for ComputePipeline

source§

fn hash<H: Hasher>(&self, state: &mut H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl PartialEq<ComputePipeline> for ComputePipeline

source§

fn eq(&self, other: &Self) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Pipeline for ComputePipeline

source§

fn bind_point(&self) -> PipelineBindPoint

Returns the bind point of this pipeline.
source§

fn layout(&self) -> &Arc<PipelineLayout>

Returns the pipeline layout used in this pipeline.
source§

fn num_used_descriptor_sets(&self) -> u32

Returns the number of descriptor sets actually accessed by this pipeline. This may be less than the number of sets in the pipeline layout.
source§

fn descriptor_binding_requirements( &self ) -> &HashMap<(u32, u32), DescriptorBindingRequirements>

Returns a reference to the descriptor binding requirements for this pipeline.
source§

impl VulkanObject for ComputePipeline

§

type Handle = Pipeline

The type of the object.
source§

fn handle(&self) -> Self::Handle

Returns the raw Vulkan handle of the object.
source§

impl Eq for ComputePipeline

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

const: unstable · source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

const: unstable · 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 Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
const: unstable · source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.