spack/var/spack/repos/builtin/packages/neko/package.py
2025-01-06 07:57:14 +01:00

110 lines
5.3 KiB
Python

# Copyright Spack Project Developers. See COPYRIGHT file for details.
#
# SPDX-License-Identifier: (Apache-2.0 OR MIT)
from spack.package import *
class Neko(AutotoolsPackage, CudaPackage, ROCmPackage):
"""Neko: A modern, portable, and scalable framework
for high-fidelity computational fluid dynamics
"""
homepage = "https://neko.cfd"
git = "https://github.com/ExtremeFLOW/neko.git"
url = "https://github.com/ExtremeFLOW/neko/releases/download/v0.3.2/neko-0.3.2.tar.gz"
maintainers("njansson")
version("develop", branch="develop")
version("0.9.1", sha256="098bee5cb807d10cdf2fb56111ba8cbc592882a87e4dae18caf9dbda894611ef")
version("0.9.0", sha256="3cffe629ada1631d8774fa51d8bb14b95dc0cea21578c0e07e70deb611a5091a")
version("0.8.1", sha256="ac8162bc18e7112fd21b49c5a9c36f45c7b84896e90738be36a182990798baec")
version("0.8.0", sha256="09d0b253c8abda9f384bf8f03b17b50d774cb0a1f7b72744a8e863acac516a51")
version("0.7.2", sha256="5dd17fbae83d0b26dc46fafce4e5444be679cdce9493cef4ff7d504e2f854254")
version("0.7.1", sha256="c935c3d93b0975db46448045f97aced6ac2cab31a2b8803047f8086f98dcb981")
version("0.7.0", sha256="fe871e0a79f388073e0b3dc191d1c0d5da3a53883f5b1951d88b9423fc79a53c")
with default_args(deprecated=True):
version("0.6.1", sha256="6282baaf9c8a201669e274cba23c37922f7ad701ba20ef086442e48f00dabf29")
version("0.6.0", sha256="ce37c7cea1a7bf1bf554c5717aa7fed35bbd079ff68c2fc9d3529facc717e31a")
version("0.5.2", sha256="8873f5ada106f92f21c9bb13ea8164550bccde9301589b9e7f1c1a82a2efe2b8")
version("0.5.1", sha256="8b176bcc9f2d4a6804b68dd93a2f5e02e2dfa986d5c88063bbc72d39e9659cc4")
version("0.5.0", sha256="01a745f2e19dd278330889a0dd6c5ab8af49da99c888d95c10adb5accc1cbfc4")
version("0.4.3", sha256="ba8fde09cbc052bb4791a03f69c880705615b572982cd3177ee31e4e14931da2")
version("0.4.2", sha256="927f926bdbf027c30e8e383e1790e84b60f5a9ed61e48a413092aac2ab24abcc")
version("0.3.2", sha256="0628910aa9838a414f2f27d09ea9474d1b3d7dcb5a7715556049a2fdf81a71ae")
version("0.3.0", sha256="e46bef72f694e59945514ab8b1ad7d74f87ec9dca2ba2b230e2148662baefdc8")
depends_on("c", type="build") # generated
depends_on("fortran", type="build") # generated
variant("parmetis", default=False, description="Build with support for parmetis")
variant("xsmm", default=False, description="Build with support for libxsmm")
variant("gslib", default=False, when="@0.7.0:", description="Build with support for gslib")
variant("hdf5", default=False, when="@develop", description="Build with support for HDF5")
variant("hdf5", default=False, when="@0.9.0:", description="Build with support for HDF5")
variant(
"shared",
default=False,
when="@develop",
description="Builds a shared version of the library",
)
variant(
"shared",
default=False,
when="@0.9.0:",
description="Builds a shared version of the library",
)
# Requires cuda or rocm enabled MPI
variant(
"device-mpi",
default=False,
when="@0.4.0:",
description="Build with support for device-aware MPI",
)
depends_on("autoconf", type="build")
depends_on("automake", type="build")
depends_on("libtool", type="build")
depends_on("m4", type="build")
depends_on("pkgconfig", type="build")
depends_on("parmetis", when="+parmetis")
depends_on("libxsmm", when="+xsmm")
depends_on("mpi")
depends_on("blas")
depends_on("lapack")
depends_on("json-fortran", when="@develop")
depends_on("json-fortran", when="@0.7.0:")
depends_on("gslib", when="+gslib")
depends_on("hdf5+fortran+mpi", when="+hdf5")
depends_on("libtool", type="build", when="@develop")
depends_on("libtool", type="build", when="@0.9.0:")
def configure_args(self):
args = []
args.append("--with-blas={0}".format(self.spec["blas"].libs.joined(";")))
args.append("--with-lapack={0}".format(self.spec["lapack"].libs.joined(";")))
args += self.with_or_without("parmetis", variant="parmetis", activation_value="prefix")
args += self.with_or_without("metis", variant="parmetis", activation_value="prefix")
args += self.with_or_without("libxsmm", variant="xsmm")
args += self.with_or_without("gslib", variant="gslib", activation_value="prefix")
args += self.with_or_without("hdf5", variant="hdf5", activation_value="prefix")
args += self.with_or_without("cuda", activation_value="prefix")
rocm_fn = lambda x: self.spec["hip"].prefix
args += self.with_or_without("hip", variant="rocm", activation_value=rocm_fn)
args += self.enable_or_disable("device-mpi", variant="device-mpi")
args += self.enable_or_disable("shared", variant="shared")
if self.spec.satisfies("+cuda"):
cuda_arch_list = self.spec.variants["cuda_arch"].value
cuda_arch = cuda_arch_list[0]
if cuda_arch != "none":
args.append(f"CUDA_ARCH=-arch=sm_{cuda_arch}")
if self.spec.satisfies("+rocm"):
rocm_arch_list = self.spec.variants["amdgpu_target"].value
rocm_arch = rocm_arch_list[0]
if rocm_arch != "none":
args.append(f"HIP_HIPCC_FLAGS=-O3 --offload-arch={rocm_arch}")
return args