hipSYCL relies on the fact that many existing programming models as well as and SYCL are single-source programming models based on C++. This means that it is possible to extend existing toolchains, such as CUDA and HIP toolchains, to also support SYCL code. hipSYCL does that by using clang's CUDA and HIP toolchains with a custom clang plugin. Additionally, hipSYCL can utilize the clang SYCL frontend to generate SPIR-V code. hipSYCL contains mechanisms to embed and aggregate compilation results from multiple toolchains into a single binary, allowing it to effectively combine multiple toolchains into one. This is illustrated here:
hipSYCL distinguishes two modes of compilation:
- integrated multipass, where host and device compilation passes are handled by clang's CUDA and HIP drivers. This mode allows for the most interoperability with backends because backend-specific language extensions are also available in the host pass. For example, kernels can be launched using the
<<<>>>
syntax. However, limitations in clang's compilation drivers also affect hipSYCL in this mode. In particular, CUDA and HIP cannot be targeted simultaneously because host code cannot support language extensions from both at the same time. - explicit multipass, where host and device compilation passes are handled by hipSYCL's
syclcc
compiler driver. Here,syclcc
invokes backend-specific device passes, which then result in a compiled kernel image for the target device.syclcc
then embeds the compiled kernel image into the host binary. At runtime, the kernel is extracted from the image and invoked using runtime functions instead of language extensions. As a consequence, explicit multipass compilation for one backend can be combined with arbitrary other backends simultaneously, allowing hipSYCL to target multiple device backends at the same time. Note that in explicit multipass, different guarantees might be made regarding the availability of backend-specific language extensions in the host pass compared to integrated multipass. See the section on language extension guarantees below for more details.
Not all backends support all modes. The following compilation flows are currently supported, and can be requested as backend targets in syclcc
. Note that some are available in both explicit multipass and integrated multipass flavor:
Compilation flow | Target hardware | Integrated/explicit multipass? | Short description |
---|---|---|---|
omp.library-only |
Any CPU | (no multipass compilation) | CPU backend (OpenMP library) |
omp.accelerated |
Any CPU supported by LLVM | (no multipass compilation) | CPU backend (OpenMP library with additional clang acceleration) |
cuda.integrated-multipass |
NVIDIA GPUs | Integrated | CUDA backend |
cuda.explicit-multipass |
NVIDIA GPUs | Explicit | CUDA backend |
cuda-nvcxx |
NVIDIA GPUs | Integrated (single-pass host/device compiler) | CUDA backend using nvc++ |
hip.integrated-multipass |
AMD GPUs (supported by ROCm) | Integrated | HIP backend |
hip.explicit-multipass |
AMD GPUs (supported by ROCm) | Explicit | HIP backend |
spirv |
Intel GPUs | Explicit | SPIR-V/Level Zero backend |
Note: Explicit multipass requires building hipSYCL against a clang that supports __builtin_unique_stable_name()
(available in clang 11), or clang 13 or newer as described in the installation documentation. hip.explicit-multipass
requires clang 13 or newer.
hipSYCL allows using backend-specific language extensions (e.g. CUDA/HIP C++). The precise guarantees about the availability of these extensions are as follows:
- If a backend runs on a compiler that provides a unified, single compilation pass for both host and device, backend-specific language extensions are always available. Currently this only affects the CUDA-nvc++ backend.
- If the compiler relies on separate compilation passes for host and device:
- In device compilation passes, backend-specific language extensions are always available.
- In host compilation passes, the following applies:
- If the backend runs in integrated multipass mode, backend-specific language extensions are available.
- If the backend runs in explicit multipass mode:
- For SPIR-V, language extensions are always available
- For CUDA and HIP: Language extensions from one of them are available in the host pass.
- If one of them runs in integrated multipass and one in explicit multipass, language extensions from the one in integrated multipass are available
- If both are in explicit multipass,
syclcc
will currently automatically pick one that will have language extensions enabled in the host pass.
The nd_range parallel_for
paradigm is not efficiently implementable without explicit compiler support.
hipSYCL however provides multiple options to circumvent this.
- The recommended and library-only solution is writing kernels using a performance portable paradigm as hipSYCL's scoped parallelism extension.
- If that is not an option (e.g. due to preexisting code), hipSYCL provides a compiler extension that allows efficient execution of the nd_range paradigm at the cost of forcing the host compiler to Clang.
- Without the Clang plugin, a fiber-based implementation of the
nd_range
paradigm will be used. However, the relative cost of a barrier in this paradigm is significantly higher compared to e.g. GPU backends. This means that kernels relying on barriers may experience substantial performance degradation, especially if the ratio between barriers and other instructions was tuned for GPUs. Additionally, utilizing barriers in this scenario may prevent vectorization across work items.
For the compiler extension variant, the hipSYCL Clang plugin implements a set of passes to perform deep loop fission on nd_range parallel_for kernels that contain barriers. The continuation-based synchronization approach is employed to achieve good performance and functional correctness (Karrenberg, Ralf, and Sebastian Hack. "Improving performance of OpenCL on CPUs." International Conference on Compiler Construction. Springer, Berlin, Heidelberg, 2012. https://link.springer.com/content/pdf/10.1007/978-3-642-28652-0_1.pdf). A deep dive into how the implementation works and why this approach was chosen can be found in Joachim Meyer's master thesis.
For more details, see the installation instructions and the documentation using hipSYCL.
hipSYCL relies on the hipSYCL container format (HCF) whenever it takes control over the embedding process of device code (e.g. explicit multipass scenarios).