Module Arrayjit.Backend_impl

The components for use in backend implementations

Implementation-facing types and components.

module Lazy = Utils.Lazy
val _get_local_debug_runtime : unit -> (module Minidebug_runtime.Debug_runtime)
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
val next_global_device_id : Utils.atomic_int
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.