CUDA Minor Version Compatibility
CUDA Minor Version Compatibility (MVC) enables the use of a newer CUDA Toolkit version than the CUDA version supported by the driver, provided that the Toolkit and driver both have the same major version. For example, use of CUDA Toolkit 11.5 with CUDA driver 450 (CUDA version 11.0) is supported through MVC.
Numba supports MVC for CUDA 12 on Linux using the external pynvjitlink
package.
Numba supports MVC for CUDA 11 on Linux using the external cubinlinker
and
ptxcompiler
packages, subject to the following limitations:
Linking of archives is unsupported.
Cooperative Groups are unsupported, because they require an archive to be linked.
MVC is not supported on Windows.
Installation
CUDA 12
To use MVC support, the pynvjitlink
package must be installed. To install
using conda, use:
conda install -c rapidsai pynvjitlink
To install with pip, use the NVIDIA package index:
pip install --extra-index-url https://pypi.nvidia.com pynvjitlink-cu12
CUDA 11
To use MVC support, the cubinlinker
and ptxcompiler
compiler packages
must be installed from the appropriate channels. To install using conda, use:
conda install -c rapidsai -c conda-forge cubinlinker ptxcompiler
To install with pip, use the NVIDIA package index:
pip install --extra-index-url https://pypi.nvidia.com ptxcompiler-cu11 cubinlinker-cu11
Enabling MVC Support
MVC support is enabled by setting the environment variable:
export NUMBA_CUDA_ENABLE_MINOR_VERSION_COMPATIBILITY=1 # CUDA 11
export NUMBA_CUDA_ENABLE_PYNVJITLINK=1 # CUDA 12
or by setting a configuration variable prior to using any CUDA functionality in Numba:
from numba import config
config.CUDA_ENABLE_MINOR_VERSION_COMPATIBILITY = True # CUDA 11
config.CUDA_ENABLE_PYNVJITLINK = True # CUDA 12
References
Further information about Minor Version Compatibility may be found in: