The Julia CUDA stack requires users to have a functional NVIDIA driver and corresponding CUDA toolkit. The former should be installed by you or your system administrator, while the latter can be automatically downloaded by Julia using the artifact subsystem.
For most users, installing the latest tagged version of CUDA.jl will be sufficient. You can easily do that using the package manager:
pkg> add CUDA
Or, equivalently, via the
julia> import Pkg; Pkg.add("CUDA")
In some cases, you might need to use the
master version of this package, e.g., because it includes a specific fix you need. Often, however, the development version of this package itself relies on unreleased versions of other packages. This information is recorded in the manifest at the root of the repository, which you can use by starting Julia from the CUDA.jl directory with the
$ cd .julia/dev/CUDA.jl # or wherever you have CUDA.jl checked out $ julia --project pkg> instantiate # to install correct dependencies julia> using CUDA
In the case you want to use the development version of CUDA.jl with other packages, you cannot use the manifest and you need to manually install those dependencies from the master branch. Again, the exact requirements are recorded in CUDA.jl's manifest, but often the following instructions will work:
pkg> add GPUCompiler#master pkg> add GPUArrays#master pkg> add LLVM#master
All three major operation systems are supported: Linux, Windows and macOS. However, that support is subject to NVIDIA providing a CUDA toolkit for your system, subsequently macOS support might be deprecated soon.
Similarly, we support x86, ARM, PPC, ... as long as Julia is supported on it and there exists an NVIDIA driver and CUDA toolkit for your platform. The main development platform (and the only CI system) however is x86_64 on Linux, so if you are using a more exotic combination there might be bugs.
To use the Julia GPU stack, you need to install the NVIDIA driver for your system and GPU. You can find detailed instructions on the NVIDIA home page.
If you're using Linux you should always consider installing the driver through the package manager of your distribution. In the case that driver is out of date or does not support your GPU, and you need to download a driver from the NVIDIA home page, similarly prefer a distribution-specific package (e.g., deb, rpm) instead of the generic runfile option.
If you are using a shared system, ask your system administrator on how to install or load the NVIDIA driver. Generally, you should be able to find and use the CUDA driver library, called
libcuda.so on Linux,
libcuda.dylib on macOS and
nvcuda64.dll on Windows. You should also be able to execute the
nvidia-smi command, which lists all available GPUs you have access to.
Finally, to be able to use all of the Julia GPU stack you need to have permission to profile GPU code. On Linux, that means loading the
nvidia kernel module with the
NVreg_RestrictProfilingToAdminUsers=0 option configured (e.g., in
/etc/modprobe.d). Refer to the following document for more information.
There are two different options to provide CUDA: either you install it yourself in a way that is discoverable by the Julia CUDA packages, or you let the packages download CUDA from artifacts. If you can use artifacts (i.e., you are not using an unsupported platform or have no specific requirements), it is recommended to do so: The CUDA toolkit is tightly coupled to the NVIDIA driver, and compatibility is automatically taken into account when selecting an artifact to use.
Use of artifacts is the default option: Importing CUDA.jl will automatically download CUDA upon first use of the API. You can inspect details about the process by enabling debug logging:
$ JULIA_DEBUG=CUDA julia julia> using CUDA julia> CUDA.version() ┌ Debug: Trying to use artifacts... └ @ CUDA CUDA/src/bindeps.jl:52 ┌ Debug: Using CUDA 10.2.89 from an artifact at /home/tim/Julia/depot/artifacts/93956fcdec9ac5ea76289d25066f02c2f4ebe56e └ @ CUDA CUDA/src/bindeps.jl:108 v"10.2.89"
If artifacts are unavailable for your platform, the Julia CUDA packages will look for a local CUDA installation:
julia> CUDA.version() ┌ Debug: Trying to use artifacts... └ @ CUDA CUDA/src/bindeps.jl:52 ┌ Debug: Could not find a compatible artifact. └ @ CUDA CUDA/src/bindeps.jl:73 ┌ Debug: Trying to use local installation... └ @ CUDA CUDA/src/bindeps.jl:114 ┌ Debug: Found local CUDA 10.0.326 at /usr/local/cuda-10.0/targets/aarch64-linux, /usr/local/cuda-10.0 └ @ CUDA CUDA/src/bindeps.jl:141 v"10.0.326"
You might want to disallow use of artifacts, e.g., because an optimized CUDA installation is available for your system. You can do so by setting the environment variable
false when importing CUDA.jl.
To troubleshoot discovery of a local CUDA installation, you can set
JULIA_DEBUG=CUDA and see the various paths where CUDA.jl looks. By setting any of the
CUDA_PATH environment variables, you can guide the package to a specific directory.
CUDA.jl is container friendly: You can install, precompile, and even import the package on a system without a GPU, as is often the case when building an image:
$ docker run --rm -it julia (@v1.5) pkg> add CUDA (@v1.5) pkg> precompile Precompiling project... [ Info: Precompiling CUDA [052768ef-5323-5732-b1bb-66c8b64840ba] (@v1.5) pkg>
At run time you obviously do need a CUDA-compatible GPU as well as the CUDA driver library to interface with it. Typically, that library is imported from the host system, e.g., by launching
docker using the
--gpus=all flag. Because of how the NVIDIA container runtime works, you also need to define the
NVIDIA_DRIVER_CAPABILITIES environment variables to configure which parts of the host driver are made available:
$ docker run --rm -it --runtime=nvidia -e NVIDIA_VISIBLE_DEVICES=all -e NVIDIA_DRIVER_CAPABILITIES=compute,utility julia julia> using CUDA julia> CUDA.version() Downloading artifact: CUDA110 v"11.0.0"
Note that your image needs to provide
libgomp, e.g. by executing
apt install libgomp1.
If you want to use an image that already provide the CUDA toolkit, you can set the
JULIA_CUDA_USE_BINARYBUILDER environment variable to
false as documented above. For example, you could use NVIDIA's official CUDA images (which also do not require you to define the
NVIDIA_DRIVER_CAPABILITIES). Of course, these images do not come with Julia pre-installed.
Combining both, the Julia NGC images come with both Julia and the CUDA toolkit pre-installed, together with the CUDA.jl package for maximum ease-of-use:
$ docker run --rm -it --gpus=all nvcr.io/hpc/julia:v1.2.0 julia> using CUDA
Note that the current version of this image is woefully outdated, but you can find the updated source on GitHub.