1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
|
# Copyright 2013-2023 Lawrence Livermore National Security, LLC and other
# Spack Project Developers. See the top-level COPYRIGHT file for details.
#
# SPDX-License-Identifier: (Apache-2.0 OR MIT)
from spack.package import *
class Spfft(CMakePackage, CudaPackage, ROCmPackage):
"""Sparse 3D FFT library with MPI, OpenMP, CUDA and ROCm support."""
homepage = "https://github.com/eth-cscs/SpFFT"
url = "https://github.com/eth-cscs/SpFFT/archive/v0.9.8.zip"
git = "https://github.com/eth-cscs/SpFFT.git"
maintainers("AdhocMan", "haampie")
license("BSD-3-Clause")
version("develop", branch="develop")
version("master", branch="master")
version("1.0.6", sha256="e1b927c61f8abbb4a9937653f917169e6253e8c40b850df491594310943ca14b")
version("1.0.5", sha256="2a59d856286ea8559f00a32fc38f9f7546209cfa90112232a5288a69689a6e05")
version("1.0.4", sha256="41e63880d95343da0d8c3dbe5bfb3d46a1d612199cc9cc13a936f1628a7fdb8e")
version("1.0.3", sha256="4f87734e3582ef96ddc0402d0db78cfc173bed9cab3e0d9c6a6bf8b660d69559")
version("1.0.2", sha256="9b1296bda0b9ec3d37c74fd64354a01ebc6e2da7cb026c1f821882160b03c692")
version("1.0.1", sha256="f8ab706309776cfbd2bfd8e29a6a9ffb5c8f3cd62399bf82db1e416ae5c490c8")
version("1.0.0", sha256="bd98897aa6734563ec63cd84168e731ef2e2bbc01a574c6dc59b74475742b6ee")
version("0.9.13", sha256="5ccc93c9362bec14cfb6e31dd0e7ae7e48db0453ab49ebc9722041b69db759ef")
version("0.9.12", sha256="1f7bf5164dcceb0e3bbce7d6ff9faef3145ad17cf3430149d40a98c43c010acc")
version("0.9.11", sha256="36542a60378e8672654188dee006975ef9e10f502791459ff7ebf4b38451cb9b")
version("0.9.10", sha256="9cbbb7ba5e53e17eeb45e809841d8272e5333f739c2442a99c3e255c1ddec3e9")
version("0.9.9", sha256="a8fd7a2d767716bb73185ca03bf4c106c6981b79130f3e456e5d2e744a2b3ba0")
version("0.9.8", sha256="f49fa51316bbfa68309e951d2375e1f6904120c93868cbe13bc2974c0b801a3f")
variant("openmp", default=True, description="Build with OpenMP support")
variant("mpi", default=True, description="enable MPI")
variant("single_precision", default=False, description="Sinlge precision")
variant("gpu_direct", default=False, description="GPU aware MPI")
variant("static", default=False, description="build static library")
variant("fortran", default=False, description="enable fortran")
variant(
"build_type",
default="Release",
description="CMake build type",
values=("Debug", "Release", "RelWithDebInfo"),
)
depends_on("fftw-api@3")
depends_on("mpi", when="+mpi")
depends_on("cmake@3.11:", type="build")
depends_on("cuda@:10", when="@:0.9.11 +cuda")
with when("+rocm"):
# FindHIP cmake script only works for < 4.1
depends_on("hip@:4.0", when="@:1.0.1")
# Workaround for compiler bug in ROCm 4.5 added in SpFFT 1.0.6
depends_on("hip@:4.3.1", when="@:1.0.5")
depends_on("rocfft")
# rocFFT and hipFFT have split with latest versions
depends_on("hipfft", when="^rocfft@4.1.0:")
# Fix compilation error in some cases due to missing include statement
# before version 1.0.3
patch("0001-fix-missing-limits-include.patch", when="@:1.0.2")
def cmake_args(self):
spec = self.spec
args = [
self.define_from_variant("SPFFT_OMP", "openmp"),
self.define_from_variant("SPFFT_MPI", "mpi"),
self.define_from_variant("SPFFT_SINGLE_PRECISION", "single_precision"),
self.define_from_variant("SPFFT_GPU_DIRECT", "gpu_direct"),
self.define_from_variant("SPFFT_FORTRAN", "fortran"),
self.define_from_variant("SPFFT_STATIC", "static"),
]
if spec.satisfies("+cuda"):
args += ["-DSPFFT_GPU_BACKEND=CUDA"]
cuda_arch = self.spec.variants["cuda_arch"].value
if cuda_arch[0] != "none":
args += [self.define("CMAKE_CUDA_ARCHITECTURES", cuda_arch)]
if spec.satisfies("+rocm"):
archs = ",".join(self.spec.variants["amdgpu_target"].value)
args += [
"-DSPFFT_GPU_BACKEND=ROCM",
"-DHIP_ROOT_DIR={0}".format(spec["hip"].prefix),
"-DHIP_HCC_FLAGS=--amdgpu-target={0}".format(archs),
"-DHIP_CXX_COMPILER={0}".format(self.spec["hip"].hipcc),
]
if "fftw" in spec:
args += ["-DSPFFT_FFTW_LIB=FFTW"]
elif "intel-mkl" in spec:
args += ["-DSPFFT_FFTW_LIB=MKL"]
return args
|