summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJim Galarowicz <jeg@trenzasynergy.com>2023-02-06 09:10:41 -0600
committerGitHub <noreply@github.com>2023-02-06 16:10:41 +0100
commita913ed229d62e8291cc0328ebea86aaa300bf1bb (patch)
tree07424a52541889a3ec35951499fc0fe4f3c4f314
parent7c122da48b70ccf8ecab34ec0e4048fed44c85db (diff)
downloadspack-a913ed229d62e8291cc0328ebea86aaa300bf1bb.tar.gz
spack-a913ed229d62e8291cc0328ebea86aaa300bf1bb.tar.bz2
spack-a913ed229d62e8291cc0328ebea86aaa300bf1bb.tar.xz
spack-a913ed229d62e8291cc0328ebea86aaa300bf1bb.zip
Restore openspeedshop and openspeedshop-utils, update the cbtf components (#35052)
-rw-r--r--var/spack/repos/builtin/packages/cbtf-argonavis-gui/package.py17
-rw-r--r--var/spack/repos/builtin/packages/cbtf-argonavis/package.py14
-rw-r--r--var/spack/repos/builtin/packages/cbtf-krell/package.py18
-rw-r--r--var/spack/repos/builtin/packages/cbtf-lanl/package.py10
-rw-r--r--var/spack/repos/builtin/packages/cbtf/package.py2
-rw-r--r--var/spack/repos/builtin/packages/openspeedshop-utils/arm.patch25
-rw-r--r--var/spack/repos/builtin/packages/openspeedshop-utils/package.py321
-rw-r--r--var/spack/repos/builtin/packages/openspeedshop/arm.patch25
-rw-r--r--var/spack/repos/builtin/packages/openspeedshop/package.py363
9 files changed, 790 insertions, 5 deletions
diff --git a/var/spack/repos/builtin/packages/cbtf-argonavis-gui/package.py b/var/spack/repos/builtin/packages/cbtf-argonavis-gui/package.py
index 275486e7ce..c8911b0e62 100644
--- a/var/spack/repos/builtin/packages/cbtf-argonavis-gui/package.py
+++ b/var/spack/repos/builtin/packages/cbtf-argonavis-gui/package.py
@@ -17,7 +17,10 @@ class CbtfArgonavisGui(QMakePackage):
homepage = "https://sourceforge.net/p/cbtf/wiki/Home/"
git = "https://github.com/OpenSpeedShop/cbtf-argonavis-gui.git"
+ maintainers = ["jgalarowicz"]
+
version("develop", branch="master")
+ version("1.3.0.0", branch="1.3.0.0")
depends_on("cmake@3.0.2:", type="build")
@@ -31,21 +34,28 @@ class CbtfArgonavisGui(QMakePackage):
depends_on(Boost.with_default_variants)
# For MRNet
- depends_on("mrnet@5.0.1-3:+lwthreads", when="@develop")
+ depends_on("mrnet@5.0.1-3+lwthreads", when="@1.3.0.0:9999")
# Dependencies for the openspeedshop cbtf packages.
depends_on("cbtf@develop", when="@develop")
+ depends_on("cbtf@1.9.3:9999", when="@1.3.0.0:9999")
depends_on("cbtf-krell@develop", when="@develop")
+ depends_on("cbtf-krell@1.9.3:9999", when="@1.3.0.0:9999")
depends_on("cbtf-argonavis@develop", when="@develop")
+ depends_on("cbtf-argonavis@1.9.3:9999", when="@1.3.0.0:9999")
depends_on("cuda")
+ depends_on("openspeedshop-utils+cuda@develop", when="@develop")
+ depends_on("openspeedshop-utils@2.4.0:+cuda", when="@1.3.0.0:9999")
+
# For Xerces-C
depends_on("xerces-c")
depends_on("graphviz@2.40.1:", when="@develop")
+ depends_on("graphviz@2.40.1", when="@1.3.0.0:9999")
depends_on("qtgraph")
@@ -57,6 +67,7 @@ class CbtfArgonavisGui(QMakePackage):
env.set("CBTF_ROOT", self.spec["cbtf"].prefix)
env.set("CBTF_KRELL_ROOT", self.spec["cbtf-krell"].prefix)
env.set("CBTF_ARGONAVIS_ROOT", self.spec["cbtf-argonavis"].prefix)
+ env.set("OSS_CBTF_ROOT", self.spec["openspeedshop-utils"].prefix)
env.set("GRAPHVIZ_ROOT", self.spec["graphviz"].prefix)
env.set("QTGRAPHLIB_ROOT", self.spec["qtgraph"].prefix)
env.set("KRELL_ROOT_MRNET", self.spec["mrnet"].prefix)
@@ -79,6 +90,10 @@ class CbtfArgonavisGui(QMakePackage):
join_path(qtgraph_lib_dir, "{0}".format(self.spec["qt"].version.up_to(3))),
)
+ # The openspeedshop libraries are needed to actually load the
+ # performance information into the GUI.
+ env.prepend_path("LD_LIBRARY_PATH", self.spec["openspeedshop-utils"].prefix.lib64)
+
def qmake_args(self):
options = ["-o", "Makefile", "openss-gui.pro"]
return options
diff --git a/var/spack/repos/builtin/packages/cbtf-argonavis/package.py b/var/spack/repos/builtin/packages/cbtf-argonavis/package.py
index c1862898e4..786cccdc66 100644
--- a/var/spack/repos/builtin/packages/cbtf-argonavis/package.py
+++ b/var/spack/repos/builtin/packages/cbtf-argonavis/package.py
@@ -15,7 +15,12 @@ class CbtfArgonavis(CMakePackage):
homepage = "https://sourceforge.net/p/cbtf/wiki/Home/"
git = "https://github.com/OpenSpeedShop/cbtf-argonavis.git"
+ maintainers = ["jgalarowicz"]
+
version("develop", branch="master")
+ version("1.9.4.1", branch="1.9.4.1")
+ version("1.9.4", branch="1.9.4")
+ version("1.9.3", branch="1.9.3")
variant(
"crayfe",
@@ -51,12 +56,17 @@ class CbtfArgonavis(CMakePackage):
# For MRNet
depends_on("mrnet@5.0.1-3:+lwthreads", when="@develop", type=("build", "link", "run"))
+ depends_on("mrnet@5.0.1-3+lwthreads", when="@1.9.3:9999", type=("build", "link", "run"))
# For CBTF
depends_on("cbtf@develop", when="@develop", type=("build", "link", "run"))
+ depends_on("cbtf@1.9.3:9999", when="@1.9.3:9999", type=("build", "link", "run"))
# For CBTF with runtime
depends_on("cbtf@develop+runtime", when="@develop+runtime", type=("build", "link", "run"))
+ depends_on(
+ "cbtf@1.9.3:9999+runtime", when="@1.9.3:9999+runtime", type=("build", "link", "run")
+ )
# For libmonitor
depends_on("libmonitor@2013.02.18+commrank", type=("build", "link", "run"))
@@ -66,10 +76,14 @@ class CbtfArgonavis(CMakePackage):
# For CBTF-KRELL
depends_on("cbtf-krell@develop", when="@develop", type=("build", "link", "run"))
+ depends_on("cbtf-krell@1.9.3:9999", when="@1.9.3:9999", type=("build", "link", "run"))
depends_on(
"cbtf-krell@develop+runtime", when="@develop+runtime", type=("build", "link", "run")
)
+ depends_on(
+ "cbtf-krell@1.9.3:9999+runtime", when="@1.9.3:9999+runtime", type=("build", "link", "run")
+ )
# For CUDA
depends_on("cuda")
diff --git a/var/spack/repos/builtin/packages/cbtf-krell/package.py b/var/spack/repos/builtin/packages/cbtf-krell/package.py
index 78c0cc7888..943e952d9b 100644
--- a/var/spack/repos/builtin/packages/cbtf-krell/package.py
+++ b/var/spack/repos/builtin/packages/cbtf-krell/package.py
@@ -18,7 +18,12 @@ class CbtfKrell(CMakePackage):
homepage = "https://sourceforge.net/p/cbtf/wiki/Home/"
git = "https://github.com/OpenSpeedShop/cbtf-krell.git"
+ maintainers = ["jgalarowicz"]
+
version("develop", branch="master")
+ version("1.9.4.1", branch="1.9.4.1")
+ version("1.9.4", branch="1.9.4")
+ version("1.9.3", branch="1.9.3")
# MPI variants
variant(
@@ -55,7 +60,7 @@ class CbtfKrell(CMakePackage):
depends_on("libtirpc", type="link")
# For binutils
- depends_on("binutils+plugins~gold@2.32")
+ depends_on("binutils@2.32")
# For boost
depends_on("boost@1.70.0:")
@@ -67,23 +72,30 @@ class CbtfKrell(CMakePackage):
# For Dyninst
depends_on("dyninst@10.1.0", when="@develop")
+ depends_on("dyninst@10.1.0", when="@1.9.3:9999")
# For MRNet
depends_on("mrnet@5.0.1-3:+lwthreads", when="@develop", type=("build", "link", "run"))
+ depends_on("mrnet@5.0.1-3+lwthreads", when="@1.9.3:9999", type=("build", "link", "run"))
# For Xerces-C
depends_on("xerces-c")
# For CBTF
depends_on("cbtf@develop", when="@develop", type=("build", "link", "run"))
+ depends_on("cbtf@1.9.3:9999", when="@1.9.3:9999", type=("build", "link", "run"))
# For CBTF with runtime
depends_on("cbtf@develop+runtime", when="@develop+runtime", type=("build", "link", "run"))
+ depends_on(
+ "cbtf@1.9.3:9999+runtime", when="@1.9.3:9999+runtime", type=("build", "link", "run")
+ )
# for services and collectors
depends_on("libmonitor@2013.02.18+commrank", type=("build", "link", "run"))
depends_on("libunwind", when="@develop")
+ depends_on("libunwind@1.2.1", when="@1.9.3:9999")
depends_on("papi@5.4.1:", type=("build", "link", "run"))
@@ -95,9 +107,7 @@ class CbtfKrell(CMakePackage):
depends_on("mvapich2@2:", when="+mvapich2")
depends_on("mpt", when="+mpt")
- depends_on("python", when="@develop", type=("build", "run"))
-
- depends_on("gotcha")
+ depends_on("python", type=("build", "run"))
patch("arm.patch", when="target=aarch64:")
diff --git a/var/spack/repos/builtin/packages/cbtf-lanl/package.py b/var/spack/repos/builtin/packages/cbtf-lanl/package.py
index 30b0e7cb1c..4e521a653f 100644
--- a/var/spack/repos/builtin/packages/cbtf-lanl/package.py
+++ b/var/spack/repos/builtin/packages/cbtf-lanl/package.py
@@ -13,7 +13,12 @@ class CbtfLanl(CMakePackage):
homepage = "https://sourceforge.net/p/cbtf/wiki/Home/"
git = "https://github.com/OpenSpeedShop/cbtf-lanl.git"
+ maintainers = ["jgalarowicz"]
+
version("develop", branch="master")
+ version("1.9.4.1", branch="1.9.4.1")
+ version("1.9.4", branch="1.9.4")
+ version("1.9.3", branch="1.9.3")
variant(
"build_type",
@@ -30,20 +35,25 @@ class CbtfLanl(CMakePackage):
# For MRNet
depends_on("mrnet@5.0.1-3:+lwthreads", when="@develop")
+ depends_on("mrnet@5.0.1-3+lwthreads", when="@1.9.3:9999")
# For Xerces-C
depends_on("xerces-c")
# For CBTF
depends_on("cbtf@develop", when="@develop")
+ depends_on("cbtf@1.9.3:9999", when="@1.9.3:9999")
# For CBTF with runtime
depends_on("cbtf@develop+runtime", when="@develop+runtime")
+ depends_on("cbtf@1.9.3:9999+runtime", when="@1.9.3:9999+runtime")
# For CBTF-KRELL
depends_on("cbtf-krell@develop", when="@develop")
+ depends_on("cbtf-krell@1.9.3:9999", when="@1.9.3:9999")
depends_on("cbtf-krell@develop+runtime", when="@develop+runtime")
+ depends_on("cbtf-krell@1.9.3:9999+runtime", when="@1.9.3:9999+runtime")
parallel = False
diff --git a/var/spack/repos/builtin/packages/cbtf/package.py b/var/spack/repos/builtin/packages/cbtf/package.py
index cb2119faef..3783b8c5cb 100644
--- a/var/spack/repos/builtin/packages/cbtf/package.py
+++ b/var/spack/repos/builtin/packages/cbtf/package.py
@@ -18,6 +18,8 @@ class Cbtf(CMakePackage):
homepage = "https://sourceforge.net/p/cbtf/wiki/Home"
git = "https://github.com/OpenSpeedShop/cbtf.git"
+ maintainers = ["jgalarowicz"]
+
version("develop", branch="master")
version("1.9.4.1", branch="1.9.4.1")
version("1.9.4", branch="1.9.4")
diff --git a/var/spack/repos/builtin/packages/openspeedshop-utils/arm.patch b/var/spack/repos/builtin/packages/openspeedshop-utils/arm.patch
new file mode 100644
index 0000000000..c0099cfd35
--- /dev/null
+++ b/var/spack/repos/builtin/packages/openspeedshop-utils/arm.patch
@@ -0,0 +1,25 @@
+diff --git a/plugins/views/iot/iot_view.cxx b/plugins/views/iot/iot_view.cxx
+index f4cdf48..ef1b81f 100644
+--- a/plugins/views/iot/iot_view.cxx
++++ b/plugins/views/iot/iot_view.cxx
+@@ -45,6 +45,20 @@
+ # endif
+ #endif
+ /* End part 2 of 2 for Hack to get around inconsistent syscall definitions */
++/* Start Added Hack to get around inconsistent syscall definitions */
++#ifndef SYS_open
++#define SYS_open SYS_openat
++#endif
++#ifndef SYS_creat
++#define SYS_creat SYS_openat
++#endif
++#ifndef SYS_dup2
++#define SYS_dup2 SYS_dup3
++#endif
++#ifndef SYS_pipe
++#define SYS_pipe SYS_pipe2
++#endif
++/* end Added Hack to get around inconsistent syscall definitions */
+
+
+
diff --git a/var/spack/repos/builtin/packages/openspeedshop-utils/package.py b/var/spack/repos/builtin/packages/openspeedshop-utils/package.py
new file mode 100644
index 0000000000..d2ab1df988
--- /dev/null
+++ b/var/spack/repos/builtin/packages/openspeedshop-utils/package.py
@@ -0,0 +1,321 @@
+# Copyright 2013-2023 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)
+
+import os
+
+import spack.store
+from spack.package import *
+from spack.pkg.builtin.boost import Boost
+
+
+class OpenspeedshopUtils(CMakePackage):
+ """OpenSpeedShop is a community effort led by Trenza, Inc.
+ 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
+ Trenza Inc.. The infrastructure and base components of OpenSpeedShop
+ are released as open source code primarily under LGPL.
+ openspeedshop-utils is a package that does not have the
+ qt3 gui. It was created to avoid a conflict between
+ openspeedshop and cbtf-argonavis-gui based on the fact
+ that spack will not allow a qt3 and qt4/qt5 dependency in a
+ packages dependency tree.
+ """
+
+ homepage = "http://www.openspeedshop.org"
+ git = "https://github.com/OpenSpeedShop/openspeedshop.git"
+
+ maintainers = ["jgalarowicz"]
+
+ version("develop", branch="master")
+ version("2.4.2.1", branch="2.4.2.1")
+ version("2.4.2", branch="2.4.2")
+ version("2.4.1", branch="2.4.1")
+
+ variant(
+ "runtime", default=False, description="build only the runtime libraries and collectors."
+ )
+ variant(
+ "crayfe",
+ 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(
+ "build_type",
+ default="RelWithDebInfo",
+ description="The build type to build",
+ values=("Debug", "Release", "RelWithDebInfo"),
+ )
+
+ # 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(
+ "mpich2",
+ default=False,
+ description="Build mpi collector for mpich2\
+ 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@2.6.1", type="build")
+
+ # For binutils
+ depends_on("binutils@2.32", type="build")
+
+ depends_on("elfutils", type="link")
+ depends_on("libdwarf")
+
+ depends_on("sqlite")
+
+ # For boost
+ depends_on("boost@1.66.0:1.69.0")
+ # TODO: replace this with an explicit list of components of Boost,
+ # for instance depends_on('boost +filesystem')
+ # See https://github.com/spack/spack/pull/22303 for reference
+ depends_on(Boost.with_default_variants)
+
+ depends_on("dyninst@10:", when="@2.4.0:9999")
+
+ depends_on("python", type=("build", "run"))
+
+ depends_on("libxml2")
+
+ # Dependencies for the openspeedshop cbtf packages.
+ depends_on("cbtf@develop", when="@develop", type=("build", "link", "run"))
+ depends_on("cbtf@1.9.3:9999", when="@2.4.0:9999", type=("build", "link", "run"))
+
+ depends_on("cbtf-krell@develop", when="@develop", type=("build", "link", "run"))
+ depends_on("cbtf-krell@1.9.3:9999", when="@2.4.0:9999", type=("build", "link", "run"))
+
+ depends_on("cbtf-krell@develop+crayfe", when="@develop+crayfe", type=("build", "link", "run"))
+ depends_on(
+ "cbtf-krell@1.9.3:9999+crayfe", when="@2.4.0:9999+crayfe", type=("build", "link", "run")
+ )
+
+ depends_on("cbtf-krell@develop+mpich2", when="@develop+mpich2", type=("build", "link", "run"))
+ depends_on(
+ "cbtf-krell@1.9.3:9999+mpich2", when="@2.4.0:9999+mpich2", type=("build", "link", "run")
+ )
+
+ depends_on("cbtf-krell@develop+mpt", when="@develop+mpt", type=("build", "link", "run"))
+ depends_on("cbtf-krell@1.9.3:9999+mpt", when="@2.4.0:9999+mpt", type=("build", "link", "run"))
+
+ depends_on(
+ "cbtf-krell@develop+mvapich2", when="@develop+mvapich2", type=("build", "link", "run")
+ )
+ depends_on(
+ "cbtf-krell@1.9.3:9999+mvapich2",
+ when="@2.4.0:9999+mvapich2",
+ type=("build", "link", "run"),
+ )
+
+ depends_on(
+ "cbtf-krell@develop+openmpi", when="@develop+openmpi", type=("build", "link", "run")
+ )
+ depends_on(
+ "cbtf-krell@1.9.3:9999+openmpi", when="@2.4.0:9999+openmpi", type=("build", "link", "run")
+ )
+
+ depends_on("cbtf-argonavis@develop", when="@develop+cuda", type=("build", "link", "run"))
+ depends_on("cbtf-argonavis@1.9.3:9999", when="@2.4.0:9999+cuda", type=("build", "link", "run"))
+
+ # For MRNet
+ depends_on("mrnet@5.0.1-3:+lwthreads", when="@develop", type=("build", "link", "run"))
+ depends_on("mrnet@5.0.1-3:+lwthreads", when="@2.4.0:9999", type=("build", "link", "run"))
+
+ patch("arm.patch", when="target=aarch64:")
+ parallel = False
+
+ build_directory = "build_openspeedshop"
+
+ def set_cray_login_node_cmake_options(self, spec, cmake_options):
+ # Appends to cmake_options the options that will enable the appropriate
+ # Cray login node libraries
+
+ cray_login_node_options = []
+ rt_platform = "cray"
+
+ # How do we get the compute node (CNL) cbtf package install
+ # directory path?
+ # spec['cbtf'].prefix is the login node value for this build, as
+ # we only get here when building the login node components and
+ # that is all that is known to spack.
+ be_ck = spack.store.db.query_one("cbtf-krell arch=cray-CNL-haswell")
+
+ # Equivalent to install-tool cmake arg:
+ # '-DCBTF_KRELL_CN_RUNTIME_DIR=%s'
+ # % <base dir>/cbtf_v2.4.0elease/compute)
+ cray_login_node_options.append("-DCBTF_KRELL_CN_RUNTIME_DIR=%s" % be_ck.prefix)
+ cray_login_node_options.append("-DRUNTIME_PLATFORM=%s" % rt_platform)
+
+ cmake_options.extend(cray_login_node_options)
+
+ def cmake_args(self):
+ # Appends base options to cmake_args
+ spec = self.spec
+
+ compile_flags = "-O2 -g -Wall"
+
+ cmake_args = []
+
+ # Indicate building cbtf vers (transfer rawdata files)
+ instrumentor_setting = "cbtf"
+
+ if spec.satisfies("+runtime"):
+ self.set_defaultbase_cmake_options(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:
+
+ # Appends base options to cmake_args
+ self.set_defaultbase_cmake_options(spec, cmake_args)
+ 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 spec.satisfies("+crayfe"):
+ # We need to build target/compute node
+ # components/libraries first then pass
+ # those libraries to the openspeedshop
+ # login node build
+ self.set_cray_login_node_cmake_options(spec, cmake_args)
+
+ cmake_args.extend(["-DBUILD_QT3_GUI=FALSE"])
+
+ return cmake_args
+
+ def set_defaultbase_cmake_options(self, spec, cmake_options):
+ # Appends to cmake_options 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]
+
+ base_options = []
+
+ base_options.append("-DBINUTILS_DIR=%s" % spec["binutils"].prefix)
+ base_options.append("-DLIBELF_DIR=%s" % spec["elfutils"].prefix)
+ base_options.append("-DLIBDWARF_DIR=%s" % spec["libdwarf"].prefix)
+ base_options.append("-DPYTHON_EXECUTABLE=%s" % python_exe)
+ base_options.append("-DPYTHON_INCLUDE_DIR=%s" % python_include)
+ base_options.append("-DPYTHON_LIBRARY=%s" % python_library)
+ base_options.append("-DBoost_NO_SYSTEM_PATHS=TRUE")
+ base_options.append("-DBoost_NO_BOOST_CMAKE=TRUE")
+ base_options.append("-DBOOST_ROOT=%s" % spec["boost"].prefix)
+ base_options.append("-DBoost_DIR=%s" % spec["boost"].prefix)
+ base_options.append("-DBOOST_LIBRARYDIR=%s" % spec["boost"].prefix.lib)
+ base_options.append("-DDYNINST_DIR=%s" % spec["dyninst"].prefix)
+
+ cmake_options.extend(base_options)
+
+ def set_mpi_cmake_options(self, spec, cmake_options):
+ # Appends to cmake_options the options that will enable
+ # the appropriate MPI implementations
+
+ mpi_options = []
+
+ # openmpi
+ if spec.satisfies("+openmpi"):
+ mpi_options.append("-DOPENMPI_DIR=%s" % spec["openmpi"].prefix)
+ # mpich
+ if spec.satisfies("+mpich"):
+ mpi_options.append("-DMPICH_DIR=%s" % spec["mpich"].prefix)
+ # mpich2
+ if spec.satisfies("+mpich2"):
+ mpi_options.append("-DMPICH2_DIR=%s" % spec["mpich2"].prefix)
+ # mvapich
+ if spec.satisfies("+mvapich"):
+ mpi_options.append("-DMVAPICH_DIR=%s" % spec["mvapich"].prefix)
+ # mvapich2
+ if spec.satisfies("+mvapich2"):
+ mpi_options.append("-DMVAPICH2_DIR=%s" % spec["mvapich2"].prefix)
+ # mpt
+ if spec.satisfies("+mpt"):
+ mpi_options.append("-DMPT_DIR=%s" % spec["mpt"].prefix)
+
+ cmake_options.extend(mpi_options)
+
+ def setup_run_environment(self, env):
+ """Set up the compile and runtime environments for a package."""
+
+ # 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, recursive=True
+ )
+
+ # Set Dyninst RT library path to support OSS loop resolution code
+ env.set("DYNINSTAPI_RT_LIB", dyninst_libdir[0])
+
+ # Find openspeedshop library path
+ oss_libdir = find_libraries(
+ "libopenss-framework",
+ root=self.spec["openspeedshop-utils"].prefix,
+ shared=True,
+ recursive=True,
+ )
+ env.prepend_path("LD_LIBRARY_PATH", os.path.dirname(oss_libdir.joined()))
+
+ env.set("OPENSS_RAWDATA_DIR", ".")
+
+ cbtf_mc = "/sbin/cbtf_mrnet_commnode"
+ cbtf_lmb = "/sbin/cbtf_libcbtf_mrnet_backend"
+ env.set("XPLAT_RSH", "ssh")
+ env.set("MRNET_COMM_PATH", join_path(self.spec["cbtf-krell"].prefix + cbtf_mc))
+ env.set("CBTF_MRNET_BACKEND_PATH", join_path(self.spec["cbtf-krell"].prefix + cbtf_lmb))
+ env.prepend_path("PATH", self.spec["mrnet"].prefix.bin)
+ env.prepend_path("PATH", self.spec["cbtf-krell"].prefix.bin)
+ env.prepend_path("PATH", self.spec["cbtf-krell"].prefix.sbin)
+ env.prepend_path("PATH", self.spec["python"].prefix.bin)
diff --git a/var/spack/repos/builtin/packages/openspeedshop/arm.patch b/var/spack/repos/builtin/packages/openspeedshop/arm.patch
new file mode 100644
index 0000000000..c0099cfd35
--- /dev/null
+++ b/var/spack/repos/builtin/packages/openspeedshop/arm.patch
@@ -0,0 +1,25 @@
+diff --git a/plugins/views/iot/iot_view.cxx b/plugins/views/iot/iot_view.cxx
+index f4cdf48..ef1b81f 100644
+--- a/plugins/views/iot/iot_view.cxx
++++ b/plugins/views/iot/iot_view.cxx
+@@ -45,6 +45,20 @@
+ # endif
+ #endif
+ /* End part 2 of 2 for Hack to get around inconsistent syscall definitions */
++/* Start Added Hack to get around inconsistent syscall definitions */
++#ifndef SYS_open
++#define SYS_open SYS_openat
++#endif
++#ifndef SYS_creat
++#define SYS_creat SYS_openat
++#endif
++#ifndef SYS_dup2
++#define SYS_dup2 SYS_dup3
++#endif
++#ifndef SYS_pipe
++#define SYS_pipe SYS_pipe2
++#endif
++/* end Added Hack to get around inconsistent syscall definitions */
+
+
+
diff --git a/var/spack/repos/builtin/packages/openspeedshop/package.py b/var/spack/repos/builtin/packages/openspeedshop/package.py
new file mode 100644
index 0000000000..5f1a74bac8
--- /dev/null
+++ b/var/spack/repos/builtin/packages/openspeedshop/package.py
@@ -0,0 +1,363 @@
+# Copyright 2013-2023 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)
+
+import os
+
+import spack.store
+from spack.package import *
+from spack.pkg.builtin.boost import Boost
+
+
+class Openspeedshop(CMakePackage):
+ """OpenSpeedShop is a community effort led by Trenza, Inc.
+ 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
+ Trenza Inc.. The infrastructure and base components of OpenSpeedShop
+ are released as open source code primarily under LGPL.
+ """
+
+ homepage = "http://www.openspeedshop.org"
+ git = "https://github.com/OpenSpeedShop/openspeedshop.git"
+
+ maintainers = ["jgalarowicz"]
+
+ version("develop", branch="master")
+ version("2.4.2.1", branch="2.4.2.1")
+ version("2.4.2", branch="2.4.2")
+ version("2.4.1", branch="2.4.1")
+
+ variant(
+ "runtime", default=False, description="build only the runtime libraries and collectors."
+ )
+ variant(
+ "crayfe",
+ 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="none",
+ values=("none", "qt3", "qt4"),
+ description="Build or not build a GUI of choice",
+ )
+
+ variant(
+ "build_type",
+ default="RelWithDebInfo",
+ description="The build type to build",
+ values=("Debug", "Release", "RelWithDebInfo"),
+ )
+
+ # 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(
+ "mpich2",
+ default=False,
+ description="Build mpi collector for mpich2\
+ 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@2.6.1", type="build")
+
+ # For binutils
+ depends_on("binutils@2.32")
+
+ depends_on("elfutils", type="link")
+ depends_on("libdwarf")
+
+ depends_on("sqlite")
+
+ # For boost
+ depends_on("boost@1.70.0:")
+ # TODO: replace this with an explicit list of components of Boost,
+ # for instance depends_on('boost +filesystem')
+ # See https://github.com/spack/spack/pull/22303 for reference
+ depends_on(Boost.with_default_variants)
+
+ depends_on("dyninst@10:", when="@2.4.0:9999")
+
+ depends_on("python", type=("build", "run"))
+
+ depends_on("libxml2")
+
+ depends_on("qt@3:3.9", when="gui=qt3")
+
+ # Dependencies for the openspeedshop cbtf packages.
+ depends_on("cbtf@develop", when="@develop", type=("build", "link", "run"))
+ depends_on("cbtf@1.9.3:9999", when="@2.4.0:9999", type=("build", "link", "run"))
+
+ depends_on("cbtf-krell@develop", when="@develop", type=("build", "link", "run"))
+ depends_on("cbtf-krell@1.9.3:9999", when="@2.4.0:9999", type=("build", "link", "run"))
+
+ depends_on("cbtf-krell@develop+crayfe", when="@develop+crayfe", type=("build", "link", "run"))
+ depends_on(
+ "cbtf-krell@1.9.3:9999+crayfe", when="@2.4.0:9999+crayfe", type=("build", "link", "run")
+ )
+
+ depends_on("cbtf-krell@develop+mpich2", when="@develop+mpich2", type=("build", "link", "run"))
+ depends_on(
+ "cbtf-krell@1.9.3:9999+mpich2", when="@2.4.0:9999+mpich2", type=("build", "link", "run")
+ )
+
+ depends_on("cbtf-krell@develop+mpt", when="@develop+mpt", type=("build", "link", "run"))
+ depends_on("cbtf-krell@1.9.3:9999+mpt", when="@2.4.0:9999+mpt", type=("build", "link", "run"))
+
+ depends_on(
+ "cbtf-krell@develop+mvapich2", when="@develop+mvapich2", type=("build", "link", "run")
+ )
+ depends_on(
+ "cbtf-krell@1.9.3:9999+mvapich2",
+ when="@2.4.0:9999+mvapich2",
+ type=("build", "link", "run"),
+ )
+
+ depends_on(
+ "cbtf-krell@develop+openmpi", when="@develop+openmpi", type=("build", "link", "run")
+ )
+ depends_on(
+ "cbtf-krell@1.9.3:9999+openmpi", when="@2.4.0:9999+openmpi", type=("build", "link", "run")
+ )
+
+ depends_on("cbtf-argonavis@develop", when="@develop+cuda", type=("build", "link", "run"))
+ depends_on("cbtf-argonavis@1.9.3:9999", when="@2.4.0:9999+cuda", type=("build", "link", "run"))
+
+ # For MRNet
+ depends_on("mrnet@5.0.1-3:+lwthreads", when="@develop", type=("build", "link", "run"))
+ depends_on("mrnet@5.0.1-3:+lwthreads", when="@2.4.0:9999", type=("build", "link", "run"))
+
+ patch("arm.patch", when="target=aarch64:")
+ parallel = False
+
+ build_directory = "build_openspeedshop"
+
+ def set_cray_login_node_cmake_options(self, spec, cmake_options):
+ # Appends to cmake_options the options that will enable the appropriate
+ # Cray login node libraries
+
+ cray_login_node_options = []
+ rt_platform = "cray"
+
+ # How do we get the compute node (CNL) cbtf package install
+ # directory path?
+ # spec['cbtf'].prefix is the login node value for this build, as
+ # we only get here when building the login node components and
+ # that is all that is known to spack.
+ store = spack.store
+ be_ck = store.db.query_one("cbtf-krell arch=cray-CNL-haswell")
+
+ # Equivalent to install-tool cmake arg:
+ # '-DCBTF_KRELL_CN_RUNTIME_DIR=%s'
+ # % <base dir>/cbtf_v2.4.0.release/compute)
+ cray_login_node_options.append("-DCBTF_KRELL_CN_RUNTIME_DIR=%s" % be_ck.prefix)
+ cray_login_node_options.append("-DRUNTIME_PLATFORM=%s" % rt_platform)
+
+ cmake_options.extend(cray_login_node_options)
+
+ def cmake_args(self):
+
+ spec = self.spec
+
+ compile_flags = "-O2 -g -Wall"
+
+ cmake_args = []
+
+ # Indicate building cbtf vers (transfer rawdata files)
+ instrumentor_setting = "cbtf"
+
+ if spec.satisfies("+runtime"):
+ # Appends base options to cmake_args
+ self.set_defaultbase_cmake_options(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,
+ ]
+ )
+
+ if spec.satisfies("+cuda"):
+ cmake_args.extend(["-DCBTF_ARGONAVIS_DIR=%s" % spec["cbtf-argonavis"].prefix])
+
+ else:
+
+ # Appends base options to cmake_args
+ self.set_defaultbase_cmake_options(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])
+
+ if spec.satisfies("+cuda"):
+ cmake_args.extend(["-DCBTF_ARGONAVIS_DIR=%s" % spec["cbtf-argonavis"].prefix])
+
+ if spec.satisfies("+crayfe"):
+ # We need to build target/compute node
+ # components/libraries first then pass
+ # those libraries to the openspeedshop
+ # login node build
+ self.set_cray_login_node_cmake_options(spec, cmake_args)
+
+ return cmake_args
+
+ def set_defaultbase_cmake_options(self, spec, cmake_options):
+ # Appends to cmake_options 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]
+ true_value = "TRUE"
+
+ base_options = []
+
+ base_options.append("-DBINUTILS_DIR=%s" % spec["binutils"].prefix)
+ base_options.append("-DLIBELF_DIR=%s" % spec["elfutils"].prefix)
+ base_options.append("-DLIBDWARF_DIR=%s" % spec["libdwarf"].prefix)
+ base_options.append("-DPYTHON_EXECUTABLE=%s" % python_exe)
+ base_options.append("-DPYTHON_INCLUDE_DIR=%s" % python_include)
+ base_options.append("-DPYTHON_LIBRARY=%s" % python_library)
+ base_options.append("-DBoost_NO_SYSTEM_PATHS=%s" % true_value)
+ base_options.append("-DBoost_NO_BOOST_CMAKE=%s" % true_value)
+ base_options.append("-DBOOST_ROOT=%s" % spec["boost"].prefix)
+ base_options.append("-DBoost_DIR=%s" % spec["boost"].prefix)
+ base_options.append("-DBOOST_LIBRARYDIR=%s" % spec["boost"].prefix.lib)
+ base_options.append("-DDYNINST_DIR=%s" % spec["dyninst"].prefix)
+
+ cmake_options.extend(base_options)
+
+ def set_mpi_cmake_options(self, spec, cmake_options):
+ # Appends to cmake_options the options that will enable
+ # the appropriate MPI implementations
+
+ mpi_options = []
+
+ # openmpi
+ if spec.satisfies("+openmpi"):
+ mpi_options.append("-DOPENMPI_DIR=%s" % spec["openmpi"].prefix)
+ # mpich
+ if spec.satisfies("+mpich"):
+ mpi_options.append("-DMPICH_DIR=%s" % spec["mpich"].prefix)
+ # mpich2
+ if spec.satisfies("+mpich2"):
+ mpi_options.append("-DMPICH2_DIR=%s" % spec["mpich2"].prefix)
+ # mvapich
+ if spec.satisfies("+mvapich"):
+ mpi_options.append("-DMVAPICH_DIR=%s" % spec["mvapich"].prefix)
+ # mvapich2
+ if spec.satisfies("+mvapich2"):
+ mpi_options.append("-DMVAPICH2_DIR=%s" % spec["mvapich2"].prefix)
+ # mpt
+ if spec.satisfies("+mpt"):
+ mpi_options.append("-DMPT_DIR=%s" % spec["mpt"].prefix)
+
+ cmake_options.extend(mpi_options)
+
+ def setup_run_environment(self, env):
+ """Set up the compile and runtime environments for a package."""
+
+ # 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, recursive=True
+ )
+
+ # Set Dyninst RT library path to support OSS loop resolution code
+ env.set("DYNINSTAPI_RT_LIB", dyninst_libdir[0])
+
+ env.set("OPENSS_RAWDATA_DIR", ".")
+
+ # Set the openspeedshop plugin path
+ if os.path.isdir(self.prefix.lib64):
+ lib_dir = self.prefix.lib64
+ else:
+ lib_dir = self.prefix.lib
+
+ plugin_path = "/openspeedshop"
+ oss_plugin_path = lib_dir + plugin_path
+ env.set("OPENSS_PLUGIN_PATH", oss_plugin_path)
+
+ cbtf_mc = "/sbin/cbtf_mrnet_commnode"
+ cbtf_lmb = "/sbin/cbtf_libcbtf_mrnet_backend"
+ env.set("XPLAT_RSH", "ssh")
+ env.set("MRNET_COMM_PATH", join_path(self.spec["cbtf-krell"].prefix + cbtf_mc))
+
+ # Set CBTF_MPI_IMPLEMENTATON to the appropriate mpi implementation
+ # This is needed by O|SS and CBTF tools to deploy the correct
+ # mpi runtimes for ossmpi, ossmpit, ossmpip, and cbtfsummary
+ # Users may have to set the CBTF_MPI_IMPLEMENTATION variable
+ # manually if multiple mpi's are specified in the build
+ if self.spec.satisfies("+mpich"):
+ env.set("CBTF_MPI_IMPLEMENTATION", "mpich")
+
+ if self.spec.satisfies("+mvapich"):
+ env.set("CBTF_MPI_IMPLEMENTATION", "mvapich")
+
+ if self.spec.satisfies("+mvapich2"):
+ env.set("CBTF_MPI_IMPLEMENTATION", "mvapich2")
+
+ if self.spec.satisfies("+mpt"):
+ env.set("CBTF_MPI_IMPLEMENTATION", "mpt")
+
+ if self.spec.satisfies("+openmpi"):
+ env.set("CBTF_MPI_IMPLEMENTATION", "openmpi")
+
+ env.set("CBTF_MRNET_BACKEND_PATH", join_path(self.spec["cbtf-krell"].prefix + cbtf_lmb))
+ env.prepend_path("PATH", self.spec["mrnet"].prefix.bin)
+ env.prepend_path("PATH", self.spec["cbtf-krell"].prefix.bin)
+ env.prepend_path("PATH", self.spec["cbtf-krell"].prefix.sbin)
+ mpath = "/share/man"
+ env.prepend_path("MANPATH", self.spec["cbtf-krell"].prefix + mpath)
+ env.prepend_path("PATH", self.spec["python"].prefix.bin)