
* stand-alone test API update: self.cache_extra_test_sources(...) -> cache_extra_test_sources(self, ...) * superlu: switch to new cache_extra_test_sources API --------- Co-authored-by: Tamara Dahlgren <dahlgren1@llnl.gov>
235 lines
9.4 KiB
Python
235 lines
9.4 KiB
Python
# Copyright 2013-2024 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)
|
|
|
|
import os
|
|
import sys
|
|
|
|
from spack.package import *
|
|
|
|
|
|
class Caliper(CMakePackage, CudaPackage, ROCmPackage):
|
|
"""Caliper is a program instrumentation and performance measurement
|
|
framework. It is designed as a performance analysis toolbox in a
|
|
library, allowing one to bake performance analysis capabilities
|
|
directly into applications and activate them at runtime.
|
|
"""
|
|
|
|
homepage = "https://github.com/LLNL/Caliper"
|
|
git = "https://github.com/LLNL/Caliper.git"
|
|
url = "https://github.com/LLNL/Caliper/archive/v2.11.0.tar.gz"
|
|
tags = ["e4s", "radiuss"]
|
|
|
|
maintainers("daboehme")
|
|
|
|
test_requires_compiler = True
|
|
|
|
license("BSD-3-Clause")
|
|
|
|
version("master", branch="master")
|
|
version("2.11.0", sha256="b86b733cbb73495d5f3fe06e6a9885ec77365c8aa9195e7654581180adc2217c")
|
|
version("2.10.0", sha256="14c4fb5edd5e67808d581523b4f8f05ace8549698c0e90d84b53171a77f58565")
|
|
version("2.9.1", sha256="4771d630de505eff9227e0ec498d0da33ae6f9c34df23cb201b56181b8759e9e")
|
|
version("2.9.0", sha256="507ea74be64a2dfd111b292c24c4f55f459257528ba51a5242313fa50978371f")
|
|
version("2.8.0", sha256="17807b364b5ac4b05997ead41bd173e773f9a26ff573ff2fe61e0e70eab496e4")
|
|
version(
|
|
"2.7.0",
|
|
sha256="b3bf290ec2692284c6b4f54cc0c507b5700c536571d3e1a66e56626618024b2b",
|
|
deprecated=True,
|
|
)
|
|
version(
|
|
"2.6.0",
|
|
sha256="6efcd3e4845cc9a6169e0d934840766b12182c6d09aa3ceca4ae776e23b6360f",
|
|
deprecated=True,
|
|
)
|
|
version(
|
|
"2.5.0",
|
|
sha256="d553e60697d61c53de369b9ca464eb30710bda90fba9671201543b64eeac943c",
|
|
deprecated=True,
|
|
)
|
|
version(
|
|
"2.4.0", tag="v2.4.0", commit="30577b4b8beae104b2b35ed487fec52590a99b3d", deprecated=True
|
|
)
|
|
version(
|
|
"2.3.0", tag="v2.3.0", commit="9fd89bb0120750d1f9dfe37bd963e24e478a2a20", deprecated=True
|
|
)
|
|
version(
|
|
"2.2.0", tag="v2.2.0", commit="c408e9b3642c7aa80eff37b0826d819c57e7bc04", deprecated=True
|
|
)
|
|
version(
|
|
"2.1.1", tag="v2.1.1", commit="0593b0e01c1d8d3e50c990399cc0fee403485599", deprecated=True
|
|
)
|
|
version(
|
|
"2.0.1", tag="v2.0.1", commit="4d7ff46381c53a461e62edd949e2d9dea9db7b08", deprecated=True
|
|
)
|
|
version(
|
|
"1.9.1", tag="v1.9.1", commit="cfc1defbbee20b50dd3e3477badd09a92b1df970", deprecated=True
|
|
)
|
|
version(
|
|
"1.9.0", tag="v1.9.0", commit="8356e747349b285aa621c5b74e71559f0babc4a1", deprecated=True
|
|
)
|
|
version(
|
|
"1.8.0", tag="v1.8.0", commit="117c1ef596b617dc71407b8b67eebef094a654f8", deprecated=True
|
|
)
|
|
version(
|
|
"1.7.0", tag="v1.7.0", commit="898277c93d884d4e7ca1ffcf3bbea81d22364f26", deprecated=True
|
|
)
|
|
|
|
depends_on("c", type="build") # generated
|
|
depends_on("cxx", type="build") # generated
|
|
depends_on("fortran", type="build") # generated
|
|
|
|
is_linux = sys.platform.startswith("linux")
|
|
variant("shared", default=True, description="Build shared libraries")
|
|
variant("adiak", default=True, description="Enable Adiak support")
|
|
variant("mpi", default=True, description="Enable MPI support")
|
|
# libunwind has some issues on Mac
|
|
variant(
|
|
"libunwind", default=sys.platform != "darwin", description="Enable stack unwind support"
|
|
)
|
|
variant("libdw", default=is_linux, description="Enable DWARF symbol lookup")
|
|
# pthread_self() signature is incompatible with PAPI_thread_init() on Mac
|
|
variant("papi", default=sys.platform != "darwin", description="Enable PAPI service")
|
|
variant("libpfm", default=False, description="Enable libpfm (perf_events) service")
|
|
# Gotcha is Linux-only
|
|
variant("gotcha", default=is_linux, description="Enable GOTCHA support")
|
|
variant("sampler", default=is_linux, description="Enable sampling support on Linux")
|
|
variant("sosflow", default=False, description="Enable SOSflow support")
|
|
variant("fortran", default=False, description="Enable Fortran support")
|
|
variant("variorum", default=False, description="Enable Variorum support")
|
|
variant("vtune", default=False, description="Enable Intel Vtune support")
|
|
variant("kokkos", default=True, when="@2.3.0:", description="Enable Kokkos profiling support")
|
|
variant("tests", default=False, description="Enable tests")
|
|
|
|
depends_on("adiak@0.1:0", when="@2.2:2.10 +adiak")
|
|
depends_on("adiak@0.4:0", when="@2.11: +adiak")
|
|
|
|
depends_on("papi@5.3:5", when="@:2.2 +papi")
|
|
depends_on("papi@5.3:", when="@2.3: +papi")
|
|
|
|
depends_on("libpfm4@4.8:4", when="+libpfm")
|
|
|
|
depends_on("mpi", when="+mpi")
|
|
depends_on("unwind@1.2:1", when="+libunwind")
|
|
depends_on("elfutils", when="+libdw")
|
|
depends_on("variorum", when="+variorum")
|
|
depends_on("intel-oneapi-vtune", when="+vtune")
|
|
|
|
depends_on("sosflow@spack", when="@1.0:1+sosflow")
|
|
|
|
depends_on("cmake", type="build")
|
|
depends_on("python", type="build")
|
|
|
|
# sosflow support not yet in 2.0
|
|
conflicts("+sosflow", "@2.0.0:2.11")
|
|
conflicts("+adiak", "@:2.1")
|
|
conflicts("+libdw", "@:2.4")
|
|
conflicts("+rocm", "@:2.7")
|
|
conflicts("+rocm+cuda")
|
|
|
|
patch("for_aarch64.patch", when="target=aarch64:")
|
|
patch(
|
|
"sampler-service-missing-libunwind-include-dir.patch",
|
|
when="@2.9.0:2.9.1 +libunwind +sampler",
|
|
)
|
|
|
|
def cmake_args(self):
|
|
spec = self.spec
|
|
|
|
args = [
|
|
"-DBUILD_TESTING=Off",
|
|
"-DBUILD_DOCS=Off",
|
|
self.define_from_variant("BUILD_SHARED_LIBS", "shared"),
|
|
self.define_from_variant("WITH_ADIAK", "adiak"),
|
|
self.define_from_variant("WITH_GOTCHA", "gotcha"),
|
|
self.define_from_variant("WITH_PAPI", "papi"),
|
|
self.define_from_variant("WITH_LIBDW", "libdw"),
|
|
self.define_from_variant("WITH_LIBPFM", "libpfm"),
|
|
self.define_from_variant("WITH_SOSFLOW", "sosflow"),
|
|
self.define_from_variant("WITH_SAMPLER", "sampler"),
|
|
self.define_from_variant("WITH_MPI", "mpi"),
|
|
self.define_from_variant("WITH_FORTRAN", "fortran"),
|
|
self.define_from_variant("WITH_CUPTI", "cuda"),
|
|
self.define_from_variant("WITH_NVTX", "cuda"),
|
|
self.define_from_variant("WITH_ROCTRACER", "rocm"),
|
|
self.define_from_variant("WITH_ROCTX", "rocm"),
|
|
self.define_from_variant("WITH_VARIORUM", "variorum"),
|
|
self.define_from_variant("WITH_VTUNE", "vtune"),
|
|
self.define_from_variant("WITH_KOKKOS", "kokkos"),
|
|
]
|
|
|
|
if spec.satisfies("+papi"):
|
|
args.append("-DPAPI_PREFIX=%s" % spec["papi"].prefix)
|
|
if spec.satisfies("+libdw"):
|
|
args.append("-DLIBDW_PREFIX=%s" % spec["elfutils"].prefix)
|
|
if spec.satisfies("+libpfm"):
|
|
args.append("-DLIBPFM_INSTALL=%s" % spec["libpfm4"].prefix)
|
|
if spec.satisfies("+sosflow"):
|
|
args.append("-DSOS_PREFIX=%s" % spec["sosflow"].prefix)
|
|
if spec.satisfies("+variorum"):
|
|
args.append("-DVARIORUM_PREFIX=%s" % spec["variorum"].prefix)
|
|
|
|
# -DWITH_CALLPATH was renamed -DWITH_LIBUNWIND in 2.5
|
|
callpath_flag = "LIBUNWIND" if spec.satisfies("@2.5:") else "CALLPATH"
|
|
if spec.satisfies("+libunwind"):
|
|
args.append("-DLIBUNWIND_PREFIX=%s" % spec["unwind"].prefix)
|
|
args.append("-DWITH_%s=On" % callpath_flag)
|
|
else:
|
|
args.append("-DWITH_%s=Off" % callpath_flag)
|
|
|
|
if spec.satisfies("+mpi"):
|
|
args.append("-DMPI_C_COMPILER=%s" % spec["mpi"].mpicc)
|
|
args.append("-DMPI_CXX_COMPILER=%s" % spec["mpi"].mpicxx)
|
|
|
|
if spec.satisfies("+cuda"):
|
|
args.append("-DCUDA_TOOLKIT_ROOT_DIR=%s" % spec["cuda"].prefix)
|
|
# technically only works with cuda 10.2+, otherwise cupti is in
|
|
# ${CUDA_TOOLKIT_ROOT_DIR}/extras/CUPTI
|
|
args.append("-DCUPTI_PREFIX=%s" % spec["cuda"].prefix)
|
|
|
|
if spec.satisfies("+vtune"):
|
|
itt_dir = join_path(spec["intel-oneapi-vtune"].prefix, "vtune", "latest")
|
|
args.append("-DITT_PREFIX=%s" % itt_dir)
|
|
|
|
if spec.satisfies("+rocm"):
|
|
args.append("-DCMAKE_CXX_COMPILER={0}".format(spec["hip"].hipcc))
|
|
args.append("-DROCM_PREFIX=%s" % spec["hsa-rocr-dev"].prefix)
|
|
|
|
return args
|
|
|
|
@run_after("install")
|
|
def cache_test_sources(self):
|
|
"""Copy the example source files after the package is installed to an
|
|
install test subdirectory for use during `spack test run`."""
|
|
cache_extra_test_sources(self, [join_path("examples", "apps")])
|
|
|
|
def test_cxx_example(self):
|
|
"""build and run cxx-example"""
|
|
|
|
exe = "cxx-example"
|
|
source_file = "{0}.cpp".format(exe)
|
|
|
|
source_path = find_required_file(
|
|
self.test_suite.current_test_cache_dir, source_file, expected=1, recursive=True
|
|
)
|
|
|
|
lib_dir = self.prefix.lib if os.path.exists(self.prefix.lib) else self.prefix.lib64
|
|
|
|
cxx = which(os.environ["CXX"])
|
|
test_dir = os.path.dirname(source_path)
|
|
with working_dir(test_dir):
|
|
cxx(
|
|
"-L{0}".format(lib_dir),
|
|
"-I{0}".format(self.prefix.include),
|
|
source_path,
|
|
"-o",
|
|
exe,
|
|
"-std=c++11",
|
|
"-lcaliper",
|
|
"-lstdc++",
|
|
)
|
|
|
|
cxx_example = which(exe)
|
|
cxx_example()
|