spack/var/spack/repos/builtin/packages/flecsi/package.py

241 lines
10 KiB
Python
Raw Normal View History

# Copyright 2013-2021 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 import *
class Flecsi(CMakePackage, CudaPackage):
'''FleCSI is a compile-time configurable framework designed to support
multi-physics application development. As such, FleCSI attempts to
provide a very general set of infrastructure design patterns that can
be specialized and extended to suit the needs of a broad variety of
solver and data requirements. Current support includes multi-dimensional
mesh topology, mesh geometry, and mesh adjacency information,
n-dimensional hashed-tree data structures, graph partitioning
interfaces,and dependency closures.
'''
homepage = 'http://flecsi.org/'
git = 'https://github.com/flecsi/flecsi.git'
maintainers = ['rspavel', 'ktsai7']
tags = ['e4s']
version('develop', branch='devel', submodules=False)
version('1', git="https://github.com/laristra/flecsi.git", branch='1', submodules=False, preferred=False)
version('1.4', git="https://github.com/laristra/flecsi.git", branch='1.4', submodules=False, preferred=False)
version('1.4.2', git="https://github.com/laristra/flecsi.git", tag='v1.4.2', submodules=False, preferred=True)
version('2.1.0', tag='v2.1.0', submodules=False, preferred=False)
version('flecsph', git="https://github.com/laristra/flecsi.git", branch="stable/flecsph", submodules=True, preferred=False)
variant('backend', default='mpi', values=('serial', 'mpi', 'legion', 'hpx', 'charmpp'),
description='Backend to use for distributed memory', multi=False)
variant('debug_backend', default=False,
description='Build Backend with Debug Mode')
variant('disable_metis', default=False,
description='Disable FindPackageMetis')
variant('shared', default=True,
description='Build shared libraries')
variant('flog', default=False,
description='Enable flog testing')
variant('doxygen', default=False,
description='Enable doxygen')
variant('doc', default=False,
description='Enable documentation')
variant('coverage', default=False,
description='Enable coverage build')
variant('hdf5', default=True,
description='Enable HDF5 Support')
variant('caliper_detail', default='none',
values=('none', 'low', 'medium', 'high'),
description='Set Caliper Profiling Detail', multi=False)
variant('graphviz', default=False,
description='Enable GraphViz Support')
variant('tutorial', default=False,
description='Build FleCSI Tutorials')
variant('flecstan', default=False,
description='Build FleCSI Static Analyzer')
variant('external_cinch', default=True,
description='Enable External Cinch')
variant('kokkos', default=False,
description='Enable Kokkos Support')
variant('unit_tests', default=False,
description='Build with Unit Tests Enabled')
variant('openmp', default=False,
description='Enable OpenMP Support')
# All Current FleCSI Releases
for level in ('low', 'medium', 'high'):
depends_on('caliper@2.0.1~adiak~libdw', when='@:1.9 caliper_detail=%s' % level)
depends_on('caliper@2.4.0~libdw', when='@2.0: caliper_detail=%s' % level)
depends_on('graphviz', when='+graphviz')
depends_on('hdf5+hl+mpi', when='+hdf5')
depends_on('metis@5.1.0:')
depends_on('parmetis@4.0.3:')
depends_on('boost@1.70.0: cxxstd=17 +program_options')
depends_on('openmpi+legacylaunchers', when='+unit_tests ^openmpi')
depends_on('legion network=gasnet', when='backend=legion')
# FleCSI@1.x
depends_on('cmake@3.12:', when='@:1.9')
# Requires cinch > 1.0 due to cinchlog installation issue
depends_on('cinch@1.01:', type='build', when='+external_cinch @:1.9')
depends_on('mpi', when='backend=mpi @:1.9')
depends_on('mpi', when='backend=legion @:1.9')
depends_on('mpi', when='backend=hpx @:1.9')
depends_on('legion+shared', when='backend=legion @:1.9')
depends_on('legion+hdf5', when='backend=legion +hdf5 @:1.9')
depends_on('legion build_type=Debug', when='backend=legion +debug_backend @:1.9')
depends_on('legion@ctrl-rep-7', when='backend=legion @:1.9')
depends_on('hpx@1.4.1 cxxstd=17 malloc=system max_cpu_count=128', when='backend=hpx @:1.9')
depends_on('hpx build_type=Debug', when='backend=hpx +debug_backend @:1.9')
depends_on('googletest@1.8.1+gmock', when='@:1.9')
depends_on('python@3.0:', when='+tutorial @:1.9')
depends_on('doxygen', when='+doxygen @:1.9')
depends_on('llvm', when='+flecstan @:1.9')
depends_on('pfunit@3.0:3', when='@:1.9')
depends_on('py-gcovr', when='+coverage @:1.9')
# FleCSI@2.x
depends_on('cmake@3.15:', when='@2.0:')
depends_on('boost +atomic +filesystem +regex +system', when='@2.0:')
depends_on('kokkos@3.2.00:', when='+kokkos @2.0:')
depends_on('legion@ctrl-rep-9:ctrl-rep-99', when='backend=legion @2.0:')
depends_on('legion+hdf5', when='backend=legion +hdf5 @2.0:')
depends_on('hdf5@1.10.7:', when='backend=legion +hdf5 @2.0:')
depends_on('hpx@1.3.0 cxxstd=17 malloc=system', when='backend=hpx @2.0:')
depends_on('kokkos@3.2.00:', when='+kokkos @2.0:')
depends_on('mpich@3.4.1:', when='@2.0: ^mpich')
depends_on('openmpi@4.1.0:', when='@2.0: ^openmpi')
conflicts('+tutorial', when='backend=hpx')
# FleCSI@2: no longer supports serial or charmpp backends
conflicts('backend=serial', when='@2.0:')
conflicts('backend=charmpp', when='@2.0:')
# FleCSI@2: no longer expects to control how backend is built
conflicts('+debug_backend', when='@2.0:')
# FleCSI@2: No longer supports previous TPL related flags
conflicts('+disable_metis', when='@2.0:')
# FleCSI@2: no longer provides documentation variants
conflicts('+doxygen', when='@2.0:')
conflicts('+doc', when='@2.0:')
# FleCSI@2: no longer provides coverage variants
conflicts('+coverage', when='@2.0:')
# FleCSI@2: no longer provides tutorial variants
conflicts('+tutorial', when='@2.0:')
# FleCSI@2: no longer supports flecstan
conflicts('+flecstan', when='@2.0:')
# FleCSI@2: integrates cinch and no longer depends on external installs
conflicts('+external_cinch', when='@2.0:')
# Current FleCSI@:1.9 releases do not support kokkos, omp, or cuda
conflicts('+kokkos', when='@:1.9')
conflicts('+openmp', when='@:1.9')
conflicts('+cuda', when='@:1.9')
# Unit tests require flog support
conflicts('+unit_tests', when='~flog')
# Disallow conduit=none when using legion as a backend
conflicts('legion conduit=none', when='backend=legion')
# Due to overhauls of Legion and Gasnet spackages
# flecsi@:1.9 can no longer be built with a usable legion
conflicts('backend=legion', when='@:1.9')
def cmake_args(self):
spec = self.spec
options = []
if '+external_cinch' in spec:
options.append('-DCINCH_SOURCE_DIR=' + spec['cinch'].prefix)
if spec.variants['backend'].value == 'legion':
options.append('-DFLECSI_RUNTIME_MODEL=legion')
options.append('-DENABLE_MPI=ON')
elif spec.variants['backend'].value == 'mpi':
options.append('-DFLECSI_RUNTIME_MODEL=mpi')
options.append('-DENABLE_MPI=ON')
elif spec.variants['backend'].value == 'hpx':
options.append('-DFLECSI_RUNTIME_MODEL=hpx')
options.append('-DENABLE_MPI=ON')
options.append('-DHPX_IGNORE_CMAKE_BUILD_TYPE_COMPATIBILITY=ON')
elif spec.variants['backend'].value == 'charmpp':
options.append('-DFLECSI_RUNTIME_MODEL=charmpp')
options.append('-DENABLE_MPI=ON')
else:
options.append('-DFLECSI_RUNTIME_MODEL=serial')
options.append('-DENABLE_MPI=OFF')
if '+shared' in spec:
options.append('-DBUILD_SHARED_LIBS=ON')
else:
options.append('-DBUILD_SHARED_LIBS=OFF')
options.append('-DCALIPER_DETAIL=%s' %
spec.variants['caliper_detail'].value)
if spec.satisfies('@:1.9'):
if spec.variants['caliper_detail'].value == 'none':
options.append('-DENABLE_CALIPER=OFF')
else:
options.append('-DENABLE_CALIPER=ON')
if self.run_tests or '+unit' in spec:
options.append('-DENABLE_UNIT_TESTS=ON')
else:
options.append('-DENABLE_UNIT_TESTS=OFF')
if ('+flog' in spec):
options.append('-DENABLE_FLOG=ON')
else:
options.append('-DENABLE_FLOG=OFF')
if '+hdf5' in spec and spec.variants['backend'].value != 'hpx':
options.append('-DENABLE_HDF5=ON')
else:
options.append('-DENABLE_HDF5=OFF')
if '+graphviz' in spec:
options.append('-DENABLE_GRAPHVIZ=ON')
else:
options.append('-DENABLE_GRAPHVIZ=OFF')
if '+kokkos' in spec:
options.append('-DENABLE_KOKKOS=ON')
else:
options.append('-DENABLE_KOKKOS=OFF')
if '+openmp' in spec:
options.append('-DENABLE_OPENMP=ON')
else:
options.append('-DENABLE_OPENMP=OFF')
if '+disable_metis' in spec:
options.append('-DCMAKE_DISABLE_FIND_PACKAGE_METIS=ON')
else:
options.append('-DCMAKE_DISABLE_FIND_PACKAGE_METIS=OFF')
if '+tutorial' in spec:
options.append('-DENABLE_FLECSIT=ON')
options.append('-DENABLE_FLECSI_TUTORIAL=ON')
else:
options.append('-DENABLE_FLECSIT=OFF')
options.append('-DENABLE_FLECSI_TUTORIAL=OFF')
if '+flecstan' in spec:
options.append('-DENABLE_FLECSTAN=ON')
else:
options.append('-DENABLE_FLECSTAN=OFF')
if '+doxygen' in spec:
options.append('-DENABLE_DOXYGEN=ON')
else:
options.append('-DENABLE_DOXYGEN=OFF')
if '+doc' in spec:
options.append('-DENABLE_DOCUMENTATION=ON')
else:
options.append('-DENABLE_DOCUMENTATION=OFF')
if '+coverage' in spec:
options.append('-DENABLE_COVERAGE_BUILD=ON')
else:
options.append('-DENABLE_COVERAGE_BUILD=OFF')
return options