Skip to main content

Stream

Struct Stream 

Source
pub struct Stream { /* private fields */ }
Expand description

A CUDA stream (GPU command queue).

Streams provide ordered, asynchronous execution of GPU commands. Commands enqueued on the same stream execute sequentially, while commands on different streams may execute concurrently.

The stream holds an Arc<Context> to ensure the parent context outlives the stream.

Implementations§

Source§

impl Stream

Source

pub fn new(ctx: &Arc<Context>) -> CudaResult<Self>

Creates a new stream with CU_STREAM_NON_BLOCKING flag.

Non-blocking streams do not implicitly synchronise with the default (NULL) stream, allowing maximum concurrency.

§Errors

Returns a CudaError if the driver call fails (e.g. invalid context, out of resources).

Source

pub fn with_priority(ctx: &Arc<Context>, priority: i32) -> CudaResult<Self>

Creates a new stream with the specified priority and CU_STREAM_NON_BLOCKING flag.

Lower numerical values indicate higher priority. The valid range can be queried via cuCtxGetStreamPriorityRange.

§Errors

Returns a CudaError if the priority is out of range or the driver call otherwise fails.

Source

pub fn synchronize(&self) -> CudaResult<()>

Blocks the calling thread until all previously enqueued commands in this stream have completed.

§Errors

Returns a CudaError if any enqueued operation failed or the driver reports an error.

Source

pub fn wait_event(&self, event: &Event) -> CudaResult<()>

Makes all future work submitted to this stream wait until the given event has been recorded and completed.

This is the primary mechanism for inter-stream synchronisation: record an Event on one stream, then call wait_event on another stream to establish an ordering dependency.

§Errors

Returns a CudaError if the driver call fails (e.g. invalid event handle).

Source

pub fn raw(&self) -> CUstream

Returns the raw CUstream handle.

§Safety (caller)

The caller must not destroy or otherwise invalidate the handle while this Stream is still alive.

Source

pub fn context(&self) -> &Arc<Context>

Returns a reference to the parent Context.

Trait Implementations§

Source§

impl Drop for Stream

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl Send for Stream

Auto Trait Implementations§

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

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more