pub struct MutexComputeChannel<Server> { /* private fields */ }
Expand description
The MutexComputeChannel ensures thread-safety by locking the server on every operation
Implementations§
Source§impl<Server> MutexComputeChannel<Server>where
Server: ComputeServer,
impl<Server> MutexComputeChannel<Server>where
Server: ComputeServer,
Sourcepub fn new(server: Server) -> MutexComputeChannel<Server>
pub fn new(server: Server) -> MutexComputeChannel<Server>
Create a new mutex compute channel.
Trait Implementations§
Source§impl<S> Clone for MutexComputeChannel<S>
impl<S> Clone for MutexComputeChannel<S>
Source§fn clone(&self) -> MutexComputeChannel<S>
fn clone(&self) -> MutexComputeChannel<S>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreSource§impl<Server> ComputeChannel<Server> for MutexComputeChannel<Server>where
Server: ComputeServer,
impl<Server> ComputeChannel<Server> for MutexComputeChannel<Server>where
Server: ComputeServer,
Source§async fn read(&self, bindings: Vec<Binding>) -> Vec<Vec<u8>>
async fn read(&self, bindings: Vec<Binding>) -> Vec<Vec<u8>>
Given bindings, returns owned resources as bytes
Source§async fn read_tensor(&self, bindings: Vec<BindingWithMeta>) -> Vec<Vec<u8>>
async fn read_tensor(&self, bindings: Vec<BindingWithMeta>) -> Vec<Vec<u8>>
Given bindings, returns owned resources as bytes
Source§fn get_resource(
&self,
binding: Binding,
) -> BindingResource<<<Server as ComputeServer>::Storage as ComputeStorage>::Resource>
fn get_resource( &self, binding: Binding, ) -> BindingResource<<<Server as ComputeServer>::Storage as ComputeStorage>::Resource>
Given a resource handle, return the storage resource.
Source§fn create(&self, data: &[u8]) -> Handle
fn create(&self, data: &[u8]) -> Handle
Given a resource as bytes, stores it and returns the resource handle
Source§fn create_tensor(
&self,
data: &[u8],
shape: &[usize],
elem_size: usize,
) -> (Handle, Vec<usize>)
fn create_tensor( &self, data: &[u8], shape: &[usize], elem_size: usize, ) -> (Handle, Vec<usize>)
Given a resource as bytes and a shape, stores it and returns the tensor handle
Source§fn empty(&self, size: usize) -> Handle
fn empty(&self, size: usize) -> Handle
Reserves
size
bytes in the storage, and returns a handle over themSource§fn empty_tensor(
&self,
shape: &[usize],
elem_size: usize,
) -> (Handle, Vec<usize>)
fn empty_tensor( &self, shape: &[usize], elem_size: usize, ) -> (Handle, Vec<usize>)
Reserves a tensor with
shape
in the storage, and returns a handle to itSource§unsafe fn execute(
&self,
kernel: <Server as ComputeServer>::Kernel,
count: CubeCount,
handles: Bindings,
kind: ExecutionMode,
)
unsafe fn execute( &self, kernel: <Server as ComputeServer>::Kernel, count: CubeCount, handles: Bindings, kind: ExecutionMode, )
Source§fn memory_usage(&self) -> MemoryUsage
fn memory_usage(&self) -> MemoryUsage
Get the current memory usage of the server.
Source§fn memory_cleanup(&self)
fn memory_cleanup(&self)
Ask the server to release memory that it can release.
Source§fn start_profile(&self)
fn start_profile(&self)
Start a profile on the server. This allows you to profile kernels. Read more
Source§fn end_profile(&self) -> ProfileDuration
fn end_profile(&self) -> ProfileDuration
End the profile and return a
ProfileDuration
. Read moreAuto Trait Implementations§
impl<Server> Freeze for MutexComputeChannel<Server>
impl<Server> !RefUnwindSafe for MutexComputeChannel<Server>
impl<Server> Send for MutexComputeChannel<Server>where
Server: Send,
impl<Server> Sync for MutexComputeChannel<Server>where
Server: Send,
impl<Server> Unpin for MutexComputeChannel<Server>
impl<Server> !UnwindSafe for MutexComputeChannel<Server>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more