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( device: Arc<Device>, cache: Option<Arc<PipelineCache>>, create_info: ComputePipelineCreateInfo ) -> Result<Arc<ComputePipeline>, Validated<VulkanError>>

Creates a new ComputePipeline.

source

pub unsafe fn from_handle( device: Arc<Device>, handle: Pipeline, create_info: ComputePipelineCreateInfo ) -> Arc<ComputePipeline>

Creates a new ComputePipeline from a raw object handle.

Safety
  • handle must be a valid Vulkan object handle created from device.
  • create_info must match the info used to create the object.
source

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

Returns the Device that the pipeline was created with.

source

pub fn flags(&self) -> PipelineCreateFlags

Returns the flags that the pipeline was created with.

Trait Implementations§

source§

impl Debug for ComputePipeline

source§

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

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 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,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> DeviceOwnedVulkanObject for Twhere T: DeviceOwned + VulkanObject,

source§

fn set_debug_utils_object_name( &self, object_name: Option<&str> ) -> Result<(), VulkanError>

Assigns a human-readable name to the object for debugging purposes. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere 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 Twhere U: Into<T>,

§

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 Twhere U: TryFrom<T>,

§

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.