| # Liboffload |
| |
| This directory contains the implementation of the work-in-progress new API for |
| Offload. It builds on top of the existing plugin implementations but provides a |
| single level of abstraction suitable for implementation of many offloading |
| language runtimes, rather than just OpenMP. |
| |
| ## Testing liboffload |
| |
| The main test suite for liboffload can be run with the `check-offload-unit` |
| target, which runs the `offload.unittests` executable. The test suite will |
| automatically run on every available device, but can be restricted to a single |
| platform (CUDA, AMDGPU) with a command line argument: |
| |
| ```sh |
| $ ./offload.unittests --platform=CUDA |
| ``` |
| |
| Tracing of Offload API calls can be enabled by setting the `OFFLOAD_TRACE` |
| environment variable. This works with any program that uses liboffload. |
| |
| ```sh |
| $ OFFLOAD_TRACE=1 ./offload.unittests |
| ---> olInit()-> OL_SUCCESS |
| # etc |
| ``` |
| |
| The host plugin is not currently supported. |
| |
| ## Modifying liboffload |
| |
| The main header (`OffloadAPI.h`) and some implementation details are |
| autogenerated with tablegen. See the [API definition README](API/README.md) |
| for implementation details. |