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§fn read(
&self,
bindings: Vec<Binding>,
) -> Pin<Box<dyn Future<Output = Vec<Vec<u8>>> + Send>>
fn read( &self, bindings: Vec<Binding>, ) -> Pin<Box<dyn Future<Output = Vec<Vec<u8>>> + Send>>
Given bindings, returns owned resources as bytes
Source§fn read_tensor(
&self,
bindings: Vec<BindingWithMeta>,
) -> Pin<Box<dyn Future<Output = Vec<Vec<u8>>> + Send>>
fn read_tensor( &self, bindings: Vec<BindingWithMeta>, ) -> Pin<Box<dyn Future<Output = Vec<Vec<u8>>> + Send>>
Given bindings, returns owned resources as bytes
Source§fn sync(&self) -> Pin<Box<dyn Future<Output = ()> + Send>>
fn sync(&self) -> Pin<Box<dyn Future<Output = ()> + Send>>
Wait for the completion of every task in the server.
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_tensors(
&self,
data: Vec<&[u8]>,
shape: Vec<&[usize]>,
elem_size: Vec<usize>,
) -> Vec<(Handle, Vec<usize>)>
fn create_tensors( &self, data: Vec<&[u8]>, shape: Vec<&[usize]>, elem_size: Vec<usize>, ) -> Vec<(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_tensors(
&self,
shape: Vec<&[usize]>,
elem_size: Vec<usize>,
) -> Vec<(Handle, Vec<usize>)>
fn empty_tensors( &self, shape: Vec<&[usize]>, elem_size: Vec<usize>, ) -> Vec<(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,
logger: Arc<ServerLogger>,
)
unsafe fn execute( &self, kernel: <Server as ComputeServer>::Kernel, count: CubeCount, handles: Bindings, kind: ExecutionMode, logger: Arc<ServerLogger>, )
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) -> ProfilingToken
fn start_profile(&self) -> ProfilingToken
Start a profile on the server. This allows you to profile kernels. Read more
Source§fn end_profile(
&self,
token: ProfilingToken,
) -> Result<ProfileDuration, ProfileError>
fn end_profile( &self, token: ProfilingToken, ) -> Result<ProfileDuration, ProfileError>
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