summaryrefslogtreecommitdiff
path: root/var
diff options
context:
space:
mode:
Diffstat (limited to 'var')
-rw-r--r--var/spack/packages/adept-utils/package.py41
-rw-r--r--var/spack/packages/callpath/package.py13
-rw-r--r--var/spack/packages/cube/package.py55
-rw-r--r--var/spack/packages/dtcmp/package.py20
-rw-r--r--var/spack/packages/libarchive/package.py16
-rw-r--r--var/spack/packages/libcircle/package.py18
-rw-r--r--var/spack/packages/libmonitor/package.py37
-rw-r--r--var/spack/packages/lwgrp/package.py18
-rw-r--r--var/spack/packages/mpileaks/package.py13
-rw-r--r--var/spack/packages/mvapich2/package.py86
-rw-r--r--var/spack/packages/opari2/package.py65
-rw-r--r--var/spack/packages/openssl/package.py26
-rw-r--r--var/spack/packages/otf2/package.py74
-rw-r--r--var/spack/packages/postgresql/package.py20
-rw-r--r--var/spack/packages/scalasca/package.py43
-rw-r--r--var/spack/packages/scorep/package.py75
-rw-r--r--var/spack/packages/sqlite/package.py40
-rw-r--r--var/spack/packages/stat/package.py1
-rw-r--r--var/spack/packages/tau/package.py1
19 files changed, 651 insertions, 11 deletions
diff --git a/var/spack/packages/adept-utils/package.py b/var/spack/packages/adept-utils/package.py
new file mode 100644
index 0000000000..2515322ec2
--- /dev/null
+++ b/var/spack/packages/adept-utils/package.py
@@ -0,0 +1,41 @@
+##############################################################################
+# Copyright (c) 2013, Lawrence Livermore National Security, LLC.
+# Produced at the Lawrence Livermore National Laboratory.
+#
+# This file is part of Spack.
+# Written by Todd Gamblin, tgamblin@llnl.gov, All rights reserved.
+# LLNL-CODE-647188
+#
+# For details, see https://scalability-llnl.github.io/spack
+# Please also see the LICENSE file 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 General Public License (as published by
+# the Free Software Foundation) version 2.1 dated 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 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
+##############################################################################
+from spack import *
+
+class AdeptUtils(Package):
+ """Utility libraries for LLNL performance tools."""
+
+ homepage = "https://github.com/scalability-llnl/adept-utils"
+ url = "https://github.com/scalability-llnl/adept-utils/archive/v1.0.tar.gz"
+
+ version('1.0', '5c6cd9badce56c945ac8551e34804397')
+
+ depends_on("boost")
+ depends_on("mpi")
+
+ def install(self, spec, prefix):
+ cmake(*std_cmake_args)
+ make()
+ make("install")
diff --git a/var/spack/packages/callpath/package.py b/var/spack/packages/callpath/package.py
index 5d92d77302..84170d9c9e 100644
--- a/var/spack/packages/callpath/package.py
+++ b/var/spack/packages/callpath/package.py
@@ -25,13 +25,20 @@
from spack import *
class Callpath(Package):
- homepage = "https://github.com/tgamblin/callpath"
- url = "http://github.com/tgamblin/callpath-0.2.tar.gz"
+ """Library for representing callpaths consistently in
+ distributed-memory performance tools."""
+
+ homepage = "https://github.com/scalability-llnl/callpath"
+ url = "https://github.com/scalability-llnl/callpath/archive/v1.0.1.tar.gz"
+
+ version('1.0.1', '0047983d2a52c5c335f8ba7f5bab2325')
depends_on("dyninst")
+ depends_on("adept-utils")
depends_on("mpi")
def install(self, spec, prefix):
- configure("--prefix=" + prefix)
+ # TODO: offer options for the walker used.
+ cmake('.', "-DCALLPATH_WALKER=dyninst", *std_cmake_args)
make()
make("install")
diff --git a/var/spack/packages/cube/package.py b/var/spack/packages/cube/package.py
new file mode 100644
index 0000000000..d97cd25636
--- /dev/null
+++ b/var/spack/packages/cube/package.py
@@ -0,0 +1,55 @@
+# FIXME: Add copyright statement
+#
+from spack import *
+from contextlib import closing
+
+class Cube(Package):
+ """Cube the profile viewer for Score-P and Scalasca profiles. It
+ displays a multi-dimensional performance space consisting
+ of the dimensions (i) performance metric, (ii) call path,
+ and (iii) system resource."""
+
+ homepage = "http://www.scalasca.org/software/cube-4.x/download.html"
+ url = "http://apps.fz-juelich.de/scalasca/releases/cube/4.2/dist/cube-4.2.3.tar.gz"
+
+ version('4.2.3', '8f95b9531f5a8f8134f279c2767c9b20')
+
+ version('4.3TP1', 'a2090fbc7b2ba394bd5c09ba971e237f',
+ url = 'http://apps.fz-juelich.de/scalasca/releases/cube/4.3/dist/cube-4.3-TP1.tar.gz')
+
+ # Using CC as C++ compiler provides quirky workaround for a Score-P build system attempt
+ # to guess a matching C compiler when configuring scorep-score
+ backend_user_provided = """\
+CC=cc
+CXX=CC
+F77=f77
+FC=f90
+#CFLAGS=-fPIC
+#CXXFLAGS=-fPIC
+"""
+ frontend_user_provided = """\
+CC_FOR_BUILD=cc
+CXX_FOR_BUILD=CC
+F77_FOR_BUILD=f70
+FC_FOR_BUILD=f90
+"""
+
+ def install(self, spec, prefix):
+ # Use a custom compiler configuration, otherwise the score-p
+ # build system messes with spack's compiler settings.
+ # Create these three files in the build directory
+
+ with closing(open("vendor/common/build-config/platforms/platform-backend-user-provided", "w")) as backend_file:
+ backend_file.write(self.backend_user_provided)
+ with closing(open("vendor/common/build-config/platforms/platform-frontend-user-provided", "w")) as frontend_file:
+ frontend_file.write(self.frontend_user_provided)
+
+ configure_args = ["--prefix=%s" % prefix,
+ "--with-custom-compilers",
+ "--without-paraver",
+ "--without-gui"]
+
+ configure(*configure_args)
+
+ make(parallel=False)
+ make("install", parallel=False)
diff --git a/var/spack/packages/dtcmp/package.py b/var/spack/packages/dtcmp/package.py
new file mode 100644
index 0000000000..9d940583c1
--- /dev/null
+++ b/var/spack/packages/dtcmp/package.py
@@ -0,0 +1,20 @@
+import os
+from spack import *
+
+class Dtcmp(Package):
+ """The Datatype Comparison Library provides comparison operations and
+ parallel sort algorithms for MPI applications."""
+
+ homepage = "https://github.com/hpc/dtcmp"
+ url = "https://github.com/hpc/dtcmp/releases/download/v1.0.3/dtcmp-1.0.3.tar.gz"
+
+ version('1.0.3', 'cdd8ccf71e8ff67de2558594a7fcd317')
+
+ depends_on('mpi')
+ depends_on('lwgrp')
+
+ def install(self, spec, prefix):
+ configure("--prefix=" + prefix,
+ "--with-lwgrp=" + spec['lwgrp'].prefix)
+ make()
+ make("install")
diff --git a/var/spack/packages/libarchive/package.py b/var/spack/packages/libarchive/package.py
new file mode 100644
index 0000000000..cbd4b89cd0
--- /dev/null
+++ b/var/spack/packages/libarchive/package.py
@@ -0,0 +1,16 @@
+from spack import *
+
+class Libarchive(Package):
+ """libarchive: C library and command-line tools for reading and
+ writing tar, cpio, zip, ISO, and other archive formats."""
+ homepage = "http://www.libarchive.org"
+ url = "http://www.libarchive.org/downloads/libarchive-3.1.2.tar.gz"
+
+ version('3.1.2', 'efad5a503f66329bb9d2f4308b5de98a')
+ version('3.1.1', '1f3d883daf7161a0065e42a15bbf168f')
+ version('3.1.0', '095a287bb1fd687ab50c85955692bf3a')
+
+ def install(self, spec, prefix):
+ configure("--prefix=%s" % prefix)
+ make()
+ make("install")
diff --git a/var/spack/packages/libcircle/package.py b/var/spack/packages/libcircle/package.py
new file mode 100644
index 0000000000..3f7c996fb0
--- /dev/null
+++ b/var/spack/packages/libcircle/package.py
@@ -0,0 +1,18 @@
+import os
+from spack import *
+
+class Libcircle(Package):
+ """libcircle provides an efficient distributed queue on a cluster,
+ using self-stabilizing work stealing."""
+
+ homepage = "https://github.com/hpc/libcircle"
+
+ version('0.2.1-rc.1', '2b1369a5736457239f908abf88143ec2',
+ url='https://github.com/hpc/libcircle/releases/download/0.2.1-rc.1/libcircle-0.2.1-rc.1.tar.gz')
+
+ depends_on('mpi')
+
+ def install(self, spec, prefix):
+ configure("--prefix=" + prefix)
+ make()
+ make("install")
diff --git a/var/spack/packages/libmonitor/package.py b/var/spack/packages/libmonitor/package.py
new file mode 100644
index 0000000000..210712436a
--- /dev/null
+++ b/var/spack/packages/libmonitor/package.py
@@ -0,0 +1,37 @@
+##############################################################################
+# Copyright (c) 2013, Lawrence Livermore National Security, LLC.
+# Produced at the Lawrence Livermore National Laboratory.
+#
+# This file is part of Spack.
+# Written by Todd Gamblin, tgamblin@llnl.gov, All rights reserved.
+# LLNL-CODE-647188
+#
+# For details, see https://scalability-llnl.github.io/spack
+# Please also see the LICENSE file 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 General Public License (as published by
+# the Free Software Foundation) version 2.1 dated 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 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
+##############################################################################
+from spack import *
+
+class Libmonitor(Package):
+ """Libmonitor is a library for process and thread control."""
+ homepage = "http://hpctoolkit.org"
+ url = "file:///g/g0/legendre/tools/oss/openspeedshop-release-2.1/SOURCES/libmonitor-20130218.tar.gz"
+
+ version('20130218', 'aa85c2c580e2dafb823cc47b09374279')
+
+ def install(self, spec, prefix):
+ configure("--prefix=" + prefix)
+ make()
+ make("install")
diff --git a/var/spack/packages/lwgrp/package.py b/var/spack/packages/lwgrp/package.py
new file mode 100644
index 0000000000..5963382b92
--- /dev/null
+++ b/var/spack/packages/lwgrp/package.py
@@ -0,0 +1,18 @@
+import os
+from spack import *
+
+class Lwgrp(Package):
+ """Thie light-weight group library provides process group
+ representations using O(log N) space and time."""
+
+ homepage = "https://github.com/hpc/lwgrp"
+ url = "https://github.com/hpc/lwgrp/releases/download/v1.0.2/lwgrp-1.0.2.tar.gz"
+
+ version('1.0.2', 'ab7ba3bdd8534a651da5076f47f27d8a')
+
+ depends_on('mpi')
+
+ def install(self, spec, prefix):
+ configure("--prefix=" + prefix)
+ make()
+ make("install")
diff --git a/var/spack/packages/mpileaks/package.py b/var/spack/packages/mpileaks/package.py
index 3307b9fdee..4ef866588c 100644
--- a/var/spack/packages/mpileaks/package.py
+++ b/var/spack/packages/mpileaks/package.py
@@ -25,13 +25,20 @@
from spack import *
class Mpileaks(Package):
- homepage = "http://www.llnl.gov"
- url = "http://www.llnl.gov/mpileaks-1.0.tar.gz"
+ """Tool to detect and report leaked MPI objects like MPI_Requests and MPI_Datatypes."""
+
+ homepage = "https://github.com/hpc/mpileaks"
+ url = "https://github.com/hpc/mpileaks/releases/download/v1.0/mpileaks-1.0.tar.gz"
+
+ version('1.0', '8838c574b39202a57d7c2d68692718aa')
depends_on("mpi")
+ depends_on("adept-utils")
depends_on("callpath")
def install(self, spec, prefix):
- configure("--prefix=" + prefix)
+ configure("--prefix=" + prefix,
+ "--with-adept-utils=" + spec['adept-utils'].prefix,
+ "--with-callpath=" + spec['callpath'].prefix)
make()
make("install")
diff --git a/var/spack/packages/mvapich2/package.py b/var/spack/packages/mvapich2/package.py
index 0f0f849c51..ca0b1287c1 100644
--- a/var/spack/packages/mvapich2/package.py
+++ b/var/spack/packages/mvapich2/package.py
@@ -1,3 +1,4 @@
+import os
from spack import *
class Mvapich2(Package):
@@ -6,21 +7,98 @@ class Mvapich2(Package):
version('1.9', '5dc58ed08fd3142c260b70fe297e127c',
url="http://mvapich.cse.ohio-state.edu/download/mvapich2/mv2/mvapich2-1.9.tgz")
+ patch('ad_lustre_rwcontig_open_source.patch', when='@1.9')
+
version('2.0', '9fbb68a4111a8b6338e476dc657388b4',
url='http://mvapich.cse.ohio-state.edu/download/mvapich/mv2/mvapich2-2.0.tar.gz')
- provides('mpi@:1', when='@1.9:')
+ provides('mpi@:2.2', when='@1.9') # MVAPICH2-1.9 supports MPI 2.2
+ provides('mpi@:3.0', when='@2.0') # MVAPICH2-2.0 supports MPI 3.0
+
def install(self, spec, prefix):
+ # we'll set different configure flags depending on our environment
+ configure_args = []
+
+ # TODO: The MPICH*_FLAGS have a different name for 1.9
+
+ if '+debug' in spec:
+ # set configure flags for debug build
+ configure_args.append("--disable-fast")
+ configure_args.append("--enable-g=dbg")
+ configure_args.append("--enable-error-checking=runtime")
+ configure_args.append("--enable-error-messages=all")
+ configure_args.append("--enable-nmpi-as-mpi")
+
+ if "%gnu" in spec:
+ # set variables for GNU compilers
+ os.environ['MPICHLIB_CFLAGS'] = "-g -O0"
+ os.environ['MPICHLIB_CXXFLAGS'] = "-g -O0"
+ os.environ['MPICHLIB_FFLAGS'] = "-g -O0 -fno-second-underscore"
+ os.environ['MPICHLIB_F90FLAGS'] = "-g -O0 -fno-second-underscore"
+ elif "%intel" in spec:
+ # set variables for Inel compilers
+ os.environ['MPICHLIB_CFLAGS'] = "-g -O0"
+ os.environ['MPICHLIB_CXXFLAGS'] = "-g -O0"
+ os.environ['MPICHLIB_FFLAGS'] = "-g -O0"
+ os.environ['MPICHLIB_F90FLAGS'] = "-g -O0"
+ elif "%pgi" in spec:
+ # set variables for PGI compilers
+ os.environ['MPICHLIB_CFLAGS'] = "-g -O0 -fPIC"
+ os.environ['MPICHLIB_CXXFLAGS'] = "-g -O0 -fPIC"
+ os.environ['MPICHLIB_FFLAGS'] = "-g -O0 -fPIC"
+ os.environ['MPICHLIB_F90FLAGS'] = "-g -O0 -fPIC"
+
+ else:
+ # set configure flags for normal optimizations
+ configure_args.append("--enable-fast=all")
+ configure_args.append("--enable-g=dbg")
+ configure_args.append("--enable-nmpi-as-mpi")
+
+ if "%gnu" in spec:
+ # set variables for what compilers
+ os.environ['MPICHLIB_CFLAGS'] = "-g -O2"
+ os.environ['MPICHLIB_CXXFLAGS'] = "-g -O2"
+ os.environ['MPICHLIB_FFLAGS'] = "-g -O2 -fno-second-underscore"
+ os.environ['MPICHLIB_F90FLAGS'] = "-g -O2 -fno-second-underscore"
+ elif "%intel" in spec:
+ # set variables for Inel compilers
+ os.environ['MPICHLIB_CFLAGS'] = "-g -O2"
+ os.environ['MPICHLIB_CXXFLAGS'] = "-g -O2"
+ os.environ['MPICHLIB_FFLAGS'] = "-g -O2"
+ os.environ['MPICHLIB_F90FLAGS'] = "-g -O2"
+ elif "%pgi" in spec:
+ # set variables for PGI compilers
+ os.environ['MPICHLIB_CFLAGS'] = "-g -O2 -fPIC"
+ os.environ['MPICHLIB_CXXFLAGS'] = "-g -O2 -fPIC"
+ os.environ['MPICHLIB_FFLAGS'] = "-g -O2 -fPIC"
+ os.environ['MPICHLIB_F90FLAGS'] = "-g -O2 -fPIC"
+
+ # determine network type by variant
+ if "+psm" in spec:
+ # throw this flag on QLogic systems to use PSM
+ configure_args.append("--with-device=ch3:psm")
+ else:
+ # throw this flag on IB systems
+ configure_args.append("--with-device=ch3:mrail", "--with-rdma=gen2")
+
+ # TODO: shared-memory build
+
+ # TODO: CUDA
+
+ # TODO: other file systems like panasis
+
configure(
"--prefix=" + prefix,
"--enable-f77", "--enable-fc", "--enable-cxx",
- "--enable-fast=all", "--enable-g=dbg", "--enable-nmpi-as-mpi",
"--enable-shared", "--enable-sharedlibs=gcc",
"--enable-debuginfo",
"--with-pm=no", "--with-pmi=slurm",
- "--with-device=ch3:psm",
"--enable-romio", "--with-file-system=lustre+nfs+ufs",
- "--disable-mpe", "--without-mpe")
+ "--disable-mpe", "--without-mpe",
+ "--disable-silent-rules",
+ *configure_args)
+
make()
+
make("install")
diff --git a/var/spack/packages/opari2/package.py b/var/spack/packages/opari2/package.py
new file mode 100644
index 0000000000..daaee61e3a
--- /dev/null
+++ b/var/spack/packages/opari2/package.py
@@ -0,0 +1,65 @@
+# FIXME: Add copyright statement here
+
+from spack import *
+from contextlib import closing
+
+class Opari2(Package):
+ """OPARI2 is a source-to-source instrumentation tool for OpenMP and
+ hybrid codes. It surrounds OpenMP directives and runtime library
+ calls with calls to the POMP2 measurement interface.
+ OPARI2 will provide you with a new initialization method that allows
+ for multi-directory and parallel builds as well as the usage of
+ pre-instrumented libraries. Furthermore, an efficient way of
+ tracking parent-child relationships was added. Additionally, we
+ extended OPARI2 to support instrumentation of OpenMP 3.0
+ tied tasks. """
+
+ homepage = "http://www.vi-hps.org/projects/score-p"
+ url = "http://www.vi-hps.org/upload/packages/opari2/opari2-1.1.2.tar.gz"
+
+ version('1.1.2', '9a262c7ca05ff0ab5f7775ae96f3539e')
+
+ backend_user_provided = """\
+CC=cc
+CXX=c++
+F77=f77
+FC=f90
+CFLAGS=-fPIC
+CXXFLAGS=-fPIC
+"""
+ frontend_user_provided = """\
+CC_FOR_BUILD=cc
+CXX_FOR_BUILD=c++
+F77_FOR_BUILD=f70
+FC_FOR_BUILD=f90
+CFLAGS_FOR_BUILD=-fPIC
+CXXFLAGS_FOR_BUILD=-fPIC
+"""
+ mpi_user_provided = """\
+MPICC=mpicc
+MPICXX=mpicxx
+MPIF77=mpif77
+MPIFC=mpif90
+MPI_CFLAGS=-fPIC
+MPI_CXXFLAGS=-fPIC
+"""
+
+ def install(self, spec, prefix):
+ # Use a custom compiler configuration, otherwise the score-p
+ # build system messes with spack's compiler settings.
+ # Create these three files in the build directory
+ with closing(open("platform-backend-user-provided", "w")) as backend_file:
+ backend_file.write(self.backend_user_provided)
+ with closing(open("platform-frontend-user-provided", "w")) as frontend_file:
+ frontend_file.write(self.frontend_user_provided)
+ with closing(open("platform-mpi-user-provided", "w")) as mpi_file:
+ mpi_file.write(self.mpi_user_provided)
+
+ # FIXME: Modify the configure line to suit your build system here.
+ configure("--prefix=%s" % prefix,
+ "--with-custom-compilers",
+ "--enable-shared")
+
+ # FIXME: Add logic to build and install here
+ make()
+ make("install")
diff --git a/var/spack/packages/openssl/package.py b/var/spack/packages/openssl/package.py
new file mode 100644
index 0000000000..c5a8aeb9dc
--- /dev/null
+++ b/var/spack/packages/openssl/package.py
@@ -0,0 +1,26 @@
+from spack import *
+
+class Openssl(Package):
+ """The OpenSSL Project is a collaborative effort to develop a
+ robust, commercial-grade, full-featured, and Open Source
+ toolkit implementing the Secure Sockets Layer (SSL v2/v3) and
+ Transport Layer Security (TLS v1) protocols as well as a
+ full-strength general purpose cryptography library."""
+ homepage = "http://www.openssl.org"
+ url = "http://www.openssl.org/source/openssl-1.0.1h.tar.gz"
+
+ version('1.0.1h', '8d6d684a9430d5cc98a62a5d8fbda8cf')
+
+ depends_on("zlib")
+ parallel = False
+
+ def install(self, spec, prefix):
+ config = Executable("./config")
+ config("--prefix=%s" % prefix,
+ "--openssldir=%s/etc/openssl" % prefix,
+ "zlib",
+ "no-krb5",
+ "shared")
+
+ make()
+ make("install")
diff --git a/var/spack/packages/otf2/package.py b/var/spack/packages/otf2/package.py
new file mode 100644
index 0000000000..fa0a5898b6
--- /dev/null
+++ b/var/spack/packages/otf2/package.py
@@ -0,0 +1,74 @@
+# FIXME: Add copyright
+
+from spack import *
+from contextlib import closing
+import os
+
+class Otf2(Package):
+ """The Open Trace Format 2 is a highly scalable, memory efficient event
+ trace data format plus support library."""
+
+ homepage = "http://www.vi-hps.org/score-p"
+ url = "http://www.vi-hps.org/upload/packages/otf2/otf2-1.4.tar.gz"
+
+ version('1.4', 'a23c42e936eb9209c4e08b61c3cf5092',
+ url="http://www.vi-hps.org/upload/packages/otf2/otf2-1.4.tar.gz")
+ version('1.3.1', 'd0ffc4e858455ace4f596f910e68c9f2',
+ url="http://www.vi-hps.org/upload/packages/otf2/otf2-1.3.1.tar.gz")
+ version('1.2.1', '8fb3e11fb7489896596ae2c7c83d7fc8',
+ url="http://www.vi-hps.org/upload/packages/otf2/otf2-1.2.1.tar.gz")
+
+ backend_user_provided = """\
+CC=cc
+CXX=c++
+F77=f77
+FC=f90
+CFLAGS=-fPIC
+CXXFLAGS=-fPIC
+"""
+ frontend_user_provided = """\
+CC_FOR_BUILD=cc
+CXX_FOR_BUILD=c++
+F77_FOR_BUILD=f70
+FC_FOR_BUILD=f90
+CFLAGS_FOR_BUILD=-fPIC
+CXXFLAGS_FOR_BUILD=-fPIC
+"""
+ mpi_user_provided = """\
+MPICC=cc
+MPICXX=c++
+MPIF77=f77
+MPIFC=f90
+MPI_CFLAGS=-fPIC
+MPI_CXXFLAGS=-fPIC
+"""
+
+ @when('@:1.2.1')
+ def version_specific_args(self):
+ return ["--with-platform=disabled", "CC=cc", "CXX=c++", "F77=f77", "F90=f90", "CFLAGS=-fPIC", "CXXFLAGS=-fPIC"]
+
+ @when('@1.3:')
+ def version_specific_args(self):
+ # TODO: figure out what scorep's build does as of otf2 1.3
+ return ["--with-custom-compilers"]
+
+ def install(self, spec, prefix):
+ # Use a custom compiler configuration, otherwise the score-p
+ # build system messes with spack's compiler settings.
+ # Create these three files in the build directory
+ with closing(open("platform-backend-user-provided", "w")) as backend_file:
+ backend_file.write(self.backend_user_provided)
+ with closing(open("platform-frontend-user-provided", "w")) as frontend_file:
+ frontend_file.write(self.frontend_user_provided)
+ with closing(open("platform-mpi-user-provided", "w")) as mpi_file:
+ mpi_file.write(self.mpi_user_provided)
+
+ configure_args=["--prefix=%s" % prefix,
+ "--enable-shared"]
+
+ configure_args.extend(self.version_specific_args())
+
+ configure(*configure_args)
+
+ make()
+ make("install")
diff --git a/var/spack/packages/postgresql/package.py b/var/spack/packages/postgresql/package.py
new file mode 100644
index 0000000000..46922b7b71
--- /dev/null
+++ b/var/spack/packages/postgresql/package.py
@@ -0,0 +1,20 @@
+from spack import *
+
+class Postgresql(Package):
+ """PostgreSQL is a powerful, open source object-relational
+ database system. It has more than 15 years of active
+ development and a proven architecture that has earned it a
+ strong reputation for reliability, data integrity, and
+ correctness."""
+ homepage = "http://www.postgresql.org/"
+ url = "http://ftp.postgresql.org/pub/source/v9.3.4/postgresql-9.3.4.tar.bz2"
+
+ version('9.3.4', 'd0a41f54c377b2d2fab4a003b0dac762')
+
+ depends_on("openssl")
+
+ def install(self, spec, prefix):
+ configure("--prefix=%s" % prefix,
+ "--with-openssl")
+ make()
+ make("install")
diff --git a/var/spack/packages/scalasca/package.py b/var/spack/packages/scalasca/package.py
new file mode 100644
index 0000000000..b76d0a7df5
--- /dev/null
+++ b/var/spack/packages/scalasca/package.py
@@ -0,0 +1,43 @@
+# FIXME: Add copyright
+
+from spack import *
+
+class Scalasca(Package):
+ """Scalasca is a software tool that supports the performance optimization
+ of parallel programs by measuring and analyzing their runtime behavior.
+ The analysis identifies potential performance bottlenecks - in
+ particular those concerning communication and synchronization - and
+ offers guidance in exploring their causes."""
+
+ # FIXME: add a proper url for your package's homepage here.
+ homepage = "http://www.scalasca.org"
+ url = "http://apps.fz-juelich.de/scalasca/releases/scalasca/2.1/dist/scalasca-2.1-rc2.tar.gz"
+
+ version('2.1-rc2', '1a95a39e5430539753e956a7524a756b')
+
+ depends_on("mpi")
+ depends_on("otf2@1.4")
+ depends_on("cube")
+
+ def install(self, spec, prefix):
+ configure_args = ["--prefix=%s" % prefix,
+ "--with-otf2=%s" % spec['otf2'].prefix.bin,
+ "--with-cube=%s" % spec['cube'].prefix.bin,
+ "--enable-shared"]
+
+ if spec.satisfies('%gcc'):
+ configure_args.append('--with-nocross-compiler-suite=gcc')
+ if spec.satisfies('%intel'):
+ configure_args.append('--with-nocross-compiler-suite=intel')
+
+ configure(*configure_args)
+
+ make()
+ make("install")
+
+ # FIXME: Modify the configure line to suit your build system here.
+ configure("--prefix=%s" % prefix)
+
+ # FIXME: Add logic to build and install here
+ make()
+ make("install")
diff --git a/var/spack/packages/scorep/package.py b/var/spack/packages/scorep/package.py
new file mode 100644
index 0000000000..32a772e3db
--- /dev/null
+++ b/var/spack/packages/scorep/package.py
@@ -0,0 +1,75 @@
+# FIXME: Add copyright statement
+
+from spack import *
+from contextlib import closing
+
+class Scorep(Package):
+ """The Score-P measurement infrastructure is a highly scalable and
+ easy-to-use tool suite for profiling, event tracing, and online
+ analysis of HPC applications."""
+
+ # FIXME: add a proper url for your package's homepage here.
+ homepage = "http://www.vi-hps.org/projects/score-p"
+ url = "http://www.vi-hps.org/upload/packages/scorep/scorep-1.2.3.tar.gz"
+
+ version('1.3', '9db6f957b7f51fa01377a9537867a55c',
+ url = 'http://www.vi-hps.org/upload/packages/scorep/scorep-1.3.tar.gz')
+
+ version('1.2.3', '4978084e7cbd05b94517aa8beaea0817')
+
+ depends_on("mpi")
+ depends_on("papi")
+ # depends_on("otf2@1.2:1.2.1") # only Score-P 1.2.x
+ depends_on("otf2")
+ depends_on("opari2")
+ depends_on("cube@4.2:4.2.3")
+
+ backend_user_provided = """\
+CC=cc
+CXX=c++
+F77=f77
+FC=f90
+CFLAGS=-fPIC
+CXXFLAGS=-fPIC
+"""
+ frontend_user_provided = """\
+CC_FOR_BUILD=cc
+CXX_FOR_BUILD=c++
+F77_FOR_BUILD=f70
+FC_FOR_BUILD=f90
+CFLAGS_FOR_BUILD=-fPIC
+CXXFLAGS_FOR_BUILD=-fPIC
+"""
+ mpi_user_provided = """\
+MPICC=mpicc
+MPICXX=mpicxx
+MPIF77=mpif77
+MPIFC=mpif90
+MPI_CFLAGS=-fPIC
+MPI_CXXFLAGS=-fPIC
+"""
+
+ def install(self, spec, prefix):
+ # Use a custom compiler configuration, otherwise the score-p
+ # build system messes with spack's compiler settings.
+ # Create these three files in the build directory
+ with closing(open("platform-backend-user-provided", "w")) as backend_file:
+ backend_file.write(self.backend_user_provided)
+ with closing(open("platform-frontend-user-provided", "w")) as frontend_file:
+ frontend_file.write(self.frontend_user_provided)
+ with closing(open("platform-mpi-user-provided", "w")) as mpi_file:
+ mpi_file.write(self.mpi_user_provided)
+
+ configure_args = ["--prefix=%s" % prefix,
+ "--with-custom-compilers",
+ "--with-otf2=%s" % spec['otf2'].prefix.bin,
+ "--with-opari2=%s" % spec['opari2'].prefix.bin,
+ "--with-cube=%s" % spec['cube'].prefix.bin,
+ "--with-papi-header=%s" % spec['papi'].prefix.include,
+ "--with-papi-lib=%s" % spec['papi'].prefix.lib,
+ "--enable-shared"]
+
+ configure(*configure_args)
+
+ make()
+ make("install")
diff --git a/var/spack/packages/sqlite/package.py b/var/spack/packages/sqlite/package.py
new file mode 100644
index 0000000000..734b0b6cb6
--- /dev/null
+++ b/var/spack/packages/sqlite/package.py
@@ -0,0 +1,40 @@
+##############################################################################
+# Copyright (c) 2013, Lawrence Livermore National Security, LLC.
+# Produced at the Lawrence Livermore National Laboratory.
+#
+# This file is part of Spack.
+# Written by Todd Gamblin, tgamblin@llnl.gov, All rights reserved.
+# LLNL-CODE-647188
+#
+# For details, see https://scalability-llnl.github.io/spack
+# Please also see the LICENSE file 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 General Public License (as published by
+# the Free Software Foundation) version 2.1 dated 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 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
+##############################################################################
+from spack import *
+
+class Sqlite(Package):
+ """SQLite3 is an SQL database engine in a C library. Programs that
+ link the SQLite3 library can have SQL database access without
+ running a separate RDBMS process.
+ """
+ homepage = "www.sqlite.org"
+
+ version('3.8.5', '0544ef6d7afd8ca797935ccc2685a9ed',
+ url='http://www.sqlite.org/2014/sqlite-autoconf-3080500.tar.gz')
+
+ def install(self, spec, prefix):
+ configure("--prefix=" + prefix)
+ make()
+ make("install")
diff --git a/var/spack/packages/stat/package.py b/var/spack/packages/stat/package.py
index 583ae48e82..956b0dcc8c 100644
--- a/var/spack/packages/stat/package.py
+++ b/var/spack/packages/stat/package.py
@@ -20,6 +20,7 @@ class Stat(Package):
configure(
"--enable-gui",
"--prefix=%s" % prefix,
+ "--disable-examples", # Examples require MPI: avoid this dependency.
"--with-launchmon=%s" % spec['launchmon'].prefix,
"--with-mrnet=%s" % spec['mrnet'].prefix,
"--with-graphlib=%s" % spec['graphlib'].prefix,
diff --git a/var/spack/packages/tau/package.py b/var/spack/packages/tau/package.py
index 8d9dbe1759..048fac80aa 100644
--- a/var/spack/packages/tau/package.py
+++ b/var/spack/packages/tau/package.py
@@ -12,7 +12,6 @@ class Tau(Package):
version('2.23.1', '6593b47ae1e7a838e632652f0426fe72')
-
def install(self, spec, prefix):
# TAU isn't happy with directories that have '@' in the path. Sigh.
change_sed_delimiter('@', ';', 'configure')