CoMD Proxy App with Serial, MPI, OpenMP Support (#4864)
This commit is contained in:
parent
ad5fb40d75
commit
9b994c05f4
@ -24,6 +24,7 @@
|
|||||||
##############################################################################
|
##############################################################################
|
||||||
|
|
||||||
from spack import *
|
from spack import *
|
||||||
|
import shutil
|
||||||
|
|
||||||
|
|
||||||
class Comd(MakefilePackage):
|
class Comd(MakefilePackage):
|
||||||
@ -36,20 +37,76 @@ class Comd(MakefilePackage):
|
|||||||
versions of CoMD will be released to incorporate the lessons learned from
|
versions of CoMD will be released to incorporate the lessons learned from
|
||||||
the co-design process."""
|
the co-design process."""
|
||||||
|
|
||||||
homepage = "http://exmatex.github.io/CoMD/"
|
tags = ['proxy-app']
|
||||||
|
|
||||||
version('master', git='https://github.com/exmatex/CoMD.git',
|
homepage = "http://www.exmatex.org/comd.html"
|
||||||
branch='master')
|
url = "https://github.com/exmatex/CoMD/archive/master.tar.gz"
|
||||||
|
|
||||||
depends_on('mpi')
|
version('master', git='https://github.com/exmatex/CoMD.git', branch='master')
|
||||||
|
|
||||||
build_directory = 'src-mpi'
|
variant('serial', default=False, description='Build without MPI support')
|
||||||
|
variant('mpi', default=True, description='Build with MPI support')
|
||||||
|
variant('openmp', default=False, description='Build with OpenMP support')
|
||||||
|
variant('precision', default=True, description='Toggle Precesion Options')
|
||||||
|
variant('graphs', default=True, description='Enable graph visuals')
|
||||||
|
|
||||||
|
depends_on('mpi', when='+mpi')
|
||||||
|
depends_on('graphviz', when='+graphs')
|
||||||
|
|
||||||
|
conflicts('+openmp', when='~serial')
|
||||||
|
|
||||||
def edit(self, spec, prefix):
|
def edit(self, spec, prefix):
|
||||||
with working_dir('src-mpi'):
|
with working_dir('src-mpi') or working_dir('src-openmp'):
|
||||||
filter_file(r'^CC\s*=.*', 'CC = %s' % self.spec['mpi'].mpicc,
|
shutil.copy('Makefile.vanilla', 'Makefile')
|
||||||
'Makefile.vanilla')
|
|
||||||
install('Makefile.vanilla', 'Makefile')
|
@property
|
||||||
|
def build_targets(self):
|
||||||
|
targets = []
|
||||||
|
cflags = ' -std=c99 '
|
||||||
|
optflags = ' -g -O5 '
|
||||||
|
clib = ' -lm '
|
||||||
|
comd_variant = 'CoMD'
|
||||||
|
cc = spack_cc
|
||||||
|
|
||||||
|
if '+openmp' in self.spec:
|
||||||
|
targets.append('--directory=src-openmp')
|
||||||
|
comd_variant += '-openmp'
|
||||||
|
cflags += ' -fopenmp '
|
||||||
|
if '+mpi' in self.spec:
|
||||||
|
comd_variant += '-mpi'
|
||||||
|
targets.append('CC = {0}'.format(self.spec['mpi'].mpicc))
|
||||||
|
else:
|
||||||
|
targets.append('CC = {0}'.format('spack_cc'))
|
||||||
|
|
||||||
|
else:
|
||||||
|
targets.append('--directory=src-mpi')
|
||||||
|
if '+serial' in self.spec:
|
||||||
|
comd_variant += '-serial'
|
||||||
|
targets.append('CC = {0}'.format(cc))
|
||||||
|
else:
|
||||||
|
comd_variant += '-mpi'
|
||||||
|
targets.append('CC = {0}'.format(self.spec['mpi'].mpicc))
|
||||||
|
if '+mpi' in self.spec:
|
||||||
|
cflags += '-DDO_MPI'
|
||||||
|
targets.append(
|
||||||
|
'INCLUDES = {0}'.format(self.spec['mpi'].prefix.include))
|
||||||
|
|
||||||
|
if '+precision' in self.spec:
|
||||||
|
cflags += ' -DDOUBLE '
|
||||||
|
else:
|
||||||
|
cflags += ' -DSINGLE '
|
||||||
|
|
||||||
|
targets.append('CoMD_VARIANT = {0}'.format(comd_variant))
|
||||||
|
targets.append('CFLAGS = {0}'.format(cflags))
|
||||||
|
targets.append('OPTFLAGS = {0}'.format(optflags))
|
||||||
|
targets.append('C_LIB = {0}'.format(clib))
|
||||||
|
|
||||||
|
return targets
|
||||||
|
|
||||||
def install(self, spec, prefix):
|
def install(self, spec, prefix):
|
||||||
install_tree('bin', prefix.bin)
|
install_tree('bin', prefix.bin)
|
||||||
|
install_tree('examples', prefix.examples)
|
||||||
|
install_tree('pots', prefix.pots)
|
||||||
|
mkdirp(prefix.doc)
|
||||||
|
install('README.md', prefix.doc)
|
||||||
|
install('LICENSE.md', prefix.doc)
|
||||||
|
Loading…
Reference in New Issue
Block a user