Skip to content

Latest commit

 

History

History
9 lines (5 loc) · 1.34 KB

README.md

File metadata and controls

9 lines (5 loc) · 1.34 KB

PJRT Plugins

A PJRT plugin provides the compiler and hardware device support required to execute spidr graphs. We provide plugins for CPU and CUDA-enabled GPUs. You can also use third-party plugins, or make your own.

How to integrate your own plugin

Third-party vendors have written a number of PJRT plugins that we haven't integrated into spidr, such as for ROCm-enabled AMD GPUs, and TPUs. When we say "PJRT plugin", we mean both the third-party libraries and their Idris wrappers, but try to make it clear from the context which we mean. The third-party plugins all share a common API, written in C, and it requires relatively little code to integrate these into spidr. If you would like any assistance with plugin development, please contact us.

To integrate a plugin, have a read of the CPU and CUDA implementations. Ultimately, you need to implement an Idris Device. A Device is made of a PjrtApi and a PjrtClient. A PjrtApi is a thin wrapper round a pointer to a PJRT_Api C struct, which should be available in the plugin C API. To call this API, you will need to compile the plugin as a shared library and make it available to Idris. You can create a PjrtClient with pjrtClientCreate.