diff --git a/docs/maintainer/knowledge_base.md b/docs/maintainer/knowledge_base.md index 94990147a6..ac64429312 100644 --- a/docs/maintainer/knowledge_base.md +++ b/docs/maintainer/knowledge_base.md @@ -2006,56 +2006,9 @@ if you're using a `c_stdlib_version` of `2.28`, set it to `alma8`. ## CUDA builds Although the provisioned CI machines do not feature a GPU, conda-forge does provide mechanisms -to build CUDA-enabled packages. These mechanisms involve several packages: - -- `cudatoolkit`: The runtime libraries for the CUDA toolkit. This is what end-users will end - up installing next to your package. -- `nvcc`: Nvidia's EULA does not allow the redistribution of compilers and drivers. Instead, we - provide a wrapper package that locates the CUDA installation in the system. The main role of this - package is to set some environment variables (`CUDA_HOME`, `CUDA_PATH`, `CFLAGS` and others), - as well as wrapping the real `nvcc` executable to set some extra command line arguments. - -In practice, to enable CUDA on your package, add `{{ compiler('cuda') }}` to the `build` -section of your requirements and rerender. The matching `cudatoolkit` will be added to the `run` -requirements automatically. - -On Linux, CMake users are required to use `${CMAKE_ARGS}` so CMake can find CUDA correctly. For example: - -```shell-session -mkdir build && cd build -cmake ${CMAKE_ARGS} ${SRC_DIR} -make -``` - -:::note - -**How is CUDA provided at the system level?** - -- On Linux, Nvidia provides official Docker images, which we then - [adapt](https://github.com/conda-forge/docker-images) to conda-forge's needs. -- On Windows, the compilers need to be installed for every CI run. This is done through the - [conda-forge-ci-setup](https://github.com/conda-forge/conda-forge-ci-setup-feedstock/) scripts. - Do note that the Nvidia executable won't install the drivers because no GPU is present in the machine. - -**How is cudatoolkit selected at install time?** - -Conda exposes the maximum CUDA version supported by the installed Nvidia drivers through a virtual package -named `__cuda`. By default, `conda` will install the highest version available -for the packages involved. To override this behaviour, you can define a `CONDA_OVERRIDE_CUDA` environment -variable. More details in the -[Conda docs](https://docs.conda.io/projects/conda/en/stable/user-guide/tasks/manage-virtual.html#overriding-detected-packages). - -Note that prior to v4.8.4, `__cuda` versions would not be part of the constraints, so you would always -get the latest one, regardless the supported CUDA version. - -If for some reason you want to install a specific version, you can use: - -```default -conda install your-gpu-package cudatoolkit=10.1 -``` - -::: - +to build CUDA-enabled packages. +See the [guide for maintainers of recipes that use CUDA](https://github.com/conda-forge/cuda-feedstock/blob/main/recipe/doc/recipe_guide.md) +for more information. If a feedstock does need access to additional resource (like GPUs), please see the following section (#packages-that-require-a-gpu-or-long-running-builds) @@ -2120,34 +2073,6 @@ burden on our CI resources. Only proceed if there's a known use case for the ext 2. In your feedstock fork, create a new branch and place the migration file under `.ci_support/migrations`. 3. Open a PR and re-render. CUDA 9.2, 10.0 and 10.1 will appear in the CI checks now. Merge when ready! - - -### Adding support for a new CUDA version - -Providing a new CUDA version involves five repositores: - -- [cudatoolkit-feedstock](https://github.com/conda-forge/cudatoolkit-feedstock) -- [nvcc-feedstock](https://github.com/conda-forge/nvcc-feedstock) -- [conda-forge-pinning-feedstock](https://github.com/conda-forge/conda-forge-pinning-feedstock) -- [docker-images](https://github.com/conda-forge/docker-images) (Linux only) -- [conda-forge-ci-setup-feedstock](https://github.com/conda-forge/conda-forge-ci-setup-feedstock) (Windows only) - -The steps involved are, roughly: - -1. Add the `cudatoolkit` packages in `cudatoolkit-feedstock`. -2. Submit the version migrator to `conda-forge-pinning-feedstock`. - This will stay open during the following steps. -3. For Linux, add the corresponding Docker images at `docker-images`. - Copy the migration file manually to `.ci_support/migrations`. - This copy should not specify a timestamp. Comment it out and rerender. -4. For Windows, add the installer URLs and hashes to the `conda-forge-ci-setup` - [script](https://github.com/conda-forge/conda-forge-ci-setup-feedstock/blob/master/recipe/install_cuda.bat). - The migration file must also be manually copied here. Rerender. -5. Create the new `nvcc` packages for the new version. Again, manual - migration must be added. Rerender. -6. When everything else has been merged and testing has taken place, - consider merging the PR opened at step 2 now so it can apply to all the downstream feedstocks. -