summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--var/spack/repos/builtin/packages/timemory/package.py47
1 files changed, 43 insertions, 4 deletions
diff --git a/var/spack/repos/builtin/packages/timemory/package.py b/var/spack/repos/builtin/packages/timemory/package.py
index 717de208df..d11ac8a62c 100644
--- a/var/spack/repos/builtin/packages/timemory/package.py
+++ b/var/spack/repos/builtin/packages/timemory/package.py
@@ -16,16 +16,24 @@ class Timemory(CMakePackage):
maintainers = ['jrmadsen']
version('master', branch='master', submodules=True)
+ version('develop', branch='develop', submodules=True)
+ version('3.0.0', commit='b36b1673b2c6b7ff3126d8261bef0f8f176c7beb',
+ submodules=True)
variant('python', default=True, description='Enable Python support')
variant('mpi', default=False, description='Enable MPI support')
+ variant('tau', default=True, description='Enable TAU support')
variant('papi', default=True, description='Enable PAPI support')
variant('cuda', default=True, description='Enable CUDA support')
variant('cupti', default=True, description='Enable CUPTI support')
+ variant('upcxx', default=False, description='Enable UPC++ support')
+ variant('gotcha', default=True, description='Enable GOTCHA support')
+ variant('likwid', default=True, description='Enable LIKWID support')
variant('caliper', default=True, description='Enable Caliper support')
- variant('gperftools', default=True, description='Enable gperftools support')
+ variant('gperftools', default=True,
+ description='Enable gperftools support')
- depends_on('cmake@3.10:', type='build')
+ depends_on('cmake@3.11:', type='build')
extends('python', when='+python')
depends_on('python@3:', when='+python', type=('build', 'run'))
@@ -33,29 +41,40 @@ class Timemory(CMakePackage):
depends_on('py-pillow', when='+python', type=('run'))
depends_on('py-matplotlib', when='+python', type=('run'))
depends_on('mpi', when='+mpi')
+ depends_on('tau', when='+tau')
depends_on('papi', when='+papi')
depends_on('cuda', when='+cuda')
+ depends_on('cuda', when='+cupti')
+ depends_on('upcxx', when='+upcxx')
+ depends_on('gotcha', when='+gotcha')
+ depends_on('likwid', when='+likwid')
depends_on('caliper', when='+caliper')
depends_on('gperftools', when='+gperftools')
+ conflicts('+cupti', when='~cuda', msg='CUPTI requires CUDA')
+
def cmake_args(self):
spec = self.spec
- # Use spack install of Caliper instead of internal build
+ # Use spack install of Caliper and/or GOTCHA
+ # instead of internal submodule build
args = [
+ '-DTIMEMORY_BUILD_GOTCHA=OFF',
'-DTIMEMORY_BUILD_CALIPER=OFF',
'-DTIMEMORY_BUILD_TOOLS=ON',
+ '-DTIMEMORY_BUILD_TESTING=OFF',
'-DTIMEMORY_BUILD_EXTRA_OPTIMIZATIONS=ON',
- '-DTIMEMORY_BUILD_GTEST=OFF',
'-DCMAKE_INSTALL_RPATH_USE_LINK_PATH=ON',
]
if '+python' in spec:
args.append('-DPYTHON_EXECUTABLE={0}'.format(
spec['python'].command.path))
+ args.append('-DTIMEMORY_USE_PYTHON=ON')
args.append('-DTIMEMORY_BUILD_PYTHON=ON')
args.append('-DTIMEMORY_TLS_MODEL=global-dynamic')
else:
+ args.append('-DTIMEMORY_USE_PYTHON=OFF')
args.append('-DTIMEMORY_BUILD_PYTHON=OFF')
if '+caliper' in spec:
@@ -63,6 +82,16 @@ class Timemory(CMakePackage):
else:
args.append('-DTIMEMORY_USE_CALIPER=OFF')
+ if '+tau' in spec:
+ args.append('-DTIMEMORY_USE_TAU=ON')
+ else:
+ args.append('-DTIMEMORY_USE_TAU=OFF')
+
+ if '+likwid' in spec:
+ args.append('-DTIMEMORY_USE_LIKWID=ON')
+ else:
+ args.append('-DTIMEMORY_USE_LIKWID=OFF')
+
if '+papi' in spec:
args.append('-DTIMEMORY_USE_PAPI=ON')
args.append('-DPAPI_ROOT_DIR={0}'.format(spec['papi'].prefix))
@@ -75,6 +104,16 @@ class Timemory(CMakePackage):
else:
args.append('-DTIMEMORY_USE_MPI=OFF')
+ if '+gotcha' in spec:
+ args.append('-DTIMEMORY_USE_GOTCHA=ON')
+ else:
+ args.append('-DTIMEMORY_USE_GOTCHA=OFF')
+
+ if '+cuda' in spec:
+ args.append('-DTIMEMORY_USE_CUDA=ON')
+ else:
+ args.append('-DTIMEMORY_USE_CUDA=OFF')
+
if '+cupti' in spec:
args.append('-DTIMEMORY_USE_CUPTI=ON')
else: