
* 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. * Add libxml2+python depends on to get around issues with the libxml2 package file. * Using boost over 1.60.0 causes compile errors. This is a known boost bug. Also, dyninst-9.2.0 is set to be the vesrion of dyninst to use with OSS, as of now. The newer version fails to build. * Fix bad syntax in specifying the boost version range. * Update the version numbers for the krell institute components and tools: cbtf and openspeedshop. * Do not build glib for qt3, it is not needed and causes build problems at this time anyway. * A fix was added for setting LD_LIBRARY_PATH in the qt3 build, but if LD_LIBRARY_PATH is not set the qt build fails. So so check and set LD_LIBRARY_PATH if not set, update if it is set. * Update the fix for qt3 build by setting LD_LIBRARY_PATH instead of checking for whether it is set or not per Adams comment that spack clears LD_LIBRARY_PATH. * A fix was added for setting LD_LIBRARY_PATH in the qt3 build, but if LD_LIBRARY_PATH is not set the qt build fails. So so check and set LD_LIBRARY_PATH if not set, update if it is set. * Trim comments to fit more concisely. * Fix tabs versus spaces and swap if and else clause check from a negative to a positive check. * Fix issues with the cbtf-argonavis build, update to use dyninst-9.3.2, fixes to openspeedshop package build. * Fix issues with the cbtf-argonavis package.py files related to comments. * Add changes for changing the krell packages from Package to CMakePackage. * Add better changes for changing the krell packages from Package to CMakePackage. * Add more modifications for changing the krell packages from Package to CMakePackage. * Add additional modifications for changing the krell packages from Package to CMakePackage and fixing Travis erros * Fix new travis errors. * Fix new travis errors. * Add more changes for PR 4765. * Add more refinements to the conversion from Package to CMakePackage. * Fix new travis errors. * Add dependencies for MPI to be passed to cbtf-krell, so it can build the MPI collectors requested by the builder of openspeedshop. * Remove extra unnecessary routine to adjust build arguments. Fix if-else clause issue. * Fix more flake issues caused by last changes. * Fix a bug where openspeedshop will not build when no mpi variants are specified. Also switch to a multiple level variant for building the gui(s). Use none, qt3, and qt4 as the variants with qt3 being the default. * Add fix for spack issue #4843, where LTDL include files were not found. * Add the build_type variant back into the openspeedshop package file.
344 lines
15 KiB
Python
344 lines
15 KiB
Python
##############################################################################
|
|
# Copyright (c) 2013-2017, Lawrence Livermore National Security, LLC.
|
|
# Produced at the Lawrence Livermore National Laboratory.
|
|
#
|
|
# This file is part of Spack.
|
|
# Created by Todd Gamblin, tgamblin@llnl.gov, All rights reserved.
|
|
# LLNL-CODE-647188
|
|
#
|
|
# For details, see https://github.com/llnl/spack
|
|
# Please also see the NOTICE and LICENSE files for our notice and the LGPL.
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU Lesser General Public License (as
|
|
# published by the Free Software Foundation) version 2.1, February 1999.
|
|
#
|
|
# 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 FOR A PARTICULAR PURPOSE. See the terms and
|
|
# conditions of the GNU Lesser General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Lesser General Public
|
|
# License along with this program; if not, write to the Free Software
|
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
##############################################################################
|
|
##############################################################################
|
|
# Copyright (c) 2015-2017 Krell Institute. All Rights Reserved.
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify it
|
|
# under the terms of the GNU General Public License as published by the Free
|
|
# Software Foundation; either version 2 of the License, or (at your option)
|
|
# any later version.
|
|
#
|
|
# 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 FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
|
# more details.
|
|
#
|
|
# 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
|
|
# Place, Suite 330, Boston, MA 02111-1307 USA
|
|
##############################################################################
|
|
|
|
from spack import *
|
|
import os
|
|
import os.path
|
|
|
|
|
|
class Openspeedshop(CMakePackage):
|
|
"""OpenSpeedShop is a community effort by The Krell Institute with
|
|
current direct funding from DOEs NNSA. It builds on top of a
|
|
broad list of community infrastructures, most notably Dyninst
|
|
and MRNet from UW, libmonitor from Rice, and PAPI from UTK.
|
|
OpenSpeedShop is an open source multi platform Linux performance
|
|
tool which is targeted to support performance analysis of
|
|
applications running on both single node and large scale IA64,
|
|
IA32, EM64T, AMD64, PPC, ARM, Power8, Intel Phi, Blue Gene and
|
|
Cray platforms. OpenSpeedShop development is hosted by the Krell
|
|
Institute. The infrastructure and base components of OpenSpeedShop
|
|
are released as open source code primarily under LGPL.
|
|
"""
|
|
|
|
homepage = "http://www.openspeedshop.org"
|
|
url = "https://github.com/OpenSpeedShop"
|
|
|
|
# Use when the git repository is available
|
|
version('2.3', branch='master',
|
|
git='https://github.com/OpenSpeedShop/openspeedshop.git')
|
|
|
|
variant('offline', default=False,
|
|
description="build with offline instrumentor enabled.")
|
|
variant('cbtf', default=True,
|
|
description="build with cbtf instrumentor enabled.")
|
|
variant('runtime', default=False,
|
|
description="build only the runtime libraries and collectors.")
|
|
variant('frontend', default=False,
|
|
description="build only the FE tool using the runtime_dir \
|
|
to point to target build.")
|
|
variant('cuda', default=False,
|
|
description="build with cuda packages included.")
|
|
|
|
variant('gui', default='qt3', values=('none', 'qt3', 'qt4'),
|
|
description='Build or not build a GUI of choice'
|
|
)
|
|
|
|
variant('build_type', default='None', values=('None'),
|
|
description='CMake build type')
|
|
|
|
# MPI variants
|
|
variant('openmpi', default=False,
|
|
description="Build mpi collector for openmpi \
|
|
MPI when variant is enabled.")
|
|
variant('mpt', default=False,
|
|
description="Build mpi collector for SGI \
|
|
MPT MPI when variant is enabled.")
|
|
variant('mvapich2', default=False,
|
|
description="Build mpi collector for mvapich2\
|
|
MPI when variant is enabled.")
|
|
variant('mvapich', default=False,
|
|
description="Build mpi collector for mvapich\
|
|
MPI when variant is enabled.")
|
|
variant('mpich2', default=False,
|
|
description="Build mpi collector for mpich2\
|
|
MPI when variant is enabled.")
|
|
variant('mpich', default=False,
|
|
description="Build mpi collector for mpich\
|
|
MPI when variant is enabled.")
|
|
|
|
depends_on("cmake@3.0.2:", type='build')
|
|
# Dependencies for openspeedshop that are common to all
|
|
# the variants of the OpenSpeedShop build
|
|
depends_on("libtool", type='build')
|
|
depends_on("bison", type='build')
|
|
depends_on("flex", type='build')
|
|
depends_on("binutils@2.24+krellpatch", type='build')
|
|
depends_on("elf", type="link")
|
|
depends_on("libdwarf")
|
|
depends_on("sqlite")
|
|
depends_on("boost@1.50.0:1.59.0")
|
|
depends_on("dyninst@9.3.2")
|
|
depends_on("libxml2+python")
|
|
depends_on("qt@3.3.8b+krellpatch", when='gui=qt3')
|
|
# Actively working on adding this gui package
|
|
# depends_on("cbtf-argonavis-gui", when='gui=qt4')
|
|
|
|
# Dependencies only for the openspeedshop offline package.
|
|
depends_on("libunwind", when='+offline')
|
|
depends_on("papi", when='+offline')
|
|
depends_on("libmonitor+krellpatch", when='+offline')
|
|
depends_on("openmpi", when='+offline+openmpi')
|
|
depends_on("mpich", when='+offline+mpich')
|
|
depends_on("mpich2", when='+offline+mpich2')
|
|
depends_on("mvapich2", when='+offline+mvapich2')
|
|
depends_on("mvapich", when='+offline+mvapich')
|
|
depends_on("mpt", when='+offline+mpt')
|
|
|
|
# Dependencies only for the openspeedshop cbtf package.
|
|
depends_on("cbtf", when='+cbtf')
|
|
depends_on('cbtf-krell', when='+cbtf')
|
|
depends_on('cbtf-krell+mpich', when='+cbtf+mpich')
|
|
depends_on('cbtf-krell+mpich2', when='+cbtf+mpich2')
|
|
depends_on('cbtf-krell+mpt', when='+cbtf+mpt')
|
|
depends_on('cbtf-krell+mvapich', when='+cbtf+mvapich')
|
|
depends_on('cbtf-krell+mvapich2', when='+cbtf+mvapich2')
|
|
depends_on('cbtf-krell+openmpi', when='+cbtf+openmpi')
|
|
depends_on("cbtf-argonavis", when='+cbtf+cuda')
|
|
depends_on("mrnet@5.0.1:+lwthreads", when='+cbtf')
|
|
|
|
parallel = False
|
|
|
|
build_directory = 'build_openspeedshop'
|
|
|
|
def cmake_args(self):
|
|
spec = self.spec
|
|
compile_flags = "-O2 -g"
|
|
|
|
if '+offline' in spec:
|
|
# Indicate building offline vers (writes rawdata files)
|
|
instrumentor_setting = "offline"
|
|
if '+runtime' in spec:
|
|
cmake_args = [
|
|
'-DCMAKE_CXX_FLAGS=%s' % compile_flags,
|
|
'-DCMAKE_C_FLAGS=%s' % compile_flags,
|
|
'-DINSTRUMENTOR=%s' % instrumentor_setting,
|
|
'-DLIBMONITOR_DIR=%s' % spec['libmonitor'].prefix,
|
|
'-DLIBUNWIND_DIR=%s' % spec['libunwind'].prefix,
|
|
'-DPAPI_DIR=%s' % spec['papi'].prefix]
|
|
|
|
# Add any MPI implementations coming from variant settings
|
|
self.set_mpi_cmakeOptions(spec, cmake_args)
|
|
|
|
else:
|
|
cmake_args = []
|
|
|
|
# Appends base options to cmake_args
|
|
self.set_defaultbase_cmakeOptions(spec, cmake_args)
|
|
|
|
cmake_args.extend(
|
|
['-DCMAKE_CXX_FLAGS=%s' % compile_flags,
|
|
'-DCMAKE_C_FLAGS=%s' % compile_flags,
|
|
'-DINSTRUMENTOR=%s' % instrumentor_setting,
|
|
'-DLIBMONITOR_DIR=%s' % spec['libmonitor'].prefix,
|
|
'-DLIBUNWIND_DIR=%s' % spec['libunwind'].prefix,
|
|
'-DPAPI_DIR=%s' % spec['papi'].prefix,
|
|
'-DSQLITE3_DIR=%s' % spec['sqlite'].prefix,
|
|
'-DQTLIB_DIR=%s' % spec['qt'].prefix])
|
|
|
|
# Add any MPI implementations coming from variant settings
|
|
self.set_mpi_cmakeOptions(spec, cmake_args)
|
|
|
|
elif '+cbtf' in spec:
|
|
# Indicate building cbtf vers (transfer rawdata files)
|
|
instrumentor_setting = "cbtf"
|
|
|
|
if '+runtime' in spec:
|
|
# Appends base options to cmake_args
|
|
self.set_defaultbase_cmakeOptions(spec, cmake_args)
|
|
|
|
cmake_args.extend(
|
|
['-DCMAKE_CXX_FLAGS=%s' % compile_flags,
|
|
'-DCMAKE_C_FLAGS=%s' % compile_flags,
|
|
'-DINSTRUMENTOR=%s' % instrumentor_setting,
|
|
'-DCBTF_DIR=%s' % spec['cbtf'].prefix,
|
|
'-DCBTF_KRELL_DIR=%s' % spec['cbtf-krell'].prefix,
|
|
'-DMRNET_DIR=%s' % spec['mrnet'].prefix])
|
|
|
|
else:
|
|
cmake_args = []
|
|
|
|
# Appends base options to cmake_args
|
|
self.set_defaultbase_cmakeOptions(spec, cmake_args)
|
|
guitype = self.spec.variants['gui'].value
|
|
cmake_args.extend(
|
|
['-DCMAKE_CXX_FLAGS=%s' % compile_flags,
|
|
'-DCMAKE_C_FLAGS=%s' % compile_flags,
|
|
'-DINSTRUMENTOR=%s' % instrumentor_setting,
|
|
'-DSQLITE3_DIR=%s' % spec['sqlite'].prefix,
|
|
'-DCBTF_DIR=%s' % spec['cbtf'].prefix,
|
|
'-DCBTF_KRELL_DIR=%s' % spec['cbtf-krell'].prefix,
|
|
'-DMRNET_DIR=%s' % spec['mrnet'].prefix])
|
|
|
|
if guitype == 'none':
|
|
cmake_args.extend(
|
|
['-DBUILD_QT3_GUI=FALSE'])
|
|
elif guitype == 'qt4':
|
|
cmake_args.extend(
|
|
['-DBUILD_QT3_GUI=FALSE'])
|
|
elif guitype == 'qt3':
|
|
cmake_args.extend(
|
|
['-DQTLIB_DIR=%s'
|
|
% spec['qt'].prefix])
|
|
|
|
return cmake_args
|
|
|
|
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_exe = spec['python'].command.path
|
|
python_library = spec['python'].libs[0]
|
|
python_include = spec['python'].headers.directories[0]
|
|
|
|
BaseOptions = []
|
|
|
|
BaseOptions.append('-DBINUTILS_DIR=%s' % spec['binutils'].prefix)
|
|
BaseOptions.append('-DLIBELF_DIR=%s' % spec['elf'].prefix)
|
|
BaseOptions.append('-DLIBDWARF_DIR=%s' % spec['libdwarf'].prefix)
|
|
BaseOptions.append('-DPYTHON_EXECUTABLE=%s' % python_exe)
|
|
BaseOptions.append('-DPYTHON_INCLUDE_DIR=%s' % python_include)
|
|
BaseOptions.append('-DPYTHON_LIBRARY=%s' % python_library)
|
|
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):
|
|
# Appends to cmakeOptions the options that will enable
|
|
# the appropriate MPI implementations
|
|
|
|
MPIOptions = []
|
|
|
|
# openmpi
|
|
if '+openmpi' in spec:
|
|
MPIOptions.append('-DOPENMPI_DIR=%s' % spec['openmpi'].prefix)
|
|
# mpich
|
|
if '+mpich' in spec:
|
|
MPIOptions.append('-DMPICH_DIR=%s' % spec['mpich'].prefix)
|
|
# mpich2
|
|
if '+mpich2' in spec:
|
|
MPIOptions.append('-DMPICH2_DIR=%s' % spec['mpich2'].prefix)
|
|
# mvapich
|
|
if '+mvapich' in spec:
|
|
MPIOptions.append('-DMVAPICH_DIR=%s' % spec['mvapich'].prefix)
|
|
# mvapich2
|
|
if '+mvapich2' in spec:
|
|
MPIOptions.append('-DMVAPICH2_DIR=%s' % spec['mvapich2'].prefix)
|
|
# mpt
|
|
if '+mpt' in spec:
|
|
MPIOptions.append('-DMPT_DIR=%s' % spec['mpt'].prefix)
|
|
|
|
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')
|