Updated versions and more variants (#14310)

* Updated versions and more variants

- Added 'develop' and '3.0.0' versions
- Added 'tau', 'upcxx', 'gotcha', and 'likwid'

* Added conflict handling for +cupti~cuda

* Removed extra cmake args line
This commit is contained in:
Jonathan R. Madsen 2019-12-31 11:33:41 -08:00 committed by Adam J. Stewart
parent b70a5245f2
commit 026534dadb

View file

@ -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 @@ def cmake_args(self):
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 @@ def cmake_args(self):
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: