2023-01-21 10:41:28 +00:00
|
|
|
{
|
|
|
|
lib,
|
|
|
|
buildPythonPackage,
|
2024-07-03 18:33:52 +00:00
|
|
|
fetchFromGitHub,
|
|
|
|
cython_0,
|
2023-01-21 10:41:28 +00:00
|
|
|
fastrlock,
|
|
|
|
numpy,
|
|
|
|
wheel,
|
|
|
|
pytestCheckHook,
|
|
|
|
mock,
|
|
|
|
setuptools,
|
2022-04-03 09:19:04 +00:00
|
|
|
cudaPackages,
|
2023-12-18 18:34:35 +00:00
|
|
|
addDriverRunpath,
|
2023-01-21 10:43:33 +00:00
|
|
|
pythonOlder,
|
2023-11-27 17:36:57 +00:00
|
|
|
symlinkJoin,
|
2024-07-03 18:33:52 +00:00
|
|
|
fetchpatch
|
2017-12-28 16:42:53 +00:00
|
|
|
}:
|
|
|
|
|
2022-04-03 09:19:04 +00:00
|
|
|
let
|
2023-11-27 17:36:57 +00:00
|
|
|
inherit (cudaPackages) cudnn cutensor nccl;
|
2024-07-09 19:24:38 +00:00
|
|
|
outpaths = with cudaPackages; [
|
2023-11-27 17:36:57 +00:00
|
|
|
cuda_cccl # <nv/target>
|
|
|
|
cuda_cudart
|
2024-06-28 01:09:23 +00:00
|
|
|
cuda_nvcc # <crt/host_defines.h>
|
2023-11-27 17:36:57 +00:00
|
|
|
cuda_nvprof
|
|
|
|
cuda_nvrtc
|
|
|
|
cuda_nvtx
|
|
|
|
cuda_profiler_api
|
|
|
|
libcublas
|
|
|
|
libcufft
|
|
|
|
libcurand
|
|
|
|
libcusolver
|
|
|
|
libcusparse
|
|
|
|
|
|
|
|
# Missing:
|
|
|
|
# cusparselt
|
2024-07-09 19:24:38 +00:00
|
|
|
];
|
|
|
|
cudatoolkit-joined = symlinkJoin {
|
|
|
|
name = "cudatoolkit-joined-${cudaPackages.cudaVersion}";
|
|
|
|
paths = outpaths ++ lib.concatMap (f: lib.map f outpaths) [lib.getLib lib.getDev (lib.getOutput "static") (lib.getOutput "stubs")];
|
2023-11-27 17:36:57 +00:00
|
|
|
};
|
|
|
|
in
|
|
|
|
buildPythonPackage rec {
|
2017-12-28 16:42:53 +00:00
|
|
|
pname = "cupy";
|
2024-09-29 15:04:07 +00:00
|
|
|
version = "13.3.0";
|
2023-12-07 03:53:02 +00:00
|
|
|
format = "setuptools";
|
2023-01-22 12:48:18 +00:00
|
|
|
|
2023-01-21 10:43:33 +00:00
|
|
|
disabled = pythonOlder "3.7";
|
2017-12-28 16:42:53 +00:00
|
|
|
|
2024-07-03 18:33:52 +00:00
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "cupy";
|
|
|
|
repo = "cupy";
|
2024-09-29 15:04:07 +00:00
|
|
|
rev = "refs/tags/v${version}";
|
|
|
|
hash = "sha256-eQZwOGCaWZ4b0JCHZlrPHVQVXQwSkibHb02j0czAMt8=";
|
2024-07-03 18:33:52 +00:00
|
|
|
fetchSubmodules = true;
|
2017-12-28 16:42:53 +00:00
|
|
|
};
|
|
|
|
|
2024-07-03 18:33:52 +00:00
|
|
|
patches = [
|
|
|
|
(fetchpatch {
|
|
|
|
url =
|
|
|
|
"https://github.com/cfhammill/cupy/commit/67526c756e4a0a70f0420bf0e7f081b8a35a8ee5.patch";
|
|
|
|
hash = "sha256-WZgexBdM9J0ep5s+9CGZriVq0ZidCRccox+g0iDDywQ=";
|
|
|
|
})
|
|
|
|
];
|
|
|
|
|
2022-04-01 08:02:18 +00:00
|
|
|
# See https://docs.cupy.dev/en/v10.2.0/reference/environment.html. Seting both
|
|
|
|
# CUPY_NUM_BUILD_JOBS and CUPY_NUM_NVCC_THREADS to NIX_BUILD_CORES results in
|
|
|
|
# a small amount of thrashing but it turns out there are a large number of
|
|
|
|
# very short builds and a few extremely long ones, so setting both ends up
|
|
|
|
# working nicely in practice.
|
2020-01-14 12:26:09 +00:00
|
|
|
preConfigure = ''
|
2022-04-01 08:02:18 +00:00
|
|
|
export CUPY_NUM_BUILD_JOBS="$NIX_BUILD_CORES"
|
|
|
|
export CUPY_NUM_NVCC_THREADS="$NIX_BUILD_CORES"
|
2020-08-25 02:07:09 +00:00
|
|
|
'';
|
2020-01-14 12:26:09 +00:00
|
|
|
|
2021-03-23 04:25:41 +00:00
|
|
|
nativeBuildInputs = [
|
2023-11-27 17:36:57 +00:00
|
|
|
setuptools
|
|
|
|
wheel
|
2023-12-18 18:34:35 +00:00
|
|
|
addDriverRunpath
|
2024-07-03 18:33:52 +00:00
|
|
|
cython_0
|
2023-11-27 17:36:57 +00:00
|
|
|
cudaPackages.cuda_nvcc
|
2021-03-23 04:25:41 +00:00
|
|
|
];
|
|
|
|
|
2023-11-27 17:36:57 +00:00
|
|
|
buildInputs = [
|
|
|
|
cudatoolkit-joined
|
2017-12-28 16:42:53 +00:00
|
|
|
cudnn
|
2021-03-15 23:09:15 +00:00
|
|
|
cutensor
|
2017-12-28 16:42:53 +00:00
|
|
|
nccl
|
2023-11-27 17:36:57 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
NVCC = "${lib.getExe cudaPackages.cuda_nvcc}"; # FIXME: splicing/buildPackages
|
|
|
|
CUDA_PATH = "${cudatoolkit-joined}";
|
|
|
|
|
|
|
|
propagatedBuildInputs = [
|
2017-12-28 16:42:53 +00:00
|
|
|
fastrlock
|
|
|
|
numpy
|
|
|
|
];
|
|
|
|
|
2023-01-21 12:00:00 +00:00
|
|
|
nativeCheckInputs = [
|
2021-03-23 04:25:41 +00:00
|
|
|
pytestCheckHook
|
|
|
|
mock
|
|
|
|
];
|
|
|
|
|
|
|
|
# Won't work with the GPU, whose drivers won't be accessible from the build
|
|
|
|
# sandbox
|
|
|
|
doCheck = false;
|
|
|
|
|
|
|
|
postFixup = ''
|
|
|
|
find $out -type f \( -name '*.so' -or -name '*.so.*' \) | while read lib; do
|
2023-12-18 18:34:35 +00:00
|
|
|
addDriverRunpath "$lib"
|
2021-03-23 04:25:41 +00:00
|
|
|
done
|
|
|
|
'';
|
2017-12-28 16:42:53 +00:00
|
|
|
|
2020-01-14 12:26:09 +00:00
|
|
|
enableParallelBuilding = true;
|
|
|
|
|
2021-01-11 07:54:33 +00:00
|
|
|
meta = with lib; {
|
2017-12-28 16:42:53 +00:00
|
|
|
description = "NumPy-compatible matrix library accelerated by CUDA";
|
2020-04-01 01:11:51 +00:00
|
|
|
homepage = "https://cupy.chainer.org/";
|
2023-01-21 10:41:28 +00:00
|
|
|
changelog = "https://github.com/cupy/cupy/releases/tag/v${version}";
|
2017-12-28 16:42:53 +00:00
|
|
|
license = licenses.mit;
|
|
|
|
platforms = [ "x86_64-linux" ];
|
|
|
|
maintainers = with maintainers; [ hyphon81 ];
|
|
|
|
};
|
|
|
|
}
|