Update the Krell Institute products to use the latest features of spa… (#1984)

* Update the krell institute products to use the latest features of spack for building on cluster platforms.

* Address travis error messages and resubmit the pull request.

* Update the contents of openspeedshop package.py so it passes the flake8 tests.

* Fix flake8 error-whitespack issue in mrnet package.py file.

* Add updates based on spack reviewer feedback.

* More fixes based on comments from reviewers.  Switch using extend to using append, remove additional setting of PATH and LD_LIBRARY_PATH that should not be required due to RPATH.

* More review related changes.  Update MPIOption.append lines and take out xercesc references.

* Create a base options function for common openspeedshop base cmake options to reduce redundencies.
This commit is contained in:
Jim Galarowicz 2016-10-17 01:18:30 -07:00 committed by Todd Gamblin
parent b5e20018b5
commit 87adcfeea8
6 changed files with 253 additions and 316 deletions

View File

@ -57,14 +57,13 @@ class CbtfArgonavis(Package):
version('1.6', branch='master', version('1.6', branch='master',
git='https://github.com/OpenSpeedShop/cbtf-argonavis.git') git='https://github.com/OpenSpeedShop/cbtf-argonavis.git')
depends_on("cmake@3.0.2", type='build') depends_on("cmake@3.0.2:", type='build')
depends_on("boost@1.50.0:") depends_on("boost@1.50.0:")
depends_on("papi") depends_on("papi")
depends_on("mrnet@5.0.1:+lwthreads+krellpatch") depends_on("mrnet@5.0.1:+lwthreads")
depends_on("cbtf") depends_on("cbtf")
depends_on("cbtf-krell") depends_on("cbtf-krell")
depends_on("cuda@6.0.37") depends_on("cuda")
# depends_on("cuda")
parallel = False parallel = False

View File

@ -74,7 +74,7 @@ class CbtfKrell(Package):
description="Build mpi experiment collector for mpich MPI.") description="Build mpi experiment collector for mpich MPI.")
# Dependencies for cbtf-krell # Dependencies for cbtf-krell
depends_on("cmake@3.0.2", type='build') depends_on("cmake@3.0.2:", type='build')
# For binutils service # For binutils service
depends_on("binutils@2.24+krellpatch") depends_on("binutils@2.24+krellpatch")
@ -82,7 +82,7 @@ class CbtfKrell(Package):
# collectionTool # collectionTool
depends_on("boost@1.50.0:") depends_on("boost@1.50.0:")
depends_on("dyninst@8.2.1:") depends_on("dyninst@8.2.1:")
depends_on("mrnet@5.0.1:+lwthreads+krellpatch") depends_on("mrnet@5.0.1:+lwthreads")
depends_on("xerces-c@3.1.1:") depends_on("xerces-c@3.1.1:")
depends_on("cbtf") depends_on("cbtf")
@ -138,34 +138,22 @@ def set_mpi_cmakeOptions(self, spec, cmakeOptions):
# openmpi # openmpi
if '+openmpi' in spec: if '+openmpi' in spec:
MPIOptions.extend([ MPIOptions.append('-DOPENMPI_DIR=%s' % spec['openmpi'].prefix)
'-DOPENMPI_DIR=%s' % spec['openmpi'].prefix
])
# mpich # mpich
if '+mpich' in spec: if '+mpich' in spec:
MPIOptions.extend([ MPIOptions.append('-DMPICH_DIR=%s' % spec['mpich'].prefix)
'-DMPICH_DIR=%s' % spec['mpich'].prefix
])
# mpich2 # mpich2
if '+mpich2' in spec: if '+mpich2' in spec:
MPIOptions.extend([ MPIOptions.append('-DMPICH2_DIR=%s' % spec['mpich2'].prefix)
'-DMPICH2_DIR=%s' % spec['mpich2'].prefix
])
# mvapich # mvapich
if '+mvapich' in spec: if '+mvapich' in spec:
MPIOptions.extend([ MPIOptions.append('-DMVAPICH_DIR=%s' % spec['mvapich'].prefix)
'-DMVAPICH_DIR=%s' % spec['mvapich'].prefix
])
# mvapich2 # mvapich2
if '+mvapich2' in spec: if '+mvapich2' in spec:
MPIOptions.extend([ MPIOptions.append('-DMVAPICH2_DIR=%s' % spec['mvapich2'].prefix)
'-DMVAPICH2_DIR=%s' % spec['mvapich2'].prefix
])
# mpt # mpt
if '+mpt' in spec: if '+mpt' in spec:
MPIOptions.extend([ MPIOptions.append('-DMPT_DIR=%s' % spec['mpt'].prefix)
'-DMPT_DIR=%s' % spec['mpt'].prefix
])
cmakeOptions.extend(MPIOptions) cmakeOptions.extend(MPIOptions)

View File

@ -55,9 +55,9 @@ class CbtfLanl(Package):
version('1.6', branch='master', version('1.6', branch='master',
git='http://git.code.sf.net/p/cbtf-lanl/cbtf-lanl') git='http://git.code.sf.net/p/cbtf-lanl/cbtf-lanl')
depends_on("cmake@3.0.2", type='build') depends_on("cmake@3.0.2:", type='build')
# Dependencies for cbtf-krell # Dependencies for cbtf-krell
depends_on("mrnet@5.0.1:+lwthreads+krellpatch") depends_on("mrnet@5.0.1:+lwthreads")
depends_on("xerces-c@3.1.1:") depends_on("xerces-c@3.1.1:")
depends_on("cbtf") depends_on("cbtf")
depends_on("cbtf-krell") depends_on("cbtf-krell")

View File

@ -63,9 +63,9 @@ class Cbtf(Package):
variant('runtime', default=False, variant('runtime', default=False,
description="build only the runtime libraries and collectors.") description="build only the runtime libraries and collectors.")
depends_on("cmake@3.0.2", type='build') depends_on("cmake@3.0.2:", type='build')
depends_on("boost@1.50.0:") depends_on("boost@1.50.0:")
depends_on("mrnet@5.0.1:+lwthreads+krellpatch") depends_on("mrnet@5.0.1:+lwthreads")
depends_on("xerces-c@3.1.1:") depends_on("xerces-c@3.1.1:")
# Work around for spack libxml2 package bug, take off python when fixed # Work around for spack libxml2 package bug, take off python when fixed
depends_on("libxml2+python") depends_on("libxml2+python")

View File

@ -37,13 +37,6 @@ class Mrnet(Package):
version('4.1.0', '5a248298b395b329e2371bf25366115c') version('4.1.0', '5a248298b395b329e2371bf25366115c')
version('4.0.0', 'd00301c078cba57ef68613be32ceea2f') version('4.0.0', 'd00301c078cba57ef68613be32ceea2f')
# Add a patch that brings mrnet-5.0.1 up to date with the current
# development tree The development tree contains fixes needed for the
# krell based tools
variant('krellpatch', default=False,
description="Build MRNet with krell openspeedshop based patch.")
patch('krell-5.0.1.patch', when='@5.0.1+krellpatch')
variant('lwthreads', default=False, variant('lwthreads', default=False,
description="Also build the MRNet LW threadsafe libraries") description="Also build the MRNet LW threadsafe libraries")
parallel = False parallel = False
@ -51,8 +44,8 @@ class Mrnet(Package):
depends_on("boost") depends_on("boost")
def install(self, spec, prefix): def install(self, spec, prefix):
# Build the MRNet LW thread safe libraries when the krelloptions # Build the MRNet LW thread safe libraries when the
# variant is present # lwthreads variant is present
if '+lwthreads' in spec: if '+lwthreads' in spec:
configure("--prefix=%s" % prefix, "--enable-shared", configure("--prefix=%s" % prefix, "--enable-shared",
"--enable-ltwt-threadsafe") "--enable-ltwt-threadsafe")

View File

@ -22,39 +22,41 @@
# License along with this program; if not, write to the Free Software # License along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
############################################################################## ##############################################################################
########################################################################## ##############################################################################
# Copyright (c) 2015-2016 Krell Institute. All Rights Reserved. # Copyright (c) 2015-2016 Krell Institute. All Rights Reserved.
# #
# This program is free software; you can redistribute it and/or modify it under # This program is free software; you can redistribute it and/or modify it
# the terms of the GNU General Public License as published by the Free Software # under the terms of the GNU General Public License as published by the Free
# Foundation; either version 2 of the License, or (at your option) any later # Software Foundation; either version 2 of the License, or (at your option)
# version. # any later version.
# #
# This program is distributed in the hope that it will be useful, but WITHOUT # This program is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
# details. # more details.
# #
# You should have received a copy of the GNU General Public License along with # You should have received a copy of the GNU General Public License along with
# this program; if not, write to the Free Software Foundation, Inc., 59 Temple # this program; if not, write to the Free Software Foundation, Inc., 59 Temple
# Place, Suite 330, Boston, MA 02111-1307 USA # Place, Suite 330, Boston, MA 02111-1307 USA
########################################################################## ##############################################################################
from spack import * from spack import *
import os
import os.path
class Openspeedshop(Package): class Openspeedshop(Package):
"""OpenSpeedShop is a community effort by The Krell Institute with """OpenSpeedShop is a community effort by The Krell Institute with
current direct funding from DOEs NNSA. It builds on top of a broad current direct funding from DOEs NNSA. It builds on top of a
list of community infrastructures, most notably Dyninst and MRNet broad list of community infrastructures, most notably Dyninst
from UW, libmonitor from Rice, and PAPI from UTK. OpenSpeedShop is an and MRNet from UW, libmonitor from Rice, and PAPI from UTK.
open source multi platform Linux performance tool which is targeted OpenSpeedShop is an open source multi platform Linux performance
to support performance analysis of applications running on both tool which is targeted to support performance analysis of
single node and large scale IA64, IA32, EM64T, AMD64, PPC, ARM, Blue applications running on both single node and large scale IA64,
Gene and Cray platforms. OpenSpeedShop development is hosted by the IA32, EM64T, AMD64, PPC, ARM, Power8, Intel Phi, Blue Gene and
Krell Institute. The infrastructure and base components of Cray platforms. OpenSpeedShop development is hosted by the Krell
OpenSpeedShop are released as open source code primarily under LGPL. Institute. The infrastructure and base components of OpenSpeedShop
are released as open source code primarily under LGPL.
""" """
homepage = "http://www.openspeedshop.org" homepage = "http://www.openspeedshop.org"
@ -65,45 +67,51 @@ class Openspeedshop(Package):
git='https://github.com/OpenSpeedShop/openspeedshop.git') git='https://github.com/OpenSpeedShop/openspeedshop.git')
# Optional mirror template # Optional mirror template
# url="file:/home/jeg/OpenSpeedShop_ROOT/SOURCES/openspeedshop-2.2.tar.gz" # url = "file:/home/jeg/OpenSpeedShop_ROOT/SOURCES/openspeedshop-2.2.tar.gz"
# version('2.2', '643337740dc6c2faca60f42d3620b0e1') # version('2.2', '517a7798507241ad8abd8b0626a4d2cf')
parallel = False parallel = False
variant('offline', default=True, variant('offline', default=False,
description="build with offline instrumentor enabled.") description="build with offline instrumentor enabled.")
variant('cbtf', default=False, variant('cbtf', default=True,
description="build with cbtf instrumentor enabled.") description="build with cbtf instrumentor enabled.")
variant('runtime', default=False, variant('runtime', default=False,
description="build only the runtime libraries and collectors.") description="build only the runtime libraries and collectors.")
variant('frontend', default=False, variant('frontend', default=False,
description="build only the front-end tool using the runtime_dir " description="build only the FE tool using the runtime_dir \
"to point to the target build.") to point to target build.")
variant('cuda', default=False, variant('cuda', default=False,
description="build with cuda packages included.") description="build with cuda packages included.")
variant('ptgf', default=False, variant('ptgf', default=False,
description="build with the PTGF based gui package enabled.") description="build with the PTGF based gui package enabled.")
variant('rtfe', default=False, variant('rtfe', default=False,
description="build for generic cluster platforms that have " description="build for clusters heterogeneous processors \
"different processors on the fe and be nodes.") on fe/be nodes.")
# MPI variants # MPI variants
variant('openmpi', default=False, variant('openmpi', default=False,
description="Build mpi experiment collector for openmpi MPI.") description="Build mpi collector for openmpi \
MPI when variant is enabled.")
variant('mpt', default=False, variant('mpt', default=False,
description="Build mpi experiment collector for SGI MPT MPI.") description="Build mpi collector for SGI \
MPT MPI when variant is enabled.")
variant('mvapich2', default=False, variant('mvapich2', default=False,
description="Build mpi experiment collector for mvapich2 MPI.") description="Build mpi collector for mvapich2\
MPI when variant is enabled.")
variant('mvapich', default=False, variant('mvapich', default=False,
description="Build mpi experiment collector for mvapich MPI.") description="Build mpi collector for mvapich\
MPI when variant is enabled.")
variant('mpich2', default=False, variant('mpich2', default=False,
description="Build mpi experiment collector for mpich2 MPI.") description="Build mpi collector for mpich2\
MPI when variant is enabled.")
variant('mpich', default=False, variant('mpich', default=False,
description="Build mpi experiment collector for mpich MPI.") description="Build mpi collector for mpich\
MPI when variant is enabled.")
depends_on("cmake@3.0.2", type='build') depends_on("cmake@3.0.2:", type='build')
# Dependencies for openspeedshop that are common to all the variants of # Dependencies for openspeedshop that are common to all
# the OpenSpeedShop build # the variants of the OpenSpeedShop build
depends_on("bison", type='build') depends_on("bison", type='build')
depends_on("flex", type='build') depends_on("flex", type='build')
depends_on("binutils@2.24+krellpatch", type='build') depends_on("binutils@2.24+krellpatch", type='build')
@ -111,7 +119,7 @@ class Openspeedshop(Package):
depends_on("libdwarf") depends_on("libdwarf")
depends_on("sqlite") depends_on("sqlite")
depends_on("boost@1.50.0:") depends_on("boost@1.50.0:")
depends_on("dyninst@9.1.0") depends_on("dyninst@9.1.0:")
depends_on("python") depends_on("python")
depends_on("qt@3.3.8b+krellpatch") depends_on("qt@3.3.8b+krellpatch")
@ -130,16 +138,16 @@ class Openspeedshop(Package):
depends_on("cbtf", when='+cbtf') depends_on("cbtf", when='+cbtf')
depends_on("cbtf-krell", when='+cbtf') depends_on("cbtf-krell", when='+cbtf')
depends_on("cbtf-argonavis", when='+cbtf+cuda') depends_on("cbtf-argonavis", when='+cbtf+cuda')
depends_on("mrnet@5.0.1:+lwthreads+krellpatch", when='+cbtf') depends_on("mrnet@5.0.1:+lwthreads", when='+cbtf')
def adjustBuildTypeParams_cmakeOptions(self, spec, cmakeOptions): def adjustBuildTypeParams_cmakeOptions(self, spec, cmakeOptions):
# Sets build type parameters into cmakeOptions the options that will # Sets build type parameters into cmakeOptions the
# enable the cbtf-krell built type settings # options that will enable the cbtf-krell built type settings
compile_flags = "-O2 -g" compile_flags = "-O2 -g"
BuildTypeOptions = [] BuildTypeOptions = []
# Set CMAKE_BUILD_TYPE to what cbtf-krell wants it to be, not the # Set CMAKE_BUILD_TYPE to what cbtf-krell wants it
# stdcmakeargs # to be, not the stdcmakeargs
for word in cmakeOptions[:]: for word in cmakeOptions[:]:
if word.startswith('-DCMAKE_BUILD_TYPE'): if word.startswith('-DCMAKE_BUILD_TYPE'):
cmakeOptions.remove(word) cmakeOptions.remove(word)
@ -147,68 +155,131 @@ def adjustBuildTypeParams_cmakeOptions(self, spec, cmakeOptions):
cmakeOptions.remove(word) cmakeOptions.remove(word)
if word.startswith('-DCMAKE_C_FLAGS'): if word.startswith('-DCMAKE_C_FLAGS'):
cmakeOptions.remove(word) cmakeOptions.remove(word)
BuildTypeOptions.extend([ BuildTypeOptions.extend(['-DCMAKE_BUILD_TYPE=None',
'-DCMAKE_BUILD_TYPE=None',
'-DCMAKE_CXX_FLAGS=%s' % compile_flags, '-DCMAKE_CXX_FLAGS=%s' % compile_flags,
'-DCMAKE_C_FLAGS=%s' % compile_flags '-DCMAKE_C_FLAGS=%s' % compile_flags])
])
cmakeOptions.extend(BuildTypeOptions) cmakeOptions.extend(BuildTypeOptions)
def set_defaultbase_cmakeOptions(self, spec, cmakeOptions):
# Appends to cmakeOptions the options that will enable
# the appropriate base level options to the openspeedshop
# cmake build.
python_vers = format(spec['python'].version.up_to(2))
python_pv = '/python' + python_vers
python_pvs = '/libpython' + python_vers + '.' + format(dso_suffix)
BaseOptions = []
BaseOptions.append('-DBINUTILS_DIR=%s' % spec['binutils'].prefix)
BaseOptions.append('-DLIBELF_DIR=%s' % spec['libelf'].prefix)
BaseOptions.append('-DLIBDWARF_DIR=%s' % spec['libdwarf'].prefix)
BaseOptions.append(
'-DPYTHON_EXECUTABLE=%s'
% join_path(spec['python'].prefix + '/bin/python'))
BaseOptions.append(
'-DPYTHON_INCLUDE_DIR=%s'
% join_path(spec['python'].prefix.include) + python_pv)
BaseOptions.append(
'-DPYTHON_LIBRARY=%s'
% join_path(spec['python'].prefix.lib) + python_pvs)
BaseOptions.append('-DBoost_NO_SYSTEM_PATHS=TRUE')
BaseOptions.append('-DBoost_NO_BOOST_CMAKE=TRUE')
BaseOptions.append('-DBOOST_ROOT=%s' % spec['boost'].prefix)
BaseOptions.append('-DBoost_DIR=%s' % spec['boost'].prefix)
BaseOptions.append('-DBOOST_LIBRARYDIR=%s' % spec['boost'].prefix.lib)
BaseOptions.append('-DDYNINST_DIR=%s' % spec['dyninst'].prefix)
cmakeOptions.extend(BaseOptions)
def set_mpi_cmakeOptions(self, spec, cmakeOptions): def set_mpi_cmakeOptions(self, spec, cmakeOptions):
# Appends to cmakeOptions the options that will enable the appropriate # Appends to cmakeOptions the options that will enable
# MPI implementations # the appropriate MPI implementations
MPIOptions = [] MPIOptions = []
# openmpi # openmpi
if '+openmpi' in spec: if '+openmpi' in spec:
MPIOptions.extend([ MPIOptions.append('-DOPENMPI_DIR=%s' % spec['openmpi'].prefix)
'-DOPENMPI_DIR=%s' % spec['openmpi'].prefix
])
# mpich # mpich
if '+mpich' in spec: if '+mpich' in spec:
MPIOptions.extend([ MPIOptions.append('-DMPICH_DIR=%s' % spec['mpich'].prefix)
'-DMPICH_DIR=%s' % spec['mpich'].prefix
])
# mpich2 # mpich2
if '+mpich2' in spec: if '+mpich2' in spec:
MPIOptions.extend([ MPIOptions.append('-DMPICH2_DIR=%s' % spec['mpich2'].prefix)
'-DMPICH2_DIR=%s' % spec['mpich2'].prefix
])
# mvapich # mvapich
if '+mvapich' in spec: if '+mvapich' in spec:
MPIOptions.extend([ MPIOptions.append('-DMVAPICH_DIR=%s' % spec['mvapich'].prefix)
'-DMVAPICH_DIR=%s' % spec['mvapich'].prefix
])
# mvapich2 # mvapich2
if '+mvapich2' in spec: if '+mvapich2' in spec:
MPIOptions.extend([ MPIOptions.append('-DMVAPICH2_DIR=%s' % spec['mvapich2'].prefix)
'-DMVAPICH2_DIR=%s' % spec['mvapich2'].prefix
])
# mpt # mpt
if '+mpt' in spec: if '+mpt' in spec:
MPIOptions.extend([ MPIOptions.append('-DMPT_DIR=%s' % spec['mpt'].prefix)
'-DMPT_DIR=%s' % spec['mpt'].prefix
])
cmakeOptions.extend(MPIOptions) cmakeOptions.extend(MPIOptions)
def setup_environment(self, spack_env, run_env):
"""Set up the compile and runtime environments for a package."""
# Common settings to both offline and cbtf versions
# of OpenSpeedShop
run_env.prepend_path('PATH', self.prefix.bin)
# Find Dyninst library path, this is needed to
# set the DYNINSTAPI_RT_LIB library which is
# required for OpenSpeedShop to find loop level
# performance information
dyninst_libdir = find_libraries(['libdyninstAPI_RT'],
root=self.spec['dyninst'].prefix,
shared=True, recurse=True)
# Set Dyninst RT library path to support OSS loop resolution code
run_env.set('DYNINSTAPI_RT_LIB', dyninst_libdir)
# Find openspeedshop library path
oss_libdir = find_libraries(['libopenss-framework'],
root=self.spec['openspeedshop'].prefix,
shared=True, recurse=True)
run_env.prepend_path('LD_LIBRARY_PATH',
os.path.dirname(oss_libdir.joined()))
# Settings specific to the version, checking here
# for the cbtf instrumentor
if '+cbtf' in self.spec:
cbtf_mc = '/sbin/cbtf_mrnet_commnode'
cbtf_lmb = '/sbin/cbtf_libcbtf_mrnet_backend'
run_env.set('XPLAT_RSH', 'ssh')
run_env.set('MRNET_COMM_PATH',
join_path(self.spec['cbtf-krell'].prefix + cbtf_mc))
run_env.set('CBTF_MRNET_BACKEND_PATH',
join_path(self.spec['cbtf-krell'].prefix + cbtf_lmb))
run_env.prepend_path('PATH', self.spec['mrnet'].prefix.bin)
run_env.prepend_path('PATH', self.spec['cbtf-krell'].prefix.bin)
run_env.prepend_path('PATH', self.spec['cbtf-krell'].prefix.sbin)
elif '+offline' in self.spec:
# Had to use this form of syntax self.prefix.lib and
# self.prefix.lib64 returned None all the time
run_env.set('OPENSS_RAWDATA_DIR', '.')
run_env.set('OPENSS_PLUGIN_PATH',
join_path(oss_libdir + '/openspeedshop'))
run_env.prepend_path('PATH', self.spec['papi'].prefix.bin)
run_env.prepend_path('PATH', self.spec['libdwarf'].prefix.bin)
if '+mpich' in self.spec:
run_env.set('OPENSS_MPI_IMPLEMENTATION', 'mpich')
if '+mpich2' in self.spec:
run_env.set('OPENSS_MPI_IMPLEMENTATION', 'mpich2')
if '+mvapich2' in self.spec:
run_env.set('OPENSS_MPI_IMPLEMENTATION', 'mvapich2')
if '+openmpi' in self.spec:
run_env.set('OPENSS_MPI_IMPLEMENTATION', 'openmpi')
def install(self, spec, prefix): def install(self, spec, prefix):
# openmpi_prefix_path = "/opt/openmpi-1.8.2"
# mvapich_prefix_path = "/usr/local/tools/mvapich-gnu"
# '-DOPENMPI_DIR=%s' % spec['openmpi'].prefix,
# '-DOPENMPI_DIR=%s' % openmpi_prefix_path,
# '-DMVAPICH_DIR=%s' % mvapich_prefix_path,
# FIXME: How do we make this dynamic in spack?
# FIXME: That is, can we specify the paths to cuda dynamically?
# WAITING for external package support.
# if '+cuda' in spec:
# cuda_prefix_path = "/usr/local/cuda-6.0"
# cupti_prefix_path = "/usr/local/cuda-6.0/extras/CUPTI"
if '+offline' in spec: if '+offline' in spec:
instrumentor_setting = "offline" instrumentor_setting = "offline"
if '+runtime' in spec: if '+runtime' in spec:
@ -217,7 +288,6 @@ def install(self, spec, prefix):
cmakeOptions = [] cmakeOptions = []
cmakeOptions.extend([ cmakeOptions.extend([
'-DCMAKE_INSTALL_PREFIX=%s' % prefix, '-DCMAKE_INSTALL_PREFIX=%s' % prefix,
'-DCMAKE_LIBRARY_PATH=%s' % prefix.lib64,
'-DINSTRUMENTOR=%s' % instrumentor_setting, '-DINSTRUMENTOR=%s' % instrumentor_setting,
'-DLIBMONITOR_DIR=%s' % spec['libmonitor'].prefix, '-DLIBMONITOR_DIR=%s' % spec['libmonitor'].prefix,
'-DLIBUNWIND_DIR=%s' % spec['libunwind'].prefix, '-DLIBUNWIND_DIR=%s' % spec['libunwind'].prefix,
@ -227,8 +297,8 @@ def install(self, spec, prefix):
self.set_mpi_cmakeOptions(spec, cmakeOptions) self.set_mpi_cmakeOptions(spec, cmakeOptions)
cmakeOptions.extend(std_cmake_args) cmakeOptions.extend(std_cmake_args)
# Adjust the build options to the favored ones for this # Adjust the build options to the favored
# build # ones for this build
self.adjustBuildTypeParams_cmakeOptions(spec, cmakeOptions) self.adjustBuildTypeParams_cmakeOptions(spec, cmakeOptions)
cmake('..', *cmakeOptions) cmake('..', *cmakeOptions)
@ -239,50 +309,35 @@ def install(self, spec, prefix):
else: else:
cmake_prefix_path = join_path(spec['dyninst'].prefix) cmake_prefix_path = join_path(spec['dyninst'].prefix)
with working_dir('build', create=True): with working_dir('build', create=True):
# python_vers=join_path(spec['python'].version[:2])
# '-DOPENMPI_DIR=%s' % openmpi_prefix_path,
# '-DMVAPICH_DIR=%s' % mvapich_prefix_path,
# '-DMPICH_DIR=%s' % spec['mpich'].prefix,
# '-DMPICH2_DIR=%s' % spec['mpich2'].prefix,
# '-DBoost_NO_SYSTEM_PATHS=TRUE',
# '-DBOOST_ROOT=%s' % spec['boost'].prefix,
# '-DOPENMPI_DIR=%s' % spec['openmpi'].prefix,
python_vers = '%d.%d' % spec['python'].version[:2]
cmakeOptions = [] cmakeOptions = []
cmakeOptions.extend([
'-DCMAKE_INSTALL_PREFIX=%s' % prefix, # Appends base options to cmakeOptions
'-DCMAKE_LIBRARY_PATH=%s' % prefix.lib64, self.set_defaultbase_cmakeOptions(spec, cmakeOptions)
'-DCMAKE_PREFIX_PATH=%s' % cmake_prefix_path,
'-DINSTRUMENTOR=%s' % instrumentor_setting, cmakeOptions.extend(
'-DBINUTILS_DIR=%s' % spec['binutils'].prefix, ['-DCMAKE_INSTALL_PREFIX=%s'
'-DLIBELF_DIR=%s' % spec['libelf'].prefix, % prefix,
'-DLIBDWARF_DIR=%s' % spec['libdwarf'].prefix, '-DCMAKE_PREFIX_PATH=%s'
'-DLIBMONITOR_DIR=%s' % spec['libmonitor'].prefix, % cmake_prefix_path,
'-DLIBUNWIND_DIR=%s' % spec['libunwind'].prefix, '-DINSTRUMENTOR=%s'
'-DPAPI_DIR=%s' % spec['papi'].prefix, % instrumentor_setting,
'-DSQLITE3_DIR=%s' % spec['sqlite'].prefix, '-DLIBMONITOR_DIR=%s'
'-DQTLIB_DIR=%s' % spec['qt'].prefix, % spec['libmonitor'].prefix,
'-DPYTHON_EXECUTABLE=%s' % join_path( '-DLIBUNWIND_DIR=%s'
spec['python'].prefix, '/bin/python'), % spec['libunwind'].prefix,
'-DPYTHON_INCLUDE_DIR=%s' % join_path( '-DPAPI_DIR=%s'
spec['python'].prefix.include, % spec['papi'].prefix,
'python' + python_vers), '-DSQLITE3_DIR=%s'
'-DPYTHON_LIBRARY=%s' % join_path( % spec['sqlite'].prefix,
spec['python'].prefix.lib, '-DQTLIB_DIR=%s'
'libpython' + python_vers + '.so'), % spec['qt'].prefix])
'-DBoost_NO_SYSTEM_PATHS=TRUE',
'-DBOOST_ROOT=%s' % spec['boost'].prefix,
'-DDYNINST_DIR=%s' % spec['dyninst'].prefix])
# Add any MPI implementations coming from variant settings # Add any MPI implementations coming from variant settings
self.set_mpi_cmakeOptions(spec, cmakeOptions) self.set_mpi_cmakeOptions(spec, cmakeOptions)
cmakeOptions.extend(std_cmake_args) cmakeOptions.extend(std_cmake_args)
# Adjust the build options to the favored ones for this # Adjust the build options to the favored
# build # ones for this build
self.adjustBuildTypeParams_cmakeOptions(spec, cmakeOptions) self.adjustBuildTypeParams_cmakeOptions(spec, cmakeOptions)
cmake('..', *cmakeOptions) cmake('..', *cmakeOptions)
@ -293,74 +348,37 @@ def install(self, spec, prefix):
elif '+cbtf' in spec: elif '+cbtf' in spec:
instrumentor_setting = "cbtf" instrumentor_setting = "cbtf"
cmake_prefix_path = ':'.join(spec['cbtf'].prefix,
spec['cbtf-krell'].prefix,
spec['dyninst'].prefix)
# resolve_symbols = "symtabapi" # resolve_symbols = "symtabapi"
# runtime_platform_cray = "cray" cmake_prefix_path = join_path(spec['cbtf'].prefix) \
# if '+cray' in spec: + ':' + join_path(spec['cbtf-krell'].prefix)\
# if '+runtime' in spec: + ':' + join_path(spec['dyninst'].prefix)
# #-DCBTF_KRELL_CN_RUNTIME_DIR=${CBTF_KRELL_CN_INSTALL_DIR} \
# with working_dir('build_cbtf_cray_runtime', create=True):
# python_vers='%d.%d' % spec['python'].version[:2]
# cmake('..',
# '-DCMAKE_INSTALL_PREFIX=%s' % prefix,
# '-DCMAKE_LIBRARY_PATH=%s' % prefix.lib64,
# '-DRUNTIME_PLATFORM=%s' % runtime_platform_cray,
# '-DCMAKE_PREFIX_PATH=%s' % cmake_prefix_path,
# '-DRESOLVE_SYMBOLS=%s' % resolve_symbols,
# '-DINSTRUMENTOR=%s' % instrumentor_setting,
# '-DCBTF_DIR=%s' % spec['cbtf'].prefix,
# '-DCBTF_KRELL_DIR=%s' % spec['cbtf-krell'].prefix,
# '-DCBTF_KRELL_CN_RUNTIME_DIR=%s' % spec['cbtf-krell'].prefix,
# '-DBINUTILS_DIR=%s' % spec['binutils'].prefix,
# '-DLIBELF_DIR=%s' % spec['libelf'].prefix,
# '-DLIBDWARF_DIR=%s' % spec['libdwarf'].prefix,
# '-DLIBUNWIND_DIR=%s' % spec['libunwind'].prefix,
# '-DPAPI_DIR=%s' % spec['papi'].prefix,
# '-DDYNINST_DIR=%s' % spec['dyninst'].prefix,
# '-DXERCESC_DIR=%s' % spec['xerces-c'].prefix,
# '-DMRNET_DIR=%s' % spec['mrnet'].prefix,
# '-DBoost_NO_SYSTEM_PATHS=TRUE',
# '-DBOOST_ROOT=%s' % spec['boost'].prefix,
# *std_cmake_args)
# make("clean")
# make()
# make("install")
# elif '+mic' in spec:
# comment out else and shift over the default case below
# until arch detection is in else:
if '+runtime' in spec: if '+runtime' in spec:
with working_dir('build_cbtf_runtime', create=True): with working_dir('build_cbtf_runtime', create=True):
python_vers = '%d.%d' % spec['python'].version[:2] cmakeOptions = []
cmake(
'..', # Appends base options to cmakeOptions
'-DCMAKE_INSTALL_PREFIX=%s' % prefix, self.set_defaultbase_cmakeOptions(spec, cmakeOptions)
'-DCMAKE_LIBRARY_PATH=%s' % prefix.lib64,
'-DCMAKE_PREFIX_PATH=%s' % cmake_prefix_path, cmakeOptions.extend(
'-DINSTRUMENTOR=%s' % instrumentor_setting, ['-DCMAKE_INSTALL_PREFIX=%s'
'-DBINUTILS_DIR=%s' % spec['binutils'].prefix, % prefix,
'-DLIBELF_DIR=%s' % spec['libelf'].prefix, '-DCMAKE_PREFIX_PATH=%s'
'-DLIBDWARF_DIR=%s' % spec['libdwarf'].prefix, % cmake_prefix_path,
'-DCBTF_DIR=%s' % spec['cbtf'].prefix, '-DINSTRUMENTOR=%s'
'-DCBTF_KRELL_DIR=%s' % spec['cbtf-krell'].prefix, % instrumentor_setting,
'-DPYTHON_EXECUTABLE=%s' % join_path( '-DCBTF_DIR=%s'
spec['python'].prefix, 'bin', 'python'), % spec['cbtf'].prefix,
'-DPYTHON_INCLUDE_DIR=%s' % join_path( '-DCBTF_KRELL_DIR=%s'
spec['python'].prefix.include, % spec['cbtf-krell'].prefix,
'python' + python_vers), '-DMRNET_DIR=%s'
'-DPYTHON_LIBRARY=%s' % join_path( % spec['mrnet'].prefix])
spec['python'].prefix.lib,
'libpython' + python_vers + '.so'), # Adjust the build options to the
'-DBoost_NO_SYSTEM_PATHS=TRUE', # favored ones for this build
'-DBOOST_ROOT=%s' % spec['boost'].prefix, self.adjustBuildTypeParams_cmakeOptions(spec, cmakeOptions)
'-DDYNINST_DIR=%s' % spec['dyninst'].prefix,
'-DMRNET_DIR=%s' % spec['mrnet'].prefix, cmake('..', *cmakeOptions)
*std_cmake_args)
make("clean") make("clean")
make() make()
@ -368,96 +386,35 @@ def install(self, spec, prefix):
else: else:
with working_dir('build_cbtf', create=True): with working_dir('build_cbtf', create=True):
python_vers = '%d.%d' % spec['python'].version[:2] cmakeOptions = []
# python_vers=join_path(spec['python'].version[:2])
cmake( # Appends base options to cmakeOptions
'..', self.set_defaultbase_cmakeOptions(spec, cmakeOptions)
'-DCMAKE_INSTALL_PREFIX=%s' % prefix,
'-DCMAKE_LIBRARY_PATH=%s' % prefix.lib64, cmakeOptions.extend(
'-DCMAKE_PREFIX_PATH=%s' % cmake_prefix_path, ['-DCMAKE_INSTALL_PREFIX=%s'
'-DINSTRUMENTOR=%s' % instrumentor_setting, % prefix,
'-DBINUTILS_DIR=%s' % spec['binutils'].prefix, '-DCMAKE_PREFIX_PATH=%s'
'-DLIBELF_DIR=%s' % spec['libelf'].prefix, % cmake_prefix_path,
'-DLIBDWARF_DIR=%s' % spec['libdwarf'].prefix, '-DINSTRUMENTOR=%s'
'-DSQLITE3_DIR=%s' % spec['sqlite'].prefix, % instrumentor_setting,
'-DCBTF_DIR=%s' % spec['cbtf'].prefix, '-DSQLITE3_DIR=%s'
'-DCBTF_KRELL_DIR=%s' % spec['cbtf-krell'].prefix, % spec['sqlite'].prefix,
'-DQTLIB_DIR=%s' % spec['qt'].prefix, '-DCBTF_DIR=%s'
'-DPYTHON_EXECUTABLE=%s' % join_path( % spec['cbtf'].prefix,
spec['python'].prefix, 'bin', 'python'), '-DCBTF_KRELL_DIR=%s'
'-DPYTHON_INCLUDE_DIR=%s' % join_path( % spec['cbtf-krell'].prefix,
spec['python'].prefix.include, '-DQTLIB_DIR=%s'
'python' + python_vers), % spec['qt'].prefix,
'-DPYTHON_LIBRARY=%s' % join_path( '-DMRNET_DIR=%s'
spec['python'].prefix.lib, % spec['mrnet'].prefix])
'libpython' + python_vers + '.so'),
'-DBoost_NO_SYSTEM_PATHS=TRUE', # Adjust the build options to the favored
'-DBOOST_ROOT=%s' % spec['boost'].prefix, # ones for this build
'-DDYNINST_DIR=%s' % spec['dyninst'].prefix, self.adjustBuildTypeParams_cmakeOptions(spec, cmakeOptions)
'-DMRNET_DIR=%s' % spec['mrnet'].prefix,
*std_cmake_args) cmake('..', *cmakeOptions)
make("clean") make("clean")
make() make()
make("install") make("install")
# if '+frontend' in spec:
# with working_dir('build_frontend', create=True):
# tbd
# if '+cbtf' in spec:
# if cray build type detected:
# if '+runtime' in spec:
# with working_dir('build_cray_cbtf_compute', create=True):
# tbd
# else:
# with working_dir('build_cray_cbtf_frontend', create=True):
# tbd
# with working_dir('build_cray_osscbtf_frontend', create=True):
# tbd
# fi
# elif '+intelmic' in spec:
# if '+runtime' in spec:
# with working_dir('build_intelmic_cbtf_compute', create=True):
# tbd
# else:
# with working_dir('build_intelmic_cbtf_frontend', create=True):
# tbd
# with working_dir('build_intelmic_osscbtf_frontend', create=True):
# fi
# else
# with working_dir('build_cluster_cbtf', create=True):
# tbd
# with working_dir('build_cluster osscbtf', create=True):
# tbd
# fi
# elif '+offline' in spec:
# if cray build type detected:
# if '+runtime' in spec:
# with working_dir('build_cray_ossoff_compute', create=True):
# tbd
# else:
# with working_dir('build_cray_ossoff_frontend', create=True):
# tbd
# fi
# elif '+intelmic' in spec:
# if '+runtime' in spec:
# with working_dir('build_intelmic_ossoff_compute', create=True):
# tbd
# else:
# with working_dir('build_intelmic_ossoff_frontend', create=True):
# tbd
# fi
# elif bgq build type detected:
# if '+runtime' in spec:
# with working_dir('build_bgq_ossoff_compute', create=True):
# tbd
# else:
# with working_dir('build_bgq_ossoff_frontend', create=True):
# tbd
# fi
# else
# with working_dir('build_cluster ossoff', create=True):
# tbd
# fi
# fi