summaryrefslogtreecommitdiff
path: root/var/spack/repos/builtin/packages/vampirtrace/package.py
blob: bc28a286d0466f2bb4dbbef6bc0f52c56bfedffe (plain) (blame)
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
# 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)

from spack.package import *


class Vampirtrace(AutotoolsPackage):
    """VampirTrace is an open source library that allows detailed logging of
    program execution for parallel applications using message passing (MPI)
    and threads (OpenMP, Pthreads)."""

    homepage = "https://tu-dresden.de/zih/forschung/projekte/vampirtrace"
    url = "https://wwwpub.zih.tu-dresden.de/~mlieber/dcount/dcount.php?package=vampirtrace&get=VampirTrace-5.14.4.tar.gz"

    version("5.14.4", sha256="1719a1666dd274c221b781631958cae56aa8bcb3f22861fb4ba6526c1b465a30")

    variant("mpi", default=True, description="Enable MPI support")

    depends_on("mpi", when="+mpi")
    depends_on("otf")
    depends_on("papi")
    depends_on("zlib-api")

    # VampirTrace fails to build with newer versions of MPICH due to
    # https://github.com/pmodels/mpich/commit/c3dbc09ae20a503ac4b870893e3e330d52ea5a3b
    patch("mpi3-const.patch", when="^mpich@3.3:")
    # VampirTrace fails to build with OpenMPI for the same reason
    patch("mpi3-const.patch", when="^openmpi")

    def patch(self):
        path = "tools/vtwrapper/vt{0}-wrapper-data.txt.in"

        for wrapper in ("cc", "c++", "fort"):
            filter_file(
                "@VT_WRAPPER_OPARI_TAB_COMPILER@", "@VT_WRAPPER_CC_COMPILER@", path.format(wrapper)
            )

    def configure_args(self):
        spec = self.spec
        compiler = self.compiler

        args = [
            "--with-extern-otf",
            "--with-extern-otf-dir={0}".format(spec["otf"].prefix),
            "--with-papi-dir={0}".format(spec["papi"].prefix),
            "--with-zlib-dir={0}".format(spec["zlib-api"].prefix),
            "--with-wrapper-cc-compiler={0}".format(compiler.cc),
            "--with-wrapper-cc-cpp={0} -E".format(compiler.cc),
            "--with-wrapper-cxx-compiler={0}".format(compiler.cxx),
            "--with-wrapper-cxx-cpp={0} -E".format(compiler.cxx),
            "--with-wrapper-fc-compiler={0}".format(compiler.fc),
            "--with-wrapper-fc-cpp={0} -E".format(compiler.fc),
        ]

        if "+mpi" in spec:
            args.append("--with-mpi-dir={0}".format(spec["mpi"].prefix))

        return args