
* Make boost composable Currently Boost enables a few components through variants by default, which means that if you want to use only what you need and no more, you have to explicitly disable these variants, leading to concretization errors whenever a second package explicitly needs those components. For instance if package A only needs `+component_a` it might depend on `boost +component_a ~component_b`. And if packge B only needs `+component_b` it might depend on `boost ~component_a +component_b`. If package C now depends on both A and B, this leads to unsatisfiable variants and hence a concretization error. However, if we default to disabling all components, package A can simply depend on `boost +component_a` and package B on `boost +component_b` and package C will concretize to depending on `boost +component_a +component_b`, and whatever you install, you get the bare minimum. * Fix style * Added composable boost dependencies for folly * fixing akantu merge issue * hpctoolkit boost dependencies already defined * Fix Styles * Fixup style once more * Adding isort fix * isort one more time * Fix for package audit issue Co-authored-by: Harmen Stoppels <harmenstoppels@gmail.com> Co-authored-by: Ryan O'Malley <rd.omalley@comcast.net>
144 lines
5.3 KiB
Python
144 lines
5.3 KiB
Python
# Copyright 2013-2022 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
|
|
|
|
from spack import *
|
|
from spack.pkg.builtin.boost import Boost
|
|
|
|
# typical working line with extrae 3.0.1
|
|
# ./configure
|
|
# --prefix=/usr/local
|
|
# --with-mpi=/usr/lib64/mpi/gcc/openmpi
|
|
# --with-unwind=/usr/local
|
|
# --with-papi=/usr
|
|
# --with-dwarf=/usr
|
|
# --with-elf=/usr
|
|
# --with-dyninst=/usr
|
|
# --with-binutils=/usr
|
|
# --with-xml-prefix=/usr
|
|
# --enable-openmp
|
|
# --enable-nanos
|
|
# --enable-pthread
|
|
# --disable-parallel-merge
|
|
#
|
|
# LDFLAGS=-pthread
|
|
|
|
|
|
class Extrae(AutotoolsPackage):
|
|
"""Extrae is the package devoted to generate tracefiles which can
|
|
be analyzed later by Paraver. Extrae is a tool that uses
|
|
different interposition mechanisms to inject probes into the
|
|
target application so as to gather information regarding the
|
|
application performance. The Extrae instrumentation package can
|
|
instrument the MPI programin model, and the following parallel
|
|
programming models either alone or in conjunction with MPI :
|
|
OpenMP, CUDA, OpenCL, pthread, OmpSs"""
|
|
|
|
homepage = "https://tools.bsc.es/extrae"
|
|
url = "https://ftp.tools.bsc.es/extrae/extrae-3.4.1-src.tar.bz2"
|
|
|
|
version('3.8.3', sha256='c3bf27fb6f18e66200e40a0b4c35bc257766e5c1a525dc5725f561879e88bf32')
|
|
version('3.7.1', sha256='c83ddd18a380c9414d64ee5de263efc6f7bac5fe362d5b8374170c7f18360378')
|
|
version('3.4.1', sha256='77bfec16d6b5eee061fbaa879949dcef4cad28395d6a546b1ae1b9246f142725')
|
|
|
|
depends_on("autoconf", type='build')
|
|
depends_on("automake", type='build')
|
|
depends_on("libtool", type='build')
|
|
depends_on("m4", type='build')
|
|
|
|
depends_on("mpi")
|
|
depends_on("libunwind")
|
|
|
|
# TODO: replace this with an explicit list of components of Boost,
|
|
# for instance depends_on('boost +filesystem')
|
|
# See https://github.com/spack/spack/pull/22303 for reference
|
|
depends_on(Boost.with_default_variants)
|
|
depends_on("libdwarf")
|
|
depends_on("papi")
|
|
depends_on("elf", type="link")
|
|
depends_on("libxml2")
|
|
depends_on("numactl")
|
|
depends_on("binutils+libiberty@:2.33")
|
|
depends_on("gettext")
|
|
# gettext dependency added to find -lintl
|
|
# https://www.gnu.org/software/gettext/FAQ.html#integrating_undefined
|
|
|
|
build_directory = 'spack-build'
|
|
|
|
variant('dyninst', default=False, description="Use dyninst for dynamic code installation")
|
|
depends_on('dyninst@:9', when='+dyninst')
|
|
|
|
variant('papi', default=True, description="Use PAPI to collect performance counters")
|
|
depends_on('papi', when='+papi')
|
|
|
|
variant('cuda', default=False, description="Enable support for tracing CUDA")
|
|
depends_on('cuda', when='+cuda')
|
|
|
|
variant('cupti', default=False, description='Enable CUPTI support')
|
|
depends_on('cuda', when='+cupti')
|
|
conflicts('+cupti', when='~cuda', msg='CUPTI requires CUDA')
|
|
|
|
def configure_args(self):
|
|
spec = self.spec
|
|
args = ["--with-mpi=%s" % spec['mpi'].prefix,
|
|
"--with-unwind=%s" % spec['libunwind'].prefix,
|
|
"--with-boost=%s" % spec['boost'].prefix,
|
|
"--with-dwarf=%s" % spec['libdwarf'].prefix,
|
|
"--with-elf=%s" % spec['elf'].prefix,
|
|
"--with-xml-prefix=%s" % spec['libxml2'].prefix,
|
|
"--with-binutils=%s" % spec['binutils'].prefix]
|
|
|
|
args += (["--with-papi=%s" % spec['papi'].prefix]
|
|
if '+papi' in self.spec else
|
|
["--without-papi"])
|
|
|
|
args += (["--with-dyninst=%s" % spec['dyninst'].prefix]
|
|
if '+dyninst' in self.spec else
|
|
["--without-dyninst"])
|
|
|
|
args += (["--with-cuda=%s" % spec['cuda'].prefix]
|
|
if '+cuda' in self.spec else
|
|
["--without-cuda"])
|
|
|
|
if '+cupti' in self.spec:
|
|
cupti_h = find_headers('cupti', spec['cuda'].prefix,
|
|
recursive=True)
|
|
cupti_dir = os.path.dirname(os.path.dirname(cupti_h[0]))
|
|
|
|
args += (["--with-cupti=%s" % cupti_dir]
|
|
if '+cupti' in self.spec else
|
|
["--without-cupti"])
|
|
|
|
if spec.satisfies("^dyninst@9.3.0:"):
|
|
make.add_default_arg("CXXFLAGS=%s" % self.compiler.cxx11_flag)
|
|
args.append("CXXFLAGS=%s" % self.compiler.cxx11_flag)
|
|
|
|
# This was added due to:
|
|
# - configure failure
|
|
# https://www.gnu.org/software/gettext/FAQ.html#integrating_undefined
|
|
# - linking error
|
|
# https://github.com/bsc-performance-tools/extrae/issues/57
|
|
args.append('LDFLAGS=-lintl -pthread')
|
|
|
|
return(args)
|
|
|
|
def install(self, spec, prefix):
|
|
with working_dir(self.build_directory):
|
|
# parallel installs are buggy prior to 3.7
|
|
# see https://github.com/bsc-performance-tools/extrae/issues/18
|
|
if(spec.satisfies('@3.7:')):
|
|
make('install', parallel=True)
|
|
else:
|
|
make('install', parallel=False)
|
|
|
|
def setup_run_environment(self, env):
|
|
# set EXTRAE_HOME in the module file
|
|
env.set('EXTRAE_HOME', self.prefix)
|
|
|
|
def setup_dependent_build_environment(self, env, dependent_spec):
|
|
# set EXTRAE_HOME for everyone using the Extrae package
|
|
env.set('EXTRAE_HOME', self.prefix)
|