Arrayjit.Backend_impl
Implementation-facing types and components.
module Lazy = Utils.Lazy
module type No_device_buffer_and_copying = sig ... end
module No_device_buffer_and_copying
() :
No_device_buffer_and_copying with type buffer_ptr = Base.unit Ctypes.ptr
module Device_types (Device_config : Backend_intf.Device_config) : sig ... end
val next_global_device_id : Utils.atomic_int
module Device
(Device_types : Backend_intf.Device_types)
(Alloc_buffer :
Backend_intf.Alloc_buffer
with type buffer_ptr := Device_types.buffer_ptr
and type stream := Device_types.stream) :
sig ... end
module type Backend_impl_common = sig ... end
Parts shared by backend implementations excluding what's already in Backend_any_common
, except for Buffer
which is duplicated for technical reasons.
module type For_add_scheduler = sig ... end
An interface to adding schedulers for stream-agnostic (typically CPU) backend implementations.
module type Lowered_no_device_backend = sig ... end
Lowered-level stream agnostic backend interface: implementation-facing API for CPU backends.
module type No_buffer_retrieval_or_syncing = sig ... end
module type With_scheduler = sig ... end
An intermediate stage for converting Lowered_no_device_backend
backends into Lowered_backend
.
module type Lowered_backend = sig ... end
Lowered-level backend interface: implementation-facing API for device-based (GPU, or CPU after adding a scheduler) backends.
module Alloc_buffer_ignore_stream
(Device_types : Backend_intf.Device_types)
(Backend :
Backend_intf.Alloc_buffer
with type buffer_ptr = Device_types.buffer_ptr
and type stream := Base.unit) :
Backend_intf.Alloc_buffer
with type buffer_ptr = Backend.buffer_ptr
and type stream = Device_types.stream